parse-server 8.0.1 → 8.0.2-alpha.1
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/Adapters/Auth/AuthAdapter.js +16 -9
- package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
- package/lib/Adapters/Auth/apple.js +45 -1
- package/lib/Adapters/Auth/facebook.js +61 -1
- package/lib/Adapters/Auth/gcenter.js +201 -157
- package/lib/Adapters/Auth/github.js +119 -31
- package/lib/Adapters/Auth/google.js +45 -1
- package/lib/Adapters/Auth/gpgames.js +120 -27
- package/lib/Adapters/Auth/index.js +33 -33
- package/lib/Adapters/Auth/instagram.js +114 -24
- package/lib/Adapters/Auth/janraincapture.js +45 -1
- package/lib/Adapters/Auth/janrainengage.js +11 -2
- package/lib/Adapters/Auth/keycloak.js +68 -35
- package/lib/Adapters/Auth/ldap.js +75 -1
- package/lib/Adapters/Auth/line.js +119 -32
- package/lib/Adapters/Auth/linkedin.js +111 -35
- package/lib/Adapters/Auth/meetup.js +16 -8
- package/lib/Adapters/Auth/mfa.js +80 -2
- package/lib/Adapters/Auth/microsoft.js +105 -30
- package/lib/Adapters/Auth/oauth2.js +96 -109
- package/lib/Adapters/Auth/phantauth.js +16 -8
- package/lib/Adapters/Auth/qq.js +107 -36
- package/lib/Adapters/Auth/spotify.js +108 -39
- package/lib/Adapters/Auth/twitter.js +187 -40
- package/lib/Adapters/Auth/vkontakte.js +20 -13
- package/lib/Adapters/Auth/wechat.js +105 -25
- package/lib/Adapters/Auth/weibo.js +135 -37
- package/lib/Auth.js +26 -17
- package/lib/Config.js +14 -1
- package/lib/Deprecator/Deprecations.js +5 -2
- package/lib/Options/Definitions.js +7 -1
- package/lib/Options/docs.js +2 -1
- package/lib/Options/index.js +1 -1
- package/lib/RestWrite.js +4 -5
- package/lib/Security/CheckGroups/CheckGroupServerConfig.js +10 -1
- package/lib/cli/parse-server.js +1 -1
- package/package.json +6 -6
|
@@ -1,3 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parse Server authentication adapter for Google.
|
|
3
|
+
*
|
|
4
|
+
* @class GoogleAdapter
|
|
5
|
+
* @param {Object} options - The adapter configuration options.
|
|
6
|
+
* @param {string} options.clientId - Your Google application Client ID. Required for authentication.
|
|
7
|
+
*
|
|
8
|
+
* @description
|
|
9
|
+
* ## Parse Server Configuration
|
|
10
|
+
* To configure Parse Server for Google authentication, use the following structure:
|
|
11
|
+
* ```json
|
|
12
|
+
* {
|
|
13
|
+
* "auth": {
|
|
14
|
+
* "google": {
|
|
15
|
+
* "clientId": "your-client-id"
|
|
16
|
+
* }
|
|
17
|
+
* }
|
|
18
|
+
* }
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
* The adapter requires the following `authData` fields:
|
|
22
|
+
* - **id**: The Google user ID.
|
|
23
|
+
* - **id_token**: The Google ID token.
|
|
24
|
+
* - **access_token**: The Google access token.
|
|
25
|
+
*
|
|
26
|
+
* ## Auth Payload
|
|
27
|
+
* ### Example Auth Data Payload
|
|
28
|
+
* ```json
|
|
29
|
+
* {
|
|
30
|
+
* "google": {
|
|
31
|
+
* "id": "1234567",
|
|
32
|
+
* "id_token": "xxxxx.yyyyy.zzzzz",
|
|
33
|
+
* "access_token": "abc123def456ghi789"
|
|
34
|
+
* }
|
|
35
|
+
* }
|
|
36
|
+
* ```
|
|
37
|
+
*
|
|
38
|
+
* ## Notes
|
|
39
|
+
* - Ensure your Google Client ID is configured properly in the Parse Server configuration.
|
|
40
|
+
* - The `id_token` and `access_token` are validated against Google's authentication services.
|
|
41
|
+
*
|
|
42
|
+
* @see {@link https://developers.google.com/identity/sign-in/web/backend-auth Google Authentication Documentation}
|
|
43
|
+
*/
|
|
44
|
+
|
|
1
45
|
'use strict';
|
|
2
46
|
|
|
3
47
|
// Helper functions for accessing the google API.
|
|
@@ -133,4 +177,4 @@ function encodeLengthHex(n) {
|
|
|
133
177
|
const lengthOfLengthByte = 128 + nHex.length / 2;
|
|
134
178
|
return toHex(lengthOfLengthByte) + nHex;
|
|
135
179
|
}
|
|
136
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","https","jwt","authUtils","TOKEN_ISSUER","HTTPS_TOKEN_ISSUER","cache","getGoogleKeyByKeyId","keyId","expiresAt","Date","Promise","resolve","reject","get","res","data","on","chunk","toString","keys","JSON","parse","pems","reduce","n","modulus","e","exposant","kid","Object","assign","rsaPublicKeyToPEM","headers","expire","match","getTime","Number","verifyIdToken","id_token","token","id","clientId","Error","OBJECT_NOT_FOUND","alg","algorithm","getHeaderFromToken","jwtClaims","googleKey","verify","algorithms","audience","exception","message","iss","sub","aud","validateAuthData","authData","options","validateAppId","module","exports","modulusB64","exponentB64","Buffer","exponent","modulusHex","prepadSigned","exponentHex","modlen","length","explen","encodedModlen","encodeLengthHex","encodedExplen","encodedPubkey","der","pem","join","hexStr","msb","toHex","number","nstr","nHex","lengthOfLengthByte"],"sources":["../../../src/Adapters/Auth/google.js"],"sourcesContent":["'use strict';\n\n// Helper functions for accessing the google API.\nvar Parse = require('parse/node').Parse;\n\nconst https = require('https');\nconst jwt = require('jsonwebtoken');\nconst authUtils = require('./utils');\n\nconst TOKEN_ISSUER = 'accounts.google.com';\nconst HTTPS_TOKEN_ISSUER = 'https://accounts.google.com';\n\nlet cache = {};\n\n// Retrieve Google Signin Keys (with cache control)\nfunction getGoogleKeyByKeyId(keyId) {\n  if (cache[keyId] && cache.expiresAt > new Date()) {\n    return cache[keyId];\n  }\n\n  return new Promise((resolve, reject) => {\n    https\n      .get(`https://www.googleapis.com/oauth2/v3/certs`, res => {\n        let data = '';\n        res.on('data', chunk => {\n          data += chunk.toString('utf8');\n        });\n        res.on('end', () => {\n          const { keys } = JSON.parse(data);\n          const pems = keys.reduce(\n            (pems, { n: modulus, e: exposant, kid }) =>\n              Object.assign(pems, {\n                [kid]: rsaPublicKeyToPEM(modulus, exposant),\n              }),\n            {}\n          );\n\n          if (res.headers['cache-control']) {\n            var expire = res.headers['cache-control'].match(/max-age=([0-9]+)/);\n\n            if (expire) {\n              cache = Object.assign({}, pems, {\n                expiresAt: new Date(new Date().getTime() + Number(expire[1]) * 1000),\n              });\n            }\n          }\n\n          resolve(pems[keyId]);\n        });\n      })\n      .on('error', reject);\n  });\n}\n\nasync function verifyIdToken({ id_token: token, id }, { clientId }) {\n  if (!token) {\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `id token is invalid for this user.`);\n  }\n\n  const { kid: keyId, alg: algorithm } = authUtils.getHeaderFromToken(token);\n  let jwtClaims;\n  const googleKey = await getGoogleKeyByKeyId(keyId);\n\n  try {\n    jwtClaims = jwt.verify(token, googleKey, {\n      algorithms: algorithm,\n      audience: clientId,\n    });\n  } catch (exception) {\n    const message = exception.message;\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `${message}`);\n  }\n\n  if (jwtClaims.iss !== TOKEN_ISSUER && jwtClaims.iss !== HTTPS_TOKEN_ISSUER) {\n    throw new Parse.Error(\n      Parse.Error.OBJECT_NOT_FOUND,\n      `id token not issued by correct provider - expected: ${TOKEN_ISSUER} or ${HTTPS_TOKEN_ISSUER} | from: ${jwtClaims.iss}`\n    );\n  }\n\n  if (jwtClaims.sub !== id) {\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `auth data is invalid for this user.`);\n  }\n\n  if (clientId && jwtClaims.aud !== clientId) {\n    throw new Parse.Error(\n      Parse.Error.OBJECT_NOT_FOUND,\n      `id token not authorized for this clientId.`\n    );\n  }\n\n  return jwtClaims;\n}\n\n// Returns a promise that fulfills if this user id is valid.\nfunction validateAuthData(authData, options = {}) {\n  return verifyIdToken(authData, options);\n}\n\n// Returns a promise that fulfills if this app id is valid.\nfunction validateAppId() {\n  return Promise.resolve();\n}\n\nmodule.exports = {\n  validateAppId: validateAppId,\n  validateAuthData: validateAuthData,\n};\n\n// Helpers functions to convert the RSA certs to PEM (from jwks-rsa)\nfunction rsaPublicKeyToPEM(modulusB64, exponentB64) {\n  const modulus = new Buffer(modulusB64, 'base64');\n  const exponent = new Buffer(exponentB64, 'base64');\n  const modulusHex = prepadSigned(modulus.toString('hex'));\n  const exponentHex = prepadSigned(exponent.toString('hex'));\n  const modlen = modulusHex.length / 2;\n  const explen = exponentHex.length / 2;\n\n  const encodedModlen = encodeLengthHex(modlen);\n  const encodedExplen = encodeLengthHex(explen);\n  const encodedPubkey =\n    '30' +\n    encodeLengthHex(modlen + explen + encodedModlen.length / 2 + encodedExplen.length / 2 + 2) +\n    '02' +\n    encodedModlen +\n    modulusHex +\n    '02' +\n    encodedExplen +\n    exponentHex;\n\n  const der = new Buffer(encodedPubkey, 'hex').toString('base64');\n\n  let pem = '-----BEGIN RSA PUBLIC KEY-----\\n';\n  pem += `${der.match(/.{1,64}/g).join('\\n')}`;\n  pem += '\\n-----END RSA PUBLIC KEY-----\\n';\n  return pem;\n}\n\nfunction prepadSigned(hexStr) {\n  const msb = hexStr[0];\n  if (msb < '0' || msb > '7') {\n    return `00${hexStr}`;\n  }\n  return hexStr;\n}\n\nfunction toHex(number) {\n  const nstr = number.toString(16);\n  if (nstr.length % 2) {\n    return `0${nstr}`;\n  }\n  return nstr;\n}\n\nfunction encodeLengthHex(n) {\n  if (n <= 127) {\n    return toHex(n);\n  }\n  const nHex = toHex(n);\n  const lengthOfLengthByte = 128 + nHex.length / 2;\n  return toHex(lengthOfLengthByte) + nHex;\n}\n"],"mappings":"AAAA,YAAY;;AAEZ;AACA,IAAIA,KAAK,GAAGC,OAAO,CAAC,YAAY,CAAC,CAACD,KAAK;AAEvC,MAAME,KAAK,GAAGD,OAAO,CAAC,OAAO,CAAC;AAC9B,MAAME,GAAG,GAAGF,OAAO,CAAC,cAAc,CAAC;AACnC,MAAMG,SAAS,GAAGH,OAAO,CAAC,SAAS,CAAC;AAEpC,MAAMI,YAAY,GAAG,qBAAqB;AAC1C,MAAMC,kBAAkB,GAAG,6BAA6B;AAExD,IAAIC,KAAK,GAAG,CAAC,CAAC;;AAEd;AACA,SAASC,mBAAmBA,CAACC,KAAK,EAAE;EAClC,IAAIF,KAAK,CAACE,KAAK,CAAC,IAAIF,KAAK,CAACG,SAAS,GAAG,IAAIC,IAAI,CAAC,CAAC,EAAE;IAChD,OAAOJ,KAAK,CAACE,KAAK,CAAC;EACrB;EAEA,OAAO,IAAIG,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;IACtCZ,KAAK,CACFa,GAAG,CAAC,4CAA4C,EAAEC,GAAG,IAAI;MACxD,IAAIC,IAAI,GAAG,EAAE;MACbD,GAAG,CAACE,EAAE,CAAC,MAAM,EAAEC,KAAK,IAAI;QACtBF,IAAI,IAAIE,KAAK,CAACC,QAAQ,CAAC,MAAM,CAAC;MAChC,CAAC,CAAC;MACFJ,GAAG,CAACE,EAAE,CAAC,KAAK,EAAE,MAAM;QAClB,MAAM;UAAEG;QAAK,CAAC,GAAGC,IAAI,CAACC,KAAK,CAACN,IAAI,CAAC;QACjC,MAAMO,IAAI,GAAGH,IAAI,CAACI,MAAM,CACtB,CAACD,IAAI,EAAE;UAAEE,CAAC,EAAEC,OAAO;UAAEC,CAAC,EAAEC,QAAQ;UAAEC;QAAI,CAAC,KACrCC,MAAM,CAACC,MAAM,CAACR,IAAI,EAAE;UAClB,CAACM,GAAG,GAAGG,iBAAiB,CAACN,OAAO,EAAEE,QAAQ;QAC5C,CAAC,CAAC,EACJ,CAAC,CACH,CAAC;QAED,IAAIb,GAAG,CAACkB,OAAO,CAAC,eAAe,CAAC,EAAE;UAChC,IAAIC,MAAM,GAAGnB,GAAG,CAACkB,OAAO,CAAC,eAAe,CAAC,CAACE,KAAK,CAAC,kBAAkB,CAAC;UAEnE,IAAID,MAAM,EAAE;YACV5B,KAAK,GAAGwB,MAAM,CAACC,MAAM,CAAC,CAAC,CAAC,EAAER,IAAI,EAAE;cAC9Bd,SAAS,EAAE,IAAIC,IAAI,CAAC,IAAIA,IAAI,CAAC,CAAC,CAAC0B,OAAO,CAAC,CAAC,GAAGC,MAAM,CAACH,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI;YACrE,CAAC,CAAC;UACJ;QACF;QAEAtB,OAAO,CAACW,IAAI,CAACf,KAAK,CAAC,CAAC;MACtB,CAAC,CAAC;IACJ,CAAC,CAAC,CACDS,EAAE,CAAC,OAAO,EAAEJ,MAAM,CAAC;EACxB,CAAC,CAAC;AACJ;AAEA,eAAeyB,aAAaA,CAAC;EAAEC,QAAQ,EAAEC,KAAK;EAAEC;AAAG,CAAC,EAAE;EAAEC;AAAS,CAAC,EAAE;EAClE,IAAI,CAACF,KAAK,EAAE;IACV,MAAM,IAAIzC,KAAK,CAAC4C,KAAK,CAAC5C,KAAK,CAAC4C,KAAK,CAACC,gBAAgB,EAAE,oCAAoC,CAAC;EAC3F;EAEA,MAAM;IAAEf,GAAG,EAAErB,KAAK;IAAEqC,GAAG,EAAEC;EAAU,CAAC,GAAG3C,SAAS,CAAC4C,kBAAkB,CAACP,KAAK,CAAC;EAC1E,IAAIQ,SAAS;EACb,MAAMC,SAAS,GAAG,MAAM1C,mBAAmB,CAACC,KAAK,CAAC;EAElD,IAAI;IACFwC,SAAS,GAAG9C,GAAG,CAACgD,MAAM,CAACV,KAAK,EAAES,SAAS,EAAE;MACvCE,UAAU,EAAEL,SAAS;MACrBM,QAAQ,EAAEV;IACZ,CAAC,CAAC;EACJ,CAAC,CAAC,OAAOW,SAAS,EAAE;IAClB,MAAMC,OAAO,GAAGD,SAAS,CAACC,OAAO;IACjC,MAAM,IAAIvD,KAAK,CAAC4C,KAAK,CAAC5C,KAAK,CAAC4C,KAAK,CAACC,gBAAgB,EAAE,GAAGU,OAAO,EAAE,CAAC;EACnE;EAEA,IAAIN,SAAS,CAACO,GAAG,KAAKnD,YAAY,IAAI4C,SAAS,CAACO,GAAG,KAAKlD,kBAAkB,EAAE;IAC1E,MAAM,IAAIN,KAAK,CAAC4C,KAAK,CACnB5C,KAAK,CAAC4C,KAAK,CAACC,gBAAgB,EAC5B,uDAAuDxC,YAAY,OAAOC,kBAAkB,YAAY2C,SAAS,CAACO,GAAG,EACvH,CAAC;EACH;EAEA,IAAIP,SAAS,CAACQ,GAAG,KAAKf,EAAE,EAAE;IACxB,MAAM,IAAI1C,KAAK,CAAC4C,KAAK,CAAC5C,KAAK,CAAC4C,KAAK,CAACC,gBAAgB,EAAE,qCAAqC,CAAC;EAC5F;EAEA,IAAIF,QAAQ,IAAIM,SAAS,CAACS,GAAG,KAAKf,QAAQ,EAAE;IAC1C,MAAM,IAAI3C,KAAK,CAAC4C,KAAK,CACnB5C,KAAK,CAAC4C,KAAK,CAACC,gBAAgB,EAC5B,4CACF,CAAC;EACH;EAEA,OAAOI,SAAS;AAClB;;AAEA;AACA,SAASU,gBAAgBA,CAACC,QAAQ,EAAEC,OAAO,GAAG,CAAC,CAAC,EAAE;EAChD,OAAOtB,aAAa,CAACqB,QAAQ,EAAEC,OAAO,CAAC;AACzC;;AAEA;AACA,SAASC,aAAaA,CAAA,EAAG;EACvB,OAAOlD,OAAO,CAACC,OAAO,CAAC,CAAC;AAC1B;AAEAkD,MAAM,CAACC,OAAO,GAAG;EACfF,aAAa,EAAEA,aAAa;EAC5BH,gBAAgB,EAAEA;AACpB,CAAC;;AAED;AACA,SAAS1B,iBAAiBA,CAACgC,UAAU,EAAEC,WAAW,EAAE;EAClD,MAAMvC,OAAO,GAAG,IAAIwC,MAAM,CAACF,UAAU,EAAE,QAAQ,CAAC;EAChD,MAAMG,QAAQ,GAAG,IAAID,MAAM,CAACD,WAAW,EAAE,QAAQ,CAAC;EAClD,MAAMG,UAAU,GAAGC,YAAY,CAAC3C,OAAO,CAACP,QAAQ,CAAC,KAAK,CAAC,CAAC;EACxD,MAAMmD,WAAW,GAAGD,YAAY,CAACF,QAAQ,CAAChD,QAAQ,CAAC,KAAK,CAAC,CAAC;EAC1D,MAAMoD,MAAM,GAAGH,UAAU,CAACI,MAAM,GAAG,CAAC;EACpC,MAAMC,MAAM,GAAGH,WAAW,CAACE,MAAM,GAAG,CAAC;EAErC,MAAME,aAAa,GAAGC,eAAe,CAACJ,MAAM,CAAC;EAC7C,MAAMK,aAAa,GAAGD,eAAe,CAACF,MAAM,CAAC;EAC7C,MAAMI,aAAa,GACjB,IAAI,GACJF,eAAe,CAACJ,MAAM,GAAGE,MAAM,GAAGC,aAAa,CAACF,MAAM,GAAG,CAAC,GAAGI,aAAa,CAACJ,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC,GAC1F,IAAI,GACJE,aAAa,GACbN,UAAU,GACV,IAAI,GACJQ,aAAa,GACbN,WAAW;EAEb,MAAMQ,GAAG,GAAG,IAAIZ,MAAM,CAACW,aAAa,EAAE,KAAK,CAAC,CAAC1D,QAAQ,CAAC,QAAQ,CAAC;EAE/D,IAAI4D,GAAG,GAAG,kCAAkC;EAC5CA,GAAG,IAAI,GAAGD,GAAG,CAAC3C,KAAK,CAAC,UAAU,CAAC,CAAC6C,IAAI,CAAC,IAAI,CAAC,EAAE;EAC5CD,GAAG,IAAI,kCAAkC;EACzC,OAAOA,GAAG;AACZ;AAEA,SAASV,YAAYA,CAACY,MAAM,EAAE;EAC5B,MAAMC,GAAG,GAAGD,MAAM,CAAC,CAAC,CAAC;EACrB,IAAIC,GAAG,GAAG,GAAG,IAAIA,GAAG,GAAG,GAAG,EAAE;IAC1B,OAAO,KAAKD,MAAM,EAAE;EACtB;EACA,OAAOA,MAAM;AACf;AAEA,SAASE,KAAKA,CAACC,MAAM,EAAE;EACrB,MAAMC,IAAI,GAAGD,MAAM,CAACjE,QAAQ,CAAC,EAAE,CAAC;EAChC,IAAIkE,IAAI,CAACb,MAAM,GAAG,CAAC,EAAE;IACnB,OAAO,IAAIa,IAAI,EAAE;EACnB;EACA,OAAOA,IAAI;AACb;AAEA,SAASV,eAAeA,CAAClD,CAAC,EAAE;EAC1B,IAAIA,CAAC,IAAI,GAAG,EAAE;IACZ,OAAO0D,KAAK,CAAC1D,CAAC,CAAC;EACjB;EACA,MAAM6D,IAAI,GAAGH,KAAK,CAAC1D,CAAC,CAAC;EACrB,MAAM8D,kBAAkB,GAAG,GAAG,GAAGD,IAAI,CAACd,MAAM,GAAG,CAAC;EAChD,OAAOW,KAAK,CAACI,kBAAkB,CAAC,GAAGD,IAAI;AACzC","ignoreList":[]}
|
|
180
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","https","jwt","authUtils","TOKEN_ISSUER","HTTPS_TOKEN_ISSUER","cache","getGoogleKeyByKeyId","keyId","expiresAt","Date","Promise","resolve","reject","get","res","data","on","chunk","toString","keys","JSON","parse","pems","reduce","n","modulus","e","exposant","kid","Object","assign","rsaPublicKeyToPEM","headers","expire","match","getTime","Number","verifyIdToken","id_token","token","id","clientId","Error","OBJECT_NOT_FOUND","alg","algorithm","getHeaderFromToken","jwtClaims","googleKey","verify","algorithms","audience","exception","message","iss","sub","aud","validateAuthData","authData","options","validateAppId","module","exports","modulusB64","exponentB64","Buffer","exponent","modulusHex","prepadSigned","exponentHex","modlen","length","explen","encodedModlen","encodeLengthHex","encodedExplen","encodedPubkey","der","pem","join","hexStr","msb","toHex","number","nstr","nHex","lengthOfLengthByte"],"sources":["../../../src/Adapters/Auth/google.js"],"sourcesContent":["/**\n * Parse Server authentication adapter for Google.\n *\n * @class GoogleAdapter\n * @param {Object} options - The adapter configuration options.\n * @param {string} options.clientId - Your Google application Client ID. Required for authentication.\n *\n * @description\n * ## Parse Server Configuration\n * To configure Parse Server for Google authentication, use the following structure:\n * ```json\n * {\n *   \"auth\": {\n *     \"google\": {\n *       \"clientId\": \"your-client-id\"\n *     }\n *   }\n * }\n * ```\n *\n * The adapter requires the following `authData` fields:\n * - **id**: The Google user ID.\n * - **id_token**: The Google ID token.\n * - **access_token**: The Google access token.\n *\n * ## Auth Payload\n * ### Example Auth Data Payload\n * ```json\n * {\n *   \"google\": {\n *     \"id\": \"1234567\",\n *     \"id_token\": \"xxxxx.yyyyy.zzzzz\",\n *     \"access_token\": \"abc123def456ghi789\"\n *   }\n * }\n * ```\n *\n * ## Notes\n * - Ensure your Google Client ID is configured properly in the Parse Server configuration.\n * - The `id_token` and `access_token` are validated against Google's authentication services.\n *\n * @see {@link https://developers.google.com/identity/sign-in/web/backend-auth Google Authentication Documentation}\n */\n\n'use strict';\n\n// Helper functions for accessing the google API.\nvar Parse = require('parse/node').Parse;\n\nconst https = require('https');\nconst jwt = require('jsonwebtoken');\nconst authUtils = require('./utils');\n\nconst TOKEN_ISSUER = 'accounts.google.com';\nconst HTTPS_TOKEN_ISSUER = 'https://accounts.google.com';\n\nlet cache = {};\n\n// Retrieve Google Signin Keys (with cache control)\nfunction getGoogleKeyByKeyId(keyId) {\n  if (cache[keyId] && cache.expiresAt > new Date()) {\n    return cache[keyId];\n  }\n\n  return new Promise((resolve, reject) => {\n    https\n      .get(`https://www.googleapis.com/oauth2/v3/certs`, res => {\n        let data = '';\n        res.on('data', chunk => {\n          data += chunk.toString('utf8');\n        });\n        res.on('end', () => {\n          const { keys } = JSON.parse(data);\n          const pems = keys.reduce(\n            (pems, { n: modulus, e: exposant, kid }) =>\n              Object.assign(pems, {\n                [kid]: rsaPublicKeyToPEM(modulus, exposant),\n              }),\n            {}\n          );\n\n          if (res.headers['cache-control']) {\n            var expire = res.headers['cache-control'].match(/max-age=([0-9]+)/);\n\n            if (expire) {\n              cache = Object.assign({}, pems, {\n                expiresAt: new Date(new Date().getTime() + Number(expire[1]) * 1000),\n              });\n            }\n          }\n\n          resolve(pems[keyId]);\n        });\n      })\n      .on('error', reject);\n  });\n}\n\nasync function verifyIdToken({ id_token: token, id }, { clientId }) {\n  if (!token) {\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `id token is invalid for this user.`);\n  }\n\n  const { kid: keyId, alg: algorithm } = authUtils.getHeaderFromToken(token);\n  let jwtClaims;\n  const googleKey = await getGoogleKeyByKeyId(keyId);\n\n  try {\n    jwtClaims = jwt.verify(token, googleKey, {\n      algorithms: algorithm,\n      audience: clientId,\n    });\n  } catch (exception) {\n    const message = exception.message;\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `${message}`);\n  }\n\n  if (jwtClaims.iss !== TOKEN_ISSUER && jwtClaims.iss !== HTTPS_TOKEN_ISSUER) {\n    throw new Parse.Error(\n      Parse.Error.OBJECT_NOT_FOUND,\n      `id token not issued by correct provider - expected: ${TOKEN_ISSUER} or ${HTTPS_TOKEN_ISSUER} | from: ${jwtClaims.iss}`\n    );\n  }\n\n  if (jwtClaims.sub !== id) {\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `auth data is invalid for this user.`);\n  }\n\n  if (clientId && jwtClaims.aud !== clientId) {\n    throw new Parse.Error(\n      Parse.Error.OBJECT_NOT_FOUND,\n      `id token not authorized for this clientId.`\n    );\n  }\n\n  return jwtClaims;\n}\n\n// Returns a promise that fulfills if this user id is valid.\nfunction validateAuthData(authData, options = {}) {\n  return verifyIdToken(authData, options);\n}\n\n// Returns a promise that fulfills if this app id is valid.\nfunction validateAppId() {\n  return Promise.resolve();\n}\n\nmodule.exports = {\n  validateAppId: validateAppId,\n  validateAuthData: validateAuthData,\n};\n\n// Helpers functions to convert the RSA certs to PEM (from jwks-rsa)\nfunction rsaPublicKeyToPEM(modulusB64, exponentB64) {\n  const modulus = new Buffer(modulusB64, 'base64');\n  const exponent = new Buffer(exponentB64, 'base64');\n  const modulusHex = prepadSigned(modulus.toString('hex'));\n  const exponentHex = prepadSigned(exponent.toString('hex'));\n  const modlen = modulusHex.length / 2;\n  const explen = exponentHex.length / 2;\n\n  const encodedModlen = encodeLengthHex(modlen);\n  const encodedExplen = encodeLengthHex(explen);\n  const encodedPubkey =\n    '30' +\n    encodeLengthHex(modlen + explen + encodedModlen.length / 2 + encodedExplen.length / 2 + 2) +\n    '02' +\n    encodedModlen +\n    modulusHex +\n    '02' +\n    encodedExplen +\n    exponentHex;\n\n  const der = new Buffer(encodedPubkey, 'hex').toString('base64');\n\n  let pem = '-----BEGIN RSA PUBLIC KEY-----\\n';\n  pem += `${der.match(/.{1,64}/g).join('\\n')}`;\n  pem += '\\n-----END RSA PUBLIC KEY-----\\n';\n  return pem;\n}\n\nfunction prepadSigned(hexStr) {\n  const msb = hexStr[0];\n  if (msb < '0' || msb > '7') {\n    return `00${hexStr}`;\n  }\n  return hexStr;\n}\n\nfunction toHex(number) {\n  const nstr = number.toString(16);\n  if (nstr.length % 2) {\n    return `0${nstr}`;\n  }\n  return nstr;\n}\n\nfunction encodeLengthHex(n) {\n  if (n <= 127) {\n    return toHex(n);\n  }\n  const nHex = toHex(n);\n  const lengthOfLengthByte = 128 + nHex.length / 2;\n  return toHex(lengthOfLengthByte) + nHex;\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,32 +1,125 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _BaseCodeAuthAdapter = _interopRequireDefault(require("./BaseCodeAuthAdapter"));
|
|
8
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
9
|
+
/**
|
|
10
|
+
* Parse Server authentication adapter for Google Play Games Services.
|
|
11
|
+
*
|
|
12
|
+
* @class GooglePlayGamesServicesAdapter
|
|
13
|
+
* @param {Object} options - The adapter configuration options.
|
|
14
|
+
* @param {string} options.clientId - Your Google Play Games Services App Client ID. Required for secure authentication.
|
|
15
|
+
* @param {string} options.clientSecret - Your Google Play Games Services App Client Secret. Required for secure authentication.
|
|
16
|
+
* @param {boolean} [options.enableInsecureAuth=false] - **[DEPRECATED]** Enable insecure authentication (not recommended).
|
|
17
|
+
*
|
|
18
|
+
* @description
|
|
19
|
+
* ## Parse Server Configuration
|
|
20
|
+
* To configure Parse Server for Google Play Games Services authentication, use the following structure:
|
|
21
|
+
* ```json
|
|
22
|
+
* {
|
|
23
|
+
* "auth": {
|
|
24
|
+
* "gpgames": {
|
|
25
|
+
* "clientId": "your-client-id",
|
|
26
|
+
* "clientSecret": "your-client-secret"
|
|
27
|
+
* }
|
|
28
|
+
* }
|
|
29
|
+
* }
|
|
30
|
+
* ```
|
|
31
|
+
* ### Insecure Configuration (Not Recommended)
|
|
32
|
+
* ```json
|
|
33
|
+
* {
|
|
34
|
+
* "auth": {
|
|
35
|
+
* "gpgames": {
|
|
36
|
+
* "enableInsecureAuth": true
|
|
37
|
+
* }
|
|
38
|
+
* }
|
|
39
|
+
* }
|
|
40
|
+
* ```
|
|
41
|
+
*
|
|
42
|
+
* The adapter requires the following `authData` fields:
|
|
43
|
+
* - **Secure Authentication**: `code`, `redirect_uri`.
|
|
44
|
+
* - **Insecure Authentication (Not Recommended)**: `id`, `access_token`.
|
|
45
|
+
*
|
|
46
|
+
* ## Auth Payloads
|
|
47
|
+
* ### Secure Authentication Payload
|
|
48
|
+
* ```json
|
|
49
|
+
* {
|
|
50
|
+
* "gpgames": {
|
|
51
|
+
* "code": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
|
|
52
|
+
* "redirect_uri": "https://example.com/callback"
|
|
53
|
+
* }
|
|
54
|
+
* }
|
|
55
|
+
* ```
|
|
56
|
+
*
|
|
57
|
+
* ### Insecure Authentication Payload (Not Recommended)
|
|
58
|
+
* ```json
|
|
59
|
+
* {
|
|
60
|
+
* "gpgames": {
|
|
61
|
+
* "id": "123456789",
|
|
62
|
+
* "access_token": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
|
|
63
|
+
* }
|
|
64
|
+
* }
|
|
65
|
+
* ```
|
|
66
|
+
*
|
|
67
|
+
* ## Notes
|
|
68
|
+
* - `enableInsecureAuth` is **not recommended** and may be removed in future versions. Use secure authentication with `code` and `redirect_uri`.
|
|
69
|
+
* - Secure authentication exchanges the `code` provided by the client for an access token using Google Play Games Services' OAuth API.
|
|
70
|
+
*
|
|
71
|
+
* @see {@link https://developers.google.com/games/services/console/enabling Google Play Games Services Authentication Documentation}
|
|
72
|
+
*/
|
|
5
73
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
74
|
+
class GooglePlayGamesServicesAdapter extends _BaseCodeAuthAdapter.default {
|
|
75
|
+
constructor() {
|
|
76
|
+
super("gpgames");
|
|
77
|
+
}
|
|
78
|
+
async getAccessTokenFromCode(authData) {
|
|
79
|
+
const tokenUrl = 'https://oauth2.googleapis.com/token';
|
|
80
|
+
const response = await fetch(tokenUrl, {
|
|
81
|
+
method: 'POST',
|
|
82
|
+
headers: {
|
|
83
|
+
'Content-Type': 'application/json',
|
|
84
|
+
Accept: 'application/json'
|
|
85
|
+
},
|
|
86
|
+
body: JSON.stringify({
|
|
87
|
+
client_id: this.clientId,
|
|
88
|
+
client_secret: this.clientSecret,
|
|
89
|
+
code: authData.code,
|
|
90
|
+
redirect_uri: authData.redirectUri,
|
|
91
|
+
grant_type: 'authorization_code'
|
|
92
|
+
})
|
|
93
|
+
});
|
|
94
|
+
if (!response.ok) {
|
|
95
|
+
throw new Parse.Error(Parse.Error.VALIDATION_ERROR, `Failed to exchange code for token: ${response.statusText}`);
|
|
96
|
+
}
|
|
97
|
+
const data = await response.json();
|
|
98
|
+
if (data.error) {
|
|
99
|
+
throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, data.error_description || data.error);
|
|
100
|
+
}
|
|
101
|
+
return data.access_token;
|
|
102
|
+
}
|
|
103
|
+
async getUserFromAccessToken(accessToken, authData) {
|
|
104
|
+
const userApiUrl = `https://www.googleapis.com/games/v1/players/${authData.id}`;
|
|
105
|
+
const response = await fetch(userApiUrl, {
|
|
106
|
+
method: 'GET',
|
|
107
|
+
headers: {
|
|
108
|
+
Authorization: `Bearer ${accessToken}`,
|
|
109
|
+
Accept: 'application/json'
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
if (!response.ok) {
|
|
113
|
+
throw new Parse.Error(Parse.Error.VALIDATION_ERROR, `Failed to fetch Google Play Games Services user: ${response.statusText}`);
|
|
114
|
+
}
|
|
115
|
+
const userData = await response.json();
|
|
116
|
+
if (!userData.playerId || userData.playerId !== authData.id) {
|
|
117
|
+
throw new Parse.Error(Parse.Error.VALIDATION_ERROR, 'Invalid Google Play Games Services user data received.');
|
|
118
|
+
}
|
|
119
|
+
return {
|
|
120
|
+
id: userData.playerId
|
|
121
|
+
};
|
|
21
122
|
}
|
|
22
123
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
function validateAppId() {
|
|
26
|
-
return Promise.resolve();
|
|
27
|
-
}
|
|
28
|
-
module.exports = {
|
|
29
|
-
validateAppId,
|
|
30
|
-
validateAuthData
|
|
31
|
-
};
|
|
32
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQYXJzZSIsInJlcXVpcmUiLCJodHRwc1JlcXVlc3QiLCJ2YWxpZGF0ZUF1dGhEYXRhIiwiYXV0aERhdGEiLCJyZXNwb25zZSIsImdldCIsImlkIiwiYWNjZXNzX3Rva2VuIiwicGxheWVySWQiLCJFcnJvciIsIk9CSkVDVF9OT1RfRk9VTkQiLCJ2YWxpZGF0ZUFwcElkIiwiUHJvbWlzZSIsInJlc29sdmUiLCJtb2R1bGUiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL0FkYXB0ZXJzL0F1dGgvZ3BnYW1lcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBHb29nbGUgUGxheSBHYW1lIFNlcnZpY2VzXG5odHRwczovL2RldmVsb3BlcnMuZ29vZ2xlLmNvbS9nYW1lcy9zZXJ2aWNlcy93ZWIvYXBpL3BsYXllcnMvZ2V0XG5cbmNvbnN0IGF1dGhEYXRhID0ge1xuICBpZDogJ3BsYXllcklkJyxcbiAgYWNjZXNzX3Rva2VuOiAndG9rZW4nLFxufTtcbiovXG5jb25zdCB7IFBhcnNlIH0gPSByZXF1aXJlKCdwYXJzZS9ub2RlJyk7XG5jb25zdCBodHRwc1JlcXVlc3QgPSByZXF1aXJlKCcuL2h0dHBzUmVxdWVzdCcpO1xuXG4vLyBSZXR1cm5zIGEgcHJvbWlzZSB0aGF0IGZ1bGZpbGxzIGlmIHRoaXMgdXNlciBpZCBpcyB2YWxpZC5cbmFzeW5jIGZ1bmN0aW9uIHZhbGlkYXRlQXV0aERhdGEoYXV0aERhdGEpIHtcbiAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBodHRwc1JlcXVlc3QuZ2V0KFxuICAgIGBodHRwczovL3d3dy5nb29nbGVhcGlzLmNvbS9nYW1lcy92MS9wbGF5ZXJzLyR7YXV0aERhdGEuaWR9P2FjY2Vzc190b2tlbj0ke2F1dGhEYXRhLmFjY2Vzc190b2tlbn1gXG4gICk7XG4gIGlmICghKHJlc3BvbnNlICYmIHJlc3BvbnNlLnBsYXllcklkID09PSBhdXRoRGF0YS5pZCkpIHtcbiAgICB0aHJvdyBuZXcgUGFyc2UuRXJyb3IoXG4gICAgICBQYXJzZS5FcnJvci5PQkpFQ1RfTk9UX0ZPVU5ELFxuICAgICAgJ0dvb2dsZSBQbGF5IEdhbWVzIFNlcnZpY2VzIC0gYXV0aERhdGEgaXMgaW52YWxpZCBmb3IgdGhpcyB1c2VyLidcbiAgICApO1xuICB9XG59XG5cbi8vIFJldHVybnMgYSBwcm9taXNlIHRoYXQgZnVsZmlsbHMgaWYgdGhpcyBhcHAgaWQgaXMgdmFsaWQuXG5mdW5jdGlvbiB2YWxpZGF0ZUFwcElkKCkge1xuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKCk7XG59XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICB2YWxpZGF0ZUFwcElkLFxuICB2YWxpZGF0ZUF1dGhEYXRhLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtFQUFFQTtBQUFNLENBQUMsR0FBR0MsT0FBTyxDQUFDLFlBQVksQ0FBQztBQUN2QyxNQUFNQyxZQUFZLEdBQUdELE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQzs7QUFFOUM7QUFDQSxlQUFlRSxnQkFBZ0JBLENBQUNDLFFBQVEsRUFBRTtFQUN4QyxNQUFNQyxRQUFRLEdBQUcsTUFBTUgsWUFBWSxDQUFDSSxHQUFHLENBQ3JDLCtDQUErQ0YsUUFBUSxDQUFDRyxFQUFFLGlCQUFpQkgsUUFBUSxDQUFDSSxZQUFZLEVBQ2xHLENBQUM7RUFDRCxJQUFJLEVBQUVILFFBQVEsSUFBSUEsUUFBUSxDQUFDSSxRQUFRLEtBQUtMLFFBQVEsQ0FBQ0csRUFBRSxDQUFDLEVBQUU7SUFDcEQsTUFBTSxJQUFJUCxLQUFLLENBQUNVLEtBQUssQ0FDbkJWLEtBQUssQ0FBQ1UsS0FBSyxDQUFDQyxnQkFBZ0IsRUFDNUIsaUVBQ0YsQ0FBQztFQUNIO0FBQ0Y7O0FBRUE7QUFDQSxTQUFTQyxhQUFhQSxDQUFBLEVBQUc7RUFDdkIsT0FBT0MsT0FBTyxDQUFDQyxPQUFPLENBQUMsQ0FBQztBQUMxQjtBQUVBQyxNQUFNLENBQUNDLE9BQU8sR0FBRztFQUNmSixhQUFhO0VBQ2JUO0FBQ0YsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
|
|
124
|
+
var _default = exports.default = new GooglePlayGamesServicesAdapter();
|
|
125
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_BaseCodeAuthAdapter","_interopRequireDefault","require","e","__esModule","default","GooglePlayGamesServicesAdapter","BaseCodeAuthAdapter","constructor","getAccessTokenFromCode","authData","tokenUrl","response","fetch","method","headers","Accept","body","JSON","stringify","client_id","clientId","client_secret","clientSecret","code","redirect_uri","redirectUri","grant_type","ok","Parse","Error","VALIDATION_ERROR","statusText","data","json","error","OBJECT_NOT_FOUND","error_description","access_token","getUserFromAccessToken","accessToken","userApiUrl","id","Authorization","userData","playerId","_default","exports"],"sources":["../../../src/Adapters/Auth/gpgames.js"],"sourcesContent":["/**\n * Parse Server authentication adapter for Google Play Games Services.\n *\n * @class GooglePlayGamesServicesAdapter\n * @param {Object} options - The adapter configuration options.\n * @param {string} options.clientId - Your Google Play Games Services App Client ID. Required for secure authentication.\n * @param {string} options.clientSecret - Your Google Play Games Services App Client Secret. Required for secure authentication.\n * @param {boolean} [options.enableInsecureAuth=false] - **[DEPRECATED]** Enable insecure authentication (not recommended).\n *\n * @description\n * ## Parse Server Configuration\n * To configure Parse Server for Google Play Games Services authentication, use the following structure:\n * ```json\n * {\n *   \"auth\": {\n *     \"gpgames\": {\n *       \"clientId\": \"your-client-id\",\n *       \"clientSecret\": \"your-client-secret\"\n *     }\n *   }\n * }\n * ```\n * ### Insecure Configuration (Not Recommended)\n * ```json\n * {\n *   \"auth\": {\n *     \"gpgames\": {\n *       \"enableInsecureAuth\": true\n *     }\n *   }\n * }\n * ```\n *\n * The adapter requires the following `authData` fields:\n * - **Secure Authentication**: `code`, `redirect_uri`.\n * - **Insecure Authentication (Not Recommended)**: `id`, `access_token`.\n *\n * ## Auth Payloads\n * ### Secure Authentication Payload\n * ```json\n * {\n *   \"gpgames\": {\n *     \"code\": \"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\",\n *     \"redirect_uri\": \"https://example.com/callback\"\n *   }\n * }\n * ```\n *\n * ### Insecure Authentication Payload (Not Recommended)\n * ```json\n * {\n *   \"gpgames\": {\n *     \"id\": \"123456789\",\n *     \"access_token\": \"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\"\n *   }\n * }\n * ```\n *\n * ## Notes\n * - `enableInsecureAuth` is **not recommended** and may be removed in future versions. Use secure authentication with `code` and `redirect_uri`.\n * - Secure authentication exchanges the `code` provided by the client for an access token using Google Play Games Services' OAuth API.\n *\n * @see {@link https://developers.google.com/games/services/console/enabling Google Play Games Services Authentication Documentation}\n */\n\nimport BaseCodeAuthAdapter from './BaseCodeAuthAdapter';\nclass GooglePlayGamesServicesAdapter extends BaseCodeAuthAdapter {\n  constructor() {\n    super(\"gpgames\");\n  }\n\n  async getAccessTokenFromCode(authData) {\n    const tokenUrl = 'https://oauth2.googleapis.com/token';\n    const response = await fetch(tokenUrl, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n        Accept: 'application/json',\n      },\n      body: JSON.stringify({\n        client_id: this.clientId,\n        client_secret: this.clientSecret,\n        code: authData.code,\n        redirect_uri: authData.redirectUri,\n        grant_type: 'authorization_code',\n      }),\n    });\n\n    if (!response.ok) {\n      throw new Parse.Error(\n        Parse.Error.VALIDATION_ERROR,\n        `Failed to exchange code for token: ${response.statusText}`\n      );\n    }\n\n    const data = await response.json();\n    if (data.error) {\n      throw new Parse.Error(\n        Parse.Error.OBJECT_NOT_FOUND,\n        data.error_description || data.error\n      );\n    }\n\n    return data.access_token;\n  }\n\n  async getUserFromAccessToken(accessToken, authData) {\n    const userApiUrl = `https://www.googleapis.com/games/v1/players/${authData.id}`;\n    const response = await fetch(userApiUrl, {\n      method: 'GET',\n      headers: {\n        Authorization: `Bearer ${accessToken}`,\n        Accept: 'application/json',\n      },\n    });\n\n    if (!response.ok) {\n      throw new Parse.Error(\n        Parse.Error.VALIDATION_ERROR,\n        `Failed to fetch Google Play Games Services user: ${response.statusText}`\n      );\n    }\n\n    const userData = await response.json();\n    if (!userData.playerId || userData.playerId !== authData.id) {\n      throw new Parse.Error(\n        Parse.Error.VALIDATION_ERROR,\n        'Invalid Google Play Games Services user data received.'\n      );\n    }\n\n    return {\n      id: userData.playerId\n    };\n  }\n\n}\n\nexport default new GooglePlayGamesServicesAdapter();\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -3,32 +3,32 @@
|
|
|
3
3
|
var _AdapterLoader = _interopRequireDefault(require("../AdapterLoader"));
|
|
4
4
|
var _node = _interopRequireDefault(require("parse/node"));
|
|
5
5
|
var _AuthAdapter = _interopRequireDefault(require("./AuthAdapter"));
|
|
6
|
+
var _gcenter = _interopRequireDefault(require("./gcenter"));
|
|
7
|
+
var _github = _interopRequireDefault(require("./github"));
|
|
8
|
+
var _gpgames = _interopRequireDefault(require("./gpgames"));
|
|
9
|
+
var _instagram = _interopRequireDefault(require("./instagram"));
|
|
10
|
+
var _line = _interopRequireDefault(require("./line"));
|
|
11
|
+
var _linkedin = _interopRequireDefault(require("./linkedin"));
|
|
6
12
|
var _mfa = _interopRequireDefault(require("./mfa"));
|
|
13
|
+
var _microsoft = _interopRequireDefault(require("./microsoft"));
|
|
14
|
+
var _oauth = _interopRequireDefault(require("./oauth2"));
|
|
15
|
+
var _qq = _interopRequireDefault(require("./qq"));
|
|
16
|
+
var _spotify = _interopRequireDefault(require("./spotify"));
|
|
17
|
+
var _twitter = _interopRequireDefault(require("./twitter"));
|
|
18
|
+
var _wechat = _interopRequireDefault(require("./wechat"));
|
|
19
|
+
var _weibo = _interopRequireDefault(require("./weibo"));
|
|
7
20
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
8
21
|
const apple = require('./apple');
|
|
9
|
-
const
|
|
10
|
-
const gpgames = require('./gpgames');
|
|
22
|
+
const digits = require('./twitter'); // digits tokens are validated by twitter
|
|
11
23
|
const facebook = require('./facebook');
|
|
12
|
-
const instagram = require('./instagram');
|
|
13
|
-
const linkedin = require('./linkedin');
|
|
14
|
-
const meetup = require('./meetup');
|
|
15
24
|
const google = require('./google');
|
|
16
|
-
const github = require('./github');
|
|
17
|
-
const twitter = require('./twitter');
|
|
18
|
-
const spotify = require('./spotify');
|
|
19
|
-
const digits = require('./twitter'); // digits tokens are validated by twitter
|
|
20
|
-
const janrainengage = require('./janrainengage');
|
|
21
25
|
const janraincapture = require('./janraincapture');
|
|
22
|
-
const
|
|
23
|
-
const vkontakte = require('./vkontakte');
|
|
24
|
-
const qq = require('./qq');
|
|
25
|
-
const wechat = require('./wechat');
|
|
26
|
-
const weibo = require('./weibo');
|
|
27
|
-
const oauth2 = require('./oauth2');
|
|
28
|
-
const phantauth = require('./phantauth');
|
|
29
|
-
const microsoft = require('./microsoft');
|
|
26
|
+
const janrainengage = require('./janrainengage');
|
|
30
27
|
const keycloak = require('./keycloak');
|
|
31
28
|
const ldap = require('./ldap');
|
|
29
|
+
const meetup = require('./meetup');
|
|
30
|
+
const phantauth = require('./phantauth');
|
|
31
|
+
const vkontakte = require('./vkontakte');
|
|
32
32
|
const anonymous = {
|
|
33
33
|
validateAuthData: () => {
|
|
34
34
|
return Promise.resolve();
|
|
@@ -39,28 +39,28 @@ const anonymous = {
|
|
|
39
39
|
};
|
|
40
40
|
const providers = {
|
|
41
41
|
apple,
|
|
42
|
-
gcenter,
|
|
43
|
-
gpgames,
|
|
42
|
+
gcenter: _gcenter.default,
|
|
43
|
+
gpgames: _gpgames.default,
|
|
44
44
|
facebook,
|
|
45
|
-
instagram,
|
|
46
|
-
linkedin,
|
|
45
|
+
instagram: _instagram.default,
|
|
46
|
+
linkedin: _linkedin.default,
|
|
47
47
|
meetup,
|
|
48
48
|
mfa: _mfa.default,
|
|
49
49
|
google,
|
|
50
|
-
github,
|
|
51
|
-
twitter,
|
|
52
|
-
spotify,
|
|
50
|
+
github: _github.default,
|
|
51
|
+
twitter: _twitter.default,
|
|
52
|
+
spotify: _spotify.default,
|
|
53
53
|
anonymous,
|
|
54
54
|
digits,
|
|
55
55
|
janrainengage,
|
|
56
56
|
janraincapture,
|
|
57
|
-
line,
|
|
57
|
+
line: _line.default,
|
|
58
58
|
vkontakte,
|
|
59
|
-
qq,
|
|
60
|
-
wechat,
|
|
61
|
-
weibo,
|
|
59
|
+
qq: _qq.default,
|
|
60
|
+
wechat: _wechat.default,
|
|
61
|
+
weibo: _weibo.default,
|
|
62
62
|
phantauth,
|
|
63
|
-
microsoft,
|
|
63
|
+
microsoft: _microsoft.default,
|
|
64
64
|
keycloak,
|
|
65
65
|
ldap
|
|
66
66
|
};
|
|
@@ -129,7 +129,7 @@ function loadAuthAdapter(provider, authOptions) {
|
|
|
129
129
|
// a default auth adapter like Facebook
|
|
130
130
|
const providerOptions = authOptions[provider];
|
|
131
131
|
if (providerOptions && Object.prototype.hasOwnProperty.call(providerOptions, 'oauth2') && providerOptions['oauth2'] === true) {
|
|
132
|
-
defaultAdapter =
|
|
132
|
+
defaultAdapter = _oauth.default;
|
|
133
133
|
}
|
|
134
134
|
|
|
135
135
|
// Default provider not found and a custom auth provider was not provided
|
|
@@ -214,7 +214,7 @@ module.exports = function (authOptions = {}, enableAnonymousUsers = true) {
|
|
|
214
214
|
user: req.auth.user,
|
|
215
215
|
master: req.auth.isMaster
|
|
216
216
|
};
|
|
217
|
-
const result = afterFind.call(adapter,
|
|
217
|
+
const result = afterFind.call(adapter, authData[provider], providerOptions, requestObject);
|
|
218
218
|
if (result) {
|
|
219
219
|
authData[provider] = result;
|
|
220
220
|
}
|
|
@@ -228,4 +228,4 @@ module.exports = function (authOptions = {}, enableAnonymousUsers = true) {
|
|
|
228
228
|
});
|
|
229
229
|
};
|
|
230
230
|
module.exports.loadAuthAdapter = loadAuthAdapter;
|
|
231
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_AdapterLoader","_interopRequireDefault","require","_node","_AuthAdapter","_mfa","e","__esModule","default","apple","gcenter","gpgames","facebook","instagram","linkedin","meetup","google","github","twitter","spotify","digits","janrainengage","janraincapture","line","vkontakte","qq","wechat","weibo","oauth2","phantauth","microsoft","keycloak","ldap","anonymous","validateAuthData","Promise","resolve","validateAppId","providers","mfa","authAdapterPolicies","solo","additional","authDataValidator","provider","adapter","appIds","options","authData","req","user","requestObject","policy","Parse","Error","OTHER_CAUSE","validateSetUp","validateLogin","validateUpdate","isLoggedIn","auth","id","isMaster","hasAuthDataConfigured","get","method","validator","loadAuthAdapter","authOptions","defaultAdapter","providerOptions","Object","prototype","hasOwnProperty","call","AuthAdapter","assign","keys","defaultAuthAdapter","forEach","key","existing","toString","undefined","optionalAdapter","loadAdapter","validateOptions","module","exports","enableAnonymousUsers","_enableAnonymousUsers","setEnableAnonymousUsers","enable","getValidatorForProvider","authAdapter","runAfterFind","adapters","all","map","afterFind","ip","config","master","result","freeze"],"sources":["../../../src/Adapters/Auth/index.js"],"sourcesContent":["import loadAdapter from '../AdapterLoader';\nimport Parse from 'parse/node';\nimport AuthAdapter from './AuthAdapter';\n\nconst apple = require('./apple');\nconst gcenter = require('./gcenter');\nconst gpgames = require('./gpgames');\nconst facebook = require('./facebook');\nconst instagram = require('./instagram');\nconst linkedin = require('./linkedin');\nconst meetup = require('./meetup');\nimport mfa from './mfa';\nconst google = require('./google');\nconst github = require('./github');\nconst twitter = require('./twitter');\nconst spotify = require('./spotify');\nconst digits = require('./twitter'); // digits tokens are validated by twitter\nconst janrainengage = require('./janrainengage');\nconst janraincapture = require('./janraincapture');\nconst line = require('./line');\nconst vkontakte = require('./vkontakte');\nconst qq = require('./qq');\nconst wechat = require('./wechat');\nconst weibo = require('./weibo');\nconst oauth2 = require('./oauth2');\nconst phantauth = require('./phantauth');\nconst microsoft = require('./microsoft');\nconst keycloak = require('./keycloak');\nconst ldap = require('./ldap');\n\nconst anonymous = {\n  validateAuthData: () => {\n    return Promise.resolve();\n  },\n  validateAppId: () => {\n    return Promise.resolve();\n  },\n};\n\nconst providers = {\n  apple,\n  gcenter,\n  gpgames,\n  facebook,\n  instagram,\n  linkedin,\n  meetup,\n  mfa,\n  google,\n  github,\n  twitter,\n  spotify,\n  anonymous,\n  digits,\n  janrainengage,\n  janraincapture,\n  line,\n  vkontakte,\n  qq,\n  wechat,\n  weibo,\n  phantauth,\n  microsoft,\n  keycloak,\n  ldap,\n};\n\n// Indexed auth policies\nconst authAdapterPolicies = {\n  default: true,\n  solo: true,\n  additional: true,\n};\n\nfunction authDataValidator(provider, adapter, appIds, options) {\n  return async function (authData, req, user, requestObject) {\n    if (appIds && typeof adapter.validateAppId === 'function') {\n      await Promise.resolve(adapter.validateAppId(appIds, authData, options, requestObject));\n    }\n    if (\n      adapter.policy &&\n      !authAdapterPolicies[adapter.policy] &&\n      typeof adapter.policy !== 'function'\n    ) {\n      throw new Parse.Error(\n        Parse.Error.OTHER_CAUSE,\n        'AuthAdapter policy is not configured correctly. The value must be either \"solo\", \"additional\", \"default\" or undefined (will be handled as \"default\")'\n      );\n    }\n    if (typeof adapter.validateAuthData === 'function') {\n      return adapter.validateAuthData(authData, options, requestObject);\n    }\n    if (\n      typeof adapter.validateSetUp !== 'function' ||\n      typeof adapter.validateLogin !== 'function' ||\n      typeof adapter.validateUpdate !== 'function'\n    ) {\n      throw new Parse.Error(\n        Parse.Error.OTHER_CAUSE,\n        'Adapter is not configured. Implement either validateAuthData or all of the following: validateSetUp, validateLogin and validateUpdate'\n      );\n    }\n    // When masterKey is detected, we should trigger a logged in user\n    const isLoggedIn =\n      (req.auth.user && user && req.auth.user.id === user.id) || (user && req.auth.isMaster);\n    let hasAuthDataConfigured = false;\n\n    if (user && user.get('authData') && user.get('authData')[provider]) {\n      hasAuthDataConfigured = true;\n    }\n\n    if (isLoggedIn) {\n      // User is updating their authData\n      if (hasAuthDataConfigured) {\n        return {\n          method: 'validateUpdate',\n          validator: () => adapter.validateUpdate(authData, options, requestObject),\n        };\n      }\n      // Set up if the user does not have the provider configured\n      return {\n        method: 'validateSetUp',\n        validator: () => adapter.validateSetUp(authData, options, requestObject),\n      };\n    }\n\n    // Not logged in and authData is configured on the user\n    if (hasAuthDataConfigured) {\n      return {\n        method: 'validateLogin',\n        validator: () => adapter.validateLogin(authData, options, requestObject),\n      };\n    }\n\n    // User not logged in and the provider is not set up, for example when a new user\n    // signs up or an existing user uses a new auth provider\n    return {\n      method: 'validateSetUp',\n      validator: () => adapter.validateSetUp(authData, options, requestObject),\n    };\n  };\n}\n\nfunction loadAuthAdapter(provider, authOptions) {\n  // providers are auth providers implemented by default\n  let defaultAdapter = providers[provider];\n  // authOptions can contain complete custom auth adapters or\n  // a default auth adapter like Facebook\n  const providerOptions = authOptions[provider];\n  if (\n    providerOptions &&\n    Object.prototype.hasOwnProperty.call(providerOptions, 'oauth2') &&\n    providerOptions['oauth2'] === true\n  ) {\n    defaultAdapter = oauth2;\n  }\n\n  // Default provider not found and a custom auth provider was not provided\n  if (!defaultAdapter && !providerOptions) {\n    return;\n  }\n\n  const adapter =\n    defaultAdapter instanceof AuthAdapter ? defaultAdapter : Object.assign({}, defaultAdapter);\n  const keys = [\n    'validateAuthData',\n    'validateAppId',\n    'validateSetUp',\n    'validateLogin',\n    'validateUpdate',\n    'challenge',\n    'validateOptions',\n    'policy',\n    'afterFind',\n  ];\n  const defaultAuthAdapter = new AuthAdapter();\n  keys.forEach(key => {\n    const existing = adapter?.[key];\n    if (\n      existing &&\n      typeof existing === 'function' &&\n      existing.toString() === defaultAuthAdapter[key].toString()\n    ) {\n      adapter[key] = null;\n    }\n  });\n  const appIds = providerOptions ? providerOptions.appIds : undefined;\n\n  // Try the configuration methods\n  if (providerOptions) {\n    const optionalAdapter = loadAdapter(providerOptions, undefined, providerOptions);\n    if (optionalAdapter) {\n      keys.forEach(key => {\n        if (optionalAdapter[key]) {\n          adapter[key] = optionalAdapter[key];\n        }\n      });\n    }\n  }\n  if (adapter.validateOptions) {\n    adapter.validateOptions(providerOptions);\n  }\n\n  return { adapter, appIds, providerOptions };\n}\n\nmodule.exports = function (authOptions = {}, enableAnonymousUsers = true) {\n  let _enableAnonymousUsers = enableAnonymousUsers;\n  const setEnableAnonymousUsers = function (enable) {\n    _enableAnonymousUsers = enable;\n  };\n  // To handle the test cases on configuration\n  const getValidatorForProvider = function (provider) {\n    if (provider === 'anonymous' && !_enableAnonymousUsers) {\n      return { validator: undefined };\n    }\n    const authAdapter = loadAuthAdapter(provider, authOptions);\n    if (!authAdapter) { return; }\n    const { adapter, appIds, providerOptions } = authAdapter;\n    return { validator: authDataValidator(provider, adapter, appIds, providerOptions), adapter };\n  };\n\n  const runAfterFind = async (req, authData) => {\n    if (!authData) {\n      return;\n    }\n    const adapters = Object.keys(authData);\n    await Promise.all(\n      adapters.map(async provider => {\n        const authAdapter = getValidatorForProvider(provider);\n        if (!authAdapter) {\n          return;\n        }\n        const { adapter, providerOptions } = authAdapter;\n        const afterFind = adapter.afterFind;\n        if (afterFind && typeof afterFind === 'function') {\n          const requestObject = {\n            ip: req.config.ip,\n            user: req.auth.user,\n            master: req.auth.isMaster,\n          };\n          const result = afterFind.call(\n            adapter,\n            requestObject,\n            authData[provider],\n            providerOptions\n          );\n          if (result) {\n            authData[provider] = result;\n          }\n        }\n      })\n    );\n  };\n\n  return Object.freeze({\n    getValidatorForProvider,\n    setEnableAnonymousUsers,\n    runAfterFind,\n  });\n};\n\nmodule.exports.loadAuthAdapter = loadAuthAdapter;\n"],"mappings":"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","ignoreList":[]}
|
|
231
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_AdapterLoader","_interopRequireDefault","require","_node","_AuthAdapter","_gcenter","_github","_gpgames","_instagram","_line","_linkedin","_mfa","_microsoft","_oauth","_qq","_spotify","_twitter","_wechat","_weibo","e","__esModule","default","apple","digits","facebook","google","janraincapture","janrainengage","keycloak","ldap","meetup","phantauth","vkontakte","anonymous","validateAuthData","Promise","resolve","validateAppId","providers","gcenter","gpgames","instagram","linkedin","mfa","github","twitter","spotify","line","qq","wechat","weibo","microsoft","authAdapterPolicies","solo","additional","authDataValidator","provider","adapter","appIds","options","authData","req","user","requestObject","policy","Parse","Error","OTHER_CAUSE","validateSetUp","validateLogin","validateUpdate","isLoggedIn","auth","id","isMaster","hasAuthDataConfigured","get","method","validator","loadAuthAdapter","authOptions","defaultAdapter","providerOptions","Object","prototype","hasOwnProperty","call","oauth2","AuthAdapter","assign","keys","defaultAuthAdapter","forEach","key","existing","toString","undefined","optionalAdapter","loadAdapter","validateOptions","module","exports","enableAnonymousUsers","_enableAnonymousUsers","setEnableAnonymousUsers","enable","getValidatorForProvider","authAdapter","runAfterFind","adapters","all","map","afterFind","ip","config","master","result","freeze"],"sources":["../../../src/Adapters/Auth/index.js"],"sourcesContent":["import loadAdapter from '../AdapterLoader';\nimport Parse from 'parse/node';\nimport AuthAdapter from './AuthAdapter';\n\nconst apple = require('./apple');\nconst digits = require('./twitter'); // digits tokens are validated by twitter\nconst facebook = require('./facebook');\nimport gcenter from './gcenter';\nimport github from './github';\nconst google = require('./google');\nimport gpgames from './gpgames';\nimport instagram from './instagram';\nconst janraincapture = require('./janraincapture');\nconst janrainengage = require('./janrainengage');\nconst keycloak = require('./keycloak');\nconst ldap = require('./ldap');\nimport line from './line';\nimport linkedin from './linkedin';\nconst meetup = require('./meetup');\nimport mfa from './mfa';\nimport microsoft from './microsoft';\nimport oauth2 from './oauth2';\nconst phantauth = require('./phantauth');\nimport qq from './qq';\nimport spotify from './spotify';\nimport twitter from './twitter';\nconst vkontakte = require('./vkontakte');\nimport wechat from './wechat';\nimport weibo from './weibo';\n\n\nconst anonymous = {\n  validateAuthData: () => {\n    return Promise.resolve();\n  },\n  validateAppId: () => {\n    return Promise.resolve();\n  },\n};\n\nconst providers = {\n  apple,\n  gcenter,\n  gpgames,\n  facebook,\n  instagram,\n  linkedin,\n  meetup,\n  mfa,\n  google,\n  github,\n  twitter,\n  spotify,\n  anonymous,\n  digits,\n  janrainengage,\n  janraincapture,\n  line,\n  vkontakte,\n  qq,\n  wechat,\n  weibo,\n  phantauth,\n  microsoft,\n  keycloak,\n  ldap,\n};\n\n// Indexed auth policies\nconst authAdapterPolicies = {\n  default: true,\n  solo: true,\n  additional: true,\n};\n\nfunction authDataValidator(provider, adapter, appIds, options) {\n  return async function (authData, req, user, requestObject) {\n    if (appIds && typeof adapter.validateAppId === 'function') {\n      await Promise.resolve(adapter.validateAppId(appIds, authData, options, requestObject));\n    }\n    if (\n      adapter.policy &&\n      !authAdapterPolicies[adapter.policy] &&\n      typeof adapter.policy !== 'function'\n    ) {\n      throw new Parse.Error(\n        Parse.Error.OTHER_CAUSE,\n        'AuthAdapter policy is not configured correctly. The value must be either \"solo\", \"additional\", \"default\" or undefined (will be handled as \"default\")'\n      );\n    }\n    if (typeof adapter.validateAuthData === 'function') {\n      return adapter.validateAuthData(authData, options, requestObject);\n    }\n    if (\n      typeof adapter.validateSetUp !== 'function' ||\n      typeof adapter.validateLogin !== 'function' ||\n      typeof adapter.validateUpdate !== 'function'\n    ) {\n      throw new Parse.Error(\n        Parse.Error.OTHER_CAUSE,\n        'Adapter is not configured. Implement either validateAuthData or all of the following: validateSetUp, validateLogin and validateUpdate'\n      );\n    }\n    // When masterKey is detected, we should trigger a logged in user\n    const isLoggedIn =\n      (req.auth.user && user && req.auth.user.id === user.id) || (user && req.auth.isMaster);\n    let hasAuthDataConfigured = false;\n\n    if (user && user.get('authData') && user.get('authData')[provider]) {\n      hasAuthDataConfigured = true;\n    }\n\n    if (isLoggedIn) {\n      // User is updating their authData\n      if (hasAuthDataConfigured) {\n        return {\n          method: 'validateUpdate',\n          validator: () => adapter.validateUpdate(authData, options, requestObject),\n        };\n      }\n      // Set up if the user does not have the provider configured\n      return {\n        method: 'validateSetUp',\n        validator: () => adapter.validateSetUp(authData, options, requestObject),\n      };\n    }\n\n    // Not logged in and authData is configured on the user\n    if (hasAuthDataConfigured) {\n      return {\n        method: 'validateLogin',\n        validator: () => adapter.validateLogin(authData, options, requestObject),\n      };\n    }\n\n    // User not logged in and the provider is not set up, for example when a new user\n    // signs up or an existing user uses a new auth provider\n    return {\n      method: 'validateSetUp',\n      validator: () => adapter.validateSetUp(authData, options, requestObject),\n    };\n  };\n}\n\nfunction loadAuthAdapter(provider, authOptions) {\n  // providers are auth providers implemented by default\n  let defaultAdapter = providers[provider];\n  // authOptions can contain complete custom auth adapters or\n  // a default auth adapter like Facebook\n  const providerOptions = authOptions[provider];\n  if (\n    providerOptions &&\n    Object.prototype.hasOwnProperty.call(providerOptions, 'oauth2') &&\n    providerOptions['oauth2'] === true\n  ) {\n    defaultAdapter = oauth2;\n  }\n\n  // Default provider not found and a custom auth provider was not provided\n  if (!defaultAdapter && !providerOptions) {\n    return;\n  }\n\n  const adapter =\n    defaultAdapter instanceof AuthAdapter ? defaultAdapter : Object.assign({}, defaultAdapter);\n  const keys = [\n    'validateAuthData',\n    'validateAppId',\n    'validateSetUp',\n    'validateLogin',\n    'validateUpdate',\n    'challenge',\n    'validateOptions',\n    'policy',\n    'afterFind',\n  ];\n  const defaultAuthAdapter = new AuthAdapter();\n  keys.forEach(key => {\n    const existing = adapter?.[key];\n    if (\n      existing &&\n      typeof existing === 'function' &&\n      existing.toString() === defaultAuthAdapter[key].toString()\n    ) {\n      adapter[key] = null;\n    }\n  });\n  const appIds = providerOptions ? providerOptions.appIds : undefined;\n\n  // Try the configuration methods\n  if (providerOptions) {\n    const optionalAdapter = loadAdapter(providerOptions, undefined, providerOptions);\n    if (optionalAdapter) {\n      keys.forEach(key => {\n        if (optionalAdapter[key]) {\n          adapter[key] = optionalAdapter[key];\n        }\n      });\n    }\n  }\n  if (adapter.validateOptions) {\n    adapter.validateOptions(providerOptions);\n  }\n\n  return { adapter, appIds, providerOptions };\n}\n\nmodule.exports = function (authOptions = {}, enableAnonymousUsers = true) {\n  let _enableAnonymousUsers = enableAnonymousUsers;\n  const setEnableAnonymousUsers = function (enable) {\n    _enableAnonymousUsers = enable;\n  };\n  // To handle the test cases on configuration\n  const getValidatorForProvider = function (provider) {\n    if (provider === 'anonymous' && !_enableAnonymousUsers) {\n      return { validator: undefined };\n    }\n    const authAdapter = loadAuthAdapter(provider, authOptions);\n    if (!authAdapter) { return; }\n    const { adapter, appIds, providerOptions } = authAdapter;\n    return { validator: authDataValidator(provider, adapter, appIds, providerOptions), adapter };\n  };\n\n  const runAfterFind = async (req, authData) => {\n    if (!authData) {\n      return;\n    }\n    const adapters = Object.keys(authData);\n    await Promise.all(\n      adapters.map(async provider => {\n        const authAdapter = getValidatorForProvider(provider);\n        if (!authAdapter) {\n          return;\n        }\n        const { adapter, providerOptions } = authAdapter;\n        const afterFind = adapter.afterFind;\n        if (afterFind && typeof afterFind === 'function') {\n          const requestObject = {\n            ip: req.config.ip,\n            user: req.auth.user,\n            master: req.auth.isMaster,\n          };\n          const result = afterFind.call(\n            adapter,\n            authData[provider],\n            providerOptions,\n            requestObject,\n          );\n          if (result) {\n            authData[provider] = result;\n          }\n        }\n      })\n    );\n  };\n\n  return Object.freeze({\n    getValidatorForProvider,\n    setEnableAnonymousUsers,\n    runAfterFind,\n  });\n};\n\nmodule.exports.loadAuthAdapter = loadAuthAdapter;\n"],"mappings":"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","ignoreList":[]}
|