fiber-firebase-functions 1.0.5 → 1.0.7
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/auth/is_user_disabled.d.ts +18 -0
- package/lib/auth/is_user_exists.d.ts +16 -0
- package/lib/auth/otp.d.ts +16 -0
- package/lib/auth/reset_password.d.ts +93 -0
- package/lib/auth/user.d.ts +23 -0
- package/lib/common/config.d.ts +17 -0
- package/lib/common/locale.d.ts +46 -0
- package/lib/common/realtime_database.d.ts +6 -0
- package/lib/email/email.d.ts +11 -0
- package/lib/email/templates/new_user.d.ts +5 -0
- package/lib/email/templates.d.ts +3 -0
- package/lib/geospatial/convert.d.ts +3 -0
- package/lib/geospatial/convert.js +82 -0
- package/lib/geospatial/convert.js.map +1 -0
- package/lib/index.d.ts +10 -0
- package/lib/index.js +1 -0
- package/lib/index.js.map +1 -1
- package/lib/middleware/rate_limiter.d.ts +31 -0
- package/package.json +9 -3
- package/lib/auth/update_password.js +0 -232
- package/lib/auth/update_password.js.map +0 -1
- package/lib/email/send_email.js +0 -81
- package/lib/email/send_email.js.map +0 -1
- package/src/auth/is_user_disabled.ts +0 -94
- package/src/auth/is_user_exists.ts +0 -86
- package/src/auth/otp.ts +0 -135
- package/src/auth/reset_password.ts +0 -359
- package/src/auth/user.ts +0 -93
- package/src/common/config.ts +0 -84
- package/src/common/locale.ts +0 -121
- package/src/common/realtime_database.ts +0 -60
- package/src/email/email.ts +0 -70
- package/src/email/templates/new_user.ts +0 -493
- package/src/email/templates.ts +0 -34
- package/src/index.ts +0 -41
- package/src/middleware/rate_limiter.ts +0 -153
- package/tsconfig.json +0 -32
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export declare enum UserDisabledByIdStatus {
|
|
2
|
+
MISSING_USER_ID = "MISSING_USER_ID",
|
|
3
|
+
ENABLED = "ENABLED",
|
|
4
|
+
DISABLED = "DISABLED",
|
|
5
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
6
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
7
|
+
}
|
|
8
|
+
export declare enum UserDisabledByEmailStatus {
|
|
9
|
+
MISSING_USER_ID = "MISSING_USER_ID",
|
|
10
|
+
ENABLED = "ENABLED",
|
|
11
|
+
DISABLED = "DISABLED",
|
|
12
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
13
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
14
|
+
}
|
|
15
|
+
export declare class IsUserDisabled {
|
|
16
|
+
static withId(userId: string): Promise<UserDisabledByIdStatus>;
|
|
17
|
+
static withEmail(email: string): Promise<UserDisabledByEmailStatus>;
|
|
18
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export declare enum UserExistsByIdStatus {
|
|
2
|
+
MISSING_USER_ID = "MISSING_USER_ID",
|
|
3
|
+
EXISTS = "EXISTS",
|
|
4
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
5
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
6
|
+
}
|
|
7
|
+
export declare enum UserExistsByEmailStatus {
|
|
8
|
+
MISSING_USER_EMAIL = "MISSING_USER_EMAIL",
|
|
9
|
+
EXISTS = "EXISTS",
|
|
10
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
11
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
12
|
+
}
|
|
13
|
+
export declare class IsUserExists {
|
|
14
|
+
static withId(userId: string): Promise<UserExistsByIdStatus>;
|
|
15
|
+
static withEmail(email: string): Promise<UserExistsByEmailStatus>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export declare enum GenerateStatus {
|
|
2
|
+
MISSING_OTP_CONFIG = "MISSING_OTP_CONFIG",
|
|
3
|
+
SUCCESS = "SUCCESS"
|
|
4
|
+
}
|
|
5
|
+
export declare enum GetOTPStatus {
|
|
6
|
+
MISSING_OTP_CONFIG = "MISSING_OTP_CONFIG",
|
|
7
|
+
OTP_NOT_FOUND = "OTP_NOT_FOUND",
|
|
8
|
+
OTP_FOUND = "OTP_FOUND"
|
|
9
|
+
}
|
|
10
|
+
export declare class Otp {
|
|
11
|
+
static generate(userId: string, type: string): Promise<GenerateStatus>;
|
|
12
|
+
static get(userId: string, type: string): Promise<{
|
|
13
|
+
status: GetOTPStatus;
|
|
14
|
+
otp?: string;
|
|
15
|
+
}>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
export declare enum ResetPasswordByEmailStatus {
|
|
2
|
+
MISSING_DATABASE_CONFIG = "MISSING_DATABASE_CONFIG",
|
|
3
|
+
MISSING_USER_EMAIL = "MISSING_USER_EMAIL",
|
|
4
|
+
MISSING_NEW_PASSWORD = "MISSING_NEW_PASSWORD",
|
|
5
|
+
MISSING_CONFIRM_NEW_PASSWORD = "MISSING_CONFIRM_NEW_PASSWORD",
|
|
6
|
+
MISSING_PASSWORD_POLICY = "MISSING_PASSWORD_POLICY",
|
|
7
|
+
NOT_IDENTICAL_CONFIRM_PASSWORD = "NOT_IDENTICAL_CONFIRM_PASSWORD",
|
|
8
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
9
|
+
USER_DISABLED = "USER_DISABLED",
|
|
10
|
+
WEAK_NEW_PASSWORD = "WEAK_NEW_PASSWORD",
|
|
11
|
+
MISSING_PASSWORD_UPPERCASE = "MISSING_PASSWORD_UPPERCASE",
|
|
12
|
+
MISSING_PASSWORD_LOWERCASE = "MISSING_PASSWORD_LOWERCASE",
|
|
13
|
+
MISSING_PASSWORD_DIGIT = "MISSING_PASSWORD_DIGIT",
|
|
14
|
+
MISSING_PASSWORD_SPECIAL_CHAR = "MISSING_PASSWORD_SPECIAL_CHAR",
|
|
15
|
+
TOO_MANY_REQUEST = "TOO_MANY_REQUEST",
|
|
16
|
+
INVALID_EMAIL_FORMAT = "INVALID_EMAIL_FORMAT",
|
|
17
|
+
SUCCESS = "SUCCESS",
|
|
18
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
19
|
+
}
|
|
20
|
+
export declare enum ResetPasswordByIdStatus {
|
|
21
|
+
MISSING_DATABASE_CONFIG = "MISSING_DATABASE_CONFIG",
|
|
22
|
+
MISSING_USER_ID = "MISSING_USER_ID",
|
|
23
|
+
MISSING_NEW_PASSWORD = "MISSING_NEW_PASSWORD",
|
|
24
|
+
MISSING_CONFIRM_NEW_PASSWORD = "MISSING_CONFIRM_NEW_PASSWORD",
|
|
25
|
+
MISSING_PASSWORD_POLICY = "MISSING_PASSWORD_POLICY",
|
|
26
|
+
NOT_IDENTICAL_CONFIRM_PASSWORD = "NOT_IDENTICAL_CONFIRM_PASSWORD",
|
|
27
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
28
|
+
USER_DISABLED = "USER_DISABLED",
|
|
29
|
+
WEAK_NEW_PASSWORD = "WEAK_NEW_PASSWORD",
|
|
30
|
+
MISSING_PASSWORD_UPPERCASE = "MISSING_PASSWORD_UPPERCASE",
|
|
31
|
+
MISSING_PASSWORD_LOWERCASE = "MISSING_PASSWORD_LOWERCASE",
|
|
32
|
+
MISSING_PASSWORD_DIGIT = "MISSING_PASSWORD_DIGIT",
|
|
33
|
+
MISSING_PASSWORD_SPECIAL_CHAR = "MISSING_PASSWORD_SPECIAL_CHAR",
|
|
34
|
+
TOO_MANY_REQUEST = "TOO_MANY_REQUEST",
|
|
35
|
+
SUCCESS = "SUCCESS",
|
|
36
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
37
|
+
}
|
|
38
|
+
export declare enum RequestResetPasswordByIdStatus {
|
|
39
|
+
MISSING_OTP_CONFIG = "MISSING_OTP_CONFIG",
|
|
40
|
+
MISSING_DATABASE_CONFIG = "MISSING_DATABASE_CONFIG",
|
|
41
|
+
MISSING_USER_ID = "MISSING_USER_ID",
|
|
42
|
+
TOO_MANY_REQUEST = "TOO_MANY_REQUEST",
|
|
43
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
44
|
+
USER_DISABLED = "USER_DISABLED",
|
|
45
|
+
SUCCESS = "SUCCESS",
|
|
46
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
47
|
+
}
|
|
48
|
+
export declare enum RequestResetPasswordByEmailStatus {
|
|
49
|
+
MISSING_OTP_CONFIG = "MISSING_OTP_CONFIG",
|
|
50
|
+
MISSING_DATABASE_CONFIG = "MISSING_DATABASE_CONFIG",
|
|
51
|
+
MISSING_USER_EMAIL = "MISSING_USER_EMAIL",
|
|
52
|
+
TOO_MANY_REQUEST = "TOO_MANY_REQUEST",
|
|
53
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
54
|
+
USER_DISABLED = "USER_DISABLED",
|
|
55
|
+
INVALID_EMAIL_FORMAT = "INVALID_EMAIL_FORMAT",
|
|
56
|
+
SUCCESS = "SUCCESS",
|
|
57
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
58
|
+
}
|
|
59
|
+
export declare enum VerifyResetPasswordOtpStatus {
|
|
60
|
+
MISSING_OTP_CONFIG = "MISSING_OTP_CONFIG",
|
|
61
|
+
MISSING_DATABASE_CONFIG = "MISSING_DATABASE_CONFIG",
|
|
62
|
+
MISSING_USER_EMAIL = "MISSING_USER_EMAIL",
|
|
63
|
+
TOO_MANY_REQUEST = "TOO_MANY_REQUEST",
|
|
64
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
65
|
+
USER_DISABLED = "USER_DISABLED",
|
|
66
|
+
INVALID_EMAIL_FORMAT = "INVALID_EMAIL_FORMAT",
|
|
67
|
+
SUCCESS = "SUCCESS",
|
|
68
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
69
|
+
}
|
|
70
|
+
export interface PasswordPolicy {
|
|
71
|
+
minLength: number;
|
|
72
|
+
requireUppercase: boolean;
|
|
73
|
+
requireLowercase: boolean;
|
|
74
|
+
requireDigit: boolean;
|
|
75
|
+
requireSpecial: boolean;
|
|
76
|
+
}
|
|
77
|
+
export interface ResetPassword {
|
|
78
|
+
newPassword: string;
|
|
79
|
+
confirmNewPassword: string;
|
|
80
|
+
passwordPolicy: PasswordPolicy;
|
|
81
|
+
}
|
|
82
|
+
export declare class RequestResetPassword {
|
|
83
|
+
static withId(userId: string): Promise<RequestResetPasswordByIdStatus>;
|
|
84
|
+
static withEmail(email: string): Promise<RequestResetPasswordByEmailStatus>;
|
|
85
|
+
}
|
|
86
|
+
export declare class VerifyRequestResetPasswordOTP {
|
|
87
|
+
static withId(userId: string, otp: string): Promise<void>;
|
|
88
|
+
static withEmail(email: string, otp: string): Promise<void>;
|
|
89
|
+
}
|
|
90
|
+
export declare class ResetPassword {
|
|
91
|
+
static withId(userId: string, password: ResetPassword): Promise<ResetPasswordByIdStatus>;
|
|
92
|
+
static withEmail(email: string, password: ResetPassword): Promise<ResetPasswordByEmailStatus>;
|
|
93
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import * as admin from "firebase-admin";
|
|
2
|
+
export declare enum UserByIdStatus {
|
|
3
|
+
MISSING_USER_ID = "MISSING_USER_ID",
|
|
4
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
5
|
+
USER_FOUND = "USER_FOUND",
|
|
6
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
7
|
+
}
|
|
8
|
+
export declare enum UserByEmailStatus {
|
|
9
|
+
MISSING_EMAIL = "MISSING_EMAIL",
|
|
10
|
+
USER_NOT_FOUND = "USER_NOT_FOUND",
|
|
11
|
+
USER_FOUND = "USER_FOUND",
|
|
12
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
13
|
+
}
|
|
14
|
+
export declare class User {
|
|
15
|
+
static withId(userId: string): Promise<{
|
|
16
|
+
status: UserByIdStatus;
|
|
17
|
+
user?: admin.auth.UserRecord;
|
|
18
|
+
}>;
|
|
19
|
+
static withEmail(email: string): Promise<{
|
|
20
|
+
status: UserByEmailStatus;
|
|
21
|
+
user?: admin.auth.UserRecord;
|
|
22
|
+
}>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export interface AppConfig {
|
|
2
|
+
rateLimiter: DatabaseConfig;
|
|
3
|
+
otp: OtpConfig;
|
|
4
|
+
email: EmailConfig;
|
|
5
|
+
}
|
|
6
|
+
export interface DatabaseConfig {
|
|
7
|
+
appName: string;
|
|
8
|
+
url: string;
|
|
9
|
+
}
|
|
10
|
+
export interface OtpConfig {
|
|
11
|
+
collection: string;
|
|
12
|
+
}
|
|
13
|
+
export interface EmailConfig {
|
|
14
|
+
applicationName: string;
|
|
15
|
+
collection: string;
|
|
16
|
+
}
|
|
17
|
+
export declare function appInitialize(): AppConfig;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
export interface LanguageCode {
|
|
2
|
+
short: string;
|
|
3
|
+
full: string;
|
|
4
|
+
}
|
|
5
|
+
export declare enum Language {
|
|
6
|
+
ARABIC = "arabic",
|
|
7
|
+
BULGARIAN = "bulgarian",
|
|
8
|
+
CATALAN = "catalan",
|
|
9
|
+
CHINESE = "chinese",
|
|
10
|
+
CROATIAN = "croatian",
|
|
11
|
+
CZECH = "czech",
|
|
12
|
+
DANISH = "danish",
|
|
13
|
+
DUTCH = "dutch",
|
|
14
|
+
ENGLISH = "english",
|
|
15
|
+
FINNISH = "finnish",
|
|
16
|
+
FRENCH = "french",
|
|
17
|
+
GERMAN = "german",
|
|
18
|
+
GREEK = "greek",
|
|
19
|
+
HEBREW = "hebrew",
|
|
20
|
+
HINDI = "hindi",
|
|
21
|
+
HUNGARIAN = "hungarian",
|
|
22
|
+
INDONESIAN = "indonesian",
|
|
23
|
+
ITALIAN = "italian",
|
|
24
|
+
JAPANESE = "japanese",
|
|
25
|
+
KOREAN = "korean",
|
|
26
|
+
LITHUANIAN = "lithuanian",
|
|
27
|
+
MALAY = "malay",
|
|
28
|
+
NORWEGIAN = "norwegian",
|
|
29
|
+
POLISH = "polish",
|
|
30
|
+
PORTUGUESE = "portuguese",
|
|
31
|
+
ROMANIAN = "romanian",
|
|
32
|
+
RUSSIAN = "russian",
|
|
33
|
+
SLOVAK = "slovak",
|
|
34
|
+
SLOVENIAN = "slovenian",
|
|
35
|
+
SPANISH = "spanish",
|
|
36
|
+
SWEDISH = "swedish",
|
|
37
|
+
THAI = "thai",
|
|
38
|
+
TURKISH = "turkish",
|
|
39
|
+
UKRAINIAN = "ukrainian",
|
|
40
|
+
VIETNAMESE = "vietnamese"
|
|
41
|
+
}
|
|
42
|
+
export declare const countryCode: Record<Language, LanguageCode>;
|
|
43
|
+
export declare namespace Language {
|
|
44
|
+
function fullCountryCode(lang: Language): string;
|
|
45
|
+
function shortCountryCode(lang: Language): string;
|
|
46
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare enum SendEmailStatus {
|
|
2
|
+
MISSING_EMAIL_CONFIG = "MISSING_EMAIL_CONFIG",
|
|
3
|
+
SUCCESS = "SUCCESS"
|
|
4
|
+
}
|
|
5
|
+
export interface EmailTemplate {
|
|
6
|
+
subject: string;
|
|
7
|
+
text: string;
|
|
8
|
+
}
|
|
9
|
+
export declare class Email {
|
|
10
|
+
static send(to: string, email: EmailTemplate): Promise<SendEmailStatus>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,82 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
33
|
+
exports.GeoSpatialConvert = void 0;
|
|
34
|
+
class GeoSpatialConvert {
|
|
35
|
+
static encode(latitude, longitude, precision = 9) {
|
|
36
|
+
const characters = [];
|
|
37
|
+
let bits = 0;
|
|
38
|
+
let bitsTotal = 0;
|
|
39
|
+
let hashValue = 0;
|
|
40
|
+
let maxLatitude = 90.0;
|
|
41
|
+
let minLatitude = -90.0;
|
|
42
|
+
let maxLongitude = 180.0;
|
|
43
|
+
let minLongitude = -180.0;
|
|
44
|
+
const alphabet = "0123456789bcdefghjkmnpqrstuvwxyz";
|
|
45
|
+
const getMiddle = (x1, x2) => (x1 + x2) / 2;
|
|
46
|
+
while (characters.length < precision) {
|
|
47
|
+
if (bitsTotal % 2 === 0) {
|
|
48
|
+
const middle = getMiddle(maxLongitude, minLongitude);
|
|
49
|
+
if (longitude > middle) {
|
|
50
|
+
hashValue = (hashValue << 1) + 1;
|
|
51
|
+
minLongitude = middle;
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
hashValue = (hashValue << 1) + 0;
|
|
55
|
+
maxLongitude = middle;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
const middle = getMiddle(maxLatitude, minLatitude);
|
|
60
|
+
if (latitude > middle) {
|
|
61
|
+
hashValue = (hashValue << 1) + 1;
|
|
62
|
+
minLatitude = middle;
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
hashValue = (hashValue << 1) + 0;
|
|
66
|
+
maxLatitude = middle;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
bits++;
|
|
70
|
+
bitsTotal++;
|
|
71
|
+
if (bits === 5) {
|
|
72
|
+
const code = alphabet[hashValue];
|
|
73
|
+
characters.push(code);
|
|
74
|
+
bits = 0;
|
|
75
|
+
hashValue = 0;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return characters.join("");
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
exports.GeoSpatialConvert = GeoSpatialConvert;
|
|
82
|
+
//# sourceMappingURL=convert.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convert.js","sourceRoot":"","sources":["../../src/geospatial/convert.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;;;AAEH,MAAa,iBAAiB;IAC1B,MAAM,CAAC,MAAM,CAAC,QAAgB,EAAE,SAAiB,EAAE,YAAoB,CAAC;QACpE,MAAM,UAAU,GAAG,EAAE,CAAC;QACtB,IAAI,IAAI,GAAG,CAAC,CAAC;QACb,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,IAAI,SAAS,GAAG,CAAC,CAAC;QAElB,IAAI,WAAW,GAAG,IAAI,CAAC;QACvB,IAAI,WAAW,GAAG,CAAC,IAAI,CAAC;QACxB,IAAI,YAAY,GAAG,KAAK,CAAC;QACzB,IAAI,YAAY,GAAG,CAAC,KAAK,CAAC;QAE1B,MAAM,QAAQ,GAAG,kCAAkC,CAAC;QAEpD,MAAM,SAAS,GAAG,CAAC,EAAU,EAAE,EAAU,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QAE5D,OAAO,UAAU,CAAC,MAAM,GAAG,SAAS,EAAE,CAAC;YACnC,IAAI,SAAS,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACtB,MAAM,MAAM,GAAG,SAAS,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;gBACrD,IAAI,SAAS,GAAG,MAAM,EAAE,CAAC;oBACrB,SAAS,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;oBACjC,YAAY,GAAG,MAAM,CAAC;gBAC1B,CAAC;qBAAM,CAAC;oBACJ,SAAS,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;oBACjC,YAAY,GAAG,MAAM,CAAC;gBAC1B,CAAC;YACL,CAAC;iBAAM,CAAC;gBACJ,MAAM,MAAM,GAAG,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;gBACnD,IAAI,QAAQ,GAAG,MAAM,EAAE,CAAC;oBACpB,SAAS,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;oBACjC,WAAW,GAAG,MAAM,CAAC;gBACzB,CAAC;qBAAM,CAAC;oBACJ,SAAS,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;oBACjC,WAAW,GAAG,MAAM,CAAC;gBACzB,CAAC;YACL,CAAC;YAED,IAAI,EAAE,CAAC;YACP,SAAS,EAAE,CAAC;YAEZ,IAAI,IAAI,KAAK,CAAC,EAAE,CAAC;gBACb,MAAM,IAAI,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;gBACjC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACtB,IAAI,GAAG,CAAC,CAAC;gBACT,SAAS,GAAG,CAAC,CAAC;YAClB,CAAC;QACL,CAAC;QAED,OAAO,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;CACJ;AAlDD,8CAkDC"}
|
package/lib/index.d.ts
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from "./auth/is_user_disabled";
|
|
2
|
+
export * from "./auth/is_user_exists";
|
|
3
|
+
export * from "./auth/reset_password";
|
|
4
|
+
export * from "./auth/user";
|
|
5
|
+
export * from "./common/locale";
|
|
6
|
+
export * from "./common/realtime_database";
|
|
7
|
+
export * from "./email/email";
|
|
8
|
+
export * from "./email/templates";
|
|
9
|
+
export * from "./geospatial/convert";
|
|
10
|
+
export * from "./middleware/rate_limiter";
|
package/lib/index.js
CHANGED
|
@@ -52,5 +52,6 @@ __exportStar(require("./common/locale"), exports);
|
|
|
52
52
|
__exportStar(require("./common/realtime_database"), exports);
|
|
53
53
|
__exportStar(require("./email/email"), exports);
|
|
54
54
|
__exportStar(require("./email/templates"), exports);
|
|
55
|
+
__exportStar(require("./geospatial/convert"), exports);
|
|
55
56
|
__exportStar(require("./middleware/rate_limiter"), exports);
|
|
56
57
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;;;;;;;;;;;;;;;;AAEH,0DAAwC;AACxC,wDAAsC;AACtC,wDAAsC;AACtC,8CAA4B;AAC5B,kDAAgC;AAChC,6DAA2C;AAC3C,gDAA8B;AAC9B,oDAAkC;AAClC,4DAA0C"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;;;;;;;;;;;;;;;;AAEH,0DAAwC;AACxC,wDAAsC;AACtC,wDAAsC;AACtC,8CAA4B;AAC5B,kDAAgC;AAChC,6DAA2C;AAC3C,gDAA8B;AAC9B,oDAAkC;AAClC,uDAAqC;AACrC,4DAA0C"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export declare enum RateLimitCheckStatus {
|
|
2
|
+
MISSING_IDENTIFIER = "MISSING_IDENTIFIER",
|
|
3
|
+
MISSING_IDENTIFIER_ID = "MISSING_IDENTIFIER_ID",
|
|
4
|
+
MISSING_IDENTIFIER_TARGET = "MISSING_IDENTIFIER_TARGET",
|
|
5
|
+
MISSING_RULE = "MISSING_RULE",
|
|
6
|
+
MISSING_DATABASE_CONFIG = "MISSING_DATABASE_CONFIG",
|
|
7
|
+
LIMIT_EXISTS = "LIMIT_EXISTS",
|
|
8
|
+
LIMIT_NOT_FOUND = "LIMIT_NOT_FOUND",
|
|
9
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
10
|
+
}
|
|
11
|
+
export declare enum SetRateLimitStatus {
|
|
12
|
+
MISSING_IDENTIFIER = "MISSING_IDENTIFIER",
|
|
13
|
+
MISSING_IDENTIFIER_ID = "MISSING_IDENTIFIER_ID",
|
|
14
|
+
MISSING_IDENTIFIER_TARGET = "MISSING_IDENTIFIER_TARGET",
|
|
15
|
+
MISSING_RULE = "MISSING_RULE",
|
|
16
|
+
MISSING_DATABASE_CONFIG = "MISSING_DATABASE_CONFIG",
|
|
17
|
+
RATE_LIMITED = "RATE_LIMITED",
|
|
18
|
+
ALLOWED = "ALLOWED",
|
|
19
|
+
INTERNAL_ERROR = "INTERNAL_ERROR"
|
|
20
|
+
}
|
|
21
|
+
export interface RateLimitIdentifier {
|
|
22
|
+
id: string;
|
|
23
|
+
target: string;
|
|
24
|
+
}
|
|
25
|
+
export interface RateLimitRule {
|
|
26
|
+
ttl: number;
|
|
27
|
+
windowMs: number;
|
|
28
|
+
maxHits: number;
|
|
29
|
+
}
|
|
30
|
+
export declare function isRateLimited(identifier: RateLimitIdentifier, rule: RateLimitRule): Promise<RateLimitCheckStatus>;
|
|
31
|
+
export declare function recordRateLimitHit(identifier: RateLimitIdentifier, rule: RateLimitRule): Promise<SetRateLimitStatus>;
|
package/package.json
CHANGED
|
@@ -1,11 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "fiber-firebase-functions",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.7",
|
|
4
4
|
"description": "A collection of ready-to-use Firebase Cloud Functions utilities and wrappers designed for any application built by Fiber. Provides reusable helpers, common patterns, and production-grade modules to streamline backend development across all Fiber projects.",
|
|
5
5
|
"author": "Fiber",
|
|
6
6
|
"license": "FIBER-PROPRIETARY",
|
|
7
|
-
"main": "
|
|
8
|
-
"types": "
|
|
7
|
+
"main": "lib/index.js",
|
|
8
|
+
"types": "lib/index.d.ts",
|
|
9
|
+
"files": [
|
|
10
|
+
"lib",
|
|
11
|
+
"package.json",
|
|
12
|
+
"README.md",
|
|
13
|
+
"LICENSE"
|
|
14
|
+
],
|
|
9
15
|
"scripts": {
|
|
10
16
|
"build": "tsc",
|
|
11
17
|
"watch": "tsc --watch",
|