@authorizerdev/authorizer-js 0.1.0 → 0.3.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/authorizer.min.js +2 -2
- package/lib/authorizer.min.js.map +1 -1
- package/lib/cjs/constants.d.ts +3 -0
- package/lib/cjs/index.d.ts +21 -95
- package/lib/cjs/index.js +203 -38
- package/lib/cjs/index.js.map +1 -1
- package/lib/cjs/utils.d.ts +13 -0
- package/lib/esm/constants.d.ts +3 -0
- package/lib/esm/index.d.ts +21 -95
- package/lib/esm/index.js +203 -38
- package/lib/esm/index.js.map +1 -1
- package/lib/esm/utils.d.ts +13 -0
- package/package.json +2 -1
- package/src/constants.ts +3 -0
- package/src/index.ts +171 -147
- package/src/types.d.ts +139 -0
- package/src/utils.ts +152 -0
package/lib/authorizer.min.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
!function(t
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("node-fetch")):"function"==typeof define&&define.amd?define(["exports","node-fetch"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).authorizerdev={},e.nodeFetch)}(this,(function(e,t){"use strict";function i(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var r=i(t);
|
|
2
2
|
/*! *****************************************************************************
|
|
3
3
|
Copyright (c) Microsoft Corporation.
|
|
4
4
|
|
|
@@ -12,5 +12,5 @@
|
|
|
12
12
|
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
13
13
|
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
14
14
|
PERFORMANCE OF THIS SOFTWARE.
|
|
15
|
-
***************************************************************************** */function
|
|
15
|
+
***************************************************************************** */function o(e,t,i,r){return new(i||(i=Promise))((function(o,n){function a(e){try{d(r.next(e))}catch(e){n(e)}}function s(e){try{d(r.throw(e))}catch(e){n(e)}}function d(e){var t;e.done?o(e.value):(t=e.value,t instanceof i?t:new i((function(e){e(t)}))).then(a,s)}d((r=r.apply(e,t||[])).next())}))}const n=()=>"undefined"!=typeof window,a=e=>{let t=e.trim();return t="/"===t[t.length-1]?t.slice(0,-1):t,t},s=()=>window.crypto||window.msCrypto,d=()=>{const e="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_~.";let t="";return Array.from(s().getRandomValues(new Uint8Array(43))).forEach((i=>t+=e[i%e.length])),t},c=e=>btoa(e),u=e=>o(void 0,void 0,void 0,(function*(){const t=(()=>{const e=s();return e.subtle||e.webkitSubtle})().digest({name:"SHA-256"},(new TextEncoder).encode(e));return window.msCrypto?new Promise(((e,i)=>{t.oncomplete=t=>{e(t.target.result)},t.onerror=e=>{i(e.error)},t.onabort=()=>{i("The digest operation was aborted")}})):yield t})),h="id email email_verified given_name family_name middle_name nickname preferred_username picture signup_methods gender birthdate phone_number phone_number_verified roles created_at updated_at ",l=`message access_token expires_in refresh_token id_token user { ${h} }`;e.Authorizer=class{constructor(e){if(this.getToken=e=>o(this,void 0,void 0,(function*(){if(!this.codeVerifier)throw new Error("invalid code verifier");const t={client_id:this.config.clientID,code:e.code,code_verifier:this.codeVerifier};try{const e=yield fetch(`${this.config.authorizerURL}/oauth/token`,{method:"POST",body:JSON.stringify(t),headers:{"Content-Type":"application/json"},credentials:"include"}),i=yield e.json();if(e.status>=400)throw new Error(i);return i}catch(e){throw e}})),this.authorize=e=>o(this,void 0,void 0,(function*(){if(!n)throw new Error("this feature is only supported in browser");const t=["openid","profile","email"];e.use_refresh_token&&t.push("offline_access");const i={redirect_uri:this.config.redirectURL,state:c(d()),nonce:c(d()),response_type:e.response_type,scope:t.join(" "),client_id:this.config.clientID};if("code"===e.response_type){this.codeVerifier=d();const e=(e=>{const t=new Uint8Array(e);return(e=>{const t={"+":"-","/":"_","=":""};return e.replace(/[+/=]/g,(e=>t[e]))})(window.btoa(String.fromCharCode(...Array.from(t))))})(yield u(this.codeVerifier));i.code_challenge=e}const r=`${this.config.authorizerURL}/authorize?${o=i,Object.keys(o).filter((e=>void 0!==o[e])).map((e=>encodeURIComponent(e)+"="+encodeURIComponent(o[e]))).join("&")}`;var o;try{const t=yield((e,t,i=60)=>new Promise(((r,o)=>{const n=window.document.createElement("iframe");n.setAttribute("id","authorizer-iframe"),n.setAttribute("width","0"),n.setAttribute("height","0"),n.style.display="none";const a=()=>{window.document.body.contains(n)&&(window.document.body.removeChild(n),window.removeEventListener("message",s,!1))};let s;const d=setTimeout((()=>{a()}),1e3*i);s=function(e){if(e.origin!=t)return;if(!e.data||!e.data.response)return;const i=e.source;i&&i.close(),e.data.response.error?o(e.data.response):r(e.data.response),clearTimeout(d),window.removeEventListener("message",s,!1),setTimeout(a,2e3)},window.addEventListener("message",s,!1),window.document.body.appendChild(n),n.setAttribute("src",e)})))(r,this.config.authorizerURL,60);if("code"===e.response_type){return yield this.getToken({code:t.code})}return t}catch(e){throw e.error&&window.location.replace(`${this.config.authorizerURL}/app?state=${c(JSON.stringify(this.config))}`),e}})),this.graphqlQuery=e=>o(this,void 0,void 0,(function*(){const t=n()?window.fetch:r.default,i=yield t(this.config.authorizerURL+"/graphql",{method:"POST",body:JSON.stringify({query:e.query,variables:e.variables||{}}),headers:Object.assign({"Content-Type":"application/json"},e.headers||{}),credentials:"include"}),o=yield i.json();if(o.errors&&o.errors.length)throw console.error(o.errors),new Error(o.errors[0].message);return o.data})),this.getMetaData=()=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:"query { meta { version is_google_login_enabled is_facebook_login_enabled is_github_login_enabled is_email_verification_enabled is_basic_authentication_enabled is_magic_link_login_enabled } }"})).meta}catch(e){throw e}})),this.getSession=(e,t)=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:`query getSession($params: SessionQueryInput){session(params: $params) { ${l} } }`,headers:e,variables:{params:t}})).session}catch(e){throw e}})),this.magicLinkLogin=e=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:"\n\t\t\t\t\tmutation magicLinkLogin($data: MagicLinkLoginInput!) { magic_link_login(params: $data) { message }}\n\t\t\t\t",variables:{data:e}})).magic_link_login}catch(e){throw e}})),this.signup=e=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:`\n\t\t\t\t\tmutation signup($data: SignUpInput!) { signup(params: $data) { ${l}}}\n\t\t\t\t`,variables:{data:e}})).signup}catch(e){throw e}})),this.verifyEmail=e=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:`\n\t\t\t\t\tmutation verifyEmail($data: VerifyEmailInput!) { verify_email(params: $data) { ${l}}}\n\t\t\t\t`,variables:{data:e}})).verify_email}catch(e){throw e}})),this.login=e=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:`\n\t\t\t\t\tmutation login($data: LoginInput!) { login(params: $data) { ${l}}}\n\t\t\t\t`,variables:{data:e}})).login}catch(e){throw e}})),this.getProfile=e=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:`query {\tprofile { ${h} } }`,headers:e})).profile}catch(e){throw e}})),this.updateProfile=(e,t)=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:"mutation updateProfile($data: UpdateProfileInput!) {\tupdate_profile(params: $data) { message } }",headers:t,variables:{data:e}})).update_profile}catch(e){throw e}})),this.forgotPassword=e=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:"mutation forgotPassword($data: ForgotPasswordInput!) {\tforgot_password(params: $data) { message } }",variables:{data:e}})).forgot_password}catch(e){throw e}})),this.resetPassword=e=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:"mutation resetPassword($data: ResetPasswordInput!) {\treset_password(params: $data) { message } }",variables:{data:e}})).reset_password}catch(e){throw e}})),this.browserLogin=()=>o(this,void 0,void 0,(function*(){try{return yield this.getSession()}catch(e){if(!n())throw new Error("browserLogin is only supported for browsers");window.location.replace(`${this.config.authorizerURL}/app?state=${c(JSON.stringify(this.config))}`)}})),this.oauthLogin=(e,t)=>o(this,void 0,void 0,(function*(){if(!Object.values(OAuthProviders).includes(e))throw new Error(`only following oauth providers are supported: ${Object.values(e).toString()}`);if(!n())throw new Error("oauthLogin is only supported for browsers");window.location.replace(`${this.config.authorizerURL}/oauth_login/${e}?redirectURL=${this.config.redirectURL||window.location.origin}${t&&t.length?`&roles=${t.join(",")}`:""}`)})),this.logout=e=>o(this,void 0,void 0,(function*(){try{return(yield this.graphqlQuery({query:" mutation { logout { message } } ",headers:e})).logout}catch(e){console.error(e)}})),!e)throw new Error("Configuration is required");if(this.config=e,!e.authorizerURL&&!e.authorizerURL.trim())throw new Error("Invalid authorizerURL");if(e.authorizerURL&&(this.config.authorizerURL=a(e.authorizerURL)),!e.redirectURL&&!e.redirectURL.trim())throw new Error("Invalid redirectURL");if(this.config.redirectURL=a(e.redirectURL),!e.clientID&&!e.clientID.trim())throw new Error("Invalid clientID");this.config.clientID=e.clientID.trim()}}}));
|
|
16
16
|
//# sourceMappingURL=authorizer.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"authorizer.min.js","sources":["../src/index.ts","../node_modules/tslib/tslib.es6.js"],"sourcesContent":[null,"/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || from);\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n"],"names":["OAuthProviders","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","hasWindow","window","userTokenFragment","constructor","config","this","data","f","fetch","nodeFetch","res","authorizerURL","method","body","JSON","stringify","query","variables","headers","credentials","json","errors","length","console","error","Error","message","graphqlQuery","meta","err","roles","token","magicLogin","signup","verifyEmail","login","profile","updateProfile","forgotPassword","resetPassword","getSession","location","href","btoa","oauthProvider","Object","values","includes","toString","redirectURL","origin","join","logout","trim","trimmedData","lastChar","slice"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"authorizer.min.js","sources":["../node_modules/tslib/tslib.es6.js","../src/constants.ts","../src/utils.ts","../src/index.ts"],"sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || from);\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n",null,null,null],"names":["__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","hasWindow","window","trimURL","url","trimmedData","trim","length","slice","getCrypto","crypto","msCrypto","createRandomString","charset","random","Array","from","getRandomValues","Uint8Array","forEach","v","encode","btoa","sha256","s","digestOp","subtle","webkitSubtle","getCryptoSubtle","digest","name","TextEncoder","res","rej","oncomplete","target","onerror","error","onabort","userFragment","authTokenFragment","constructor","config","this","data","codeVerifier","Error","requestData","client_id","clientID","code","code_verifier","fetch","authorizerURL","method","body","JSON","stringify","headers","credentials","json","status","err","scopes","use_refresh_token","push","redirect_uri","redirectURL","state","nonce","response_type","scope","join","codeChallenge","input","ie11SafeInput","b64Chars","replace","m","urlEncodeB64","String","fromCharCode","bufferToBase64UrlEncoded","code_challenge","authorizeURL","params","Object","keys","filter","k","map","encodeURIComponent","iframeRes","authorizeUrl","eventOrigin","timeoutInSeconds","iframe","document","createElement","setAttribute","style","display","removeIframe","contains","removeChild","removeEventListener","iframeEventHandler","timeoutSetTimeoutId","setTimeout","origin","response","eventSource","source","close","clearTimeout","CLEANUP_IFRAME_TIMEOUT_IN_SECONDS","addEventListener","appendChild","executeIframe","getToken","location","f","nodeFetch","query","variables","errors","console","message","graphqlQuery","meta","session","magic_link_login","signup","verify_email","login","profile","update_profile","forgot_password","reset_password","getSession","oauthProvider","roles","values","OAuthProviders","includes","toString","logout"],"mappings":"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"}
|
package/lib/cjs/index.d.ts
CHANGED
|
@@ -1,98 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
authorizerURL: string;
|
|
3
|
-
redirectURL?: string;
|
|
4
|
-
};
|
|
5
|
-
export declare type User = {
|
|
6
|
-
id: string;
|
|
7
|
-
email: string;
|
|
8
|
-
firstName?: string | null;
|
|
9
|
-
lastName?: string | null;
|
|
10
|
-
image?: string | null;
|
|
11
|
-
signupMethod?: string | null;
|
|
12
|
-
emailVerifiedAt?: number | null;
|
|
13
|
-
roles?: string[];
|
|
14
|
-
};
|
|
15
|
-
export declare type AuthToken = {
|
|
16
|
-
message?: string;
|
|
17
|
-
accessToken: string;
|
|
18
|
-
accessTokenExpiresAt: number;
|
|
19
|
-
user?: User;
|
|
20
|
-
};
|
|
21
|
-
export declare type Response = {
|
|
22
|
-
message: string;
|
|
23
|
-
};
|
|
24
|
-
export declare type Headers = Record<string, string>;
|
|
25
|
-
export declare type LoginInput = {
|
|
26
|
-
email: string;
|
|
27
|
-
password: string;
|
|
28
|
-
roles?: string[];
|
|
29
|
-
};
|
|
30
|
-
export declare type SignupInput = {
|
|
31
|
-
email: string;
|
|
32
|
-
password: string;
|
|
33
|
-
confirmPassword: string;
|
|
34
|
-
firstName?: string;
|
|
35
|
-
lastName?: string;
|
|
36
|
-
roles?: string[];
|
|
37
|
-
};
|
|
38
|
-
export declare type MagicLoginInput = {
|
|
39
|
-
email: string;
|
|
40
|
-
roles?: string[];
|
|
41
|
-
};
|
|
42
|
-
export declare type VerifyEmailInput = {
|
|
43
|
-
token: string;
|
|
44
|
-
};
|
|
45
|
-
export declare type GraphqlQueryInput = {
|
|
46
|
-
query: string;
|
|
47
|
-
variables?: Record<string, any>;
|
|
48
|
-
headers?: Headers;
|
|
49
|
-
};
|
|
50
|
-
export declare type MetaData = {
|
|
51
|
-
version: string;
|
|
52
|
-
isGoogleLoginEnabled: boolean;
|
|
53
|
-
isFacebookLoginEnabled: boolean;
|
|
54
|
-
isTwitterLoginEnabled: boolean;
|
|
55
|
-
isGithubLoginEnabled: boolean;
|
|
56
|
-
isEmailVerificationEnabled: boolean;
|
|
57
|
-
isBasicAuthenticationEnabled: boolean;
|
|
58
|
-
isMagicLoginEnabled: boolean;
|
|
59
|
-
};
|
|
60
|
-
export declare type UpdateProfileInput = {
|
|
61
|
-
oldPassword?: string;
|
|
62
|
-
newPassword?: string;
|
|
63
|
-
confirmNewPassword?: string;
|
|
64
|
-
firstName?: string;
|
|
65
|
-
lastName?: string;
|
|
66
|
-
image?: string;
|
|
67
|
-
email?: string;
|
|
68
|
-
};
|
|
69
|
-
export declare type ForgotPasswordInput = {
|
|
70
|
-
email: string;
|
|
71
|
-
};
|
|
72
|
-
export declare type ResetPasswordInput = {
|
|
73
|
-
token: string;
|
|
74
|
-
password: string;
|
|
75
|
-
confirmPassword: string;
|
|
76
|
-
};
|
|
77
|
-
export declare enum OAuthProviders {
|
|
78
|
-
Github = "github",
|
|
79
|
-
Google = "google"
|
|
80
|
-
}
|
|
1
|
+
import * as Types from './types';
|
|
81
2
|
export declare class Authorizer {
|
|
82
|
-
config: ConfigType;
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
3
|
+
config: Types.ConfigType;
|
|
4
|
+
codeVerifier: string;
|
|
5
|
+
constructor(config: Types.ConfigType);
|
|
6
|
+
getToken: (data: {
|
|
7
|
+
code?: string;
|
|
8
|
+
}) => Promise<any>;
|
|
9
|
+
authorize: (data: Types.AuthorizeInput) => Promise<any>;
|
|
10
|
+
graphqlQuery: (data: Types.GraphqlQueryInput) => Promise<any>;
|
|
11
|
+
getMetaData: () => Promise<Types.MetaData | void>;
|
|
12
|
+
getSession: (headers?: Types.Headers | undefined, params?: Types.SessionQueryInput | undefined) => Promise<Types.AuthToken>;
|
|
13
|
+
magicLinkLogin: (data: Types.MagicLinkLoginInput) => Promise<Response>;
|
|
14
|
+
signup: (data: Types.SignupInput) => Promise<Types.AuthToken | void>;
|
|
15
|
+
verifyEmail: (data: Types.VerifyEmailInput) => Promise<Types.AuthToken | void>;
|
|
16
|
+
login: (data: Types.LoginInput) => Promise<Types.AuthToken | void>;
|
|
17
|
+
getProfile: (headers?: Types.Headers | undefined) => Promise<Types.User | void>;
|
|
18
|
+
updateProfile: (data: Types.UpdateProfileInput, headers?: Types.Headers | undefined) => Promise<Types.Response | void>;
|
|
19
|
+
forgotPassword: (data: Types.ForgotPasswordInput) => Promise<Types.Response | void>;
|
|
20
|
+
resetPassword: (data: Types.ResetPasswordInput) => Promise<Types.Response | void>;
|
|
21
|
+
browserLogin: () => Promise<Types.AuthToken | void>;
|
|
96
22
|
oauthLogin: (oauthProvider: string, roles?: string[] | undefined) => Promise<void>;
|
|
97
|
-
logout: (headers?: Headers | undefined) => Promise<Response | void>;
|
|
23
|
+
logout: (headers?: Types.Headers | undefined) => Promise<Types.Response | void>;
|
|
98
24
|
}
|
package/lib/cjs/index.js
CHANGED
|
@@ -33,15 +33,174 @@ function __awaiter(thisArg, _arguments, P, generator) {
|
|
|
33
33
|
});
|
|
34
34
|
}
|
|
35
35
|
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
OAuthProviders["Google"] = "google";
|
|
40
|
-
})(exports.OAuthProviders || (exports.OAuthProviders = {}));
|
|
36
|
+
const DEFAULT_AUTHORIZE_TIMEOUT_IN_SECONDS = 60;
|
|
37
|
+
const CLEANUP_IFRAME_TIMEOUT_IN_SECONDS = 2;
|
|
38
|
+
|
|
41
39
|
const hasWindow = () => typeof window !== 'undefined';
|
|
42
|
-
const
|
|
40
|
+
const trimURL = (url) => {
|
|
41
|
+
let trimmedData = url.trim();
|
|
42
|
+
const lastChar = trimmedData[trimmedData.length - 1];
|
|
43
|
+
if (lastChar === '/') {
|
|
44
|
+
trimmedData = trimmedData.slice(0, -1);
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
trimmedData = trimmedData;
|
|
48
|
+
}
|
|
49
|
+
return trimmedData;
|
|
50
|
+
};
|
|
51
|
+
const getCrypto = () => {
|
|
52
|
+
return (window.crypto || window.msCrypto);
|
|
53
|
+
};
|
|
54
|
+
const getCryptoSubtle = () => {
|
|
55
|
+
const crypto = getCrypto();
|
|
56
|
+
return crypto.subtle || crypto.webkitSubtle;
|
|
57
|
+
};
|
|
58
|
+
const createRandomString = () => {
|
|
59
|
+
const charset = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_~.';
|
|
60
|
+
let random = '';
|
|
61
|
+
const randomValues = Array.from(getCrypto().getRandomValues(new Uint8Array(43)));
|
|
62
|
+
randomValues.forEach((v) => (random += charset[v % charset.length]));
|
|
63
|
+
return random;
|
|
64
|
+
};
|
|
65
|
+
const encode = (value) => btoa(value);
|
|
66
|
+
const createQueryParams = (params) => {
|
|
67
|
+
return Object.keys(params)
|
|
68
|
+
.filter((k) => typeof params[k] !== 'undefined')
|
|
69
|
+
.map((k) => encodeURIComponent(k) + '=' + encodeURIComponent(params[k]))
|
|
70
|
+
.join('&');
|
|
71
|
+
};
|
|
72
|
+
const sha256 = (s) => __awaiter(void 0, void 0, void 0, function* () {
|
|
73
|
+
const digestOp = getCryptoSubtle().digest({ name: 'SHA-256' }, new TextEncoder().encode(s));
|
|
74
|
+
if (window.msCrypto) {
|
|
75
|
+
return new Promise((res, rej) => {
|
|
76
|
+
digestOp.oncomplete = (e) => {
|
|
77
|
+
res(e.target.result);
|
|
78
|
+
};
|
|
79
|
+
digestOp.onerror = (e) => {
|
|
80
|
+
rej(e.error);
|
|
81
|
+
};
|
|
82
|
+
digestOp.onabort = () => {
|
|
83
|
+
rej('The digest operation was aborted');
|
|
84
|
+
};
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
return yield digestOp;
|
|
88
|
+
});
|
|
89
|
+
const urlEncodeB64 = (input) => {
|
|
90
|
+
const b64Chars = { '+': '-', '/': '_', '=': '' };
|
|
91
|
+
return input.replace(/[+/=]/g, (m) => b64Chars[m]);
|
|
92
|
+
};
|
|
93
|
+
const bufferToBase64UrlEncoded = (input) => {
|
|
94
|
+
const ie11SafeInput = new Uint8Array(input);
|
|
95
|
+
return urlEncodeB64(window.btoa(String.fromCharCode(...Array.from(ie11SafeInput))));
|
|
96
|
+
};
|
|
97
|
+
const executeIframe = (authorizeUrl, eventOrigin, timeoutInSeconds = DEFAULT_AUTHORIZE_TIMEOUT_IN_SECONDS) => {
|
|
98
|
+
return new Promise((res, rej) => {
|
|
99
|
+
const iframe = window.document.createElement('iframe');
|
|
100
|
+
iframe.setAttribute('id', 'authorizer-iframe');
|
|
101
|
+
iframe.setAttribute('width', '0');
|
|
102
|
+
iframe.setAttribute('height', '0');
|
|
103
|
+
iframe.style.display = 'none';
|
|
104
|
+
const removeIframe = () => {
|
|
105
|
+
if (window.document.body.contains(iframe)) {
|
|
106
|
+
window.document.body.removeChild(iframe);
|
|
107
|
+
window.removeEventListener('message', iframeEventHandler, false);
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
let iframeEventHandler;
|
|
111
|
+
const timeoutSetTimeoutId = setTimeout(() => {
|
|
112
|
+
removeIframe();
|
|
113
|
+
}, timeoutInSeconds * 1000);
|
|
114
|
+
iframeEventHandler = function (e) {
|
|
115
|
+
if (e.origin != eventOrigin)
|
|
116
|
+
return;
|
|
117
|
+
if (!e.data || !e.data.response)
|
|
118
|
+
return;
|
|
119
|
+
const eventSource = e.source;
|
|
120
|
+
if (eventSource) {
|
|
121
|
+
eventSource.close();
|
|
122
|
+
}
|
|
123
|
+
e.data.response.error ? rej(e.data.response) : res(e.data.response);
|
|
124
|
+
clearTimeout(timeoutSetTimeoutId);
|
|
125
|
+
window.removeEventListener('message', iframeEventHandler, false);
|
|
126
|
+
setTimeout(removeIframe, CLEANUP_IFRAME_TIMEOUT_IN_SECONDS * 1000);
|
|
127
|
+
};
|
|
128
|
+
window.addEventListener('message', iframeEventHandler, false);
|
|
129
|
+
window.document.body.appendChild(iframe);
|
|
130
|
+
iframe.setAttribute('src', authorizeUrl);
|
|
131
|
+
});
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
const userFragment = `id email email_verified given_name family_name middle_name nickname preferred_username picture signup_methods gender birthdate phone_number phone_number_verified roles created_at updated_at `;
|
|
135
|
+
const authTokenFragment = `message access_token expires_in refresh_token id_token user { ${userFragment} }`;
|
|
43
136
|
class Authorizer {
|
|
44
137
|
constructor(config) {
|
|
138
|
+
this.getToken = (data) => __awaiter(this, void 0, void 0, function* () {
|
|
139
|
+
if (!this.codeVerifier) {
|
|
140
|
+
throw new Error(`invalid code verifier`);
|
|
141
|
+
}
|
|
142
|
+
const requestData = {
|
|
143
|
+
client_id: this.config.clientID,
|
|
144
|
+
code: data.code,
|
|
145
|
+
code_verifier: this.codeVerifier,
|
|
146
|
+
};
|
|
147
|
+
try {
|
|
148
|
+
const res = yield fetch(`${this.config.authorizerURL}/oauth/token`, {
|
|
149
|
+
method: 'POST',
|
|
150
|
+
body: JSON.stringify(requestData),
|
|
151
|
+
headers: {
|
|
152
|
+
'Content-Type': 'application/json',
|
|
153
|
+
},
|
|
154
|
+
credentials: 'include',
|
|
155
|
+
});
|
|
156
|
+
const json = yield res.json();
|
|
157
|
+
if (res.status >= 400) {
|
|
158
|
+
throw new Error(json);
|
|
159
|
+
}
|
|
160
|
+
return json;
|
|
161
|
+
}
|
|
162
|
+
catch (err) {
|
|
163
|
+
throw err;
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
this.authorize = (data) => __awaiter(this, void 0, void 0, function* () {
|
|
167
|
+
if (!hasWindow) {
|
|
168
|
+
throw new Error(`this feature is only supported in browser`);
|
|
169
|
+
}
|
|
170
|
+
const scopes = ['openid', 'profile', 'email'];
|
|
171
|
+
if (data.use_refresh_token) {
|
|
172
|
+
scopes.push('offline_access');
|
|
173
|
+
}
|
|
174
|
+
const requestData = {
|
|
175
|
+
redirect_uri: this.config.redirectURL,
|
|
176
|
+
state: encode(createRandomString()),
|
|
177
|
+
nonce: encode(createRandomString()),
|
|
178
|
+
response_type: data.response_type,
|
|
179
|
+
scope: scopes.join(' '),
|
|
180
|
+
client_id: this.config.clientID,
|
|
181
|
+
};
|
|
182
|
+
if (data.response_type === `code`) {
|
|
183
|
+
this.codeVerifier = createRandomString();
|
|
184
|
+
const sha = yield sha256(this.codeVerifier);
|
|
185
|
+
const codeChallenge = bufferToBase64UrlEncoded(sha);
|
|
186
|
+
requestData.code_challenge = codeChallenge;
|
|
187
|
+
}
|
|
188
|
+
const authorizeURL = `${this.config.authorizerURL}/authorize?${createQueryParams(requestData)}`;
|
|
189
|
+
try {
|
|
190
|
+
const iframeRes = yield executeIframe(authorizeURL, this.config.authorizerURL, DEFAULT_AUTHORIZE_TIMEOUT_IN_SECONDS);
|
|
191
|
+
if (data.response_type === `code`) {
|
|
192
|
+
const token = yield this.getToken({ code: iframeRes.code });
|
|
193
|
+
return token;
|
|
194
|
+
}
|
|
195
|
+
return iframeRes;
|
|
196
|
+
}
|
|
197
|
+
catch (err) {
|
|
198
|
+
if (err.error) {
|
|
199
|
+
window.location.replace(`${this.config.authorizerURL}/app?state=${encode(JSON.stringify(this.config))}`);
|
|
200
|
+
}
|
|
201
|
+
throw err;
|
|
202
|
+
}
|
|
203
|
+
});
|
|
45
204
|
this.graphqlQuery = (data) => __awaiter(this, void 0, void 0, function* () {
|
|
46
205
|
const f = hasWindow() ? window.fetch : nodeFetch__default['default'];
|
|
47
206
|
const res = yield f(this.config.authorizerURL + '/graphql', {
|
|
@@ -63,7 +222,7 @@ class Authorizer {
|
|
|
63
222
|
this.getMetaData = () => __awaiter(this, void 0, void 0, function* () {
|
|
64
223
|
try {
|
|
65
224
|
const res = yield this.graphqlQuery({
|
|
66
|
-
query: `query { meta { version
|
|
225
|
+
query: `query { meta { version is_google_login_enabled is_facebook_login_enabled is_github_login_enabled is_email_verification_enabled is_basic_authentication_enabled is_magic_link_login_enabled } }`,
|
|
67
226
|
});
|
|
68
227
|
return res.meta;
|
|
69
228
|
}
|
|
@@ -71,29 +230,30 @@ class Authorizer {
|
|
|
71
230
|
throw err;
|
|
72
231
|
}
|
|
73
232
|
});
|
|
74
|
-
this.getSession = (headers,
|
|
233
|
+
this.getSession = (headers, params) => __awaiter(this, void 0, void 0, function* () {
|
|
75
234
|
try {
|
|
76
235
|
const res = yield this.graphqlQuery({
|
|
77
|
-
query: `query getSession($
|
|
236
|
+
query: `query getSession($params: SessionQueryInput){session(params: $params) { ${authTokenFragment} } }`,
|
|
78
237
|
headers,
|
|
79
238
|
variables: {
|
|
80
|
-
|
|
239
|
+
params,
|
|
81
240
|
},
|
|
82
241
|
});
|
|
83
|
-
return res.
|
|
242
|
+
return res.session;
|
|
84
243
|
}
|
|
85
244
|
catch (err) {
|
|
86
245
|
throw err;
|
|
87
246
|
}
|
|
88
247
|
});
|
|
89
|
-
this.
|
|
248
|
+
this.magicLinkLogin = (data) => __awaiter(this, void 0, void 0, function* () {
|
|
90
249
|
try {
|
|
91
250
|
const res = yield this.graphqlQuery({
|
|
92
251
|
query: `
|
|
93
|
-
|
|
252
|
+
mutation magicLinkLogin($data: MagicLinkLoginInput!) { magic_link_login(params: $data) { message }}
|
|
253
|
+
`,
|
|
94
254
|
variables: { data },
|
|
95
255
|
});
|
|
96
|
-
return res.
|
|
256
|
+
return res.magic_link_login;
|
|
97
257
|
}
|
|
98
258
|
catch (err) {
|
|
99
259
|
throw err;
|
|
@@ -103,7 +263,8 @@ class Authorizer {
|
|
|
103
263
|
try {
|
|
104
264
|
const res = yield this.graphqlQuery({
|
|
105
265
|
query: `
|
|
106
|
-
|
|
266
|
+
mutation signup($data: SignUpInput!) { signup(params: $data) { ${authTokenFragment}}}
|
|
267
|
+
`,
|
|
107
268
|
variables: { data },
|
|
108
269
|
});
|
|
109
270
|
return res.signup;
|
|
@@ -116,10 +277,11 @@ class Authorizer {
|
|
|
116
277
|
try {
|
|
117
278
|
const res = yield this.graphqlQuery({
|
|
118
279
|
query: `
|
|
119
|
-
|
|
280
|
+
mutation verifyEmail($data: VerifyEmailInput!) { verify_email(params: $data) { ${authTokenFragment}}}
|
|
281
|
+
`,
|
|
120
282
|
variables: { data },
|
|
121
283
|
});
|
|
122
|
-
return res.
|
|
284
|
+
return res.verify_email;
|
|
123
285
|
}
|
|
124
286
|
catch (err) {
|
|
125
287
|
throw err;
|
|
@@ -129,7 +291,8 @@ class Authorizer {
|
|
|
129
291
|
try {
|
|
130
292
|
const res = yield this.graphqlQuery({
|
|
131
293
|
query: `
|
|
132
|
-
|
|
294
|
+
mutation login($data: LoginInput!) { login(params: $data) { ${authTokenFragment}}}
|
|
295
|
+
`,
|
|
133
296
|
variables: { data },
|
|
134
297
|
});
|
|
135
298
|
return res.login;
|
|
@@ -141,7 +304,7 @@ class Authorizer {
|
|
|
141
304
|
this.getProfile = (headers) => __awaiter(this, void 0, void 0, function* () {
|
|
142
305
|
try {
|
|
143
306
|
const profileRes = yield this.graphqlQuery({
|
|
144
|
-
query: `query { profile {
|
|
307
|
+
query: `query { profile { ${userFragment} } }`,
|
|
145
308
|
headers,
|
|
146
309
|
});
|
|
147
310
|
return profileRes.profile;
|
|
@@ -153,13 +316,13 @@ class Authorizer {
|
|
|
153
316
|
this.updateProfile = (data, headers) => __awaiter(this, void 0, void 0, function* () {
|
|
154
317
|
try {
|
|
155
318
|
const updateProfileRes = yield this.graphqlQuery({
|
|
156
|
-
query: `mutation updateProfile($data: UpdateProfileInput!) {
|
|
319
|
+
query: `mutation updateProfile($data: UpdateProfileInput!) { update_profile(params: $data) { message } }`,
|
|
157
320
|
headers,
|
|
158
321
|
variables: {
|
|
159
322
|
data,
|
|
160
323
|
},
|
|
161
324
|
});
|
|
162
|
-
return updateProfileRes.
|
|
325
|
+
return updateProfileRes.update_profile;
|
|
163
326
|
}
|
|
164
327
|
catch (error) {
|
|
165
328
|
throw error;
|
|
@@ -168,12 +331,12 @@ class Authorizer {
|
|
|
168
331
|
this.forgotPassword = (data) => __awaiter(this, void 0, void 0, function* () {
|
|
169
332
|
try {
|
|
170
333
|
const forgotPasswordRes = yield this.graphqlQuery({
|
|
171
|
-
query: `mutation forgotPassword($data: ForgotPasswordInput!) {
|
|
334
|
+
query: `mutation forgotPassword($data: ForgotPasswordInput!) { forgot_password(params: $data) { message } }`,
|
|
172
335
|
variables: {
|
|
173
336
|
data,
|
|
174
337
|
},
|
|
175
338
|
});
|
|
176
|
-
return forgotPasswordRes.
|
|
339
|
+
return forgotPasswordRes.forgot_password;
|
|
177
340
|
}
|
|
178
341
|
catch (error) {
|
|
179
342
|
throw error;
|
|
@@ -182,12 +345,12 @@ class Authorizer {
|
|
|
182
345
|
this.resetPassword = (data) => __awaiter(this, void 0, void 0, function* () {
|
|
183
346
|
try {
|
|
184
347
|
const resetPasswordRes = yield this.graphqlQuery({
|
|
185
|
-
query: `mutation resetPassword($data: ResetPasswordInput!) {
|
|
348
|
+
query: `mutation resetPassword($data: ResetPasswordInput!) { reset_password(params: $data) { message } }`,
|
|
186
349
|
variables: {
|
|
187
350
|
data,
|
|
188
351
|
},
|
|
189
352
|
});
|
|
190
|
-
return resetPasswordRes.
|
|
353
|
+
return resetPasswordRes.reset_password;
|
|
191
354
|
}
|
|
192
355
|
catch (error) {
|
|
193
356
|
throw error;
|
|
@@ -202,17 +365,17 @@ class Authorizer {
|
|
|
202
365
|
if (!hasWindow()) {
|
|
203
366
|
throw new Error(`browserLogin is only supported for browsers`);
|
|
204
367
|
}
|
|
205
|
-
window.location.
|
|
368
|
+
window.location.replace(`${this.config.authorizerURL}/app?state=${encode(JSON.stringify(this.config))}`);
|
|
206
369
|
}
|
|
207
370
|
});
|
|
208
371
|
this.oauthLogin = (oauthProvider, roles) => __awaiter(this, void 0, void 0, function* () {
|
|
209
|
-
if (!Object.values(
|
|
372
|
+
if (!Object.values(OAuthProviders).includes(oauthProvider)) {
|
|
210
373
|
throw new Error(`only following oauth providers are supported: ${Object.values(oauthProvider).toString()}`);
|
|
211
374
|
}
|
|
212
375
|
if (!hasWindow()) {
|
|
213
376
|
throw new Error(`oauthLogin is only supported for browsers`);
|
|
214
377
|
}
|
|
215
|
-
window.location.
|
|
378
|
+
window.location.replace(`${this.config.authorizerURL}/oauth_login/${oauthProvider}?redirectURL=${this.config.redirectURL || window.location.origin}${roles && roles.length ? `&roles=${roles.join(',')}` : ``}`);
|
|
216
379
|
});
|
|
217
380
|
this.logout = (headers) => __awaiter(this, void 0, void 0, function* () {
|
|
218
381
|
try {
|
|
@@ -230,22 +393,24 @@ class Authorizer {
|
|
|
230
393
|
throw new Error(`Configuration is required`);
|
|
231
394
|
}
|
|
232
395
|
this.config = config;
|
|
233
|
-
if (!config.authorizerURL.trim()) {
|
|
396
|
+
if (!config.authorizerURL && !config.authorizerURL.trim()) {
|
|
234
397
|
throw new Error(`Invalid authorizerURL`);
|
|
235
398
|
}
|
|
236
399
|
if (config.authorizerURL) {
|
|
237
|
-
|
|
238
|
-
const lastChar = trimmedData[trimmedData.length - 1];
|
|
239
|
-
if (lastChar === '/') {
|
|
240
|
-
this.config.authorizerURL = trimmedData.slice(0, -1);
|
|
241
|
-
}
|
|
242
|
-
else {
|
|
243
|
-
this.config.authorizerURL = trimmedData;
|
|
244
|
-
}
|
|
400
|
+
this.config.authorizerURL = trimURL(config.authorizerURL);
|
|
245
401
|
}
|
|
246
|
-
if (!config.redirectURL) {
|
|
402
|
+
if (!config.redirectURL && !config.redirectURL.trim()) {
|
|
247
403
|
throw new Error(`Invalid redirectURL`);
|
|
248
404
|
}
|
|
405
|
+
else {
|
|
406
|
+
this.config.redirectURL = trimURL(config.redirectURL);
|
|
407
|
+
}
|
|
408
|
+
if (!config.clientID && !config.clientID.trim()) {
|
|
409
|
+
throw new Error(`Invalid clientID`);
|
|
410
|
+
}
|
|
411
|
+
else {
|
|
412
|
+
this.config.clientID = config.clientID.trim();
|
|
413
|
+
}
|
|
249
414
|
}
|
|
250
415
|
}
|
|
251
416
|
|