Auth0 Lock
Auth0 is an authentication broker that supports social identity providers as well as enterprise identity providers such as Active Directory, LDAP, Google Apps, Salesforce.
The Auth0 Lock makes it easy to integrate SSO in your app. You won't have to worry about:
- Having a professional looking login dialog that displays well on any resolution and device.
- Finding the right icons for popular social providers.
- Remembering what was the identity provider the user chose the last time.
- Solving the home realm discovery challenge with enterprise users (i.e.: asking the enterprise user the email, and redirecting to the right enterprise identity provider).
- Implementing a standard sign in protocol (OpenID Connect / OAuth2 Login)
You can try it out yourself online at our Auth0 Lock playground.
Install
From npm:
npm install auth0-lock
From bower:
bower install auth0-lock
Or our CDN:
<script src="http://cdn.auth0.com/js/lock-6.min.js"></script>
<script src="http://cdn.auth0.com/js/lock-6.0.min.js"></script>
<script src="http://cdn.auth0.com/js/lock-6.0.0.min.js"></script>
Usage
You can use Auth0Lock with Popup mode or Redirect mode. To learn more about these modes, you can read the Authentication Modes page.
There are different ways of implementing them according to your application needs. To see what kind of settings you should be using you can check the Types of Applications article.
var lock = new Auth0Lock('xxxxxx', '<account>.auth0.com');
var login = document.querySelector('a#login')
login.onclick = function (e) {
e.preventDefault();
lock.show(function onLogin(err, profile, id_token) {
if (err) {
return alert(err.message);
}
});
};
This is just one example of how Auth0Lock could work with a Single Page Application (SPA). Read the Single Page Applications and the Regular Web Applications articles for a full explanation on how to implement those scenarios with Auth0 Lock and when to use each.
API
Auth0Lock(clientID, domain[, options])
Initialize Auth0Lock
with a clientID
and the account's domain
.
var lock = new Auth0Lock('xxxxxx', '<account>.auth0.com');
Note: For a full detail on options and parameters you can check the Auth0Lock initialization wiki notes.
.show([options, callback])
Open the widget on signin
mode with signup
and reset
button actions if enabled for the configured/default account connection.
You may call this method with a single parameter, two or even none. The following examples ilustrate this:
var lock = new Auth0Lock('xxxxxx', '<account>.auth0.com');
lock.show();
lock.show(options);
lock.show(function (err, profile, token) {});
lock.show(options, function (err, profile, token) {});
Check the Auth0Lock customization article for more examples and options specification. Or enter the Authentication modes notes to learn more about implementing different authentication mechanics.
.showSignin([options, callback])
Open the widget on signin
mode, but withouht the bottom signup
nor reset
button actions. This method is useful when your site has custom signup and reset links at a different form.
You may call this method with a single parameter, two or even none. The following examples ilustrate this:
var lock = new Auth0Lock('xxxxxx', '<account>.auth0.com');
lock.showSignin();
lock.showSignin(options);
lock.showSignin(function (err, profile, token) {});
lock.showSignin(options, function (err, profile, token) {});
Check the Auth0Lock customization article for more examples and options specification. Or enter the Authentication modes notes to learn more about implementing different authentication mechanics.
.showSignup([options, callback])
Open the widget on signup
mode, but withouht the cancel
button action to go back to signin
. This method is useful when your site has custom signin and reset links at a different form.
You may call this method with a single parameter, two or even none. The following examples ilustrate this:
var lock = new Auth0Lock('xxxxxx', '<account>.auth0.com');
lock.showSignup();
lock.showSignup(options);
lock.showSignup(function (err) {});
lock.showSignup(options, function (err) {});
Check the Auth0Lock customization article for more examples and options specification. Or enter the Authentication modes notes to learn more about implementing different authentication mechanics.
.showReset([options, callback])
Open the widget on reset
mode, but withouht the bottom cancel
button action to go back to signin
. This method is useful when your site has custom signin and signup links at a different form.
You may call this method with a single parameter, two or even none. The following examples ilustrate this:
var lock = new Auth0Lock('xxxxxx', '<account>.auth0.com');
lock.showReset();
lock.showReset(options);
lock.showReset(function (err) {});
lock.showReset(options, function (err) {});
Check the Auth0Lock customization article for more examples and options specification. Or enter the Authentication modes notes to learn more about implementing different authentication mechanics.
.hide([callback])
Close the widget and invoke callback
when removed from DOM.
var lock = new Auth0Lock('xxxxxx', '<account>.auth0.com');
lock.show(options);
document.addEventListener('keypress', function(e) {
lock.hide();
}, false);
.logout([query])
Log out loggedin user with optional query parameters for the GET
request.
var lock = new Auth0Lock('xxxxxx', '<account>.auth0.com');
lock.logout({ ref: window.location.href });
Examples
The example directory has a ready-to-go app. In order to run it you need node installed.
Then execute npm i
to install dependencies (only once) and npm example
from the root of this project.
Finally, point your browser at http://localhost:9999/
and play around.
Browser Compatibility
We ensure browser compatibility in Chrome
, Safari
, Firefox
and IE >= 9
. We currently use zuul along with Saucelabs to run integration tests on each push.
Resources