fiber-firebase-functions 1.0.2 → 1.0.4
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/README.md +74 -0
- package/lib/auth/is_user_disabled.js +37 -36
- package/lib/auth/is_user_disabled.js.map +1 -1
- package/lib/auth/is_user_exists.js +31 -30
- package/lib/auth/is_user_exists.js.map +1 -1
- package/lib/auth/otp.js +162 -0
- package/lib/auth/otp.js.map +1 -0
- package/lib/auth/reset_password.js +327 -0
- package/lib/auth/reset_password.js.map +1 -0
- package/lib/auth/update_password.js +18 -7
- package/lib/auth/update_password.js.map +1 -1
- package/lib/auth/user.js +44 -32
- package/lib/auth/user.js.map +1 -1
- package/lib/common/config.js +64 -0
- package/lib/common/config.js.map +1 -0
- package/lib/common/locale.js +119 -0
- package/lib/common/locale.js.map +1 -0
- package/lib/email/email.js +96 -0
- package/lib/email/email.js.map +1 -0
- package/lib/email/send_email.js +81 -0
- package/lib/email/send_email.js.map +1 -0
- package/lib/email/templates/new_user.js +491 -0
- package/lib/email/templates/new_user.js.map +1 -0
- package/lib/email/templates.js +38 -0
- package/lib/email/templates.js.map +1 -0
- package/lib/index.js +6 -0
- package/lib/index.js.map +1 -1
- package/lib/middleware/rate_limiter.js +19 -6
- package/lib/middleware/rate_limiter.js.map +1 -1
- package/package.json +6 -4
- package/src/auth/is_user_disabled.ts +31 -29
- package/src/auth/is_user_exists.ts +25 -23
- package/src/auth/otp.ts +135 -0
- package/src/auth/reset_password.ts +317 -0
- package/src/auth/user.ts +34 -24
- package/src/common/config.ts +84 -0
- package/src/common/locale.ts +121 -0
- package/src/email/email.ts +70 -0
- package/src/email/templates/new_user.ts +493 -0
- package/src/email/templates.ts +34 -0
- package/src/index.ts +6 -0
- package/src/middleware/rate_limiter.ts +25 -6
- package/src/auth/update_password.ts +0 -211
|
@@ -0,0 +1,327 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (C) 2025 Fiber
|
|
4
|
+
*
|
|
5
|
+
* All rights reserved. This script, including its code and logic, is the
|
|
6
|
+
* exclusive property of Fiber. Redistribution, reproduction,
|
|
7
|
+
* or modification of any part of this script is strictly prohibited
|
|
8
|
+
* without prior written permission from Fiber.
|
|
9
|
+
*
|
|
10
|
+
* Conditions of use:
|
|
11
|
+
* - The code may not be copied, duplicated, or used, in whole or in part,
|
|
12
|
+
* for any purpose without explicit authorization.
|
|
13
|
+
* - Redistribution of this code, with or without modification, is not
|
|
14
|
+
* permitted unless expressly agreed upon by Fiber.
|
|
15
|
+
* - The name "Fiber" and any associated branding, logos, or
|
|
16
|
+
* trademarks may not be used to endorse or promote derived products
|
|
17
|
+
* or services without prior written approval.
|
|
18
|
+
*
|
|
19
|
+
* Disclaimer:
|
|
20
|
+
* THIS SCRIPT AND ITS CODE ARE PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
|
|
21
|
+
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY,
|
|
22
|
+
* FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL
|
|
23
|
+
* FIBER BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
24
|
+
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING BUT NOT LIMITED TO LOSS OF USE,
|
|
25
|
+
* DATA, PROFITS, OR BUSINESS INTERRUPTION) ARISING OUT OF OR RELATED TO THE USE
|
|
26
|
+
* OR INABILITY TO USE THIS SCRIPT, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
27
|
+
*
|
|
28
|
+
* Unauthorized copying or reproduction of this script, in whole or in part,
|
|
29
|
+
* is a violation of applicable intellectual property laws and will result
|
|
30
|
+
* in legal action.
|
|
31
|
+
*/
|
|
32
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
33
|
+
if (k2 === undefined) k2 = k;
|
|
34
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
35
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
36
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
37
|
+
}
|
|
38
|
+
Object.defineProperty(o, k2, desc);
|
|
39
|
+
}) : (function(o, m, k, k2) {
|
|
40
|
+
if (k2 === undefined) k2 = k;
|
|
41
|
+
o[k2] = m[k];
|
|
42
|
+
}));
|
|
43
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
44
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
45
|
+
}) : function(o, v) {
|
|
46
|
+
o["default"] = v;
|
|
47
|
+
});
|
|
48
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
49
|
+
var ownKeys = function(o) {
|
|
50
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
51
|
+
var ar = [];
|
|
52
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
53
|
+
return ar;
|
|
54
|
+
};
|
|
55
|
+
return ownKeys(o);
|
|
56
|
+
};
|
|
57
|
+
return function (mod) {
|
|
58
|
+
if (mod && mod.__esModule) return mod;
|
|
59
|
+
var result = {};
|
|
60
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
61
|
+
__setModuleDefault(result, mod);
|
|
62
|
+
return result;
|
|
63
|
+
};
|
|
64
|
+
})();
|
|
65
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
66
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
67
|
+
};
|
|
68
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
69
|
+
exports.ResetPassword = exports.VerifyRequestResetPasswordOTP = exports.RequestResetPassword = exports.RequestResetPasswordByEmailStatus = exports.RequestResetPasswordByIdStatus = exports.ResetPasswordByIdStatus = exports.ResetPasswordByEmailStatus = void 0;
|
|
70
|
+
const admin = __importStar(require("firebase-admin"));
|
|
71
|
+
const validator_1 = __importDefault(require("validator"));
|
|
72
|
+
const config_1 = require("../common/config");
|
|
73
|
+
const rate_limiter_1 = require("../middleware/rate_limiter");
|
|
74
|
+
const is_user_disabled_1 = require("./is_user_disabled");
|
|
75
|
+
const is_user_exists_1 = require("./is_user_exists");
|
|
76
|
+
const otp_1 = require("./otp");
|
|
77
|
+
const user_1 = require("./user");
|
|
78
|
+
if (admin.apps.length === 0) {
|
|
79
|
+
admin.initializeApp();
|
|
80
|
+
}
|
|
81
|
+
var ResetPasswordByEmailStatus;
|
|
82
|
+
(function (ResetPasswordByEmailStatus) {
|
|
83
|
+
ResetPasswordByEmailStatus["MISSING_DATABASE_CONFIG"] = "MISSING_DATABASE_CONFIG";
|
|
84
|
+
ResetPasswordByEmailStatus["MISSING_USER_EMAIL"] = "MISSING_USER_EMAIL";
|
|
85
|
+
ResetPasswordByEmailStatus["MISSING_NEW_PASSWORD"] = "MISSING_NEW_PASSWORD";
|
|
86
|
+
ResetPasswordByEmailStatus["MISSING_CONFIRM_NEW_PASSWORD"] = "MISSING_CONFIRM_NEW_PASSWORD";
|
|
87
|
+
ResetPasswordByEmailStatus["MISSING_PASSWORD_POLICY"] = "MISSING_PASSWORD_POLICY";
|
|
88
|
+
ResetPasswordByEmailStatus["NOT_IDENTICAL_CONFIRM_PASSWORD"] = "NOT_IDENTICAL_CONFIRM_PASSWORD";
|
|
89
|
+
ResetPasswordByEmailStatus["USER_NOT_FOUND"] = "USER_NOT_FOUND";
|
|
90
|
+
ResetPasswordByEmailStatus["USER_DISABLED"] = "USER_DISABLED";
|
|
91
|
+
ResetPasswordByEmailStatus["WEAK_NEW_PASSWORD"] = "WEAK_NEW_PASSWORD";
|
|
92
|
+
ResetPasswordByEmailStatus["MISSING_PASSWORD_UPPERCASE"] = "MISSING_PASSWORD_UPPERCASE";
|
|
93
|
+
ResetPasswordByEmailStatus["MISSING_PASSWORD_LOWERCASE"] = "MISSING_PASSWORD_LOWERCASE";
|
|
94
|
+
ResetPasswordByEmailStatus["MISSING_PASSWORD_DIGIT"] = "MISSING_PASSWORD_DIGIT";
|
|
95
|
+
ResetPasswordByEmailStatus["MISSING_PASSWORD_SPECIAL_CHAR"] = "MISSING_PASSWORD_SPECIAL_CHAR";
|
|
96
|
+
ResetPasswordByEmailStatus["TOO_MANY_REQUEST"] = "TOO_MANY_REQUEST";
|
|
97
|
+
ResetPasswordByEmailStatus["INVALID_EMAIL_FORMAT"] = "INVALID_EMAIL_FORMAT";
|
|
98
|
+
ResetPasswordByEmailStatus["SUCCESS"] = "SUCCESS";
|
|
99
|
+
ResetPasswordByEmailStatus["INTERNAL_ERROR"] = "INTERNAL_ERROR";
|
|
100
|
+
})(ResetPasswordByEmailStatus || (exports.ResetPasswordByEmailStatus = ResetPasswordByEmailStatus = {}));
|
|
101
|
+
var ResetPasswordByIdStatus;
|
|
102
|
+
(function (ResetPasswordByIdStatus) {
|
|
103
|
+
ResetPasswordByIdStatus["MISSING_DATABASE_CONFIG"] = "MISSING_DATABASE_CONFIG";
|
|
104
|
+
ResetPasswordByIdStatus["MISSING_USER_ID"] = "MISSING_USER_ID";
|
|
105
|
+
ResetPasswordByIdStatus["MISSING_NEW_PASSWORD"] = "MISSING_NEW_PASSWORD";
|
|
106
|
+
ResetPasswordByIdStatus["MISSING_CONFIRM_NEW_PASSWORD"] = "MISSING_CONFIRM_NEW_PASSWORD";
|
|
107
|
+
ResetPasswordByIdStatus["MISSING_PASSWORD_POLICY"] = "MISSING_PASSWORD_POLICY";
|
|
108
|
+
ResetPasswordByIdStatus["NOT_IDENTICAL_CONFIRM_PASSWORD"] = "NOT_IDENTICAL_CONFIRM_PASSWORD";
|
|
109
|
+
ResetPasswordByIdStatus["USER_NOT_FOUND"] = "USER_NOT_FOUND";
|
|
110
|
+
ResetPasswordByIdStatus["USER_DISABLED"] = "USER_DISABLED";
|
|
111
|
+
ResetPasswordByIdStatus["WEAK_NEW_PASSWORD"] = "WEAK_NEW_PASSWORD";
|
|
112
|
+
ResetPasswordByIdStatus["MISSING_PASSWORD_UPPERCASE"] = "MISSING_PASSWORD_UPPERCASE";
|
|
113
|
+
ResetPasswordByIdStatus["MISSING_PASSWORD_LOWERCASE"] = "MISSING_PASSWORD_LOWERCASE";
|
|
114
|
+
ResetPasswordByIdStatus["MISSING_PASSWORD_DIGIT"] = "MISSING_PASSWORD_DIGIT";
|
|
115
|
+
ResetPasswordByIdStatus["MISSING_PASSWORD_SPECIAL_CHAR"] = "MISSING_PASSWORD_SPECIAL_CHAR";
|
|
116
|
+
ResetPasswordByIdStatus["TOO_MANY_REQUEST"] = "TOO_MANY_REQUEST";
|
|
117
|
+
ResetPasswordByIdStatus["SUCCESS"] = "SUCCESS";
|
|
118
|
+
ResetPasswordByIdStatus["INTERNAL_ERROR"] = "INTERNAL_ERROR";
|
|
119
|
+
})(ResetPasswordByIdStatus || (exports.ResetPasswordByIdStatus = ResetPasswordByIdStatus = {}));
|
|
120
|
+
var RequestResetPasswordByIdStatus;
|
|
121
|
+
(function (RequestResetPasswordByIdStatus) {
|
|
122
|
+
RequestResetPasswordByIdStatus["MISSING_OTP_CONFIG"] = "MISSING_OTP_CONFIG";
|
|
123
|
+
RequestResetPasswordByIdStatus["MISSING_DATABASE_CONFIG"] = "MISSING_DATABASE_CONFIG";
|
|
124
|
+
RequestResetPasswordByIdStatus["MISSING_USER_ID"] = "MISSING_USER_ID";
|
|
125
|
+
RequestResetPasswordByIdStatus["TOO_MANY_REQUEST"] = "TOO_MANY_REQUEST";
|
|
126
|
+
RequestResetPasswordByIdStatus["USER_NOT_FOUND"] = "USER_NOT_FOUND";
|
|
127
|
+
RequestResetPasswordByIdStatus["USER_DISABLED"] = "USER_DISABLED";
|
|
128
|
+
RequestResetPasswordByIdStatus["SUCCESS"] = "SUCCESS";
|
|
129
|
+
RequestResetPasswordByIdStatus["INTERNAL_ERROR"] = "INTERNAL_ERROR";
|
|
130
|
+
})(RequestResetPasswordByIdStatus || (exports.RequestResetPasswordByIdStatus = RequestResetPasswordByIdStatus = {}));
|
|
131
|
+
var RequestResetPasswordByEmailStatus;
|
|
132
|
+
(function (RequestResetPasswordByEmailStatus) {
|
|
133
|
+
RequestResetPasswordByEmailStatus["MISSING_OTP_CONFIG"] = "MISSING_OTP_CONFIG";
|
|
134
|
+
RequestResetPasswordByEmailStatus["MISSING_DATABASE_CONFIG"] = "MISSING_DATABASE_CONFIG";
|
|
135
|
+
RequestResetPasswordByEmailStatus["MISSING_USER_EMAIL"] = "MISSING_USER_EMAIL";
|
|
136
|
+
RequestResetPasswordByEmailStatus["TOO_MANY_REQUEST"] = "TOO_MANY_REQUEST";
|
|
137
|
+
RequestResetPasswordByEmailStatus["USER_NOT_FOUND"] = "USER_NOT_FOUND";
|
|
138
|
+
RequestResetPasswordByEmailStatus["USER_DISABLED"] = "USER_DISABLED";
|
|
139
|
+
RequestResetPasswordByEmailStatus["INVALID_EMAIL_FORMAT"] = "INVALID_EMAIL_FORMAT";
|
|
140
|
+
RequestResetPasswordByEmailStatus["SUCCESS"] = "SUCCESS";
|
|
141
|
+
RequestResetPasswordByEmailStatus["INTERNAL_ERROR"] = "INTERNAL_ERROR";
|
|
142
|
+
})(RequestResetPasswordByEmailStatus || (exports.RequestResetPasswordByEmailStatus = RequestResetPasswordByEmailStatus = {}));
|
|
143
|
+
class RequestResetPassword {
|
|
144
|
+
static async withId(userId) {
|
|
145
|
+
const config = (0, config_1.appInitialize)();
|
|
146
|
+
const otp = config.otp;
|
|
147
|
+
const rateLimiter = config.rateLimiter;
|
|
148
|
+
if (otp.collection === undefined)
|
|
149
|
+
return RequestResetPasswordByIdStatus.MISSING_OTP_CONFIG;
|
|
150
|
+
if (rateLimiter.appName === undefined || rateLimiter.url === undefined) {
|
|
151
|
+
return RequestResetPasswordByIdStatus.MISSING_DATABASE_CONFIG;
|
|
152
|
+
}
|
|
153
|
+
userId = userId.trim();
|
|
154
|
+
if (!userId || userId === "")
|
|
155
|
+
return RequestResetPasswordByIdStatus.MISSING_USER_ID;
|
|
156
|
+
const identifier = {
|
|
157
|
+
id: userId,
|
|
158
|
+
target: "request_reset_password"
|
|
159
|
+
};
|
|
160
|
+
const rule = {
|
|
161
|
+
ttl: 2 * 60 * 1000,
|
|
162
|
+
windowMs: 3 * 60 * 1000,
|
|
163
|
+
maxHits: 5,
|
|
164
|
+
};
|
|
165
|
+
const userExists = await is_user_exists_1.IsUserExists.withId(userId);
|
|
166
|
+
if (userExists === is_user_exists_1.UserExistsByIdStatus.MISSING_USER_ID)
|
|
167
|
+
return RequestResetPasswordByIdStatus.MISSING_USER_ID;
|
|
168
|
+
if (userExists === is_user_exists_1.UserExistsByIdStatus.INTERNAL_ERROR)
|
|
169
|
+
return RequestResetPasswordByIdStatus.INTERNAL_ERROR;
|
|
170
|
+
if (userExists === is_user_exists_1.UserExistsByIdStatus.USER_NOT_FOUND)
|
|
171
|
+
return RequestResetPasswordByIdStatus.USER_NOT_FOUND;
|
|
172
|
+
const userDisabled = await is_user_disabled_1.IsUserDisabled.withId(userId);
|
|
173
|
+
if (userDisabled === is_user_disabled_1.UserDisabledByIdStatus.MISSING_USER_ID) {
|
|
174
|
+
return RequestResetPasswordByIdStatus.MISSING_USER_ID;
|
|
175
|
+
}
|
|
176
|
+
if (userDisabled === is_user_disabled_1.UserDisabledByIdStatus.INTERNAL_ERROR) {
|
|
177
|
+
return RequestResetPasswordByIdStatus.INTERNAL_ERROR;
|
|
178
|
+
}
|
|
179
|
+
if (userDisabled === is_user_disabled_1.UserDisabledByIdStatus.USER_NOT_FOUND) {
|
|
180
|
+
return RequestResetPasswordByIdStatus.USER_NOT_FOUND;
|
|
181
|
+
}
|
|
182
|
+
if (await (0, rate_limiter_1.isRateLimited)(identifier, rule) !== rate_limiter_1.RateLimitCheckStatus.LIMIT_NOT_FOUND) {
|
|
183
|
+
return RequestResetPasswordByIdStatus.TOO_MANY_REQUEST;
|
|
184
|
+
}
|
|
185
|
+
await (0, rate_limiter_1.recordRateLimitHit)(identifier, rule);
|
|
186
|
+
if (await is_user_exists_1.IsUserExists.withId(userId))
|
|
187
|
+
return RequestResetPasswordByIdStatus.USER_NOT_FOUND;
|
|
188
|
+
if (await is_user_disabled_1.IsUserDisabled.withId(userId))
|
|
189
|
+
return RequestResetPasswordByIdStatus.USER_DISABLED;
|
|
190
|
+
await otp_1.Otp.generate(userId, "request_reset_password");
|
|
191
|
+
return RequestResetPasswordByIdStatus.SUCCESS;
|
|
192
|
+
}
|
|
193
|
+
static async withEmail(email) {
|
|
194
|
+
email = email.trim();
|
|
195
|
+
if (!email || email === "")
|
|
196
|
+
return RequestResetPasswordByEmailStatus.MISSING_USER_EMAIL;
|
|
197
|
+
if (!validator_1.default.isEmail(email))
|
|
198
|
+
return RequestResetPasswordByEmailStatus.INVALID_EMAIL_FORMAT;
|
|
199
|
+
const user = await user_1.User.withEmail(email);
|
|
200
|
+
if (user.status === user_1.UserByEmailStatus.INTERNAL_ERROR)
|
|
201
|
+
return RequestResetPasswordByEmailStatus.INTERNAL_ERROR;
|
|
202
|
+
if (user.status === user_1.UserByEmailStatus.MISSING_EMAIL) {
|
|
203
|
+
return RequestResetPasswordByEmailStatus.MISSING_USER_EMAIL;
|
|
204
|
+
}
|
|
205
|
+
if (user.status === user_1.UserByEmailStatus.USER_NOT_FOUND)
|
|
206
|
+
return RequestResetPasswordByEmailStatus.USER_NOT_FOUND;
|
|
207
|
+
const userId = user.user?.uid;
|
|
208
|
+
if (!userId || userId === undefined)
|
|
209
|
+
return RequestResetPasswordByEmailStatus.INTERNAL_ERROR;
|
|
210
|
+
const result = await this.withId(userId);
|
|
211
|
+
const map = {
|
|
212
|
+
[RequestResetPasswordByIdStatus.MISSING_OTP_CONFIG]: RequestResetPasswordByEmailStatus.MISSING_OTP_CONFIG,
|
|
213
|
+
[RequestResetPasswordByIdStatus.MISSING_DATABASE_CONFIG]: RequestResetPasswordByEmailStatus.MISSING_DATABASE_CONFIG,
|
|
214
|
+
[RequestResetPasswordByIdStatus.MISSING_USER_ID]: RequestResetPasswordByEmailStatus.MISSING_USER_EMAIL,
|
|
215
|
+
[RequestResetPasswordByIdStatus.TOO_MANY_REQUEST]: RequestResetPasswordByEmailStatus.TOO_MANY_REQUEST,
|
|
216
|
+
[RequestResetPasswordByIdStatus.USER_NOT_FOUND]: RequestResetPasswordByEmailStatus.USER_NOT_FOUND,
|
|
217
|
+
[RequestResetPasswordByIdStatus.USER_DISABLED]: RequestResetPasswordByEmailStatus.USER_DISABLED,
|
|
218
|
+
[RequestResetPasswordByIdStatus.SUCCESS]: RequestResetPasswordByEmailStatus.SUCCESS,
|
|
219
|
+
[RequestResetPasswordByIdStatus.INTERNAL_ERROR]: RequestResetPasswordByEmailStatus.INTERNAL_ERROR,
|
|
220
|
+
};
|
|
221
|
+
return map[result];
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
exports.RequestResetPassword = RequestResetPassword;
|
|
225
|
+
class VerifyRequestResetPasswordOTP {
|
|
226
|
+
}
|
|
227
|
+
exports.VerifyRequestResetPasswordOTP = VerifyRequestResetPasswordOTP;
|
|
228
|
+
class ResetPassword {
|
|
229
|
+
static async withId(userId, password) {
|
|
230
|
+
const config = (0, config_1.appInitialize)();
|
|
231
|
+
const rateLimiter = config.rateLimiter;
|
|
232
|
+
if (rateLimiter.appName === undefined || rateLimiter.url === undefined) {
|
|
233
|
+
return ResetPasswordByIdStatus.MISSING_DATABASE_CONFIG;
|
|
234
|
+
}
|
|
235
|
+
userId = userId.trim();
|
|
236
|
+
if (!userId || userId === "")
|
|
237
|
+
return ResetPasswordByIdStatus.MISSING_USER_ID;
|
|
238
|
+
const newPassword = password.newPassword.trim();
|
|
239
|
+
const confirmNewPassword = password.confirmNewPassword.trim();
|
|
240
|
+
if (!newPassword || newPassword === "")
|
|
241
|
+
return ResetPasswordByIdStatus.MISSING_NEW_PASSWORD;
|
|
242
|
+
if (!confirmNewPassword || confirmNewPassword === "")
|
|
243
|
+
return ResetPasswordByIdStatus.MISSING_CONFIRM_NEW_PASSWORD;
|
|
244
|
+
const passwordPolicy = password.passwordPolicy;
|
|
245
|
+
if (!passwordPolicy)
|
|
246
|
+
return ResetPasswordByIdStatus.MISSING_PASSWORD_POLICY;
|
|
247
|
+
const identifier = {
|
|
248
|
+
id: userId,
|
|
249
|
+
target: "reset_password"
|
|
250
|
+
};
|
|
251
|
+
const rule = {
|
|
252
|
+
ttl: 2 * 60 * 1000,
|
|
253
|
+
windowMs: 3 * 60 * 1000,
|
|
254
|
+
maxHits: 5,
|
|
255
|
+
};
|
|
256
|
+
if (await (0, rate_limiter_1.isRateLimited)(identifier, rule) !== rate_limiter_1.RateLimitCheckStatus.LIMIT_NOT_FOUND) {
|
|
257
|
+
return ResetPasswordByIdStatus.TOO_MANY_REQUEST;
|
|
258
|
+
}
|
|
259
|
+
await (0, rate_limiter_1.recordRateLimitHit)(identifier, rule);
|
|
260
|
+
if (await is_user_exists_1.IsUserExists.withId(userId))
|
|
261
|
+
return ResetPasswordByIdStatus.USER_NOT_FOUND;
|
|
262
|
+
if (await is_user_disabled_1.IsUserDisabled.withId(userId))
|
|
263
|
+
return ResetPasswordByIdStatus.USER_DISABLED;
|
|
264
|
+
if (newPassword !== confirmNewPassword)
|
|
265
|
+
return ResetPasswordByIdStatus.NOT_IDENTICAL_CONFIRM_PASSWORD;
|
|
266
|
+
const requiredMin = Math.max(6, passwordPolicy.minLength);
|
|
267
|
+
if (newPassword.length < requiredMin)
|
|
268
|
+
return ResetPasswordByIdStatus.WEAK_NEW_PASSWORD;
|
|
269
|
+
const rules = [
|
|
270
|
+
{ enabled: passwordPolicy.requireUppercase, regex: /[A-Z]/, error: ResetPasswordByIdStatus.MISSING_PASSWORD_UPPERCASE },
|
|
271
|
+
{ enabled: passwordPolicy.requireLowercase, regex: /[a-z]/, error: ResetPasswordByIdStatus.MISSING_PASSWORD_LOWERCASE },
|
|
272
|
+
{ enabled: passwordPolicy.requireDigit, regex: /[0-9]/, error: ResetPasswordByIdStatus.MISSING_PASSWORD_DIGIT },
|
|
273
|
+
{ enabled: passwordPolicy.requireSpecial, regex: /[^A-Za-z0-9]/, error: ResetPasswordByIdStatus.MISSING_PASSWORD_SPECIAL_CHAR },
|
|
274
|
+
];
|
|
275
|
+
for (const rule of rules) {
|
|
276
|
+
if (rule.enabled && !rule.regex.test(newPassword))
|
|
277
|
+
return rule.error;
|
|
278
|
+
}
|
|
279
|
+
try {
|
|
280
|
+
await admin.auth().updateUser(userId, { password: newPassword });
|
|
281
|
+
return ResetPasswordByIdStatus.SUCCESS;
|
|
282
|
+
}
|
|
283
|
+
catch (error) {
|
|
284
|
+
return ResetPasswordByIdStatus.INTERNAL_ERROR;
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
static async withEmail(email, password) {
|
|
288
|
+
email = email.trim();
|
|
289
|
+
if (!email || email === "")
|
|
290
|
+
return ResetPasswordByEmailStatus.MISSING_USER_EMAIL;
|
|
291
|
+
if (!validator_1.default.isEmail(email))
|
|
292
|
+
return ResetPasswordByEmailStatus.INVALID_EMAIL_FORMAT;
|
|
293
|
+
const user = await user_1.User.withEmail(email);
|
|
294
|
+
if (user.status === user_1.UserByEmailStatus.INTERNAL_ERROR)
|
|
295
|
+
return ResetPasswordByEmailStatus.INTERNAL_ERROR;
|
|
296
|
+
if (user.status === user_1.UserByEmailStatus.MISSING_EMAIL) {
|
|
297
|
+
return ResetPasswordByEmailStatus.MISSING_USER_EMAIL;
|
|
298
|
+
}
|
|
299
|
+
if (user.status === user_1.UserByEmailStatus.USER_NOT_FOUND)
|
|
300
|
+
return ResetPasswordByEmailStatus.USER_NOT_FOUND;
|
|
301
|
+
const userId = user.user?.uid;
|
|
302
|
+
if (!userId || userId === undefined)
|
|
303
|
+
return ResetPasswordByEmailStatus.INTERNAL_ERROR;
|
|
304
|
+
const result = await this.withId(userId, password);
|
|
305
|
+
const map = {
|
|
306
|
+
[ResetPasswordByIdStatus.MISSING_DATABASE_CONFIG]: ResetPasswordByEmailStatus.MISSING_DATABASE_CONFIG,
|
|
307
|
+
[ResetPasswordByIdStatus.MISSING_USER_ID]: ResetPasswordByEmailStatus.MISSING_USER_EMAIL,
|
|
308
|
+
[ResetPasswordByIdStatus.MISSING_NEW_PASSWORD]: ResetPasswordByEmailStatus.MISSING_NEW_PASSWORD,
|
|
309
|
+
[ResetPasswordByIdStatus.MISSING_CONFIRM_NEW_PASSWORD]: ResetPasswordByEmailStatus.MISSING_CONFIRM_NEW_PASSWORD,
|
|
310
|
+
[ResetPasswordByIdStatus.MISSING_PASSWORD_POLICY]: ResetPasswordByEmailStatus.MISSING_PASSWORD_POLICY,
|
|
311
|
+
[ResetPasswordByIdStatus.NOT_IDENTICAL_CONFIRM_PASSWORD]: ResetPasswordByEmailStatus.NOT_IDENTICAL_CONFIRM_PASSWORD,
|
|
312
|
+
[ResetPasswordByIdStatus.USER_NOT_FOUND]: ResetPasswordByEmailStatus.USER_NOT_FOUND,
|
|
313
|
+
[ResetPasswordByIdStatus.USER_DISABLED]: ResetPasswordByEmailStatus.USER_DISABLED,
|
|
314
|
+
[ResetPasswordByIdStatus.WEAK_NEW_PASSWORD]: ResetPasswordByEmailStatus.WEAK_NEW_PASSWORD,
|
|
315
|
+
[ResetPasswordByIdStatus.MISSING_PASSWORD_UPPERCASE]: ResetPasswordByEmailStatus.MISSING_PASSWORD_UPPERCASE,
|
|
316
|
+
[ResetPasswordByIdStatus.MISSING_PASSWORD_LOWERCASE]: ResetPasswordByEmailStatus.MISSING_PASSWORD_LOWERCASE,
|
|
317
|
+
[ResetPasswordByIdStatus.MISSING_PASSWORD_DIGIT]: ResetPasswordByEmailStatus.MISSING_PASSWORD_DIGIT,
|
|
318
|
+
[ResetPasswordByIdStatus.MISSING_PASSWORD_SPECIAL_CHAR]: ResetPasswordByEmailStatus.MISSING_PASSWORD_SPECIAL_CHAR,
|
|
319
|
+
[ResetPasswordByIdStatus.TOO_MANY_REQUEST]: ResetPasswordByEmailStatus.TOO_MANY_REQUEST,
|
|
320
|
+
[ResetPasswordByIdStatus.SUCCESS]: ResetPasswordByEmailStatus.SUCCESS,
|
|
321
|
+
[ResetPasswordByIdStatus.INTERNAL_ERROR]: ResetPasswordByEmailStatus.INTERNAL_ERROR,
|
|
322
|
+
};
|
|
323
|
+
return map[result];
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
exports.ResetPassword = ResetPassword;
|
|
327
|
+
//# sourceMappingURL=reset_password.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reset_password.js","sourceRoot":"","sources":["../../src/auth/reset_password.ts"],"names":[],"mappings":"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"}
|
|
@@ -67,6 +67,7 @@ exports.ResetPasswordByIdStatus = exports.ResetPasswordByEmailStatus = void 0;
|
|
|
67
67
|
exports.resetPasswordByEmail = resetPasswordByEmail;
|
|
68
68
|
exports.resetPasswordById = resetPasswordById;
|
|
69
69
|
const admin = __importStar(require("firebase-admin"));
|
|
70
|
+
const config_1 = require("../common/config");
|
|
70
71
|
const rate_limiter_1 = require("../middleware/rate_limiter");
|
|
71
72
|
const is_user_disabled_1 = require("./is_user_disabled");
|
|
72
73
|
const is_user_exists_1 = require("./is_user_exists");
|
|
@@ -76,6 +77,7 @@ if (admin.apps.length === 0) {
|
|
|
76
77
|
}
|
|
77
78
|
var ResetPasswordByEmailStatus;
|
|
78
79
|
(function (ResetPasswordByEmailStatus) {
|
|
80
|
+
ResetPasswordByEmailStatus["MISSING_DATABASE_CONFIG"] = "MISSING_DATABASE_CONFIG";
|
|
79
81
|
ResetPasswordByEmailStatus["MISSING_USER_EMAIL"] = "MISSING_USER_EMAIL";
|
|
80
82
|
ResetPasswordByEmailStatus["MISSING_NEW_PASSWORD"] = "MISSING_NEW_PASSWORD";
|
|
81
83
|
ResetPasswordByEmailStatus["MISSING_CONFIRM_NEW_PASSWORD"] = "MISSING_CONFIRM_NEW_PASSWORD";
|
|
@@ -94,7 +96,8 @@ var ResetPasswordByEmailStatus;
|
|
|
94
96
|
})(ResetPasswordByEmailStatus || (exports.ResetPasswordByEmailStatus = ResetPasswordByEmailStatus = {}));
|
|
95
97
|
var ResetPasswordByIdStatus;
|
|
96
98
|
(function (ResetPasswordByIdStatus) {
|
|
97
|
-
ResetPasswordByIdStatus["
|
|
99
|
+
ResetPasswordByIdStatus["MISSING_DATABASE_CONFIG"] = "MISSING_DATABASE_CONFIG";
|
|
100
|
+
ResetPasswordByIdStatus["MISSING_USER_ID"] = "MISSING_USER_ID";
|
|
98
101
|
ResetPasswordByIdStatus["MISSING_NEW_PASSWORD"] = "MISSING_NEW_PASSWORD";
|
|
99
102
|
ResetPasswordByIdStatus["MISSING_CONFIRM_NEW_PASSWORD"] = "MISSING_CONFIRM_NEW_PASSWORD";
|
|
100
103
|
ResetPasswordByIdStatus["MISSING_PASSWORD_POLICY"] = "MISSING_PASSWORD_POLICY";
|
|
@@ -110,7 +113,11 @@ var ResetPasswordByIdStatus;
|
|
|
110
113
|
ResetPasswordByIdStatus["SUCCESS"] = "SUCCESS";
|
|
111
114
|
ResetPasswordByIdStatus["INTERNAL_ERROR"] = "INTERNAL_ERROR";
|
|
112
115
|
})(ResetPasswordByIdStatus || (exports.ResetPasswordByIdStatus = ResetPasswordByIdStatus = {}));
|
|
113
|
-
async function resetPasswordByEmail(email, password
|
|
116
|
+
async function resetPasswordByEmail(email, password) {
|
|
117
|
+
const config = (0, config_1.appInitialize)();
|
|
118
|
+
const middleware = config.middleware;
|
|
119
|
+
if (!middleware)
|
|
120
|
+
return ResetPasswordByEmailStatus.MISSING_DATABASE_CONFIG;
|
|
114
121
|
email = email.trim();
|
|
115
122
|
if (!email)
|
|
116
123
|
return ResetPasswordByEmailStatus.MISSING_USER_EMAIL;
|
|
@@ -136,10 +143,10 @@ async function resetPasswordByEmail(email, password, databaseConfig) {
|
|
|
136
143
|
windowMs: 3 * 60 * 1000,
|
|
137
144
|
maxHits: 5,
|
|
138
145
|
};
|
|
139
|
-
if (await (0, rate_limiter_1.isRateLimited)(identifier, rule
|
|
146
|
+
if (await (0, rate_limiter_1.isRateLimited)(identifier, rule) !== rate_limiter_1.RateLimitCheckStatus.LIMIT_NOT_FOUND) {
|
|
140
147
|
return ResetPasswordByEmailStatus.TOO_MANY_REQUEST;
|
|
141
148
|
}
|
|
142
|
-
await (0, rate_limiter_1.recordRateLimitHit)(identifier, rule
|
|
149
|
+
await (0, rate_limiter_1.recordRateLimitHit)(identifier, rule);
|
|
143
150
|
if (await (0, is_user_disabled_1.isUserDisabledById)(user.uid))
|
|
144
151
|
return ResetPasswordByEmailStatus.USER_DISABLED;
|
|
145
152
|
if (newPassword !== confirmNewPassword)
|
|
@@ -166,9 +173,13 @@ async function resetPasswordByEmail(email, password, databaseConfig) {
|
|
|
166
173
|
}
|
|
167
174
|
}
|
|
168
175
|
async function resetPasswordById(userId, password, databaseConfig) {
|
|
176
|
+
const config = (0, config_1.appInitialize)();
|
|
177
|
+
const middleware = config.middleware;
|
|
178
|
+
if (!middleware)
|
|
179
|
+
return ResetPasswordByIdStatus.MISSING_DATABASE_CONFIG;
|
|
169
180
|
userId = userId.trim();
|
|
170
181
|
if (!userId)
|
|
171
|
-
return ResetPasswordByIdStatus.
|
|
182
|
+
return ResetPasswordByIdStatus.MISSING_USER_ID;
|
|
172
183
|
const newPassword = password.newPassword.trim();
|
|
173
184
|
const confirmNewPassword = password.confirmNewPassword.trim();
|
|
174
185
|
if (!newPassword || newPassword === "")
|
|
@@ -187,10 +198,10 @@ async function resetPasswordById(userId, password, databaseConfig) {
|
|
|
187
198
|
windowMs: 3 * 60 * 1000,
|
|
188
199
|
maxHits: 5,
|
|
189
200
|
};
|
|
190
|
-
if (await (0, rate_limiter_1.isRateLimited)(identifier, rule
|
|
201
|
+
if (await (0, rate_limiter_1.isRateLimited)(identifier, rule) !== rate_limiter_1.RateLimitCheckStatus.LIMIT_NOT_FOUND) {
|
|
191
202
|
return ResetPasswordByIdStatus.TOO_MANY_REQUEST;
|
|
192
203
|
}
|
|
193
|
-
await (0, rate_limiter_1.recordRateLimitHit)(identifier, rule
|
|
204
|
+
await (0, rate_limiter_1.recordRateLimitHit)(identifier, rule);
|
|
194
205
|
if (await (0, is_user_exists_1.isUserExistsById)(userId))
|
|
195
206
|
return ResetPasswordByIdStatus.USER_NOT_FOUND;
|
|
196
207
|
if (await (0, is_user_disabled_1.isUserDisabledById)(userId))
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update_password.js","sourceRoot":"","sources":["../../src/auth/update_password.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"update_password.js","sourceRoot":"","sources":["../../src/auth/update_password.ts"],"names":[],"mappings":"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"}
|
package/lib/auth/user.js
CHANGED
|
@@ -63,9 +63,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
63
63
|
};
|
|
64
64
|
})();
|
|
65
65
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
66
|
-
exports.UserByEmailStatus = exports.UserByIdStatus = void 0;
|
|
67
|
-
exports.getUserById = getUserById;
|
|
68
|
-
exports.getUserByEmail = getUserByEmail;
|
|
66
|
+
exports.User = exports.UserByEmailStatus = exports.UserByIdStatus = void 0;
|
|
69
67
|
const admin = __importStar(require("firebase-admin"));
|
|
70
68
|
const is_user_exists_1 = require("./is_user_exists");
|
|
71
69
|
if (admin.apps.length === 0) {
|
|
@@ -74,43 +72,57 @@ if (admin.apps.length === 0) {
|
|
|
74
72
|
var UserByIdStatus;
|
|
75
73
|
(function (UserByIdStatus) {
|
|
76
74
|
UserByIdStatus["MISSING_USER_ID"] = "MISSING_USER_ID";
|
|
77
|
-
UserByIdStatus["
|
|
78
|
-
UserByIdStatus["
|
|
75
|
+
UserByIdStatus["USER_NOT_FOUND"] = "USER_NOT_FOUND";
|
|
76
|
+
UserByIdStatus["USER_FOUND"] = "USER_FOUND";
|
|
79
77
|
UserByIdStatus["INTERNAL_ERROR"] = "INTERNAL_ERROR";
|
|
80
78
|
})(UserByIdStatus || (exports.UserByIdStatus = UserByIdStatus = {}));
|
|
81
79
|
var UserByEmailStatus;
|
|
82
80
|
(function (UserByEmailStatus) {
|
|
83
81
|
UserByEmailStatus["MISSING_EMAIL"] = "MISSING_EMAIL";
|
|
84
|
-
UserByEmailStatus["
|
|
85
|
-
UserByEmailStatus["
|
|
82
|
+
UserByEmailStatus["USER_NOT_FOUND"] = "USER_NOT_FOUND";
|
|
83
|
+
UserByEmailStatus["USER_FOUND"] = "USER_FOUND";
|
|
86
84
|
UserByEmailStatus["INTERNAL_ERROR"] = "INTERNAL_ERROR";
|
|
87
85
|
})(UserByEmailStatus || (exports.UserByEmailStatus = UserByEmailStatus = {}));
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
86
|
+
class User {
|
|
87
|
+
static async withId(userId) {
|
|
88
|
+
userId = userId.trim();
|
|
89
|
+
if (!userId || userId === "")
|
|
90
|
+
return { status: UserByIdStatus.MISSING_USER_ID };
|
|
91
|
+
const userExists = await is_user_exists_1.IsUserExists.withId(userId);
|
|
92
|
+
if (userExists === is_user_exists_1.UserExistsByIdStatus.MISSING_USER_ID)
|
|
93
|
+
return { status: UserByIdStatus.MISSING_USER_ID };
|
|
94
|
+
if (userExists === is_user_exists_1.UserExistsByIdStatus.INTERNAL_ERROR)
|
|
95
|
+
return { status: UserByIdStatus.INTERNAL_ERROR };
|
|
96
|
+
if (userExists === is_user_exists_1.UserExistsByIdStatus.USER_NOT_FOUND)
|
|
97
|
+
return { status: UserByIdStatus.USER_NOT_FOUND };
|
|
98
|
+
try {
|
|
99
|
+
const user = await admin.auth().getUser(userId);
|
|
100
|
+
return { status: UserByIdStatus.USER_FOUND, user: user };
|
|
101
|
+
}
|
|
102
|
+
catch (error) {
|
|
103
|
+
return { status: UserByIdStatus.INTERNAL_ERROR };
|
|
104
|
+
}
|
|
97
105
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
106
|
+
static async withEmail(email) {
|
|
107
|
+
email = email.trim();
|
|
108
|
+
if (!email || email === "")
|
|
109
|
+
return { status: UserByEmailStatus.MISSING_EMAIL };
|
|
110
|
+
const userExists = await is_user_exists_1.IsUserExists.withEmail(email);
|
|
111
|
+
if (userExists === is_user_exists_1.UserExistsByEmailStatus.MISSING_USER_EMAIL) {
|
|
112
|
+
return { status: UserByEmailStatus.MISSING_EMAIL };
|
|
113
|
+
}
|
|
114
|
+
if (userExists === is_user_exists_1.UserExistsByEmailStatus.INTERNAL_ERROR)
|
|
115
|
+
return { status: UserByEmailStatus.INTERNAL_ERROR };
|
|
116
|
+
if (userExists === is_user_exists_1.UserExistsByEmailStatus.USER_NOT_FOUND)
|
|
117
|
+
return { status: UserByEmailStatus.USER_NOT_FOUND };
|
|
118
|
+
try {
|
|
119
|
+
const user = await admin.auth().getUserByEmail(email);
|
|
120
|
+
return { status: UserByEmailStatus.USER_FOUND, user: user };
|
|
121
|
+
}
|
|
122
|
+
catch (error) {
|
|
123
|
+
return { status: UserByEmailStatus.INTERNAL_ERROR };
|
|
124
|
+
}
|
|
114
125
|
}
|
|
115
126
|
}
|
|
127
|
+
exports.User = User;
|
|
116
128
|
//# sourceMappingURL=user.js.map
|
package/lib/auth/user.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../src/auth/user.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../src/auth/user.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,sDAAwC;AACxC,qDAA+F;AAE/F,IAAI,KAAK,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;IAC1B,KAAK,CAAC,aAAa,EAAE,CAAC;AAC1B,CAAC;AAED,IAAY,cAKX;AALD,WAAY,cAAc;IACtB,qDAAmC,CAAA;IACnC,mDAAiC,CAAA;IACjC,2CAAyB,CAAA;IACzB,mDAAiC,CAAA;AACrC,CAAC,EALW,cAAc,8BAAd,cAAc,QAKzB;AAED,IAAY,iBAKX;AALD,WAAY,iBAAiB;IACzB,oDAA+B,CAAA;IAC/B,sDAAiC,CAAA;IACjC,8CAAyB,CAAA;IACzB,sDAAiC,CAAA;AACrC,CAAC,EALW,iBAAiB,iCAAjB,iBAAiB,QAK5B;AAED,MAAa,IAAI;IACb,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAAc;QAC9B,MAAM,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC;QAEvB,IAAI,CAAC,MAAM,IAAI,MAAM,KAAK,EAAE;YAAE,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,eAAe,EAAE,CAAC;QAEhF,MAAM,UAAU,GAAG,MAAM,6BAAY,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrD,IAAI,UAAU,KAAK,qCAAoB,CAAC,eAAe;YAAE,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,eAAe,EAAE,CAAC;QAC3G,IAAI,UAAU,KAAK,qCAAoB,CAAC,cAAc;YAAE,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,cAAc,EAAE,CAAC;QACzG,IAAI,UAAU,KAAK,qCAAoB,CAAC,cAAc;YAAE,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,cAAc,EAAE,CAAC;QAEzG,IAAI,CAAC;YACD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YAEhD,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAC7D,CAAC;QAAC,OAAO,KAAU,EAAE,CAAC;YAClB,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,cAAc,EAAE,CAAC;QACrD,CAAC;IACL,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,KAAa;QAChC,KAAK,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;QAErB,IAAI,CAAC,KAAK,IAAI,KAAK,KAAK,EAAE;YAAE,OAAO,EAAE,MAAM,EAAE,iBAAiB,CAAC,aAAa,EAAE,CAAC;QAE/E,MAAM,UAAU,GAAG,MAAM,6BAAY,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACvD,IAAI,UAAU,KAAK,wCAAuB,CAAC,kBAAkB,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,iBAAiB,CAAC,aAAa,EAAE,CAAC;QACvD,CAAC;QACD,IAAI,UAAU,KAAK,wCAAuB,CAAC,cAAc;YAAE,OAAO,EAAE,MAAM,EAAE,iBAAiB,CAAC,cAAc,EAAE,CAAC;QAC/G,IAAI,UAAU,KAAK,wCAAuB,CAAC,cAAc;YAAE,OAAO,EAAE,MAAM,EAAE,iBAAiB,CAAC,cAAc,EAAE,CAAC;QAE/G,IAAI,CAAC;YACD,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,IAAI,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAEtD,OAAO,EAAE,MAAM,EAAE,iBAAiB,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAU,EAAE,CAAC;YAClB,OAAO,EAAE,MAAM,EAAE,iBAAiB,CAAC,cAAc,EAAE,CAAC;QACxD,CAAC;IACL,CAAC;CACJ;AAxCD,oBAwCC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (C) 2025 Fiber
|
|
4
|
+
*
|
|
5
|
+
* All rights reserved. This script, including its code and logic, is the
|
|
6
|
+
* exclusive property of Fiber. Redistribution, reproduction,
|
|
7
|
+
* or modification of any part of this script is strictly prohibited
|
|
8
|
+
* without prior written permission from Fiber.
|
|
9
|
+
*
|
|
10
|
+
* Conditions of use:
|
|
11
|
+
* - The code may not be copied, duplicated, or used, in whole or in part,
|
|
12
|
+
* for any purpose without explicit authorization.
|
|
13
|
+
* - Redistribution of this code, with or without modification, is not
|
|
14
|
+
* permitted unless expressly agreed upon by Fiber.
|
|
15
|
+
* - The name "Fiber" and any associated branding, logos, or
|
|
16
|
+
* trademarks may not be used to endorse or promote derived products
|
|
17
|
+
* or services without prior written approval.
|
|
18
|
+
*
|
|
19
|
+
* Disclaimer:
|
|
20
|
+
* THIS SCRIPT AND ITS CODE ARE PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
|
|
21
|
+
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY,
|
|
22
|
+
* FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL
|
|
23
|
+
* FIBER BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
24
|
+
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING BUT NOT LIMITED TO LOSS OF USE,
|
|
25
|
+
* DATA, PROFITS, OR BUSINESS INTERRUPTION) ARISING OUT OF OR RELATED TO THE USE
|
|
26
|
+
* OR INABILITY TO USE THIS SCRIPT, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
27
|
+
*
|
|
28
|
+
* Unauthorized copying or reproduction of this script, in whole or in part,
|
|
29
|
+
* is a violation of applicable intellectual property laws and will result
|
|
30
|
+
* in legal action.
|
|
31
|
+
*/
|
|
32
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
33
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
34
|
+
};
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.appInitialize = appInitialize;
|
|
37
|
+
const fs_1 = __importDefault(require("fs"));
|
|
38
|
+
const path_1 = __importDefault(require("path"));
|
|
39
|
+
let cachedConfig = null;
|
|
40
|
+
function appInitialize() {
|
|
41
|
+
if (cachedConfig)
|
|
42
|
+
return cachedConfig;
|
|
43
|
+
const configPath = path_1.default.resolve(process.cwd(), "config", "app.json");
|
|
44
|
+
if (!fs_1.default.existsSync(configPath)) {
|
|
45
|
+
throw new Error(`Missing configuration file at: ${configPath}`);
|
|
46
|
+
}
|
|
47
|
+
const raw = fs_1.default.readFileSync(configPath, "utf-8");
|
|
48
|
+
const parsed = JSON.parse(raw);
|
|
49
|
+
cachedConfig = {
|
|
50
|
+
rateLimiter: {
|
|
51
|
+
appName: parsed.rate_limiter.app_name ?? undefined,
|
|
52
|
+
url: parsed.rate_limiter.url ?? undefined,
|
|
53
|
+
},
|
|
54
|
+
otp: {
|
|
55
|
+
collection: parsed.otp.collection ?? undefined
|
|
56
|
+
},
|
|
57
|
+
email: {
|
|
58
|
+
applicationName: parsed.email.application_name ?? undefined,
|
|
59
|
+
collection: parsed.email.collection ?? undefined,
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
return cachedConfig;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/common/config.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;;;;;AA2BH,sCA2BC;AApDD,4CAAoB;AACpB,gDAAwB;AAsBxB,IAAI,YAAY,GAAqB,IAAI,CAAC;AAE1C,SAAgB,aAAa;IACzB,IAAI,YAAY;QAAE,OAAO,YAAY,CAAC;IAEtC,MAAM,UAAU,GAAG,cAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;IAErE,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC7B,MAAM,IAAI,KAAK,CAAC,kCAAkC,UAAU,EAAE,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,GAAG,GAAG,YAAE,CAAC,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IACjD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAE/B,YAAY,GAAG;QACX,WAAW,EAAE;YACT,OAAO,EAAE,MAAM,CAAC,YAAY,CAAC,QAAQ,IAAI,SAAS;YAClD,GAAG,EAAE,MAAM,CAAC,YAAY,CAAC,GAAG,IAAI,SAAS;SAC5C;QACD,GAAG,EAAE;YACD,UAAU,EAAE,MAAM,CAAC,GAAG,CAAC,UAAU,IAAI,SAAS;SACjD;QACD,KAAK,EAAE;YACH,eAAe,EAAE,MAAM,CAAC,KAAK,CAAC,gBAAgB,IAAI,SAAS;YAC3D,UAAU,EAAE,MAAM,CAAC,KAAK,CAAC,UAAU,IAAI,SAAS;SACnD;KACJ,CAAC;IAEF,OAAO,YAAY,CAAC;AACxB,CAAC"}
|