UNPKG

@zeroid/trimble.identity.passwordtokenprovider

Version:

An implementation of ITokenProvider for OAuth password grant type

60 lines (56 loc) 2.89 kB
'use strict'; // implements ITokenProvider (function (root, factory) { if (typeof define === 'function' && define.amd) { // AMD define(['@zeroid/trimble.identity.refreshabletokenprovider', '@zeroid/trimble.httpclient'], factory); } else if (typeof exports === 'object') { // CommonJS module.exports = factory(require('@zeroid/trimble.identity.refreshabletokenprovider'), require('@zeroid/trimble.httpclient')); } else { // Browser globals (Note: root is window) root.PasswordGrantTokenProvider = factory(root.RefreshableTokenProvider, root.HttpClient); } }(this, function (RefreshableTokenProvider, HttpClient) { var _passwordGrantTokenProvider = function (endpointProvider, consumerKey, consumerSecret) { this._endpointProvider = endpointProvider; this._consumerKey = consumerKey; this._consumerSecret = consumerSecret; this._refreshableTokenProvider; } _passwordGrantTokenProvider.prototype.login = function (username, password) { var self = this; return new Promise(function (resolve, reject) { self._endpointProvider.retrieveTokenEndpoint() .then((endpoint) => { var basicHeader = 'Basic ' + btoa(self._consumerKey + ':' + self._consumerSecret); var requestSettings = { headers: { authorization: basicHeader, "content-type": 'application/x-www-form-urlencoded', accept: 'application/json' } }; var content = 'grant_type=password&scope=openid' + //'&tenantDomain=trimble.com' + '&username=' + encodeURIComponent(username) + '&password=' + encodeURIComponent(password); new HttpClient().httpPost(endpoint, content, requestSettings) .then(function (json) { var result = JSON.parse(json); var now = new Date(); _refreshableTokenProvider = new RefreshableTokenProvider(self._endpointProvider, self._consumerKey, self._consumerSecret, result.access_token, new Date(now.getTime() + result.expires_in*1000), result.refresh_token); resolve(); }) .catch(() => { reject(); }); }) .catch(() => { reject(); }); }); }; _passwordGrantTokenProvider.prototype.retrieveToken = function () { return _refreshableTokenProvider.retrieveToken(); }; // Exposed public methods return _passwordGrantTokenProvider; }));