-
Notifications
You must be signed in to change notification settings - Fork 264
Home
Include the BrowserID JavaScript library in your site by adding a script tag to your
<script src="https://browserid.org/include.js" type="text/javascript"></script>
Instead of displaying a form on your site which takes a username and password, use the BrowserID JavaScript API when the user clicks your sign-in button:
navigator.id.getVerifiedEmail(function(assertion) {
if (assertion) {
// This code will be invoked once the user has successfully
// selected an email address they control to sign in with.
} else {
// something went wrong! the user isn't logged in.
}
});
Upon a successful sign-in, you'll be called back with an assertion, a string containing a signed claim that proves the user is who they say they are.
NOTE: While completely optional, you might consider replacing your sign-in button with a pretty BrowserID button:
You must verify the assertion is authentic, and extract the user's email address from it. The easiest way to do these is to use the free verification service provided by BrowserID.
To use it, you send a request to https://browserid.org/verify with two POST
parameters:
-
assertion
: The encoded assertion -
audience
: The hostname and optional port of your site
The verifier will check the the assertion was meant for your site and is valid, here's an example:
$ curl -d "assertion=<ASSERTION>&audience=mysite.com" "https://browserid.org/verify"
{
"status": "okay",
"email": "[email protected]",
"audience": "mysite.com",
"valid-until": 1308859352261,
"issuer": "browserid.org:443"
}
NOTE: You may choose to validate assertions on your own server. While a bit more complicated you can reduce your dependencies on others. Refer to the specification and the source for the reference validator.
Having completed the steps above, you can trust that the present user really owns the email address returned by the verifier. You don't need to perform any additional authentication unless you want to! From here, you can perform whatever post-authentication steps you like.
For more details, have a look at our demonstration, and view the code behind it.