Socket
Socket
Sign inDemoInstall

react-google-oauth2

Package Overview
Dependencies
8
Maintainers
1
Versions
33
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 0.0.27 to 0.0.28-rc.0

lib/_apiUtils.d.ts

4

CHANGELOG.md

@@ -19,3 +19,7 @@ # Changelog

## Pre Release
**Releases 0.0.28-rc.0**
- Disconnect auto login #27. [Issue #27](https://github.com/joegasewicz/react-google-oauth2.0/issues/27)
## Unreleased

5

lib/apiUtils.d.ts

@@ -23,2 +23,3 @@ /** @internal */

readonly apiUrl: string;
responseState: IServerResponseState;
setResponseState: Dispatch<SetStateAction<IServerResponseState>>;

@@ -84,4 +85,6 @@ }

*/
export declare function createOAuthHeaders(resource?: string): Object;
export declare function createOAuthHeaders(resource?: string): {
[k: string]: string;
};
/** @internal */
export declare function removeOAuthQueryParams(): void;

@@ -6,2 +6,4 @@ /** @internal */

/** @public */
export declare type TypePrompt = "consent" | "select_account";
/** @public */
interface IAuthorizationBase {

@@ -31,3 +33,3 @@ /** This is your client ID */

includeGrantedScopes?: boolean;
/** Not required, optional. For prefilling email fields etc. */
/** Not required, optional. For prefilling email fields */
loginHint?: string;

@@ -37,5 +39,7 @@ /**

* present the user. If you don't specify this parameter, the user will be prompted
* only the first time your project requests access.
* only the first time your project requests access. Valid values:
* consent - Prompt the user for consent.
* select_account - Prompt the user to select an account.
* */
prompt?: string;
prompt?: TypePrompt;
}

@@ -42,0 +46,0 @@ /** @public */

import { default as React, Dispatch, SetStateAction } from "react";
import { IAuthorizationOptions } from "./authorization";
import { IAuthorizationOptions, TypePrompt } from "./authorization";
import { IServerResponseState } from "./apiUtils";

@@ -49,4 +49,7 @@ /** @public */

isAuthenticated?: boolean;
setOAuthState?: Function;
setOAuthState: Function;
responseState?: IServerResponseState;
options?: IAuthorizationOptions;
setOptions: Function;
setPrompt: Function;
/**

@@ -66,3 +69,3 @@ * ```

*/
setResponseState?: Dispatch<SetStateAction<IServerResponseState>>;
setResponseState: Dispatch<SetStateAction<IServerResponseState>>;
}

@@ -124,4 +127,16 @@ /** @internal */

*/
export declare function GoogleButton(props: TypeGoogleButton): JSX.Element | null;
export declare function GoogleButton(props: TypeGoogleButton): JSX.Element;
/**
*
* @param setOptions
* @param options
* @internal TODO make public when bugs are fixed
*/
export declare function setPrompt(setOptions: Function, options?: IAuthorizationOptions): (promptType: TypePrompt) => void;
/**
*
* @param props
* @constructor
*/
export declare const GoogleAuth: (props: any) => JSX.Element;
export {};

@@ -1,4 +0,4 @@

import { IAuthorizationOptions } from "./authorization";
import { IAuthorizationOptions, TypePrompt } from "./authorization";
import { isLoggedIn, logOutOAuthUser, createOAuthHeaders, getAccessToken } from "./apiUtils";
import { GoogleButton, IGoogleButton, GoogleAuth, GoogleAuthConsumer, IOAuthState } from "./components";
export { GoogleButton, IGoogleButton, IAuthorizationOptions, isLoggedIn, logOutOAuthUser, createOAuthHeaders, GoogleAuth, GoogleAuthConsumer, getAccessToken, IOAuthState, };
import { GoogleButton, IGoogleButton, GoogleAuth, GoogleAuthConsumer, IOAuthState, setPrompt } from "./components";
export { GoogleButton, IGoogleButton, IAuthorizationOptions, isLoggedIn, logOutOAuthUser, createOAuthHeaders, GoogleAuth, GoogleAuthConsumer, getAccessToken, IOAuthState, TypePrompt, setPrompt, };

@@ -1,2 +0,2 @@

module.exports=function(e){var t={};function r(o){if(t[o])return t[o].exports;var n=t[o]={i:o,l:!1,exports:{}};return e[o].call(n.exports,n,n.exports,r),n.l=!0,n.exports}return r.m=e,r.c=t,r.d=function(e,t,o){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:o})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var o=Object.create(null);if(r.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)r.d(o,n,function(t){return e[t]}.bind(null,n));return o},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,"a",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p="",r(r.s=1)}([function(e,t){e.exports=require("react")},function(e,t,r){"use strict";r.r(t),r.d(t,"GoogleButton",(function(){return R})),r.d(t,"isLoggedIn",(function(){return i})),r.d(t,"logOutOAuthUser",(function(){return s})),r.d(t,"createOAuthHeaders",(function(){return l})),r.d(t,"GoogleAuth",(function(){return x})),r.d(t,"GoogleAuthConsumer",(function(){return O})),r.d(t,"getAccessToken",(function(){return u}));var o=function(){return(o=Object.assign||function(e){for(var t,r=1,o=arguments.length;r<o;r++)for(var n in t=arguments[r])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}).apply(this,arguments)},n=function(e,t,r,o){return new(r||(r=Promise))((function(n,c){function a(e){try{s(o.next(e))}catch(e){c(e)}}function i(e){try{s(o.throw(e))}catch(e){c(e)}}function s(e){var t;e.done?n(e.value):(t=e.value,t instanceof r?t:new r((function(e){e(t)}))).then(a,i)}s((o=o.apply(e,t||[])).next())}))},c=function(e,t){var r,o,n,c,a={label:0,sent:function(){if(1&n[0])throw n[1];return n[1]},trys:[],ops:[]};return c={next:i(0),throw:i(1),return:i(2)},"function"==typeof Symbol&&(c[Symbol.iterator]=function(){return this}),c;function i(c){return function(i){return function(c){if(r)throw new TypeError("Generator is already executing.");for(;a;)try{if(r=1,o&&(n=2&c[0]?o.return:c[0]?o.throw||((n=o.return)&&n.call(o),0):o.next)&&!(n=n.call(o,c[1])).done)return n;switch(o=0,n&&(c=[2&c[0],n.value]),c[0]){case 0:case 1:n=c;break;case 4:return a.label++,{value:c[1],done:!1};case 5:a.label++,o=c[1],c=[0];continue;case 7:c=a.ops.pop(),a.trys.pop();continue;default:if(!(n=a.trys,(n=n.length>0&&n[n.length-1])||6!==c[0]&&2!==c[0])){a=0;continue}if(3===c[0]&&(!n||c[1]>n[0]&&c[1]<n[3])){a.label=c[1];break}if(6===c[0]&&a.label<n[1]){a.label=n[1],n=c;break}if(n&&a.label<n[2]){a.label=n[2],a.ops.push(c);break}n[2]&&a.ops.pop(),a.trys.pop();continue}c=t.call(e,a)}catch(e){c=[6,e],o=0}finally{r=n=0}if(5&c[0])throw c[1];return{value:c[0]?c[1]:void 0,done:!0}}([c,i])}}};function a(e){var t=e.code;(function(e,t){return n(this,void 0,void 0,(function(){return c(this,(function(r){switch(r.label){case 0:return[4,fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(t)})];case 1:return[2,r.sent().json()]}}))}))})(e.apiUrl,{code:t,scope:e.scope}).then((function(t){"access_token"in t?e.setResponseState({accessToken:t.access_token}):e.setResponseState({error:"so access_token in response data!"})})).catch((function(t){e.setResponseState({error:t.message})}))}function i(){return!!window.localStorage.getItem("accessToken")}function s(){window.localStorage.removeItem("accessToken")}function u(){return window.localStorage.getItem("accessToken")}function l(e){var t={};return e&&(t={"X-Auth-Resource":e}),o(o({},t),{"X-Auth-Token":"Bearer "+u()})}function p(){var e=document.location.href;if(document.location.search){var t=e.substring(0,e.indexOf("?"));window.history.replaceState({},document.title,t)}}var d,f=r(0),g=r.n(f);!function(e){e.GOOGLE_OAUTH_ENDPOINT="https://accounts.google.com/o/oauth2/v2/auth"}(d||(d={}));var h=function(){function e(e,t){var r=this;this.redirect=function(e){if(!r.googleRedirectURL)throw new ReferenceError("Error creating redirect url to Google's authorization server");window.location.replace(r.googleRedirectURL)},this.params=e,this.scopesStr=t}return Object.defineProperty(e.prototype,"googleRedirectURL",{get:function(){return this._googleRedirectURL},set:function(e){this._googleRedirectURL=e},enumerable:!1,configurable:!0}),e.prototype.createAuthorizationRequestURL=function(){var e,t=this.params,r=t.accessType,o=void 0===r?"offline":r,n=t.includeGrantedScopes,c=void 0===n||n,a=t.responseType,i=void 0===a?"code":a,s=t.state,u=void 0===s?null:s,l=t.redirectUri,p=t.clientId;e=d.GOOGLE_OAUTH_ENDPOINT+"?scope="+this.scopesStr+"&",e=(e=(e=o?e+"access_type="+o+"&":e)+"include_granted_scopes="+c+"&")+"response_type="+i+"&",e=(e=(e=u?e+"state="+u+"&":e)+"redirect_uri="+l+"&")+"client_id="+p,this.googleRedirectURL=e},e.createScopes=function(e){var t="";return e.map((function(r,o){e.length-1===o?t+=""+r:t+=r+"%20"})),t},e}(),v=function(){return(v=Object.assign||function(e){for(var t,r=1,o=arguments.length;r<o;r++)for(var n in t=arguments[r])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}).apply(this,arguments)},b={},y={backgroundSize:"20px 20px",backgroundRepeat:"no-repeat",backgroundPosition:"12px 10px",textIndent:"19px",border:"1px solid #bdc3c7",padding:"9px 23px",borderRadius:"9px",backgroundColor:"#bdc3c7",fontSize:"18px"},m=g.a.createContext({}),S=m.Provider,O=m.Consumer,w=function(e){var t=e.placeholder,r=void 0===t?"":t,o=e.defaultStyle,n=void 0===o||o,c=e.options,a=e.displayErrors,i=void 0!==a&&a,s=h.createScopes(c.scopes),u=new h(c,s);u.createAuthorizationRequestURL();var l=n?function(e,t){return e?v(v({},t),{backgroundImage:"url("+e+")"}):t}(r,y):void 0;return e.error&&console.error("[React-Google-OAuth2] Error: "+e.error+"\n - To display the error to the user, set IGoogleProps displayErrors to true.\n See https://joegasewicz.github.io/react-google-oauth2.0/"),p(),g.a.createElement(g.a.Fragment,null,g.a.createElement("button",{style:l,onClick:u.redirect,className:e.className+" google-oauth-btn"},e.children),i&&e.error&&g.a.createElement("div",null,e.error))};function R(e){var t,r,o,n,c,s=e.callback,u=Object(f.useContext)(m),l=new URLSearchParams(window.location.search),d=l.get("code"),h=l.get("error"),b=g.a.createElement(w,v({},e,{placeholder:e.placeholder,error:null===(t=u.responseState)||void 0===t?void 0:t.error,options:e.options}));if((null===(r=u.responseState)||void 0===r?void 0:r.accessToken)&&!i())return c=u.responseState.accessToken,window.localStorage.setItem("accessToken",c),console.debug("`accessToken` set in local storage."),"function"==typeof u.setOAuthState&&Object(f.useEffect)((function(){u.setOAuthState(!0)})),null;if(null===(o=u.responseState)||void 0===o?void 0:o.error)return console.error("[React-Google-OAuth2] Error: Api call failed with "+(null===(n=u.responseState)||void 0===n?void 0:n.error)+" error."),b;if(d&&!i()){var y={email:l.get("email")||"",scope:l.get("scope")||"",code:d,client_id:e.options.clientId,apiUrl:e.apiUrl,responseState:u.responseState,setResponseState:u.setResponseState};return p(),Object(f.useEffect)((function(){a(y)}),[]),console.debug("Waiting for remote api response"),s?s():g.a.createElement(g.a.Fragment,null,"Loading...")}return h?(console.error("Error: Google login attempt failed with "+h+" error."),b):b}var x=function(e){var t=Object(f.useState)(b),r=t[0],o=t[1],n=Object(f.useState)(i()),c={isAuthenticated:n[0],setOAuthState:n[1],responseState:r,setResponseState:o};return g.a.createElement(S,{value:c},e.children)}}]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://react-google-oauth/webpack/bootstrap","webpack://react-google-oauth/external \"react\"","webpack://react-google-oauth/./src/apiUtils.ts","webpack://react-google-oauth/./src/authorization.ts","webpack://react-google-oauth/./src/components.tsx"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","require","serverResponse","props","code","apiUrl","payload","fetch","method","headers","body","JSON","stringify","json","postToExchangeApiUrl","scope","then","data","setResponseState","accessToken","access_token","error","catch","err","message","isLoggedIn","window","localStorage","getItem","logOutOAuthUser","removeItem","getAccessToken","createOAuthHeaders","resource","resourceHeaders","removeOAuthQueryParams","currentLocation","document","location","href","search","clean_uri","substring","indexOf","history","replaceState","title","GoogleAPIConnectionStrings","params","scopesStr","redirect","e","googleRedirectURL","ReferenceError","replace","this","_googleRedirectURL","createAuthorizationRequestURL","url","accessType","includeGrantedScopes","responseType","state","redirectUri","clientId","GOOGLE_OAUTH_ENDPOINT","createScopes","scopes","str","map","length","SERVER_RESPONSE_STATE","buttonStyling","backgroundSize","backgroundRepeat","backgroundPosition","textIndent","border","padding","borderRadius","backgroundColor","fontSize","GoogleAuthContext","createContext","GoogleAuthProvider","Provider","GoogleAuthConsumer","Consumer","InnerButton","placeholder","defaultStyle","options","displayErrors","Authorization","auth","styles","backgroundImage","_getBackgroundImg","undefined","console","style","onClick","className","children","GoogleButton","token","callback","oauthContext","currentUrl","URLSearchParams","queryParamsCode","queryParamsError","_inner","responseState","setItem","debug","setOAuthState","email","client_id","GoogleAuth","_providerProps","isAuthenticated"],"mappings":"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","file":"index.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\n","module.exports = require(\"react\");","/** @internal */\nimport {Dispatch, SetStateAction} from \"react\";\n\nexport interface IPayload {\n    readonly code: string;\n    readonly scope: string;\n}\n/** @internal */\nexport interface IApiResponseData { readonly access_token: string; }\n/** @internal */\nexport async function postToExchangeApiUrl(apiUrl: string, payload: IPayload): Promise<IApiResponseData> {\n    const res: Response = await fetch(apiUrl, {\n        method: \"POST\",\n        headers: {\n            \"Content-Type\": \"application/json\",\n        },\n        body: JSON.stringify(payload),\n    });\n    return res.json();\n}\n/** @internal */\nexport interface IServerResponseState { readonly accessToken?: string; error?: string}\n/** @internal */\nexport interface IServerResponseProps {\n    readonly code: string;\n    readonly scope: string;\n    readonly apiUrl: string;\n    setResponseState: Dispatch<SetStateAction<IServerResponseState>>;\n}\n/** @internal */\nexport function serverResponse(props: IServerResponseProps): void {\n    const { code, apiUrl, scope } = props;\n    const payload: IPayload = { code, scope };\n    postToExchangeApiUrl(apiUrl, payload)\n        .then((data: IApiResponseData) => {\n            // update responseState accessToken\n            if(!(\"access_token\" in data)) {\n                props.setResponseState({\n                    error: \"so access_token in response data!\",\n                });\n            } else {\n                props.setResponseState({\n                    accessToken: data.access_token,\n                });\n            }\n\n        })\n        .catch(err => {\n            props.setResponseState({\n                error: err.message,\n            })\n        });\n}\n/** @internal */\nexport function storeAccessToken(token: string): void {\n     window.localStorage.setItem(\"accessToken\", token);\n}\n\n/**\n * @example\n * ```\n *  if(isLoggedIn()) { // returns true is accessToken exists in LocalStorage\n *      // user logged code...\n *  }\n * ```\n */\nexport function isLoggedIn(): boolean {\n    return !!window.localStorage.getItem(\"accessToken\");\n}\n\n/**\n * @example\n * ```\n *  logOutOAuthUser() // removes the accessToken from LocalStorage\n * ```\n * @return void\n */\nexport function logOutOAuthUser(): void {\n    window.localStorage.removeItem(\"accessToken\");\n}\n\n/**\n * @description Get the stored accessToken\n * @return The Access Token or none\n */\nexport function getAccessToken(): string | null {\n    return window.localStorage.getItem(\"accessToken\");\n}\n\n/**\n * @description Warning: Please make sure that as of version `0.0.23` we have removed\n * the `application/json` content type headers from this function. This may cause an issue\n * if you originally didn't construct your request content type headers with `application/json`.\n * @example\n * ```\n *  fetch(url, {\n *      headers: createOAuthHeaders(),\n *  })\n * ```\n *\n * If you require your server to handle authenticating multiple users across many resources\n * (or tables) then pass in the name of the resource, for Example:\n * @example\n * ```\n *  fetch(url, {\n *      headers: createOAuthHeaders(\"users\"),\n *  })\n * ```\n *\n *  With the resource value, the following headers are constructed:\n *\n *  @example\n *  ```\n *  {\n *    \"X-Auth-Token\" : \"<TOKEN>\",\n *    \"X-Auth-Resource\": \"users\",\n *  }\n *  ```\n * @param resource Optional resource name to look up on the server\n * @return Objects\n */\nexport function createOAuthHeaders(resource?: string): Object {\n    let resourceHeaders = {};\n    if(resource) {\n        resourceHeaders = {\n            \"X-Auth-Resource\": resource,\n        }\n    }\n    return {\n        ...resourceHeaders,\n        \"X-Auth-Token\": `Bearer ${getAccessToken()}`,\n    }\n}\n\n/** @internal */\nexport function removeOAuthQueryParams(): void {\n    const currentLocation = document.location.href;\n    if(document.location.search) {\n        const clean_uri = currentLocation.substring(0, currentLocation.indexOf(\"?\"));\n        window.history.replaceState({}, document.title, clean_uri);\n    }\n}\n","/** @internal */\nexport enum GoogleAPIConnectionStrings {\n    GOOGLE_OAUTH_ENDPOINT = \"https://accounts.google.com/o/oauth2/v2/auth\",\n}\n/** @public */\ninterface IAuthorizationBase {\n    /** This is your client ID */\n    clientId: string;\n    /** Where you React app should redirect to if user has successfully logged in **/\n    redirectUri: string;\n    /** By default this is set to *code* */\n    responseType?: string;\n    /**\n     * Indicates if the api **apiUrl** {@link IGoogleButton} can refresh tokens on the user's\n     * behalf. The default value is *online* but if your backend api will refresh the token then\n     * you must pass in a string value of *offline* (This is recommended for react apps connected\n     * to a REST api backend).\n     */\n    accessType?: string;\n    /**\n     * This option is currently unavailable but will be in a added in a future version,\n     * TODO - See https://github.com/joegasewicz/react-google-oauth2.0/issues/3\n     * */\n    state?: string;\n    /**\n     * Defaulted to true. Any extra scopes the logged in user previously granted\n     * will be available within the new access token.\n     * */\n    includeGrantedScopes?: boolean;\n    /** Not required, optional. For prefilling email fields etc. */\n    loginHint?: string;\n    /**\n     * Not required, optional. A space-delimited, case-sensitive list of prompts to\n     * present the user. If you don't specify this parameter, the user will be prompted\n     * only the first time your project requests access.\n     * */\n    prompt?: string;\n}\n/** @public */\nexport interface IAuthorizationOptions extends IAuthorizationBase {\n    scopes: Array<string>;\n}\n/** @internal */\nexport interface IAuthorization {\n    params: IAuthorizationOptions;\n    /** Set to  `[\"openid\", \"profile\"]` by default **/\n    scopesStr: string;\n}\n/** @internal */\nexport class Authorization implements IAuthorization {\n\n    private _googleRedirectURL?: string;\n\n    public params: IAuthorizationOptions;\n\n    public scopesStr: string;\n\n    constructor(params: IAuthorizationOptions, scopesStr: string) {\n        this.params = params;\n        this.scopesStr = scopesStr;\n    }\n\n    /**\n     * @internal\n     * @property googleRedirectURL Access the url for the initial\n     * browser call to Google's OAuth 2.0 server. Useful for debugging.\n     */\n    public get googleRedirectURL() {\n        return this._googleRedirectURL;\n    }\n\n    public set googleRedirectURL(value: string | undefined) {\n        this._googleRedirectURL = value;\n    }\n\n    /** @internal */\n    public createAuthorizationRequestURL(): void {\n        const {\n            accessType = \"offline\",\n            includeGrantedScopes = true,\n            responseType = \"code\",\n            state = null,\n            redirectUri,\n            clientId,\n        } = this.params;\n        const domain = GoogleAPIConnectionStrings.GOOGLE_OAUTH_ENDPOINT;\n        let url: string;\n        url = `${domain}?scope=${this.scopesStr}&`;\n        url = accessType ? `${url}access_type=${accessType}&` : url;\n        url = `${url}include_granted_scopes=${includeGrantedScopes}&`;\n        url = `${url}response_type=${responseType}&`;\n        url = state ? `${url}state=${state}&` : url;\n        url = `${url}redirect_uri=${redirectUri}&`;\n        url = `${url}client_id=${clientId}`;\n        this.googleRedirectURL = url;\n    }\n\n    /** @internal */\n    public static createScopes(scopes: Array<string>): string {\n        let str = \"\";\n        scopes.map((scope, i) => {\n            if (scopes.length - 1 === i) {\n                str += `${scope}`;\n            } else {\n                str += `${scope}%20`;\n            }\n        });\n        return str;\n    }\n\n    /** @internal */\n    public redirect = (e: any): void => {\n        if(this.googleRedirectURL) {\n            window.location.replace(this.googleRedirectURL)\n        } else {\n            throw new ReferenceError(\"Error creating redirect url to Google's authorization server\");\n        }\n    }\n}","import {default as React, Dispatch, SetStateAction, useContext, useEffect, useState} from \"react\";\nimport {\n    Authorization,\n    IAuthorizationOptions,\n} from \"./authorization\";\nimport {\n    serverResponse,\n    storeAccessToken,\n    isLoggedIn,\n    removeOAuthQueryParams, IServerResponseState, IServerResponseProps,\n} from \"./apiUtils\";\n\n/** @public */\nexport interface IGoogleButton {\n    /** Placeholder image displayed next to button text. The placeholder prop has no effect if placeholder is set to false */\n    readonly placeholder?: string;\n    /** Remove default styles.\n     *  To Style the <button> element with CSS, use `google-oauth-btn`. For example:\n     *  ```\n     *  .google-oauth-btn {\n     *      color: red;\n     *      background-color: lime;\n     *  }\n     *  ```\n     * (you can also pass your css selectors directly with Reacts' `className` prop)\n     * */\n    readonly defaultStyle?: boolean;\n    /** See IAuthorizationRequestParams */\n    readonly options: IAuthorizationOptions;\n    /**\n     * @property\n     * @optional\n     * A React component or any function that returns a React component.\n     * This would normally be used to display a preloader to the user whilst\n     * the OAuth2.0 login strategy is in flight. By default a `Loading...`\n     * message will be displayed.\n     * @example\n     * ```\n     * <GoogleButton\n     *    callback={() => <>\"Loading...\"</>}\n     *    // other props...\n     * />\n     * ```\n     */\n    readonly callback?: () => React.ReactHTMLElement<any>;\n    /** The url of the api to perform the exchange */\n    readonly apiUrl: string;\n    /**\n     * Optional. Default set to false.\n     * Display an error to the user (will be displayed in a child `div` element).\n     */\n    readonly displayErrors?: boolean;\n}\n/** @internal */\ntype TypeButtonStyles = { [key: string]: string };\n/** @internal */\ntype TypeGoogleButton = IGoogleButton & React.ButtonHTMLAttributes<HTMLButtonElement>;\n/** @internal */\ninterface IServerResponse {\n    readonly email?: string;\n    error?: string;\n    readonly code: string;\n    readonly scope: string;\n    readonly client_id: string;\n    readonly apiUrl: string;\n    responseState: IServerResponseState;\n    setResponseState: Dispatch<SetStateAction<IServerResponseState>>;\n}\n/** @internal */\nconst SERVER_RESPONSE_STATE = { };\n\n/** @internal */\nconst buttonStyling: TypeButtonStyles = {\n    backgroundSize: \"20px 20px\",\n    backgroundRepeat: \"no-repeat\",\n    backgroundPosition: \"12px 10px\",\n    textIndent: \"19px\",\n    border: \"1px solid #bdc3c7\",\n    padding: \"9px 23px\",\n    borderRadius: \"9px\",\n    backgroundColor: \"#bdc3c7\",\n    fontSize: \"18px\",\n};\n\nexport interface IOAuthState {\n    isAuthenticated?: boolean;\n    setOAuthState?: Function;\n    responseState?: IServerResponseState;\n    /**\n     * ```\n     *    import {\n     *       responseState\n     *   } from \"react-google-oauth2\";\n     *\n     *   <GoogleAuth>\n     *   {({responseState}) => {\n     *       // access the token from the state\n     *       console.log(responseState.accessToken) // <ACCESS_TOKEN>\n     *   }}\n     *   </GoogleAuth>\n     * ```\n     */\n    setResponseState?: Dispatch<SetStateAction<IServerResponseState>>;\n}\n/** @internal */\nconst GoogleAuthContext = React.createContext<IOAuthState>({});\n/** @internal */\nexport const GoogleAuthProvider = GoogleAuthContext.Provider;\n/**\n * @example\n * Get notified when a user has logged in successfully by wrapping the GoogleButton\n * component within the GoogleAuth provider. For example:\n * ```\n *    import {\n *       GoogleAuth\n *   } from \"react-google-oauth2\";\n *\n *   <GoogleAuth>\n *   {({isAuthenticated}) => {\n *       // isAuthenticated will get set to true when a user has successfully logged in.\n *       console.log(\"value: \", isAuthenticated); // value: true or false\n *       return <GoogleButton\n *                 // options...\n *               />\n *   }}\n *   </GoogleAuth>\n * ```\n */\nexport const GoogleAuthConsumer = GoogleAuthContext.Consumer;\n/** @internal */\nconst _getBackgroundImg = (placeholder: string, styles: TypeButtonStyles): TypeButtonStyles => {\n    if(placeholder) {\n        return { ...styles, backgroundImage: `url(${placeholder})` };\n    }\n    return styles;\n}\n\n/** @internal */\ninterface IInnerButtonProps extends IGoogleButton {\n    error?: string;\n}\n/** @internal */\nexport const InnerButton = (props: IInnerButtonProps & React.ButtonHTMLAttributes<HTMLButtonElement>) => {\n    const {\n        placeholder = \"\",\n        defaultStyle = true,\n        options,\n        displayErrors = false,\n    } = props;\n\n    const scopes = Authorization.createScopes(options.scopes);\n    const auth = new Authorization(options, scopes);\n    auth.createAuthorizationRequestURL();\n\n    const styles = defaultStyle ? _getBackgroundImg(placeholder, buttonStyling) : undefined;\n    if(props.error) {\n        console.error(`[React-Google-OAuth2] Error: ${props.error}\n         - To display the error to the user, set IGoogleProps displayErrors to true.\n         See https://joegasewicz.github.io/react-google-oauth2.0/`);\n    }\n    removeOAuthQueryParams();\n    return <>\n        <button style={styles} onClick={auth.redirect} className={`${props.className} google-oauth-btn`}>{props.children}</button>\n        {(displayErrors && props.error) && <div>{props.error}</div>}\n    </>\n}\n/**\n * @example\n * **Quick Start:**\n *\n * First create an options object that implements an {@link  IAuthorizationOptions} type.\n * Check the {@link  IAuthorizationOptions} and {@link  IAuthorizationBase} types for\n * all required properties. Then, pass the options to the {@link GoogleButton} component.\n *\n * ```IAuthorizationOptions\n *  const options:  = {\n *      clientId: (process.env.CLIENT_ID as string),\n *       redirectUri: \"http://localhost:3000\",\n *       scopes: [\"openid\", \"profile\", \"email\"],\n *       includeGrantedScopes: true,\n *       accessType: \"offline\",\n *   };\n *\n *   <GoogleButton\n *         placeholder=\"demo/search.png\"\n *         options={options}\n *         apiUrl=\"http://localhost:5000/google_login\"\n *   />\n * ```\n * @param props see IGoogleButton\n * @constructor\n */\nexport function GoogleButton(props: TypeGoogleButton) {\n    const {callback} = props;\n    const oauthContext = useContext<IOAuthState>(GoogleAuthContext);\n    const currentUrl = new URLSearchParams(window.location.search);\n    const queryParamsCode = currentUrl.get(\"code\");\n    const queryParamsError = currentUrl.get(\"error\");\n    let _inner =\n        <InnerButton\n            {...props}\n            placeholder={props.placeholder}\n            error={(oauthContext as any).responseState?.error}\n            options={props.options}\n        />;\n    if ((oauthContext as any).responseState?.accessToken && !isLoggedIn()) {\n        storeAccessToken((oauthContext as any).responseState.accessToken);\n        console.debug(\"`accessToken` set in local storage.\");\n        if(typeof (oauthContext as any).setOAuthState === \"function\") {\n            useEffect(() => {\n                (oauthContext as any).setOAuthState(true);\n            });\n        }\n        return null;\n    } else if ((oauthContext as any).responseState?.error) {\n        console.error(`[React-Google-OAuth2] Error: Api call failed with ${(oauthContext as any).responseState?.error} error.`);\n        return _inner;\n    } else if (queryParamsCode && !isLoggedIn()) {\n        // Get rest of params\n        const queryParamsEmail = currentUrl.get(\"email\") || \"\";\n        const queryParamsScope = currentUrl.get(\"scope\") || \"\";\n        const serverResponseProps: IServerResponse = {\n            email: queryParamsEmail,\n            scope: queryParamsScope,\n            code: queryParamsCode,\n            client_id: props.options.clientId,\n            apiUrl: props.apiUrl,\n            responseState: (oauthContext as any).responseState,\n            setResponseState: (oauthContext as any).setResponseState,\n        };\n        removeOAuthQueryParams();\n        useEffect(() => {\n            serverResponse(serverResponseProps);\n        }, []);\n        console.debug(\"Waiting for remote api response\");\n        return callback ? callback() : <>Loading...</>;\n    } else if (queryParamsError) {\n        console.error(`Error: Google login attempt failed with ${queryParamsError} error.`)\n        return _inner;\n    }\n    // Display button with no errors\n    return _inner;\n}\n\nexport const GoogleAuth = (props: any) => {\n    const [responseState, setResponseState] = useState<IServerResponseState>(SERVER_RESPONSE_STATE);\n    const [isAuthenticated, setOAuthState] = useState<boolean>(isLoggedIn());\n    const _providerProps: IOAuthState = {\n        isAuthenticated,\n        setOAuthState,\n        responseState,\n        setResponseState,\n    };\n    return  (\n        <GoogleAuthProvider value={_providerProps}>\n            {props.children}\n        </GoogleAuthProvider>\n    );\n}"],"sourceRoot":""}
module.exports=function(e){var t={};function o(n){if(t[n])return t[n].exports;var r=t[n]={i:n,l:!1,exports:{}};return e[n].call(r.exports,r,r.exports,o),r.l=!0,r.exports}return o.m=e,o.c=t,o.d=function(e,t,n){o.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(o.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var r in e)o.d(n,r,function(t){return e[t]}.bind(null,r));return n},o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,"a",t),t},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.p="",o(o.s=1)}([function(e,t){e.exports=require("react")},function(e,t,o){"use strict";o.r(t),o.d(t,"GoogleButton",(function(){return R})),o.d(t,"isLoggedIn",(function(){return a})),o.d(t,"logOutOAuthUser",(function(){return s})),o.d(t,"createOAuthHeaders",(function(){return l})),o.d(t,"GoogleAuth",(function(){return x})),o.d(t,"GoogleAuthConsumer",(function(){return S})),o.d(t,"getAccessToken",(function(){return u})),o.d(t,"setPrompt",(function(){return k}));var n=function(){return(n=Object.assign||function(e){for(var t,o=1,n=arguments.length;o<n;o++)for(var r in t=arguments[o])Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r]);return e}).apply(this,arguments)},r=function(e,t,o,n){return new(o||(o=Promise))((function(r,c){function i(e){try{s(n.next(e))}catch(e){c(e)}}function a(e){try{s(n.throw(e))}catch(e){c(e)}}function s(e){var t;e.done?r(e.value):(t=e.value,t instanceof o?t:new o((function(e){e(t)}))).then(i,a)}s((n=n.apply(e,t||[])).next())}))},c=function(e,t){var o,n,r,c,i={label:0,sent:function(){if(1&r[0])throw r[1];return r[1]},trys:[],ops:[]};return c={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(c[Symbol.iterator]=function(){return this}),c;function a(c){return function(a){return function(c){if(o)throw new TypeError("Generator is already executing.");for(;i;)try{if(o=1,n&&(r=2&c[0]?n.return:c[0]?n.throw||((r=n.return)&&r.call(n),0):n.next)&&!(r=r.call(n,c[1])).done)return r;switch(n=0,r&&(c=[2&c[0],r.value]),c[0]){case 0:case 1:r=c;break;case 4:return i.label++,{value:c[1],done:!1};case 5:i.label++,n=c[1],c=[0];continue;case 7:c=i.ops.pop(),i.trys.pop();continue;default:if(!(r=i.trys,(r=r.length>0&&r[r.length-1])||6!==c[0]&&2!==c[0])){i=0;continue}if(3===c[0]&&(!r||c[1]>r[0]&&c[1]<r[3])){i.label=c[1];break}if(6===c[0]&&i.label<r[1]){i.label=r[1],r=c;break}if(r&&i.label<r[2]){i.label=r[2],i.ops.push(c);break}r[2]&&i.ops.pop(),i.trys.pop();continue}c=t.call(e,i)}catch(e){c=[6,e],n=0}finally{o=r=0}if(5&c[0])throw c[1];return{value:c[0]?c[1]:void 0,done:!0}}([c,a])}}};function i(e){var t=e.code;(function(e,t){return r(this,void 0,void 0,(function(){return c(this,(function(o){switch(o.label){case 0:return[4,fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(t)})];case 1:return[2,o.sent().json()]}}))}))})(e.apiUrl,{code:t,scope:e.scope}).then((function(t){"access_token"in t?e.setResponseState({accessToken:t.access_token}):e.setResponseState({error:"so access_token in response data!"})})).catch((function(t){e.setResponseState({error:t.message})}))}function a(){return!!window.localStorage.getItem("accessToken")}function s(){window.localStorage.removeItem("accessToken")}function u(){return window.localStorage.getItem("accessToken")}function l(e){var t={};return e&&(t={"X-Auth-Resource":e}),n(n({},t),{"X-Auth-Token":"Bearer "+u()})}function p(){var e=document.location.href;if(document.location.search){var t=e.substring(0,e.indexOf("?"));window.history.replaceState({},document.title,t)}}var f,d=o(0),g=o.n(d);!function(e){e.GOOGLE_OAUTH_ENDPOINT="https://accounts.google.com/o/oauth2/v2/auth"}(f||(f={}));var h=function(){function e(e,t){var o=this;this.redirect=function(e){if(!o.googleRedirectURL)throw new ReferenceError("Error creating redirect url to Google's authorization server");window.location.replace(o.googleRedirectURL)},this.params=e,this.scopesStr=t}return Object.defineProperty(e.prototype,"googleRedirectURL",{get:function(){return this._googleRedirectURL},set:function(e){this._googleRedirectURL=e},enumerable:!1,configurable:!0}),e.prototype.createAuthorizationRequestURL=function(){var e,t=this.params,o=t.accessType,n=void 0===o?"offline":o,r=t.includeGrantedScopes,c=void 0===r||r,i=t.responseType,a=void 0===i?"code":i,s=t.state,u=void 0===s?null:s,l=t.redirectUri,p=t.clientId,d=t.loginHint,g=t.prompt;e=f.GOOGLE_OAUTH_ENDPOINT+"?scope="+this.scopesStr+"&",e=(e=(e=n?e+"access_type="+n+"&":e)+"include_granted_scopes="+c+"&")+"response_type="+a+"&",e=u?e+"state="+u+"&":e,e=d?e+"login_hint="+d+"&":e,e=(e=(e=g?e+"prompt="+g+"&":e)+"redirect_uri="+l+"&")+"client_id="+p,this.googleRedirectURL=e},e.createScopes=function(e){var t="";return e.map((function(o,n){e.length-1===n?t+=""+o:t+=o+"%20"})),t},e}(),b=function(){return(b=Object.assign||function(e){for(var t,o=1,n=arguments.length;o<n;o++)for(var r in t=arguments[o])Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r]);return e}).apply(this,arguments)},v={},y={backgroundSize:"20px 20px",backgroundRepeat:"no-repeat",backgroundPosition:"12px 10px",textIndent:"19px",border:"1px solid #bdc3c7",padding:"9px 23px",borderRadius:"9px",backgroundColor:"#bdc3c7",fontSize:"18px"},m=g.a.createContext({setOAuthState:function(){},setOptions:function(){},setPrompt:function(){},setResponseState:function(){}}),O=m.Provider,S=m.Consumer,w=function(e){var t=e.placeholder,o=void 0===t?"":t,n=e.defaultStyle,r=void 0===n||n,c=e.options,i=e.displayErrors,a=void 0!==i&&i,s=h.createScopes(c.scopes),u=new h(c,s);u.createAuthorizationRequestURL();var l=r?function(e,t){return e?b(b({},t),{backgroundImage:"url("+e+")"}):t}(o,y):void 0;return e.error&&console.error("[React-Google-OAuth2] Error: "+e.error+"\n - To display the error to the user, set IGoogleProps displayErrors to true.\n See https://joegasewicz.github.io/react-google-oauth2.0/"),p(),g.a.createElement(g.a.Fragment,null,g.a.createElement("button",{style:l,onClick:u.redirect,className:e.className+" google-oauth-btn"},e.children),a&&e.error&&g.a.createElement("div",null,e.error))};function R(e){var t=e.callback,o=Object(d.useContext)(m),n=o.options,r=o.setOptions,c=o.responseState,s=o.setOAuthState,u=o.setResponseState,l=o.isAuthenticated,f=Object(d.useState)(),h=f[0],v=f[1],y=new URLSearchParams(window.location.search),O=y.get("code"),S=y.get("error");Object(d.useEffect)((function(){!n&&r&&r(e.options)}),[e.options]),Object(d.useEffect)((function(){c&&!Object.keys(c).length&&h&&i(h)}),[h,c]),Object(d.useEffect)((function(){var e;(null==c?void 0:c.accessToken)&&!a()&&(e=c.accessToken,window.localStorage.setItem("accessToken",e),console.debug("`accessToken` set in local storage."),"function"!=typeof s||l||s(!0))}),[null==c?void 0:c.accessToken]);var R=b(b({},e.options),n),k=g.a.createElement(w,b({},e,{placeholder:e.placeholder,error:null==c?void 0:c.error,options:R}));if(null==c?void 0:c.error)return console.error("[React-Google-OAuth2] Error: Api call failed with "+(null==c?void 0:c.error)+" error."),k;if(O&&!a()){var x={email:y.get("email")||"",scope:y.get("scope")||"",code:O,client_id:e.options.clientId,apiUrl:e.apiUrl,responseState:c,setResponseState:u};return p(),c&&!Object.keys(c).length&&v(x),console.debug("Waiting for remote api response"),t?t():g.a.createElement(g.a.Fragment,null,"Loading...")}return S?(console.error("Error: Google login attempt failed with "+S+" error."),k):k}function k(e,t){return function(o){t&&!t.prompt&&e(b(b({},t),{prompt:o}))}}var x=function(e){var t=Object(d.useState)(v),o=t[0],n=t[1],r=Object(d.useState)(a()),c=r[0],i=r[1],s=Object(d.useState)(),u=s[0],l=s[1],p={isAuthenticated:c,setOAuthState:i,responseState:o,setResponseState:n,options:u,setOptions:l,setPrompt:k(l,u)};return g.a.createElement(O,{value:p},e.children)}}]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://react-google-oauth/webpack/bootstrap","webpack://react-google-oauth/external \"react\"","webpack://react-google-oauth/./src/apiUtils.ts","webpack://react-google-oauth/./src/authorization.ts","webpack://react-google-oauth/./src/components.tsx"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","require","serverResponse","props","code","apiUrl","payload","fetch","method","headers","body","JSON","stringify","json","postToExchangeApiUrl","scope","then","data","setResponseState","accessToken","access_token","error","catch","err","message","isLoggedIn","window","localStorage","getItem","logOutOAuthUser","removeItem","getAccessToken","createOAuthHeaders","resource","resourceHeaders","removeOAuthQueryParams","currentLocation","document","location","href","search","clean_uri","substring","indexOf","history","replaceState","title","GoogleAPIConnectionStrings","params","scopesStr","redirect","e","googleRedirectURL","ReferenceError","replace","this","_googleRedirectURL","createAuthorizationRequestURL","url","accessType","includeGrantedScopes","responseType","state","redirectUri","clientId","loginHint","prompt","GOOGLE_OAUTH_ENDPOINT","createScopes","scopes","str","map","length","SERVER_RESPONSE_STATE","buttonStyling","backgroundSize","backgroundRepeat","backgroundPosition","textIndent","border","padding","borderRadius","backgroundColor","fontSize","GoogleAuthContext","createContext","setOAuthState","setOptions","setPrompt","GoogleAuthProvider","Provider","GoogleAuthConsumer","Consumer","InnerButton","placeholder","defaultStyle","options","displayErrors","Authorization","auth","styles","backgroundImage","_getBackgroundImg","undefined","console","style","onClick","className","children","GoogleButton","callback","responseState","isAuthenticated","serverResponseState","setServerResponseState","currentUrl","URLSearchParams","queryParamsCode","queryParamsError","keys","token","setItem","debug","mergedPropsAndStateOptions","_inner","serverResponseProps","email","client_id","promptType","GoogleAuth","_providerProps"],"mappings":"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","file":"index.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\n","module.exports = require(\"react\");","/** @internal */\nimport {Dispatch, SetStateAction, useEffect} from \"react\";\n\nexport interface IPayload {\n    readonly code: string;\n    readonly scope: string;\n}\n/** @internal */\nexport interface IApiResponseData { readonly access_token: string; }\n/** @internal */\nexport async function postToExchangeApiUrl(apiUrl: string, payload: IPayload): Promise<IApiResponseData> {\n    const res: Response = await fetch(apiUrl, {\n        method: \"POST\",\n        headers: {\n            \"Content-Type\": \"application/json\",\n        },\n        body: JSON.stringify(payload),\n    });\n    return res.json();\n}\n/** @internal */\nexport interface IServerResponseState { readonly accessToken?: string; error?: string}\n/** @internal */\nexport interface IServerResponseProps {\n    readonly code: string;\n    readonly scope: string;\n    readonly apiUrl: string;\n    responseState: IServerResponseState;\n    setResponseState: Dispatch<SetStateAction<IServerResponseState>>;\n}\n/** @internal */\nexport function serverResponse(props: IServerResponseProps): void {\n    const { code, apiUrl, scope } = props;\n    const payload: IPayload = { code, scope };\n    postToExchangeApiUrl(apiUrl, payload)\n        .then((data: IApiResponseData) => {\n            // update responseState accessToken\n            if(!(\"access_token\" in data)) {\n                props.setResponseState({\n                    error: \"so access_token in response data!\",\n                });\n            } else {\n                props.setResponseState({\n                    accessToken: data.access_token,\n                });\n            }\n\n        })\n        .catch(err => {\n            props.setResponseState({\n                error: err.message,\n            })\n        });\n}\n/** @internal */\nexport function storeAccessToken(token: string): void {\n     window.localStorage.setItem(\"accessToken\", token);\n}\n\n/**\n * @example\n * ```\n *  if(isLoggedIn()) { // returns true is accessToken exists in LocalStorage\n *      // user logged code...\n *  }\n * ```\n */\nexport function isLoggedIn(): boolean {\n    return !!window.localStorage.getItem(\"accessToken\");\n}\n\n/**\n * @example\n * ```\n *  logOutOAuthUser() // removes the accessToken from LocalStorage\n * ```\n * @return void\n */\nexport function logOutOAuthUser(): void {\n    window.localStorage.removeItem(\"accessToken\");\n}\n\n/**\n * @description Get the stored accessToken\n * @return The Access Token or none\n */\nexport function getAccessToken(): string | null {\n    return window.localStorage.getItem(\"accessToken\");\n}\n\n/**\n * @description Warning: Please make sure that as of version `0.0.23` we have removed\n * the `application/json` content type headers from this function. This may cause an issue\n * if you originally didn't construct your request content type headers with `application/json`.\n * @example\n * ```\n *  fetch(url, {\n *      headers: createOAuthHeaders(),\n *  })\n * ```\n *\n * If you require your server to handle authenticating multiple users across many resources\n * (or tables) then pass in the name of the resource, for Example:\n * @example\n * ```\n *  fetch(url, {\n *      headers: createOAuthHeaders(\"users\"),\n *  })\n * ```\n *\n *  With the resource value, the following headers are constructed:\n *\n *  @example\n *  ```\n *  {\n *    \"X-Auth-Token\" : \"<TOKEN>\",\n *    \"X-Auth-Resource\": \"users\",\n *  }\n *  ```\n * @param resource Optional resource name to look up on the server\n * @return Objects\n */\nexport function createOAuthHeaders(resource?: string): { [k: string]: string } {\n    let resourceHeaders = {};\n    if(resource) {\n        resourceHeaders = {\n            \"X-Auth-Resource\": resource,\n        }\n    }\n    return {\n        ...resourceHeaders,\n        \"X-Auth-Token\": `Bearer ${getAccessToken()}`,\n    }\n}\n\n/** @internal */\nexport function removeOAuthQueryParams(): void {\n    const currentLocation = document.location.href;\n    if(document.location.search) {\n        const clean_uri = currentLocation.substring(0, currentLocation.indexOf(\"?\"));\n        window.history.replaceState({}, document.title, clean_uri);\n    }\n}\n","/** @internal */\nexport enum GoogleAPIConnectionStrings {\n    GOOGLE_OAUTH_ENDPOINT = \"https://accounts.google.com/o/oauth2/v2/auth\",\n}\n/** @public */\nexport type TypePrompt = \"consent\" | \"select_account\";\n/** @public */\ninterface IAuthorizationBase {\n    /** This is your client ID */\n    clientId: string;\n    /** Where you React app should redirect to if user has successfully logged in **/\n    redirectUri: string;\n    /** By default this is set to *code* */\n    responseType?: string;\n    /**\n     * Indicates if the api **apiUrl** {@link IGoogleButton} can refresh tokens on the user's\n     * behalf. The default value is *online* but if your backend api will refresh the token then\n     * you must pass in a string value of *offline* (This is recommended for react apps connected\n     * to a REST api backend).\n     */\n    accessType?: string;\n    /**\n     * This option is currently unavailable but will be in a added in a future version,\n     * TODO - See https://github.com/joegasewicz/react-google-oauth2.0/issues/3\n     * */\n    state?: string;\n    /**\n     * Defaulted to true. Any extra scopes the logged in user previously granted\n     * will be available within the new access token.\n     * */\n    includeGrantedScopes?: boolean;\n    /** Not required, optional. For prefilling email fields */\n    loginHint?: string;\n    /**\n     * Not required, optional. A space-delimited, case-sensitive list of prompts to\n     * present the user. If you don't specify this parameter, the user will be prompted\n     * only the first time your project requests access. Valid values:\n     *  consent - Prompt the user for consent.\n     *  select_account - Prompt the user to select an account.\n     * */\n    prompt?: TypePrompt;\n}\n/** @public */\nexport interface IAuthorizationOptions extends IAuthorizationBase {\n    scopes: Array<string>;\n}\n/** @internal */\nexport interface IAuthorization {\n    params: IAuthorizationOptions;\n    /** Set to  `[\"openid\", \"profile\"]` by default **/\n    scopesStr: string;\n}\n/** @internal */\nexport class Authorization implements IAuthorization {\n\n    private _googleRedirectURL?: string;\n\n    public params: IAuthorizationOptions;\n\n    public scopesStr: string;\n\n    constructor(params: IAuthorizationOptions, scopesStr: string) {\n        this.params = params;\n        this.scopesStr = scopesStr;\n    }\n\n    /**\n     * @internal\n     * @property googleRedirectURL Access the url for the initial\n     * browser call to Google's OAuth 2.0 server. Useful for debugging.\n     */\n    public get googleRedirectURL() {\n        return this._googleRedirectURL;\n    }\n\n    public set googleRedirectURL(value: string | undefined) {\n        this._googleRedirectURL = value;\n    }\n\n    /** @internal */\n    public createAuthorizationRequestURL(): void {\n        const {\n            accessType = \"offline\",\n            includeGrantedScopes = true,\n            responseType = \"code\",\n            state = null,\n            redirectUri,\n            clientId,\n            loginHint,\n            prompt,\n        } = this.params;\n        const domain = GoogleAPIConnectionStrings.GOOGLE_OAUTH_ENDPOINT;\n        let url: string;\n        url = `${domain}?scope=${this.scopesStr}&`;\n        url = accessType ? `${url}access_type=${accessType}&` : url;\n        url = `${url}include_granted_scopes=${includeGrantedScopes}&`;\n        url = `${url}response_type=${responseType}&`;\n        url = state ? `${url}state=${state}&` : url;\n        url = loginHint ? `${url}login_hint=${loginHint}&` : url;\n        url = prompt ? `${url}prompt=${prompt}&` : url;\n        url = `${url}redirect_uri=${redirectUri}&`;\n        url = `${url}client_id=${clientId}`;\n        this.googleRedirectURL = url;\n    }\n\n    /** @internal */\n    public static createScopes(scopes: Array<string>): string {\n        let str = \"\";\n        scopes.map((scope, i) => {\n            if (scopes.length - 1 === i) {\n                str += `${scope}`;\n            } else {\n                str += `${scope}%20`;\n            }\n        });\n        return str;\n    }\n\n    /** @internal */\n    public redirect = (e: any): void => {\n        if(this.googleRedirectURL) {\n            window.location.replace(this.googleRedirectURL)\n        } else {\n            throw new ReferenceError(\"Error creating redirect url to Google's authorization server\");\n        }\n    }\n}","import {default as React, Dispatch, SetStateAction, useContext, useEffect, useState} from \"react\";\nimport {\n    Authorization,\n    IAuthorizationOptions, TypePrompt,\n} from \"./authorization\";\nimport {\n    serverResponse,\n    storeAccessToken,\n    isLoggedIn,\n    removeOAuthQueryParams, IServerResponseState, IServerResponseProps,\n} from \"./apiUtils\";\n\n/** @public */\nexport interface IGoogleButton {\n    /** Placeholder image displayed next to button text. The placeholder prop has no effect if placeholder is set to false */\n    readonly placeholder?: string;\n    /** Remove default styles.\n     *  To Style the <button> element with CSS, use `google-oauth-btn`. For example:\n     *  ```\n     *  .google-oauth-btn {\n     *      color: red;\n     *      background-color: lime;\n     *  }\n     *  ```\n     * (you can also pass your css selectors directly with Reacts' `className` prop)\n     * */\n    readonly defaultStyle?: boolean;\n    /** See IAuthorizationRequestParams */\n    readonly options: IAuthorizationOptions;\n    /**\n     * @property\n     * @optional\n     * A React component or any function that returns a React component.\n     * This would normally be used to display a preloader to the user whilst\n     * the OAuth2.0 login strategy is in flight. By default a `Loading...`\n     * message will be displayed.\n     * @example\n     * ```\n     * <GoogleButton\n     *    callback={() => <>\"Loading...\"</>}\n     *    // other props...\n     * />\n     * ```\n     */\n    readonly callback?: () => React.ReactHTMLElement<any>;\n    /** The url of the api to perform the exchange */\n    readonly apiUrl: string;\n    /**\n     * Optional. Default set to false.\n     * Display an error to the user (will be displayed in a child `div` element).\n     */\n    readonly displayErrors?: boolean;\n}\n/** @internal */\ntype TypeButtonStyles = { [key: string]: string };\n/** @internal */\ntype TypeGoogleButton = IGoogleButton & React.ButtonHTMLAttributes<HTMLButtonElement>;\n/** @internal */\ninterface IServerResponse {\n    readonly email?: string;\n    error?: string;\n    readonly code: string;\n    readonly scope: string;\n    readonly client_id: string;\n    readonly apiUrl: string;\n    responseState: IServerResponseState;\n    setResponseState: Dispatch<SetStateAction<IServerResponseState>>;\n}\n/** @internal */\nconst SERVER_RESPONSE_STATE = { };\n\n/** @internal */\nconst buttonStyling: TypeButtonStyles = {\n    backgroundSize: \"20px 20px\",\n    backgroundRepeat: \"no-repeat\",\n    backgroundPosition: \"12px 10px\",\n    textIndent: \"19px\",\n    border: \"1px solid #bdc3c7\",\n    padding: \"9px 23px\",\n    borderRadius: \"9px\",\n    backgroundColor: \"#bdc3c7\",\n    fontSize: \"18px\",\n};\n\nexport interface IOAuthState {\n    isAuthenticated?: boolean;\n    setOAuthState: Function;\n    responseState?: IServerResponseState;\n    options?: IAuthorizationOptions;\n    setOptions: Function;\n    setPrompt: Function;\n    /**\n     * ```\n     *    import {\n     *       responseState\n     *   } from \"react-google-oauth2\";\n     *\n     *   <GoogleAuth>\n     *   {({responseState}) => {\n     *       // access the token from the state\n     *       console.log(responseState.accessToken) // <ACCESS_TOKEN>\n     *   }}\n     *   </GoogleAuth>\n     * ```\n     */\n    setResponseState: Dispatch<SetStateAction<IServerResponseState>>;\n}\n/** @internal */\nconst DEFAULT_GOOGLE_AUTH_CONTEXT = {\n    setOAuthState: () => {},\n    setOptions: () => {},\n    setPrompt: () => {},\n    setResponseState: () => {},\n};\n/** @internal */\nconst GoogleAuthContext = React.createContext<IOAuthState>(DEFAULT_GOOGLE_AUTH_CONTEXT);\n/** @internal */\nexport const GoogleAuthProvider = GoogleAuthContext.Provider;\n/**\n * @example\n * Get notified when a user has logged in successfully by wrapping the GoogleButton\n * component within the GoogleAuth provider. For example:\n * ```\n *    import {\n *       GoogleAuth\n *   } from \"react-google-oauth2\";\n *\n *   <GoogleAuth>\n *   {({isAuthenticated}) => {\n *       // isAuthenticated will get set to true when a user has successfully logged in.\n *       console.log(\"value: \", isAuthenticated); // value: true or false\n *       return <GoogleButton\n *                 // options...\n *               />\n *   }}\n *   </GoogleAuth>\n * ```\n */\nexport const GoogleAuthConsumer = GoogleAuthContext.Consumer;\n/** @internal */\nconst _getBackgroundImg = (placeholder: string, styles: TypeButtonStyles): TypeButtonStyles => {\n    if(placeholder) {\n        return { ...styles, backgroundImage: `url(${placeholder})` };\n    }\n    return styles;\n}\n\n/** @internal */\ninterface IInnerButtonProps extends IGoogleButton {\n    error?: string;\n}\n/** @internal */\nexport const InnerButton = (props: IInnerButtonProps & React.ButtonHTMLAttributes<HTMLButtonElement>) => {\n    const {\n        placeholder = \"\",\n        defaultStyle = true,\n        options,\n        displayErrors = false,\n    } = props;\n\n    const scopes = Authorization.createScopes(options.scopes);\n    const auth = new Authorization(options, scopes);\n    auth.createAuthorizationRequestURL();\n\n\n    const styles = defaultStyle ? _getBackgroundImg(placeholder, buttonStyling) : undefined;\n    if(props.error) {\n        console.error(`[React-Google-OAuth2] Error: ${props.error}\n         - To display the error to the user, set IGoogleProps displayErrors to true.\n         See https://joegasewicz.github.io/react-google-oauth2.0/`);\n    }\n    removeOAuthQueryParams();\n    return <>\n        <button style={styles} onClick={auth.redirect} className={`${props.className} google-oauth-btn`}>{props.children}</button>\n        {(displayErrors && props.error) && <div>{props.error}</div>}\n    </>\n}\n/**\n * @example\n * **Quick Start:**\n *\n * First create an options object that implements an {@link  IAuthorizationOptions} type.\n * Check the {@link  IAuthorizationOptions} and {@link  IAuthorizationBase} types for\n * all required properties. Then, pass the options to the {@link GoogleButton} component.\n *\n * ```IAuthorizationOptions\n *  const options:  = {\n *      clientId: (process.env.CLIENT_ID as string),\n *       redirectUri: \"http://localhost:3000\",\n *       scopes: [\"openid\", \"profile\", \"email\"],\n *       includeGrantedScopes: true,\n *       accessType: \"offline\",\n *   };\n *\n *   <GoogleButton\n *         placeholder=\"demo/search.png\"\n *         options={options}\n *         apiUrl=\"http://localhost:5000/google_login\"\n *   />\n * ```\n * @param props see IGoogleButton\n * @constructor\n */\nexport function GoogleButton(props: TypeGoogleButton) {\n    const {callback} = props;\n    const { options, setOptions, responseState, setOAuthState, setResponseState, isAuthenticated } = useContext<IOAuthState>(GoogleAuthContext);\n    const [serverResponseState, setServerResponseState] = useState<IServerResponse>();\n    const currentUrl = new URLSearchParams(window.location.search);\n    const queryParamsCode = currentUrl.get(\"code\");\n    const queryParamsError = currentUrl.get(\"error\");\n    useEffect(() => {\n        if (!options && setOptions) {\n            setOptions(props.options);\n        }\n    }, [props.options]);\n    useEffect(() => {\n        if(responseState && !Object.keys(responseState).length && serverResponseState) {\n            serverResponse(serverResponseState);\n        }\n    }, [serverResponseState, responseState]);\n    useEffect(() => {\n        if(responseState?.accessToken && !isLoggedIn()) {\n            storeAccessToken(responseState.accessToken as string);\n            console.debug(\"`accessToken` set in local storage.\");\n            if (typeof setOAuthState === \"function\" && !isAuthenticated) {\n                setOAuthState(true);\n            }\n        }\n    }, [responseState?.accessToken]);\n    // Add any updates to the options state\n    let mergedPropsAndStateOptions = {\n        ...props.options,\n        ...options,\n    }\n    let _inner =\n        <InnerButton\n            {...props}\n            placeholder={props.placeholder}\n            error={responseState?.error}\n            options={mergedPropsAndStateOptions}\n        />;\n    if (responseState?.error) {\n        console.error(`[React-Google-OAuth2] Error: Api call failed with ${responseState?.error} error.`);\n        return _inner;\n    } else if (queryParamsCode && !isLoggedIn()) {\n        // Get rest of params\n        const queryParamsEmail = currentUrl.get(\"email\") || \"\";\n        const queryParamsScope = currentUrl.get(\"scope\") || \"\";\n        const serverResponseProps: IServerResponse = {\n            email: queryParamsEmail,\n            scope: queryParamsScope,\n            code: queryParamsCode,\n            client_id: props.options.clientId,\n            apiUrl: props.apiUrl,\n            responseState: responseState as IServerResponseState,\n            setResponseState: setResponseState as Dispatch<SetStateAction<IServerResponseState>>,\n        };\n        removeOAuthQueryParams();\n        if (responseState && !Object.keys(responseState).length) {\n            setServerResponseState(serverResponseProps);\n        }\n        console.debug(\"Waiting for remote api response\");\n        return callback ? callback() : <>Loading...</>;\n    } else if (queryParamsError) {\n        console.error(`Error: Google login attempt failed with ${queryParamsError} error.`)\n        return _inner;\n    }\n    // Display button with no errors\n    return _inner;\n}\n\n/**\n *\n * @param setOptions\n * @param options\n * @internal TODO make public when bugs are fixed\n */\nexport function setPrompt(setOptions: Function, options?: IAuthorizationOptions) {\n    return (promptType: TypePrompt) => {\n        if (options && !options.prompt) {\n            setOptions({\n                ...options,\n                prompt: promptType,\n            } as IAuthorizationOptions);\n        }\n    };\n}\n\n/**\n *\n * @param props\n * @constructor\n */\nexport const GoogleAuth = (props: any) => {\n    const [responseState, setResponseState] = useState<IServerResponseState>(SERVER_RESPONSE_STATE);\n    const [isAuthenticated, setOAuthState] = useState<boolean>(isLoggedIn());\n    const [options, setOptions] = useState<IAuthorizationOptions>();\n\n    const _providerProps: IOAuthState = {\n        isAuthenticated,\n        setOAuthState,\n        responseState,\n        setResponseState,\n        options,\n        setOptions,\n        setPrompt: setPrompt(setOptions, options),\n    };\n    return  (\n        <GoogleAuthProvider value={_providerProps}>\n            {props.children}\n        </GoogleAuthProvider>\n    );\n}"],"sourceRoot":""}
{
"name": "react-google-oauth2",
"version": "0.0.27",
"version": "0.0.28-rc.0",
"main": "lib/index.js",

@@ -13,2 +13,3 @@ "types": "lib/index.d.ts",

"start": "webpack-dev-server --open \"Brave Browser\" --watch --config webpack.config.dev.js --output-path=dist --output-filename=bundle.js",
"start:google": "webpack-dev-server --watch --config webpack.config.dev.js --output-path=dist --output-filename=bundle.js",
"test": "jest",

@@ -15,0 +16,0 @@ "test:update": "jest --updateSnapshot",

@@ -123,2 +123,11 @@ [![GitHub license](https://img.shields.io/github/license/joegasewicz/react-google-oauth2.0)](https://github.com/joegasewicz/react-google-oauth2.0/blob/main/LICENSE)

### Update prompts
If for example your user updates their email in your app & you redirect them
to the login again, Google will by default skip the Google email select screen
& log you in with your existing credentials. To stop this happening you can use the following function:
```typescript
```
### Flask-JWT-Router

@@ -125,0 +134,0 @@ If you are using Flask as your REST api framework then this library is designed to work

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc