summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/tstranex/u2f/README.md
blob: 95de78f8b5fc415857337860ac7dcc874e03e72e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# Go FIDO U2F Library

This Go package implements the parts of the FIDO U2F specification required on
the server side of an application.

[![Build Status](https://travis-ci.org/tstranex/u2f.svg?branch=master)](https://travis-ci.org/tstranex/u2f)

## Features

- Native Go implementation
- No dependancies other than the Go standard library
- Token attestation certificate verification

## Usage

Please visit http://godoc.org/github.com/tstranex/u2f for the full
documentation.

### How to enrol a new token

```go
app_id := "http://localhost"

// Send registration request to the browser.
c, _ := NewChallenge(app_id, []string{app_id})
req, _ := c.RegisterRequest()

// Read response from the browser.
var resp RegisterResponse
reg, err := Register(resp, c, nil)
if err != nil {
    // Registration failed.
}

// Store registration in the database.
```

### How to perform an authentication

```go
// Fetch registration and counter from the database.
var reg Registration
var counter uint32

// Send authentication request to the browser.
c, _ := NewChallenge(app_id, []string{app_id})
req, _ := c.SignRequest(reg)

// Read response from the browser.
var resp SignResponse
newCounter, err := reg.Authenticate(resp, c, counter)
if err != nil {
    // Authentication failed.
}

// Store updated counter in the database.
```

## Installation

```
$ go get github.com/tstranex/u2f
```

## Example

See u2fdemo/main.go for an full example server. To run it:

```
$ go install github.com/tstranex/u2f/u2fdemo
$ ./bin/u2fdemo
```

Open https://localhost:3483 in Chrome.
Ignore the SSL warning (due to the self-signed certificate for localhost).
You can then test registering and authenticating using your token.

## Changelog

- 2016-12-18: The package has been updated to work with the new
  U2F Javascript 1.1 API specification. This causes some breaking changes.

  `SignRequest` has been replaced by `WebSignRequest` which now includes
  multiple registrations. This is useful when the user has multiple devices
  registered since you can now authenticate against any of them with a single
  request.

  `WebRegisterRequest` has been introduced, which should generally be used
  instead of using `RegisterRequest` directly. It includes the list of existing
  registrations with the new registration request. If the user's device already
  matches one of the existing registrations, it will refuse to re-register.

  `Challenge.RegisterRequest` has been replaced by `NewWebRegisterRequest`.

## License

The Go FIDO U2F Library is licensed under the MIT License.