parse-server 2.8.4 → 8.6.2

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.
Files changed (240) hide show
  1. package/LICENSE +167 -25
  2. package/NOTICE +10 -0
  3. package/README.md +929 -278
  4. package/lib/AccountLockout.js +47 -30
  5. package/lib/Adapters/AdapterLoader.js +21 -6
  6. package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
  7. package/lib/Adapters/Auth/AuthAdapter.js +116 -13
  8. package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
  9. package/lib/Adapters/Auth/OAuth1Client.js +27 -46
  10. package/lib/Adapters/Auth/apple.js +123 -0
  11. package/lib/Adapters/Auth/facebook.js +162 -35
  12. package/lib/Adapters/Auth/gcenter.js +217 -0
  13. package/lib/Adapters/Auth/github.js +118 -48
  14. package/lib/Adapters/Auth/google.js +160 -51
  15. package/lib/Adapters/Auth/gpgames.js +125 -0
  16. package/lib/Adapters/Auth/httpsRequest.js +6 -7
  17. package/lib/Adapters/Auth/index.js +170 -62
  18. package/lib/Adapters/Auth/instagram.js +114 -40
  19. package/lib/Adapters/Auth/janraincapture.js +52 -23
  20. package/lib/Adapters/Auth/janrainengage.js +19 -36
  21. package/lib/Adapters/Auth/keycloak.js +148 -0
  22. package/lib/Adapters/Auth/ldap.js +167 -0
  23. package/lib/Adapters/Auth/line.js +125 -0
  24. package/lib/Adapters/Auth/linkedin.js +111 -55
  25. package/lib/Adapters/Auth/meetup.js +24 -34
  26. package/lib/Adapters/Auth/mfa.js +324 -0
  27. package/lib/Adapters/Auth/microsoft.js +111 -0
  28. package/lib/Adapters/Auth/oauth2.js +97 -162
  29. package/lib/Adapters/Auth/phantauth.js +53 -0
  30. package/lib/Adapters/Auth/qq.js +108 -49
  31. package/lib/Adapters/Auth/spotify.js +107 -55
  32. package/lib/Adapters/Auth/twitter.js +188 -48
  33. package/lib/Adapters/Auth/utils.js +28 -0
  34. package/lib/Adapters/Auth/vkontakte.js +26 -39
  35. package/lib/Adapters/Auth/wechat.js +106 -44
  36. package/lib/Adapters/Auth/weibo.js +132 -58
  37. package/lib/Adapters/Cache/CacheAdapter.js +13 -8
  38. package/lib/Adapters/Cache/InMemoryCache.js +3 -13
  39. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
  40. package/lib/Adapters/Cache/LRUCache.js +13 -27
  41. package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
  42. package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
  43. package/lib/Adapters/Cache/SchemaCache.js +25 -0
  44. package/lib/Adapters/Email/MailAdapter.js +10 -8
  45. package/lib/Adapters/Files/FilesAdapter.js +83 -25
  46. package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
  47. package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
  48. package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
  49. package/lib/Adapters/Logger/WinstonLogger.js +69 -88
  50. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
  51. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
  52. package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
  53. package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
  54. package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
  55. package/lib/Adapters/Push/PushAdapter.js +14 -7
  56. package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
  57. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
  58. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
  59. package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
  60. package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
  61. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
  62. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
  63. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
  64. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  65. package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
  66. package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
  67. package/lib/Auth.js +488 -125
  68. package/lib/ClientSDK.js +2 -6
  69. package/lib/Config.js +525 -94
  70. package/lib/Controllers/AdaptableController.js +5 -25
  71. package/lib/Controllers/AnalyticsController.js +22 -23
  72. package/lib/Controllers/CacheController.js +10 -31
  73. package/lib/Controllers/DatabaseController.js +767 -313
  74. package/lib/Controllers/FilesController.js +49 -54
  75. package/lib/Controllers/HooksController.js +80 -84
  76. package/lib/Controllers/LiveQueryController.js +35 -22
  77. package/lib/Controllers/LoggerController.js +22 -58
  78. package/lib/Controllers/ParseGraphQLController.js +293 -0
  79. package/lib/Controllers/PushController.js +58 -49
  80. package/lib/Controllers/SchemaController.js +916 -422
  81. package/lib/Controllers/UserController.js +265 -180
  82. package/lib/Controllers/index.js +90 -125
  83. package/lib/Controllers/types.js +1 -1
  84. package/lib/Deprecator/Deprecations.js +30 -0
  85. package/lib/Deprecator/Deprecator.js +127 -0
  86. package/lib/Error.js +48 -0
  87. package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
  88. package/lib/GraphQL/ParseGraphQLServer.js +214 -0
  89. package/lib/GraphQL/helpers/objectsMutations.js +30 -0
  90. package/lib/GraphQL/helpers/objectsQueries.js +246 -0
  91. package/lib/GraphQL/loaders/configMutations.js +87 -0
  92. package/lib/GraphQL/loaders/configQueries.js +79 -0
  93. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
  94. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
  95. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
  96. package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
  97. package/lib/GraphQL/loaders/filesMutations.js +107 -0
  98. package/lib/GraphQL/loaders/functionsMutations.js +78 -0
  99. package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
  100. package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
  101. package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
  102. package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
  103. package/lib/GraphQL/loaders/schemaMutations.js +162 -0
  104. package/lib/GraphQL/loaders/schemaQueries.js +81 -0
  105. package/lib/GraphQL/loaders/schemaTypes.js +341 -0
  106. package/lib/GraphQL/loaders/usersMutations.js +433 -0
  107. package/lib/GraphQL/loaders/usersQueries.js +90 -0
  108. package/lib/GraphQL/parseGraphQLUtils.js +63 -0
  109. package/lib/GraphQL/transformers/className.js +14 -0
  110. package/lib/GraphQL/transformers/constraintType.js +53 -0
  111. package/lib/GraphQL/transformers/inputType.js +51 -0
  112. package/lib/GraphQL/transformers/mutation.js +274 -0
  113. package/lib/GraphQL/transformers/outputType.js +51 -0
  114. package/lib/GraphQL/transformers/query.js +237 -0
  115. package/lib/GraphQL/transformers/schemaFields.js +99 -0
  116. package/lib/KeyPromiseQueue.js +48 -0
  117. package/lib/LiveQuery/Client.js +25 -33
  118. package/lib/LiveQuery/Id.js +2 -5
  119. package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
  120. package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
  121. package/lib/LiveQuery/ParsePubSub.js +7 -16
  122. package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
  123. package/lib/LiveQuery/QueryTools.js +76 -15
  124. package/lib/LiveQuery/RequestSchema.js +111 -97
  125. package/lib/LiveQuery/SessionTokenCache.js +23 -36
  126. package/lib/LiveQuery/Subscription.js +8 -17
  127. package/lib/LiveQuery/equalObjects.js +2 -3
  128. package/lib/Options/Definitions.js +1355 -382
  129. package/lib/Options/docs.js +301 -62
  130. package/lib/Options/index.js +11 -1
  131. package/lib/Options/parsers.js +14 -10
  132. package/lib/Page.js +44 -0
  133. package/lib/ParseMessageQueue.js +6 -13
  134. package/lib/ParseServer.js +474 -235
  135. package/lib/ParseServerRESTController.js +102 -40
  136. package/lib/PromiseRouter.js +39 -50
  137. package/lib/Push/PushQueue.js +24 -30
  138. package/lib/Push/PushWorker.js +32 -56
  139. package/lib/Push/utils.js +22 -35
  140. package/lib/RestQuery.js +361 -139
  141. package/lib/RestWrite.js +713 -344
  142. package/lib/Routers/AggregateRouter.js +97 -71
  143. package/lib/Routers/AnalyticsRouter.js +8 -14
  144. package/lib/Routers/AudiencesRouter.js +16 -35
  145. package/lib/Routers/ClassesRouter.js +86 -72
  146. package/lib/Routers/CloudCodeRouter.js +28 -37
  147. package/lib/Routers/FeaturesRouter.js +22 -25
  148. package/lib/Routers/FilesRouter.js +266 -171
  149. package/lib/Routers/FunctionsRouter.js +87 -103
  150. package/lib/Routers/GlobalConfigRouter.js +94 -33
  151. package/lib/Routers/GraphQLRouter.js +41 -0
  152. package/lib/Routers/HooksRouter.js +43 -47
  153. package/lib/Routers/IAPValidationRouter.js +57 -70
  154. package/lib/Routers/InstallationsRouter.js +17 -25
  155. package/lib/Routers/LogsRouter.js +10 -25
  156. package/lib/Routers/PagesRouter.js +647 -0
  157. package/lib/Routers/PublicAPIRouter.js +104 -112
  158. package/lib/Routers/PurgeRouter.js +19 -29
  159. package/lib/Routers/PushRouter.js +14 -28
  160. package/lib/Routers/RolesRouter.js +7 -14
  161. package/lib/Routers/SchemasRouter.js +63 -42
  162. package/lib/Routers/SecurityRouter.js +34 -0
  163. package/lib/Routers/SessionsRouter.js +25 -38
  164. package/lib/Routers/UsersRouter.js +463 -190
  165. package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
  166. package/lib/SchemaMigrations/Migrations.js +30 -0
  167. package/lib/Security/Check.js +109 -0
  168. package/lib/Security/CheckGroup.js +44 -0
  169. package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
  170. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
  171. package/lib/Security/CheckGroups/CheckGroups.js +21 -0
  172. package/lib/Security/CheckRunner.js +213 -0
  173. package/lib/SharedRest.js +29 -0
  174. package/lib/StatusHandler.js +96 -93
  175. package/lib/TestUtils.js +70 -14
  176. package/lib/Utils.js +468 -0
  177. package/lib/batch.js +74 -40
  178. package/lib/cache.js +8 -8
  179. package/lib/cli/definitions/parse-live-query-server.js +4 -3
  180. package/lib/cli/definitions/parse-server.js +4 -3
  181. package/lib/cli/parse-live-query-server.js +9 -17
  182. package/lib/cli/parse-server.js +49 -47
  183. package/lib/cli/utils/commander.js +20 -29
  184. package/lib/cli/utils/runner.js +31 -32
  185. package/lib/cloud-code/Parse.Cloud.js +711 -36
  186. package/lib/cloud-code/Parse.Server.js +21 -0
  187. package/lib/cryptoUtils.js +6 -11
  188. package/lib/defaults.js +21 -15
  189. package/lib/deprecated.js +1 -1
  190. package/lib/index.js +78 -67
  191. package/lib/logger.js +12 -20
  192. package/lib/middlewares.js +484 -160
  193. package/lib/password.js +10 -6
  194. package/lib/request.js +175 -0
  195. package/lib/requiredParameter.js +4 -3
  196. package/lib/rest.js +157 -82
  197. package/lib/triggers.js +627 -185
  198. package/lib/vendor/README.md +3 -3
  199. package/lib/vendor/mongodbUrl.js +224 -137
  200. package/package.json +135 -57
  201. package/postinstall.js +38 -50
  202. package/public_html/invalid_verification_link.html +3 -3
  203. package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
  204. package/types/@types/deepcopy/index.d.ts +5 -0
  205. package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
  206. package/types/Options/index.d.ts +301 -0
  207. package/types/ParseServer.d.ts +65 -0
  208. package/types/eslint.config.mjs +30 -0
  209. package/types/index.d.ts +21 -0
  210. package/types/logger.d.ts +2 -0
  211. package/types/tests.ts +44 -0
  212. package/types/tsconfig.json +24 -0
  213. package/CHANGELOG.md +0 -1246
  214. package/PATENTS +0 -37
  215. package/bin/dev +0 -37
  216. package/lib/.DS_Store +0 -0
  217. package/lib/Adapters/Auth/common.js +0 -2
  218. package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
  219. package/lib/Controllers/SchemaCache.js +0 -97
  220. package/lib/LiveQuery/.DS_Store +0 -0
  221. package/lib/cli/utils/parsers.js +0 -77
  222. package/lib/cloud-code/.DS_Store +0 -0
  223. package/lib/cloud-code/HTTPResponse.js +0 -57
  224. package/lib/cloud-code/Untitled-1 +0 -123
  225. package/lib/cloud-code/httpRequest.js +0 -102
  226. package/lib/cloud-code/team.html +0 -123
  227. package/lib/graphql/ParseClass.js +0 -234
  228. package/lib/graphql/Schema.js +0 -197
  229. package/lib/graphql/index.js +0 -1
  230. package/lib/graphql/types/ACL.js +0 -35
  231. package/lib/graphql/types/Date.js +0 -25
  232. package/lib/graphql/types/File.js +0 -24
  233. package/lib/graphql/types/GeoPoint.js +0 -35
  234. package/lib/graphql/types/JSONObject.js +0 -30
  235. package/lib/graphql/types/NumberInput.js +0 -43
  236. package/lib/graphql/types/NumberQuery.js +0 -42
  237. package/lib/graphql/types/Pointer.js +0 -35
  238. package/lib/graphql/types/QueryConstraint.js +0 -61
  239. package/lib/graphql/types/StringQuery.js +0 -39
  240. package/lib/graphql/types/index.js +0 -110
@@ -1,9 +1,8 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  var https = require('https'),
4
- crypto = require('crypto');
4
+ crypto = require('crypto');
5
5
  var Parse = require('parse/node').Parse;
6
-
7
6
  var OAuth = function (options) {
8
7
  if (!options) {
9
8
  throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'No options passed to OAuth');
@@ -15,9 +14,7 @@ var OAuth = function (options) {
15
14
  this.host = options.host;
16
15
  this.oauth_params = options.oauth_params || {};
17
16
  };
18
-
19
17
  OAuth.prototype.send = function (method, path, params, body) {
20
-
21
18
  var request = this.buildRequest(method, path, params, body);
22
19
  // Encode the body properly, the current Parse Implementation don't do it properly
23
20
  return new Promise(function (resolve, reject) {
@@ -39,41 +36,34 @@ OAuth.prototype.send = function (method, path, params, body) {
39
36
  httpRequest.end();
40
37
  });
41
38
  };
42
-
43
39
  OAuth.prototype.buildRequest = function (method, path, params, body) {
44
- if (path.indexOf("/") != 0) {
45
- path = "/" + path;
40
+ if (path.indexOf('/') != 0) {
41
+ path = '/' + path;
46
42
  }
47
43
  if (params && Object.keys(params).length > 0) {
48
- path += "?" + OAuth.buildParameterString(params);
44
+ path += '?' + OAuth.buildParameterString(params);
49
45
  }
50
-
51
46
  var request = {
52
47
  host: this.host,
53
48
  path: path,
54
49
  method: method.toUpperCase()
55
50
  };
56
-
57
51
  var oauth_params = this.oauth_params || {};
58
52
  oauth_params.oauth_consumer_key = this.consumer_key;
59
53
  if (this.auth_token) {
60
- oauth_params["oauth_token"] = this.auth_token;
54
+ oauth_params['oauth_token'] = this.auth_token;
61
55
  }
62
-
63
56
  request = OAuth.signRequest(request, oauth_params, this.consumer_secret, this.auth_token_secret);
64
-
65
57
  if (body && Object.keys(body).length > 0) {
66
58
  request.body = OAuth.buildParameterString(body);
67
59
  }
68
60
  return request;
69
61
  };
70
-
71
62
  OAuth.prototype.get = function (path, params) {
72
- return this.send("GET", path, params);
63
+ return this.send('GET', path, params);
73
64
  };
74
-
75
65
  OAuth.prototype.post = function (path, params, body) {
76
- return this.send("POST", path, params, body);
66
+ return this.send('POST', path, params, body);
77
67
  };
78
68
 
79
69
  /*
@@ -107,22 +97,20 @@ OAuth.encode = function (str) {
107
97
  // PHP behavior, you would need to add ".replace(/~/g, '%7E');" to the following.
108
98
  return encodeURIComponent(str).replace(/!/g, '%21').replace(/'/g, '%27').replace(/\(/g, '%28').replace(/\)/g, '%29').replace(/\*/g, '%2A');
109
99
  };
110
-
111
- OAuth.signatureMethod = "HMAC-SHA1";
112
- OAuth.version = "1.0";
100
+ OAuth.signatureMethod = 'HMAC-SHA1';
101
+ OAuth.version = '1.0';
113
102
 
114
103
  /*
115
104
  Generate a nonce
116
105
  */
117
106
  OAuth.nonce = function () {
118
- var text = "";
119
- var possible = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
120
-
121
- for (var i = 0; i < 30; i++) text += possible.charAt(Math.floor(Math.random() * possible.length));
122
-
107
+ var text = '';
108
+ var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
109
+ for (var i = 0; i < 30; i++) {
110
+ text += possible.charAt(Math.floor(Math.random() * possible.length));
111
+ }
123
112
  return text;
124
113
  };
125
-
126
114
  OAuth.buildParameterString = function (obj) {
127
115
  // Sort keys and encode values
128
116
  if (obj) {
@@ -130,11 +118,10 @@ OAuth.buildParameterString = function (obj) {
130
118
 
131
119
  // Map key=value, join them by &
132
120
  return keys.map(function (key) {
133
- return key + "=" + OAuth.encode(obj[key]);
134
- }).join("&");
121
+ return key + '=' + OAuth.encode(obj[key]);
122
+ }).join('&');
135
123
  }
136
-
137
- return "";
124
+ return '';
138
125
  };
139
126
 
140
127
  /*
@@ -142,17 +129,16 @@ OAuth.buildParameterString = function (obj) {
142
129
  */
143
130
 
144
131
  OAuth.buildSignatureString = function (method, url, parameters) {
145
- return [method.toUpperCase(), OAuth.encode(url), OAuth.encode(parameters)].join("&");
132
+ return [method.toUpperCase(), OAuth.encode(url), OAuth.encode(parameters)].join('&');
146
133
  };
147
134
 
148
135
  /*
149
136
  Retuns encoded HMAC-SHA1 from key and text
150
137
  */
151
138
  OAuth.signature = function (text, key) {
152
- crypto = require("crypto");
139
+ crypto = require('crypto');
153
140
  return OAuth.encode(crypto.createHmac('sha1', key).update(text).digest('base64'));
154
141
  };
155
-
156
142
  OAuth.signRequest = function (request, oauth_parameters, consumer_secret, auth_token_secret) {
157
143
  oauth_parameters = oauth_parameters || {};
158
144
 
@@ -169,13 +155,12 @@ OAuth.signRequest = function (request, oauth_parameters, consumer_secret, auth_t
169
155
  if (!oauth_parameters.oauth_version) {
170
156
  oauth_parameters.oauth_version = OAuth.version;
171
157
  }
172
-
173
158
  if (!auth_token_secret) {
174
- auth_token_secret = "";
159
+ auth_token_secret = '';
175
160
  }
176
161
  // Force GET method if unset
177
162
  if (!request.method) {
178
- request.method = "GET";
163
+ request.method = 'GET';
179
164
  }
180
165
 
181
166
  // Collect all the parameters in one signatureParameters object
@@ -192,12 +177,10 @@ OAuth.signRequest = function (request, oauth_parameters, consumer_secret, auth_t
192
177
  var parameterString = OAuth.buildParameterString(signatureParams);
193
178
 
194
179
  // Build the signature string
195
- var url = "https://" + request.host + "" + request.path;
196
-
180
+ var url = 'https://' + request.host + '' + request.path;
197
181
  var signatureString = OAuth.buildSignatureString(request.method, url, parameterString);
198
182
  // Hash the signature string
199
- var signatureKey = [OAuth.encode(consumer_secret), OAuth.encode(auth_token_secret)].join("&");
200
-
183
+ var signatureKey = [OAuth.encode(consumer_secret), OAuth.encode(auth_token_secret)].join('&');
201
184
  var signature = OAuth.signature(signatureString, signatureKey);
202
185
 
203
186
  // Set the signature in the params
@@ -210,14 +193,12 @@ OAuth.signRequest = function (request, oauth_parameters, consumer_secret, auth_t
210
193
  var authHeader = Object.keys(oauth_parameters).sort().map(function (key) {
211
194
  var value = oauth_parameters[key];
212
195
  return key + '="' + value + '"';
213
- }).join(", ");
214
-
196
+ }).join(', ');
215
197
  request.headers.Authorization = 'OAuth ' + authHeader;
216
198
 
217
199
  // Set the content type header
218
- request.headers["Content-Type"] = "application/x-www-form-urlencoded";
200
+ request.headers['Content-Type'] = 'application/x-www-form-urlencoded';
219
201
  return request;
220
202
  };
221
-
222
203
  module.exports = OAuth;
223
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Adapters/Auth/OAuth1Client.js"],"names":["https","require","crypto","Parse","OAuth","options","Error","INTERNAL_SERVER_ERROR","consumer_key","consumer_secret","auth_token","auth_token_secret","host","oauth_params","prototype","send","method","path","params","body","request","buildRequest","Promise","resolve","reject","httpRequest","res","data","on","chunk","JSON","parse","write","end","indexOf","Object","keys","length","buildParameterString","toUpperCase","oauth_consumer_key","signRequest","get","post","encode","str","toString","encodeURIComponent","replace","signatureMethod","version","nonce","text","possible","i","charAt","Math","floor","random","obj","sort","map","key","join","buildSignatureString","url","parameters","signature","createHmac","update","digest","oauth_parameters","oauth_nonce","oauth_timestamp","Date","getTime","oauth_signature_method","oauth_version","signatureParams","parametersToMerge","k","parameterString","signatureString","signatureKey","oauth_signature","headers","authHeader","value","Authorization","module","exports"],"mappings":";;AAAA,IAAIA,QAAQC,QAAQ,OAAR,CAAZ;AAAA,IACEC,SAASD,QAAQ,QAAR,CADX;AAEA,IAAIE,QAAQF,QAAQ,YAAR,EAAsBE,KAAlC;;AAEA,IAAIC,QAAQ,UAASC,OAAT,EAAkB;AAC5B,MAAG,CAACA,OAAJ,EAAa;AACX,UAAM,IAAIF,MAAMG,KAAV,CAAgBH,MAAMG,KAAN,CAAYC,qBAA5B,EAAmD,4BAAnD,CAAN;AACD;AACD,OAAKC,YAAL,GAAoBH,QAAQG,YAA5B;AACA,OAAKC,eAAL,GAAuBJ,QAAQI,eAA/B;AACA,OAAKC,UAAL,GAAkBL,QAAQK,UAA1B;AACA,OAAKC,iBAAL,GAAyBN,QAAQM,iBAAjC;AACA,OAAKC,IAAL,GAAYP,QAAQO,IAApB;AACA,OAAKC,YAAL,GAAoBR,QAAQQ,YAAR,IAAwB,EAA5C;AACD,CAVD;;AAYAT,MAAMU,SAAN,CAAgBC,IAAhB,GAAuB,UAASC,MAAT,EAAiBC,IAAjB,EAAuBC,MAAvB,EAA+BC,IAA/B,EAAoC;;AAEzD,MAAIC,UAAU,KAAKC,YAAL,CAAkBL,MAAlB,EAA0BC,IAA1B,EAAgCC,MAAhC,EAAwCC,IAAxC,CAAd;AACA;AACA,SAAO,IAAIG,OAAJ,CAAY,UAASC,OAAT,EAAkBC,MAAlB,EAA0B;AAC3C,QAAIC,cAAczB,MAAMoB,OAAN,CAAcA,OAAd,EAAuB,UAASM,GAAT,EAAc;AACrD,UAAIC,OAAO,EAAX;AACAD,UAAIE,EAAJ,CAAO,MAAP,EAAe,UAASC,KAAT,EAAgB;AAC7BF,gBAAQE,KAAR;AACD,OAFD;AAGAH,UAAIE,EAAJ,CAAO,KAAP,EAAc,YAAW;AACvBD,eAAOG,KAAKC,KAAL,CAAWJ,IAAX,CAAP;AACAJ,gBAAQI,IAAR;AACD,OAHD;AAID,KATiB,EASfC,EATe,CASZ,OATY,EASH,YAAW;AACxBJ,aAAO,iCAAP;AACD,KAXiB,CAAlB;AAYA,QAAIJ,QAAQD,IAAZ,EAAkB;AAChBM,kBAAYO,KAAZ,CAAkBZ,QAAQD,IAA1B;AACD;AACDM,gBAAYQ,GAAZ;AACD,GAjBM,CAAP;AAkBD,CAtBD;;AAwBA7B,MAAMU,SAAN,CAAgBO,YAAhB,GAA+B,UAASL,MAAT,EAAiBC,IAAjB,EAAuBC,MAAvB,EAA+BC,IAA/B,EAAqC;AAClE,MAAIF,KAAKiB,OAAL,CAAa,GAAb,KAAqB,CAAzB,EAA4B;AAC1BjB,WAAO,MAAMA,IAAb;AACD;AACD,MAAIC,UAAUiB,OAAOC,IAAP,CAAYlB,MAAZ,EAAoBmB,MAApB,GAA6B,CAA3C,EAA8C;AAC5CpB,YAAQ,MAAMb,MAAMkC,oBAAN,CAA2BpB,MAA3B,CAAd;AACD;;AAED,MAAIE,UAAU;AACZR,UAAQ,KAAKA,IADD;AAEZK,UAAOA,IAFK;AAGZD,YAAQA,OAAOuB,WAAP;AAHI,GAAd;;AAMA,MAAI1B,eAAe,KAAKA,YAAL,IAAqB,EAAxC;AACAA,eAAa2B,kBAAb,GAAkC,KAAKhC,YAAvC;AACA,MAAG,KAAKE,UAAR,EAAmB;AACjBG,iBAAa,aAAb,IAA8B,KAAKH,UAAnC;AACD;;AAEDU,YAAUhB,MAAMqC,WAAN,CAAkBrB,OAAlB,EAA2BP,YAA3B,EAAyC,KAAKJ,eAA9C,EAAgE,KAAKE,iBAArE,CAAV;;AAEA,MAAIQ,QAAQgB,OAAOC,IAAP,CAAYjB,IAAZ,EAAkBkB,MAAlB,GAA2B,CAAvC,EAA0C;AACxCjB,YAAQD,IAAR,GAAef,MAAMkC,oBAAN,CAA2BnB,IAA3B,CAAf;AACD;AACD,SAAOC,OAAP;AACD,CA1BD;;AA4BAhB,MAAMU,SAAN,CAAgB4B,GAAhB,GAAsB,UAASzB,IAAT,EAAeC,MAAf,EAAuB;AAC3C,SAAO,KAAKH,IAAL,CAAU,KAAV,EAAiBE,IAAjB,EAAuBC,MAAvB,CAAP;AACD,CAFD;;AAIAd,MAAMU,SAAN,CAAgB6B,IAAhB,GAAuB,UAAS1B,IAAT,EAAeC,MAAf,EAAuBC,IAAvB,EAA6B;AAClD,SAAO,KAAKJ,IAAL,CAAU,MAAV,EAAkBE,IAAlB,EAAwBC,MAAxB,EAAgCC,IAAhC,CAAP;AACD,CAFD;;AAIA;;;AAGAf,MAAMwC,MAAN,GAAe,UAASC,GAAT,EAAc;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEAA,QAAM,CAACA,MAAM,EAAP,EACHC,QADG,EAAN;;AAGA;AACA;AACA,SAAOC,mBAAmBF,GAAnB,EACJG,OADI,CACI,IADJ,EACU,KADV,EAEJA,OAFI,CAEI,IAFJ,EAEU,KAFV,EAGJA,OAHI,CAGI,KAHJ,EAGW,KAHX,EAIJA,OAJI,CAII,KAJJ,EAIW,KAJX,EAKJA,OALI,CAKI,KALJ,EAKW,KALX,CAAP;AAMD,CAjCD;;AAmCA5C,MAAM6C,eAAN,GAAwB,WAAxB;AACA7C,MAAM8C,OAAN,GAAgB,KAAhB;;AAEA;;;AAGA9C,MAAM+C,KAAN,GAAc,YAAU;AACtB,MAAIC,OAAO,EAAX;AACA,MAAIC,WAAW,gEAAf;;AAEA,OAAI,IAAIC,IAAI,CAAZ,EAAeA,IAAI,EAAnB,EAAuBA,GAAvB,EACEF,QAAQC,SAASE,MAAT,CAAgBC,KAAKC,KAAL,CAAWD,KAAKE,MAAL,KAAgBL,SAAShB,MAApC,CAAhB,CAAR;;AAEF,SAAOe,IAAP;AACD,CARD;;AAUAhD,MAAMkC,oBAAN,GAA6B,UAASqB,GAAT,EAAa;AACxC;AACA,MAAIA,GAAJ,EAAS;AACP,QAAIvB,OAAOD,OAAOC,IAAP,CAAYuB,GAAZ,EAAiBC,IAAjB,EAAX;;AAEA;AACA,WAAOxB,KAAKyB,GAAL,CAAS,UAASC,GAAT,EAAa;AAC3B,aAAOA,MAAM,GAAN,GAAY1D,MAAMwC,MAAN,CAAae,IAAIG,GAAJ,CAAb,CAAnB;AACD,KAFM,EAEJC,IAFI,CAEC,GAFD,CAAP;AAGD;;AAED,SAAO,EAAP;AACD,CAZD;;AAcA;;;;AAIA3D,MAAM4D,oBAAN,GAA6B,UAAShD,MAAT,EAAiBiD,GAAjB,EAAsBC,UAAtB,EAAiC;AAC5D,SAAO,CAAClD,OAAOuB,WAAP,EAAD,EAAuBnC,MAAMwC,MAAN,CAAaqB,GAAb,CAAvB,EAA0C7D,MAAMwC,MAAN,CAAasB,UAAb,CAA1C,EAAoEH,IAApE,CAAyE,GAAzE,CAAP;AACD,CAFD;;AAIA;;;AAGA3D,MAAM+D,SAAN,GAAkB,UAASf,IAAT,EAAeU,GAAf,EAAmB;AACnC5D,WAASD,QAAQ,QAAR,CAAT;AACA,SAAOG,MAAMwC,MAAN,CAAa1C,OAAOkE,UAAP,CAAkB,MAAlB,EAA0BN,GAA1B,EAA+BO,MAA/B,CAAsCjB,IAAtC,EAA4CkB,MAA5C,CAAmD,QAAnD,CAAb,CAAP;AACD,CAHD;;AAKAlE,MAAMqC,WAAN,GAAoB,UAASrB,OAAT,EAAkBmD,gBAAlB,EAAoC9D,eAApC,EAAqDE,iBAArD,EAAuE;AACzF4D,qBAAmBA,oBAAoB,EAAvC;;AAEA;AACA,MAAI,CAACA,iBAAiBC,WAAtB,EAAmC;AACjCD,qBAAiBC,WAAjB,GAA+BpE,MAAM+C,KAAN,EAA/B;AACD;AACD,MAAI,CAACoB,iBAAiBE,eAAtB,EAAuC;AACrCF,qBAAiBE,eAAjB,GAAmCjB,KAAKC,KAAL,CAAW,IAAIiB,IAAJ,GAAWC,OAAX,KAAuB,IAAlC,CAAnC;AACD;AACD,MAAI,CAACJ,iBAAiBK,sBAAtB,EAA8C;AAC5CL,qBAAiBK,sBAAjB,GAA0CxE,MAAM6C,eAAhD;AACD;AACD,MAAI,CAACsB,iBAAiBM,aAAtB,EAAqC;AACnCN,qBAAiBM,aAAjB,GAAiCzE,MAAM8C,OAAvC;AACD;;AAED,MAAG,CAACvC,iBAAJ,EAAsB;AACpBA,wBAAoB,EAApB;AACD;AACD;AACA,MAAI,CAACS,QAAQJ,MAAb,EAAqB;AACnBI,YAAQJ,MAAR,GAAiB,KAAjB;AACD;;AAED;AACA,MAAI8D,kBAAkB,EAAtB;AACA,MAAIC,oBAAoB,CAAC3D,QAAQF,MAAT,EAAiBE,QAAQD,IAAzB,EAA+BoD,gBAA/B,CAAxB;AACA,OAAI,IAAIjB,CAAR,IAAayB,iBAAb,EAAgC;AAC9B,QAAIb,aAAaa,kBAAkBzB,CAAlB,CAAjB;AACA,SAAI,IAAI0B,CAAR,IAAad,UAAb,EAAyB;AACvBY,sBAAgBE,CAAhB,IAAqBd,WAAWc,CAAX,CAArB;AACD;AACF;;AAED;AACA,MAAIC,kBAAkB7E,MAAMkC,oBAAN,CAA2BwC,eAA3B,CAAtB;;AAEA;AACA,MAAIb,MAAM,aAAa7C,QAAQR,IAArB,GAA4B,EAA5B,GAAiCQ,QAAQH,IAAnD;;AAEA,MAAIiE,kBAAkB9E,MAAM4D,oBAAN,CAA2B5C,QAAQJ,MAAnC,EAA2CiD,GAA3C,EAAgDgB,eAAhD,CAAtB;AACA;AACA,MAAIE,eAAe,CAAC/E,MAAMwC,MAAN,CAAanC,eAAb,CAAD,EAAgCL,MAAMwC,MAAN,CAAajC,iBAAb,CAAhC,EAAiEoD,IAAjE,CAAsE,GAAtE,CAAnB;;AAEA,MAAII,YAAY/D,MAAM+D,SAAN,CAAgBe,eAAhB,EAAiCC,YAAjC,CAAhB;;AAEA;AACAZ,mBAAiBa,eAAjB,GAAmCjB,SAAnC;AACA,MAAG,CAAC/C,QAAQiE,OAAZ,EAAoB;AAClBjE,YAAQiE,OAAR,GAAkB,EAAlB;AACD;;AAED;AACA,MAAIC,aAAanD,OAAOC,IAAP,CAAYmC,gBAAZ,EAA8BX,IAA9B,GAAqCC,GAArC,CAAyC,UAASC,GAAT,EAAa;AACrE,QAAIyB,QAAQhB,iBAAiBT,GAAjB,CAAZ;AACA,WAAOA,MAAM,IAAN,GAAayB,KAAb,GAAqB,GAA5B;AACD,GAHgB,EAGdxB,IAHc,CAGT,IAHS,CAAjB;;AAKA3C,UAAQiE,OAAR,CAAgBG,aAAhB,GAAgC,WAAWF,UAA3C;;AAEA;AACAlE,UAAQiE,OAAR,CAAgB,cAAhB,IAAkC,mCAAlC;AACA,SAAOjE,OAAP;AAED,CAjED;;AAmEAqE,OAAOC,OAAP,GAAiBtF,KAAjB","file":"OAuth1Client.js","sourcesContent":["var https = require('https'),\n  crypto = require('crypto');\nvar Parse = require('parse/node').Parse;\n\nvar OAuth = function(options) {\n  if(!options) {\n    throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'No options passed to OAuth');\n  }\n  this.consumer_key = options.consumer_key;\n  this.consumer_secret = options.consumer_secret;\n  this.auth_token = options.auth_token;\n  this.auth_token_secret = options.auth_token_secret;\n  this.host = options.host;\n  this.oauth_params = options.oauth_params || {};\n};\n\nOAuth.prototype.send = function(method, path, params, body){\n\n  var request = this.buildRequest(method, path, params, body);\n  // Encode the body properly, the current Parse Implementation don't do it properly\n  return new Promise(function(resolve, reject) {\n    var httpRequest = https.request(request, function(res) {\n      var data = '';\n      res.on('data', function(chunk) {\n        data += chunk;\n      });\n      res.on('end', function() {\n        data = JSON.parse(data);\n        resolve(data);\n      });\n    }).on('error', function() {\n      reject('Failed to make an OAuth request');\n    });\n    if (request.body) {\n      httpRequest.write(request.body);\n    }\n    httpRequest.end();\n  });\n};\n\nOAuth.prototype.buildRequest = function(method, path, params, body) {\n  if (path.indexOf(\"/\") != 0) {\n    path = \"/\" + path;\n  }\n  if (params && Object.keys(params).length > 0) {\n    path += \"?\" + OAuth.buildParameterString(params);\n  }\n\n  var request = {\n    host:   this.host,\n    path: \tpath,\n    method: method.toUpperCase()\n  };\n\n  var oauth_params = this.oauth_params || {};\n  oauth_params.oauth_consumer_key = this.consumer_key;\n  if(this.auth_token){\n    oauth_params[\"oauth_token\"] = this.auth_token;\n  }\n\n  request = OAuth.signRequest(request, oauth_params, this.consumer_secret,  this.auth_token_secret);\n\n  if (body && Object.keys(body).length > 0) {\n    request.body = OAuth.buildParameterString(body);\n  }\n  return request;\n}\n\nOAuth.prototype.get = function(path, params) {\n  return this.send(\"GET\", path, params);\n}\n\nOAuth.prototype.post = function(path, params, body) {\n  return this.send(\"POST\", path, params, body);\n}\n\n/*\n\tProper string %escape encoding\n*/\nOAuth.encode = function(str) {\n  //       discuss at: http://phpjs.org/functions/rawurlencode/\n  //      original by: Brett Zamir (http://brett-zamir.me)\n  //         input by: travc\n  //         input by: Brett Zamir (http://brett-zamir.me)\n  //         input by: Michael Grier\n  //         input by: Ratheous\n  //      bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)\n  //      bugfixed by: Brett Zamir (http://brett-zamir.me)\n  //      bugfixed by: Joris\n  // reimplemented by: Brett Zamir (http://brett-zamir.me)\n  // reimplemented by: Brett Zamir (http://brett-zamir.me)\n  //             note: This reflects PHP 5.3/6.0+ behavior\n  //             note: Please be aware that this function expects to encode into UTF-8 encoded strings, as found on\n  //             note: pages served as UTF-8\n  //        example 1: rawurlencode('Kevin van Zonneveld!');\n  //        returns 1: 'Kevin%20van%20Zonneveld%21'\n  //        example 2: rawurlencode('http://kevin.vanzonneveld.net/');\n  //        returns 2: 'http%3A%2F%2Fkevin.vanzonneveld.net%2F'\n  //        example 3: rawurlencode('http://www.google.nl/search?q=php.js&ie=utf-8&oe=utf-8&aq=t&rls=com.ubuntu:en-US:unofficial&client=firefox-a');\n  //        returns 3: 'http%3A%2F%2Fwww.google.nl%2Fsearch%3Fq%3Dphp.js%26ie%3Dutf-8%26oe%3Dutf-8%26aq%3Dt%26rls%3Dcom.ubuntu%3Aen-US%3Aunofficial%26client%3Dfirefox-a'\n\n  str = (str + '')\n    .toString();\n\n  // Tilde should be allowed unescaped in future versions of PHP (as reflected below), but if you want to reflect current\n  // PHP behavior, you would need to add \".replace(/~/g, '%7E');\" to the following.\n  return encodeURIComponent(str)\n    .replace(/!/g, '%21')\n    .replace(/'/g, '%27')\n    .replace(/\\(/g, '%28')\n    .replace(/\\)/g, '%29')\n    .replace(/\\*/g, '%2A');\n}\n\nOAuth.signatureMethod = \"HMAC-SHA1\";\nOAuth.version = \"1.0\";\n\n/*\n\tGenerate a nonce\n*/\nOAuth.nonce = function(){\n  var text = \"\";\n  var possible = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\";\n\n  for(var i = 0; i < 30; i++)\n    text += possible.charAt(Math.floor(Math.random() * possible.length));\n\n  return text;\n}\n\nOAuth.buildParameterString = function(obj){\n  // Sort keys and encode values\n  if (obj) {\n    var keys = Object.keys(obj).sort();\n\n    // Map key=value, join them by &\n    return keys.map(function(key){\n      return key + \"=\" + OAuth.encode(obj[key]);\n    }).join(\"&\");\n  }\n\n  return \"\";\n}\n\n/*\n\tBuild the signature string from the object\n*/\n\nOAuth.buildSignatureString = function(method, url, parameters){\n  return [method.toUpperCase(), OAuth.encode(url), OAuth.encode(parameters)].join(\"&\");\n}\n\n/*\n\tRetuns encoded HMAC-SHA1 from key and text\n*/\nOAuth.signature = function(text, key){\n  crypto = require(\"crypto\");\n  return OAuth.encode(crypto.createHmac('sha1', key).update(text).digest('base64'));\n}\n\nOAuth.signRequest = function(request, oauth_parameters, consumer_secret, auth_token_secret){\n  oauth_parameters = oauth_parameters || {};\n\n  // Set default values\n  if (!oauth_parameters.oauth_nonce) {\n    oauth_parameters.oauth_nonce = OAuth.nonce();\n  }\n  if (!oauth_parameters.oauth_timestamp) {\n    oauth_parameters.oauth_timestamp = Math.floor(new Date().getTime() / 1000);\n  }\n  if (!oauth_parameters.oauth_signature_method) {\n    oauth_parameters.oauth_signature_method = OAuth.signatureMethod;\n  }\n  if (!oauth_parameters.oauth_version) {\n    oauth_parameters.oauth_version = OAuth.version;\n  }\n\n  if(!auth_token_secret){\n    auth_token_secret = \"\";\n  }\n  // Force GET method if unset\n  if (!request.method) {\n    request.method = \"GET\"\n  }\n\n  // Collect  all the parameters in one signatureParameters object\n  var signatureParams = {};\n  var parametersToMerge = [request.params, request.body, oauth_parameters];\n  for(var i in parametersToMerge) {\n    var parameters = parametersToMerge[i];\n    for(var k in parameters) {\n      signatureParams[k] = parameters[k];\n    }\n  }\n\n  // Create a string based on the parameters\n  var parameterString = OAuth.buildParameterString(signatureParams);\n\n  // Build the signature string\n  var url = \"https://\" + request.host + \"\" + request.path;\n\n  var signatureString = OAuth.buildSignatureString(request.method, url, parameterString);\n  // Hash the signature string\n  var signatureKey = [OAuth.encode(consumer_secret), OAuth.encode(auth_token_secret)].join(\"&\");\n\n  var signature = OAuth.signature(signatureString, signatureKey);\n\n  // Set the signature in the params\n  oauth_parameters.oauth_signature = signature;\n  if(!request.headers){\n    request.headers = {};\n  }\n\n  // Set the authorization header\n  var authHeader = Object.keys(oauth_parameters).sort().map(function(key){\n    var value = oauth_parameters[key];\n    return key + '=\"' + value + '\"';\n  }).join(\", \")\n\n  request.headers.Authorization = 'OAuth ' + authHeader;\n\n  // Set the content type header\n  request.headers[\"Content-Type\"] = \"application/x-www-form-urlencoded\";\n  return request;\n\n}\n\nmodule.exports = OAuth;\n"]}
204
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["https","require","crypto","Parse","OAuth","options","Error","INTERNAL_SERVER_ERROR","consumer_key","consumer_secret","auth_token","auth_token_secret","host","oauth_params","prototype","send","method","path","params","body","request","buildRequest","Promise","resolve","reject","httpRequest","res","data","on","chunk","JSON","parse","write","end","indexOf","Object","keys","length","buildParameterString","toUpperCase","oauth_consumer_key","signRequest","get","post","encode","str","toString","encodeURIComponent","replace","signatureMethod","version","nonce","text","possible","i","charAt","Math","floor","random","obj","sort","map","key","join","buildSignatureString","url","parameters","signature","createHmac","update","digest","oauth_parameters","oauth_nonce","oauth_timestamp","Date","getTime","oauth_signature_method","oauth_version","signatureParams","parametersToMerge","k","parameterString","signatureString","signatureKey","oauth_signature","headers","authHeader","value","Authorization","module","exports"],"sources":["../../../src/Adapters/Auth/OAuth1Client.js"],"sourcesContent":["var https = require('https'),\n  crypto = require('crypto');\nvar Parse = require('parse/node').Parse;\n\nvar OAuth = function (options) {\n  if (!options) {\n    throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'No options passed to OAuth');\n  }\n  this.consumer_key = options.consumer_key;\n  this.consumer_secret = options.consumer_secret;\n  this.auth_token = options.auth_token;\n  this.auth_token_secret = options.auth_token_secret;\n  this.host = options.host;\n  this.oauth_params = options.oauth_params || {};\n};\n\nOAuth.prototype.send = function (method, path, params, body) {\n  var request = this.buildRequest(method, path, params, body);\n  // Encode the body properly, the current Parse Implementation don't do it properly\n  return new Promise(function (resolve, reject) {\n    var httpRequest = https\n      .request(request, function (res) {\n        var data = '';\n        res.on('data', function (chunk) {\n          data += chunk;\n        });\n        res.on('end', function () {\n          data = JSON.parse(data);\n          resolve(data);\n        });\n      })\n      .on('error', function () {\n        reject('Failed to make an OAuth request');\n      });\n    if (request.body) {\n      httpRequest.write(request.body);\n    }\n    httpRequest.end();\n  });\n};\n\nOAuth.prototype.buildRequest = function (method, path, params, body) {\n  if (path.indexOf('/') != 0) {\n    path = '/' + path;\n  }\n  if (params && Object.keys(params).length > 0) {\n    path += '?' + OAuth.buildParameterString(params);\n  }\n\n  var request = {\n    host: this.host,\n    path: path,\n    method: method.toUpperCase(),\n  };\n\n  var oauth_params = this.oauth_params || {};\n  oauth_params.oauth_consumer_key = this.consumer_key;\n  if (this.auth_token) {\n    oauth_params['oauth_token'] = this.auth_token;\n  }\n\n  request = OAuth.signRequest(request, oauth_params, this.consumer_secret, this.auth_token_secret);\n\n  if (body && Object.keys(body).length > 0) {\n    request.body = OAuth.buildParameterString(body);\n  }\n  return request;\n};\n\nOAuth.prototype.get = function (path, params) {\n  return this.send('GET', path, params);\n};\n\nOAuth.prototype.post = function (path, params, body) {\n  return this.send('POST', path, params, body);\n};\n\n/*\n\tProper string %escape encoding\n*/\nOAuth.encode = function (str) {\n  //       discuss at: http://phpjs.org/functions/rawurlencode/\n  //      original by: Brett Zamir (http://brett-zamir.me)\n  //         input by: travc\n  //         input by: Brett Zamir (http://brett-zamir.me)\n  //         input by: Michael Grier\n  //         input by: Ratheous\n  //      bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)\n  //      bugfixed by: Brett Zamir (http://brett-zamir.me)\n  //      bugfixed by: Joris\n  // reimplemented by: Brett Zamir (http://brett-zamir.me)\n  // reimplemented by: Brett Zamir (http://brett-zamir.me)\n  //             note: This reflects PHP 5.3/6.0+ behavior\n  //             note: Please be aware that this function expects to encode into UTF-8 encoded strings, as found on\n  //             note: pages served as UTF-8\n  //        example 1: rawurlencode('Kevin van Zonneveld!');\n  //        returns 1: 'Kevin%20van%20Zonneveld%21'\n  //        example 2: rawurlencode('http://kevin.vanzonneveld.net/');\n  //        returns 2: 'http%3A%2F%2Fkevin.vanzonneveld.net%2F'\n  //        example 3: rawurlencode('http://www.google.nl/search?q=php.js&ie=utf-8&oe=utf-8&aq=t&rls=com.ubuntu:en-US:unofficial&client=firefox-a');\n  //        returns 3: 'http%3A%2F%2Fwww.google.nl%2Fsearch%3Fq%3Dphp.js%26ie%3Dutf-8%26oe%3Dutf-8%26aq%3Dt%26rls%3Dcom.ubuntu%3Aen-US%3Aunofficial%26client%3Dfirefox-a'\n\n  str = (str + '').toString();\n\n  // Tilde should be allowed unescaped in future versions of PHP (as reflected below), but if you want to reflect current\n  // PHP behavior, you would need to add \".replace(/~/g, '%7E');\" to the following.\n  return encodeURIComponent(str)\n    .replace(/!/g, '%21')\n    .replace(/'/g, '%27')\n    .replace(/\\(/g, '%28')\n    .replace(/\\)/g, '%29')\n    .replace(/\\*/g, '%2A');\n};\n\nOAuth.signatureMethod = 'HMAC-SHA1';\nOAuth.version = '1.0';\n\n/*\n\tGenerate a nonce\n*/\nOAuth.nonce = function () {\n  var text = '';\n  var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n\n  for (var i = 0; i < 30; i++) { text += possible.charAt(Math.floor(Math.random() * possible.length)); }\n\n  return text;\n};\n\nOAuth.buildParameterString = function (obj) {\n  // Sort keys and encode values\n  if (obj) {\n    var keys = Object.keys(obj).sort();\n\n    // Map key=value, join them by &\n    return keys\n      .map(function (key) {\n        return key + '=' + OAuth.encode(obj[key]);\n      })\n      .join('&');\n  }\n\n  return '';\n};\n\n/*\n\tBuild the signature string from the object\n*/\n\nOAuth.buildSignatureString = function (method, url, parameters) {\n  return [method.toUpperCase(), OAuth.encode(url), OAuth.encode(parameters)].join('&');\n};\n\n/*\n\tRetuns encoded HMAC-SHA1 from key and text\n*/\nOAuth.signature = function (text, key) {\n  crypto = require('crypto');\n  return OAuth.encode(crypto.createHmac('sha1', key).update(text).digest('base64'));\n};\n\nOAuth.signRequest = function (request, oauth_parameters, consumer_secret, auth_token_secret) {\n  oauth_parameters = oauth_parameters || {};\n\n  // Set default values\n  if (!oauth_parameters.oauth_nonce) {\n    oauth_parameters.oauth_nonce = OAuth.nonce();\n  }\n  if (!oauth_parameters.oauth_timestamp) {\n    oauth_parameters.oauth_timestamp = Math.floor(new Date().getTime() / 1000);\n  }\n  if (!oauth_parameters.oauth_signature_method) {\n    oauth_parameters.oauth_signature_method = OAuth.signatureMethod;\n  }\n  if (!oauth_parameters.oauth_version) {\n    oauth_parameters.oauth_version = OAuth.version;\n  }\n\n  if (!auth_token_secret) {\n    auth_token_secret = '';\n  }\n  // Force GET method if unset\n  if (!request.method) {\n    request.method = 'GET';\n  }\n\n  // Collect  all the parameters in one signatureParameters object\n  var signatureParams = {};\n  var parametersToMerge = [request.params, request.body, oauth_parameters];\n  for (var i in parametersToMerge) {\n    var parameters = parametersToMerge[i];\n    for (var k in parameters) {\n      signatureParams[k] = parameters[k];\n    }\n  }\n\n  // Create a string based on the parameters\n  var parameterString = OAuth.buildParameterString(signatureParams);\n\n  // Build the signature string\n  var url = 'https://' + request.host + '' + request.path;\n\n  var signatureString = OAuth.buildSignatureString(request.method, url, parameterString);\n  // Hash the signature string\n  var signatureKey = [OAuth.encode(consumer_secret), OAuth.encode(auth_token_secret)].join('&');\n\n  var signature = OAuth.signature(signatureString, signatureKey);\n\n  // Set the signature in the params\n  oauth_parameters.oauth_signature = signature;\n  if (!request.headers) {\n    request.headers = {};\n  }\n\n  // Set the authorization header\n  var authHeader = Object.keys(oauth_parameters)\n    .sort()\n    .map(function (key) {\n      var value = oauth_parameters[key];\n      return key + '=\"' + value + '\"';\n    })\n    .join(', ');\n\n  request.headers.Authorization = 'OAuth ' + authHeader;\n\n  // Set the content type header\n  request.headers['Content-Type'] = 'application/x-www-form-urlencoded';\n  return request;\n};\n\nmodule.exports = OAuth;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,123 @@
1
+ "use strict";
2
+
3
+ /**
4
+ * Parse Server authentication adapter for Apple.
5
+ *
6
+ * @class AppleAdapter
7
+ * @param {Object} options - Configuration options for the adapter.
8
+ * @param {string} options.clientId - Your Apple App ID.
9
+ *
10
+ * @param {Object} authData - The authentication data provided by the client.
11
+ * @param {string} authData.id - The user ID obtained from Apple.
12
+ * @param {string} authData.token - The token obtained from Apple.
13
+ *
14
+ * @description
15
+ * ## Parse Server Configuration
16
+ * To configure Parse Server for Apple authentication, use the following structure:
17
+ * ```json
18
+ * {
19
+ * "auth": {
20
+ * "apple": {
21
+ * "clientId": "12345"
22
+ * }
23
+ * }
24
+ * }
25
+ * ```
26
+ *
27
+ * ## Expected `authData` from the Client
28
+ * The adapter expects the client to provide the following `authData` payload:
29
+ * - `authData.id` (**string**, required): The user ID obtained from Apple.
30
+ * - `authData.token` (**string**, required): The token obtained from Apple.
31
+ *
32
+ * Parse Server stores the required authentication data in the database.
33
+ *
34
+ * ### Example AuthData from Apple
35
+ * ```json
36
+ * {
37
+ * "apple": {
38
+ * "id": "1234567",
39
+ * "token": "xxxxx.yyyyy.zzzzz"
40
+ * }
41
+ * }
42
+ * ```
43
+ *
44
+ * @see {@link https://developer.apple.com/documentation/signinwithapplerestapi Sign in with Apple REST API Documentation}
45
+ */
46
+
47
+ // Apple SignIn Auth
48
+ // https://developer.apple.com/documentation/signinwithapplerestapi
49
+
50
+ const Parse = require('parse/node').Parse;
51
+ const jwksClient = require('jwks-rsa');
52
+ const jwt = require('jsonwebtoken');
53
+ const authUtils = require('./utils');
54
+ const TOKEN_ISSUER = 'https://appleid.apple.com';
55
+ const getAppleKeyByKeyId = async (keyId, cacheMaxEntries, cacheMaxAge) => {
56
+ const client = jwksClient({
57
+ jwksUri: `${TOKEN_ISSUER}/auth/keys`,
58
+ cache: true,
59
+ cacheMaxEntries,
60
+ cacheMaxAge
61
+ });
62
+ let key;
63
+ try {
64
+ key = await authUtils.getSigningKey(client, keyId);
65
+ } catch {
66
+ throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `Unable to find matching key for Key ID: ${keyId}`);
67
+ }
68
+ return key;
69
+ };
70
+ const verifyIdToken = async ({
71
+ token,
72
+ id
73
+ }, {
74
+ clientId,
75
+ cacheMaxEntries,
76
+ cacheMaxAge
77
+ }) => {
78
+ if (!token) {
79
+ throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `id token is invalid for this user.`);
80
+ }
81
+ const {
82
+ kid: keyId,
83
+ alg: algorithm
84
+ } = authUtils.getHeaderFromToken(token);
85
+ const ONE_HOUR_IN_MS = 3600000;
86
+ let jwtClaims;
87
+ cacheMaxAge = cacheMaxAge || ONE_HOUR_IN_MS;
88
+ cacheMaxEntries = cacheMaxEntries || 5;
89
+ const appleKey = await getAppleKeyByKeyId(keyId, cacheMaxEntries, cacheMaxAge);
90
+ const signingKey = appleKey.publicKey || appleKey.rsaPublicKey;
91
+ try {
92
+ jwtClaims = jwt.verify(token, signingKey, {
93
+ algorithms: algorithm,
94
+ // the audience can be checked against a string, a regular expression or a list of strings and/or regular expressions.
95
+ audience: clientId
96
+ });
97
+ } catch (exception) {
98
+ const message = exception.message;
99
+ throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `${message}`);
100
+ }
101
+ if (jwtClaims.iss !== TOKEN_ISSUER) {
102
+ throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `id token not issued by correct OpenID provider - expected: ${TOKEN_ISSUER} | from: ${jwtClaims.iss}`);
103
+ }
104
+ if (jwtClaims.sub !== id) {
105
+ throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `auth data is invalid for this user.`);
106
+ }
107
+ return jwtClaims;
108
+ };
109
+
110
+ // Returns a promise that fulfills if this id token is valid
111
+ function validateAuthData(authData, options = {}) {
112
+ return verifyIdToken(authData, options);
113
+ }
114
+
115
+ // Returns a promise that fulfills if this app id is valid.
116
+ function validateAppId() {
117
+ return Promise.resolve();
118
+ }
119
+ module.exports = {
120
+ validateAppId,
121
+ validateAuthData
122
+ };
123
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","jwksClient","jwt","authUtils","TOKEN_ISSUER","getAppleKeyByKeyId","keyId","cacheMaxEntries","cacheMaxAge","client","jwksUri","cache","key","getSigningKey","Error","OBJECT_NOT_FOUND","verifyIdToken","token","id","clientId","kid","alg","algorithm","getHeaderFromToken","ONE_HOUR_IN_MS","jwtClaims","appleKey","signingKey","publicKey","rsaPublicKey","verify","algorithms","audience","exception","message","iss","sub","validateAuthData","authData","options","validateAppId","Promise","resolve","module","exports"],"sources":["../../../src/Adapters/Auth/apple.js"],"sourcesContent":["/**\n * Parse Server authentication adapter for Apple.\n *\n * @class AppleAdapter\n * @param {Object} options - Configuration options for the adapter.\n * @param {string} options.clientId - Your Apple App ID.\n *\n * @param {Object} authData - The authentication data provided by the client.\n * @param {string} authData.id - The user ID obtained from Apple.\n * @param {string} authData.token - The token obtained from Apple.\n *\n * @description\n * ## Parse Server Configuration\n * To configure Parse Server for Apple authentication, use the following structure:\n * ```json\n * {\n *   \"auth\": {\n *     \"apple\": {\n *       \"clientId\": \"12345\"\n *     }\n *   }\n * }\n * ```\n *\n * ## Expected `authData` from the Client\n * The adapter expects the client to provide the following `authData` payload:\n * - `authData.id` (**string**, required): The user ID obtained from Apple.\n * - `authData.token` (**string**, required): The token obtained from Apple.\n *\n * Parse Server stores the required authentication data in the database.\n *\n * ### Example AuthData from Apple\n * ```json\n * {\n *   \"apple\": {\n *     \"id\": \"1234567\",\n *     \"token\": \"xxxxx.yyyyy.zzzzz\"\n *   }\n * }\n * ```\n *\n * @see {@link https://developer.apple.com/documentation/signinwithapplerestapi Sign in with Apple REST API Documentation}\n */\n\n// Apple SignIn Auth\n// https://developer.apple.com/documentation/signinwithapplerestapi\n\nconst Parse = require('parse/node').Parse;\nconst jwksClient = require('jwks-rsa');\nconst jwt = require('jsonwebtoken');\nconst authUtils = require('./utils');\n\nconst TOKEN_ISSUER = 'https://appleid.apple.com';\n\nconst getAppleKeyByKeyId = async (keyId, cacheMaxEntries, cacheMaxAge) => {\n  const client = jwksClient({\n    jwksUri: `${TOKEN_ISSUER}/auth/keys`,\n    cache: true,\n    cacheMaxEntries,\n    cacheMaxAge,\n  });\n\n  let key;\n  try {\n    key = await authUtils.getSigningKey(client, keyId);\n  } catch {\n    throw new Parse.Error(\n      Parse.Error.OBJECT_NOT_FOUND,\n      `Unable to find matching key for Key ID: ${keyId}`\n    );\n  }\n  return key;\n};\n\nconst verifyIdToken = async ({ token, id }, { clientId, cacheMaxEntries, cacheMaxAge }) => {\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  const ONE_HOUR_IN_MS = 3600000;\n  let jwtClaims;\n\n  cacheMaxAge = cacheMaxAge || ONE_HOUR_IN_MS;\n  cacheMaxEntries = cacheMaxEntries || 5;\n\n  const appleKey = await getAppleKeyByKeyId(keyId, cacheMaxEntries, cacheMaxAge);\n  const signingKey = appleKey.publicKey || appleKey.rsaPublicKey;\n\n  try {\n    jwtClaims = jwt.verify(token, signingKey, {\n      algorithms: algorithm,\n      // the audience can be checked against a string, a regular expression or a list of strings and/or regular expressions.\n      audience: clientId,\n    });\n  } catch (exception) {\n    const message = exception.message;\n\n    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, `${message}`);\n  }\n\n  if (jwtClaims.iss !== TOKEN_ISSUER) {\n    throw new Parse.Error(\n      Parse.Error.OBJECT_NOT_FOUND,\n      `id token not issued by correct OpenID provider - expected: ${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  return jwtClaims;\n};\n\n// Returns a promise that fulfills if this id token 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,\n  validateAuthData,\n};\n"],"mappings":"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","ignoreList":[]}