@prmichaelsen/agentbase-core 0.1.1 → 0.1.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.
- package/README.md +204 -87
- package/dist/client/api-types.generated.d.ts +4024 -0
- package/dist/client/api-types.generated.d.ts.map +1 -0
- package/dist/client/api-types.generated.js +6 -0
- package/dist/client/api-types.generated.js.map +1 -0
- package/dist/client/app.d.ts +126 -0
- package/dist/client/app.d.ts.map +1 -0
- package/dist/client/app.js +107 -0
- package/dist/client/app.js.map +1 -0
- package/dist/client/http-transport.d.ts +42 -0
- package/dist/client/http-transport.d.ts.map +1 -0
- package/dist/client/http-transport.js +113 -0
- package/dist/client/http-transport.js.map +1 -0
- package/dist/client/index.d.ts +6 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +9 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/oauth.d.ts +86 -0
- package/dist/client/oauth.d.ts.map +1 -0
- package/dist/client/oauth.js +148 -0
- package/dist/client/oauth.js.map +1 -0
- package/dist/client/svc.d.ts +511 -0
- package/dist/client/svc.d.ts.map +1 -0
- package/dist/client/svc.js +409 -0
- package/dist/client/svc.js.map +1 -0
- package/dist/config/index.d.ts +34 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +50 -0
- package/dist/config/index.js.map +1 -0
- package/dist/errors/app-errors.d.ts +34 -0
- package/dist/errors/app-errors.d.ts.map +1 -0
- package/dist/errors/app-errors.js +34 -0
- package/dist/errors/app-errors.js.map +1 -0
- package/dist/errors/base.error.d.ts +8 -0
- package/dist/errors/base.error.d.ts.map +1 -0
- package/dist/errors/base.error.js +9 -0
- package/dist/errors/base.error.js.map +1 -0
- package/dist/errors/index.d.ts +6 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +12 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -1
- package/dist/lib/auth/error-handler.d.ts +6 -0
- package/dist/lib/auth/error-handler.d.ts.map +1 -0
- package/dist/lib/auth/error-handler.js +18 -0
- package/dist/lib/auth/error-handler.js.map +1 -0
- package/dist/lib/auth/guards.d.ts +5 -6
- package/dist/lib/auth/guards.d.ts.map +1 -1
- package/dist/lib/auth/guards.js +7 -18
- package/dist/lib/auth/guards.js.map +1 -1
- package/dist/lib/auth/index.d.ts +1 -0
- package/dist/lib/auth/index.d.ts.map +1 -1
- package/dist/lib/auth/index.js +1 -0
- package/dist/lib/auth/index.js.map +1 -1
- package/dist/lib/auth/session.d.ts.map +1 -1
- package/dist/lib/auth/session.js +8 -7
- package/dist/lib/auth/session.js.map +1 -1
- package/dist/lib/rate-limiter.d.ts.map +1 -1
- package/dist/lib/rate-limiter.js +2 -1
- package/dist/lib/rate-limiter.js.map +1 -1
- package/dist/services/auth.interface.d.ts +15 -0
- package/dist/services/auth.interface.d.ts.map +1 -0
- package/dist/services/auth.interface.js +2 -0
- package/dist/services/auth.interface.js.map +1 -0
- package/dist/services/base.service.d.ts +17 -1
- package/dist/services/base.service.d.ts.map +1 -1
- package/dist/services/base.service.js +26 -3
- package/dist/services/base.service.js.map +1 -1
- package/dist/services/confirmation-token.service.d.ts +5 -1
- package/dist/services/confirmation-token.service.d.ts.map +1 -1
- package/dist/services/confirmation-token.service.js.map +1 -1
- package/dist/services/index.d.ts +3 -2
- package/dist/services/index.d.ts.map +1 -1
- package/dist/services/index.js +1 -1
- package/dist/services/index.js.map +1 -1
- package/dist/types/branded.d.ts +24 -0
- package/dist/types/branded.d.ts.map +1 -0
- package/dist/types/branded.js +9 -0
- package/dist/types/branded.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +3 -1
- package/dist/types/index.js.map +1 -1
- package/dist/types/result.d.ts +20 -0
- package/dist/types/result.d.ts.map +1 -0
- package/dist/types/result.js +44 -0
- package/dist/types/result.js.map +1 -0
- package/package.json +16 -2
- package/dist/lib/auth/guards.test.d.ts +0 -2
- package/dist/lib/auth/guards.test.d.ts.map +0 -1
- package/dist/lib/auth/guards.test.js +0 -105
- package/dist/lib/auth/guards.test.js.map +0 -1
- package/dist/lib/auth/helpers.test.d.ts +0 -2
- package/dist/lib/auth/helpers.test.d.ts.map +0 -1
- package/dist/lib/auth/helpers.test.js +0 -43
- package/dist/lib/auth/helpers.test.js.map +0 -1
- package/dist/lib/auth/session.test.d.ts +0 -2
- package/dist/lib/auth/session.test.d.ts.map +0 -1
- package/dist/lib/auth/session.test.js +0 -114
- package/dist/lib/auth/session.test.js.map +0 -1
- package/dist/lib/firebase-admin.test.d.ts +0 -2
- package/dist/lib/firebase-admin.test.d.ts.map +0 -1
- package/dist/lib/firebase-admin.test.js +0 -36
- package/dist/lib/firebase-admin.test.js.map +0 -1
- package/dist/lib/firebase-client.test.d.ts +0 -2
- package/dist/lib/firebase-client.test.d.ts.map +0 -1
- package/dist/lib/firebase-client.test.js +0 -167
- package/dist/lib/firebase-client.test.js.map +0 -1
- package/dist/lib/format-time.test.d.ts +0 -2
- package/dist/lib/format-time.test.d.ts.map +0 -1
- package/dist/lib/format-time.test.js +0 -41
- package/dist/lib/format-time.test.js.map +0 -1
- package/dist/lib/linkify.test.d.ts +0 -2
- package/dist/lib/linkify.test.d.ts.map +0 -1
- package/dist/lib/linkify.test.js +0 -40
- package/dist/lib/linkify.test.js.map +0 -1
- package/dist/lib/logger.test.d.ts +0 -2
- package/dist/lib/logger.test.d.ts.map +0 -1
- package/dist/lib/logger.test.js +0 -167
- package/dist/lib/logger.test.js.map +0 -1
- package/dist/lib/rate-limiter.test.d.ts +0 -2
- package/dist/lib/rate-limiter.test.d.ts.map +0 -1
- package/dist/lib/rate-limiter.test.js +0 -70
- package/dist/lib/rate-limiter.test.js.map +0 -1
- package/dist/lib/uuid.test.d.ts +0 -2
- package/dist/lib/uuid.test.d.ts.map +0 -1
- package/dist/lib/uuid.test.js +0 -22
- package/dist/lib/uuid.test.js.map +0 -1
- package/dist/services/base.service.test.d.ts +0 -2
- package/dist/services/base.service.test.d.ts.map +0 -1
- package/dist/services/base.service.test.js +0 -62
- package/dist/services/base.service.test.js.map +0 -1
- package/dist/services/confirmation-token.service.test.d.ts +0 -2
- package/dist/services/confirmation-token.service.test.d.ts.map +0 -1
- package/dist/services/confirmation-token.service.test.js +0 -65
- package/dist/services/confirmation-token.service.test.js.map +0 -1
- package/dist/smoke.test.d.ts +0 -2
- package/dist/smoke.test.d.ts.map +0 -1
- package/dist/smoke.test.js +0 -7
- package/dist/smoke.test.js.map +0 -1
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export interface Ok<T> {
|
|
2
|
+
readonly success: true;
|
|
3
|
+
readonly value: T;
|
|
4
|
+
}
|
|
5
|
+
export interface Err<E> {
|
|
6
|
+
readonly success: false;
|
|
7
|
+
readonly error: E;
|
|
8
|
+
}
|
|
9
|
+
export type Result<T, E = Error> = Ok<T> | Err<E>;
|
|
10
|
+
export declare function ok<T>(value: T): Ok<T>;
|
|
11
|
+
export declare function err<E>(error: E): Err<E>;
|
|
12
|
+
export declare function isOk<T, E>(result: Result<T, E>): result is Ok<T>;
|
|
13
|
+
export declare function isErr<T, E>(result: Result<T, E>): result is Err<E>;
|
|
14
|
+
export declare function mapOk<T, U, E>(result: Result<T, E>, fn: (value: T) => U): Result<U, E>;
|
|
15
|
+
export declare function mapErr<T, E, F>(result: Result<T, E>, fn: (error: E) => F): Result<T, F>;
|
|
16
|
+
export declare function andThen<T, U, E>(result: Result<T, E>, fn: (value: T) => Result<U, E>): Result<U, E>;
|
|
17
|
+
export declare function getOrElse<T, E>(result: Result<T, E>, defaultValue: T): T;
|
|
18
|
+
export declare function tryCatch<T, E = Error>(fn: () => T, onError: (e: unknown) => E): Result<T, E>;
|
|
19
|
+
export declare function tryCatchAsync<T, E = Error>(fn: () => Promise<T>, onError: (e: unknown) => E): Promise<Result<T, E>>;
|
|
20
|
+
//# sourceMappingURL=result.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"result.d.ts","sourceRoot":"","sources":["../../src/types/result.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,EAAE,CAAC,CAAC;IACnB,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC;IACvB,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC;CACnB;AAED,MAAM,WAAW,GAAG,CAAC,CAAC;IACpB,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC;IACxB,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC;CACnB;AAED,MAAM,MAAM,MAAM,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;AAElD,wBAAgB,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAErC;AAED,wBAAgB,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAEvC;AAED,wBAAgB,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,IAAI,EAAE,CAAC,CAAC,CAAC,CAEhE;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,CAElE;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAEtF;AAED,wBAAgB,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAEvF;AAED,wBAAgB,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAEnG;AAED,wBAAgB,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,YAAY,EAAE,CAAC,GAAG,CAAC,CAExE;AAED,wBAAgB,QAAQ,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,OAAO,KAAK,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAM5F;AAED,wBAAsB,aAAa,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,EAC9C,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,OAAO,EAAE,CAAC,CAAC,EAAE,OAAO,KAAK,CAAC,GACzB,OAAO,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAMvB"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
// src/types/result.ts
|
|
2
|
+
// Pattern: Result Types (core-sdk.types-result.md)
|
|
3
|
+
// Ported from remember-core
|
|
4
|
+
export function ok(value) {
|
|
5
|
+
return { success: true, value };
|
|
6
|
+
}
|
|
7
|
+
export function err(error) {
|
|
8
|
+
return { success: false, error };
|
|
9
|
+
}
|
|
10
|
+
export function isOk(result) {
|
|
11
|
+
return result.success === true;
|
|
12
|
+
}
|
|
13
|
+
export function isErr(result) {
|
|
14
|
+
return result.success === false;
|
|
15
|
+
}
|
|
16
|
+
export function mapOk(result, fn) {
|
|
17
|
+
return isOk(result) ? ok(fn(result.value)) : result;
|
|
18
|
+
}
|
|
19
|
+
export function mapErr(result, fn) {
|
|
20
|
+
return isErr(result) ? err(fn(result.error)) : result;
|
|
21
|
+
}
|
|
22
|
+
export function andThen(result, fn) {
|
|
23
|
+
return isOk(result) ? fn(result.value) : result;
|
|
24
|
+
}
|
|
25
|
+
export function getOrElse(result, defaultValue) {
|
|
26
|
+
return isOk(result) ? result.value : defaultValue;
|
|
27
|
+
}
|
|
28
|
+
export function tryCatch(fn, onError) {
|
|
29
|
+
try {
|
|
30
|
+
return ok(fn());
|
|
31
|
+
}
|
|
32
|
+
catch (e) {
|
|
33
|
+
return err(onError(e));
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
export async function tryCatchAsync(fn, onError) {
|
|
37
|
+
try {
|
|
38
|
+
return ok(await fn());
|
|
39
|
+
}
|
|
40
|
+
catch (e) {
|
|
41
|
+
return err(onError(e));
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=result.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"result.js","sourceRoot":"","sources":["../../src/types/result.ts"],"names":[],"mappings":"AAAA,sBAAsB;AACtB,mDAAmD;AACnD,4BAA4B;AAc5B,MAAM,UAAU,EAAE,CAAI,KAAQ;IAC5B,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,GAAG,CAAI,KAAQ;IAC7B,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,IAAI,CAAO,MAAoB;IAC7C,OAAO,MAAM,CAAC,OAAO,KAAK,IAAI,CAAC;AACjC,CAAC;AAED,MAAM,UAAU,KAAK,CAAO,MAAoB;IAC9C,OAAO,MAAM,CAAC,OAAO,KAAK,KAAK,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,KAAK,CAAU,MAAoB,EAAE,EAAmB;IACtE,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;AACtD,CAAC;AAED,MAAM,UAAU,MAAM,CAAU,MAAoB,EAAE,EAAmB;IACvE,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,OAAO,CAAU,MAAoB,EAAE,EAA8B;IACnF,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;AAClD,CAAC;AAED,MAAM,UAAU,SAAS,CAAO,MAAoB,EAAE,YAAe;IACnE,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,QAAQ,CAAe,EAAW,EAAE,OAA0B;IAC5E,IAAI,CAAC;QACH,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAClB,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,EAAoB,EACpB,OAA0B;IAE1B,IAAI,CAAC;QACH,OAAO,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IACxB,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;AACH,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@prmichaelsen/agentbase-core",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.2",
|
|
4
4
|
"description": "Shared service infrastructure for agentbase projects — BaseService, auth, Firebase wrappers, logging, and common utilities",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -25,6 +25,14 @@
|
|
|
25
25
|
"./types": {
|
|
26
26
|
"import": "./dist/types/index.js",
|
|
27
27
|
"types": "./dist/types/index.d.ts"
|
|
28
|
+
},
|
|
29
|
+
"./client": {
|
|
30
|
+
"import": "./dist/client/index.js",
|
|
31
|
+
"types": "./dist/client/index.d.ts"
|
|
32
|
+
},
|
|
33
|
+
"./config": {
|
|
34
|
+
"import": "./dist/config/index.js",
|
|
35
|
+
"types": "./dist/config/index.d.ts"
|
|
28
36
|
}
|
|
29
37
|
},
|
|
30
38
|
"files": [
|
|
@@ -36,7 +44,8 @@
|
|
|
36
44
|
"typecheck": "tsc --noEmit",
|
|
37
45
|
"test": "vitest run",
|
|
38
46
|
"test:watch": "vitest",
|
|
39
|
-
"test:coverage": "vitest run --coverage",
|
|
47
|
+
"test:coverage": "vitest run --coverage && npx tsx scripts/build-banner.ts",
|
|
48
|
+
"generate:types": "npx openapi-typescript openapi.yaml -o src/client/api-types.generated.ts",
|
|
40
49
|
"prepublishOnly": "npm run build"
|
|
41
50
|
},
|
|
42
51
|
"keywords": [
|
|
@@ -67,8 +76,13 @@
|
|
|
67
76
|
"@prmichaelsen/firebase-admin-sdk-v8": "^2.8.0",
|
|
68
77
|
"@types/jsonwebtoken": "^9.0.0",
|
|
69
78
|
"@vitest/coverage-v8": "^4.1.0",
|
|
79
|
+
"chalk": "^5.6.2",
|
|
80
|
+
"figlet": "^1.11.0",
|
|
70
81
|
"firebase": "^10.14.1",
|
|
82
|
+
"gradient-string": "^3.0.0",
|
|
71
83
|
"jsonwebtoken": "^9.0.3",
|
|
84
|
+
"openapi-typescript": "^7.13.0",
|
|
85
|
+
"tsx": "^4.21.0",
|
|
72
86
|
"typescript": "^5.5.0",
|
|
73
87
|
"vitest": "^4.1.0"
|
|
74
88
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"guards.test.d.ts","sourceRoot":"","sources":["../../../src/lib/auth/guards.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
|
-
const { mockVerifySessionCookie, mockVerifyIdToken } = vi.hoisted(() => ({
|
|
3
|
-
mockVerifySessionCookie: vi.fn(),
|
|
4
|
-
mockVerifyIdToken: vi.fn(),
|
|
5
|
-
}));
|
|
6
|
-
vi.mock('@prmichaelsen/firebase-admin-sdk-v8', () => ({
|
|
7
|
-
verifySessionCookie: mockVerifySessionCookie,
|
|
8
|
-
verifyIdToken: mockVerifyIdToken,
|
|
9
|
-
createSessionCookie: vi.fn(),
|
|
10
|
-
}));
|
|
11
|
-
// Suppress console output
|
|
12
|
-
vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
13
|
-
vi.spyOn(console, 'warn').mockImplementation(() => { });
|
|
14
|
-
vi.spyOn(console, 'error').mockImplementation(() => { });
|
|
15
|
-
vi.spyOn(console, 'debug').mockImplementation(() => { });
|
|
16
|
-
import { requireAuth, requireAdmin, isAdmin } from './guards.js';
|
|
17
|
-
function makeRequest(cookie) {
|
|
18
|
-
const headers = new Headers();
|
|
19
|
-
if (cookie)
|
|
20
|
-
headers.set('cookie', cookie);
|
|
21
|
-
return new Request('https://example.com', { headers });
|
|
22
|
-
}
|
|
23
|
-
const decodedToken = {
|
|
24
|
-
sub: 'user-123',
|
|
25
|
-
email: 'admin@example.com',
|
|
26
|
-
name: 'Admin',
|
|
27
|
-
picture: null,
|
|
28
|
-
email_verified: true,
|
|
29
|
-
firebase: { sign_in_provider: 'password' },
|
|
30
|
-
};
|
|
31
|
-
describe('requireAuth', () => {
|
|
32
|
-
beforeEach(() => {
|
|
33
|
-
vi.clearAllMocks();
|
|
34
|
-
});
|
|
35
|
-
it('returns null (pass) for authenticated request', async () => {
|
|
36
|
-
mockVerifySessionCookie.mockResolvedValue(decodedToken);
|
|
37
|
-
const result = await requireAuth(makeRequest('session=valid'));
|
|
38
|
-
expect(result).toBeNull();
|
|
39
|
-
});
|
|
40
|
-
it('returns 401 for unauthenticated request', async () => {
|
|
41
|
-
const result = await requireAuth(makeRequest());
|
|
42
|
-
expect(result).toBeInstanceOf(Response);
|
|
43
|
-
expect(result.status).toBe(401);
|
|
44
|
-
const body = await result.json();
|
|
45
|
-
expect(body.error).toContain('Unauthorized');
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
describe('requireAdmin', () => {
|
|
49
|
-
beforeEach(() => {
|
|
50
|
-
vi.clearAllMocks();
|
|
51
|
-
});
|
|
52
|
-
it('returns null for admin email', async () => {
|
|
53
|
-
mockVerifySessionCookie.mockResolvedValue(decodedToken);
|
|
54
|
-
const result = await requireAdmin(makeRequest('session=valid'), 'admin@example.com,other@ex.com');
|
|
55
|
-
expect(result).toBeNull();
|
|
56
|
-
});
|
|
57
|
-
it('returns 401 for unauthenticated request', async () => {
|
|
58
|
-
const result = await requireAdmin(makeRequest());
|
|
59
|
-
expect(result).toBeInstanceOf(Response);
|
|
60
|
-
expect(result.status).toBe(401);
|
|
61
|
-
});
|
|
62
|
-
it('returns 403 for non-admin authenticated user', async () => {
|
|
63
|
-
mockVerifySessionCookie.mockResolvedValue({
|
|
64
|
-
...decodedToken,
|
|
65
|
-
email: 'regular@example.com',
|
|
66
|
-
});
|
|
67
|
-
const result = await requireAdmin(makeRequest('session=valid'), 'admin@example.com');
|
|
68
|
-
expect(result).toBeInstanceOf(Response);
|
|
69
|
-
expect(result.status).toBe(403);
|
|
70
|
-
const body = await result.json();
|
|
71
|
-
expect(body.error).toContain('Forbidden');
|
|
72
|
-
});
|
|
73
|
-
it('reads OWNER_EMAILS from env when not passed', async () => {
|
|
74
|
-
const original = process.env.OWNER_EMAILS;
|
|
75
|
-
process.env.OWNER_EMAILS = 'admin@example.com';
|
|
76
|
-
mockVerifySessionCookie.mockResolvedValue(decodedToken);
|
|
77
|
-
const result = await requireAdmin(makeRequest('session=valid'));
|
|
78
|
-
expect(result).toBeNull();
|
|
79
|
-
process.env.OWNER_EMAILS = original;
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
describe('isAdmin', () => {
|
|
83
|
-
beforeEach(() => {
|
|
84
|
-
vi.clearAllMocks();
|
|
85
|
-
});
|
|
86
|
-
it('returns true for admin email', async () => {
|
|
87
|
-
mockVerifySessionCookie.mockResolvedValue(decodedToken);
|
|
88
|
-
expect(await isAdmin(makeRequest('session=valid'), 'admin@example.com')).toBe(true);
|
|
89
|
-
});
|
|
90
|
-
it('returns false for non-admin', async () => {
|
|
91
|
-
mockVerifySessionCookie.mockResolvedValue({
|
|
92
|
-
...decodedToken,
|
|
93
|
-
email: 'nope@example.com',
|
|
94
|
-
});
|
|
95
|
-
expect(await isAdmin(makeRequest('session=valid'), 'admin@example.com')).toBe(false);
|
|
96
|
-
});
|
|
97
|
-
it('returns false for unauthenticated', async () => {
|
|
98
|
-
expect(await isAdmin(makeRequest(), 'admin@example.com')).toBe(false);
|
|
99
|
-
});
|
|
100
|
-
it('handles comma-separated emails', async () => {
|
|
101
|
-
mockVerifySessionCookie.mockResolvedValue(decodedToken);
|
|
102
|
-
expect(await isAdmin(makeRequest('session=valid'), 'other@x.com, admin@example.com')).toBe(true);
|
|
103
|
-
});
|
|
104
|
-
});
|
|
105
|
-
//# sourceMappingURL=guards.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"guards.test.js","sourceRoot":"","sources":["../../../src/lib/auth/guards.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.test.d.ts","sourceRoot":"","sources":["../../../src/lib/auth/helpers.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { isRealUser, isRealUserServer } from './helpers.js';
|
|
3
|
-
describe('isRealUser', () => {
|
|
4
|
-
it('returns true for non-anonymous user', () => {
|
|
5
|
-
expect(isRealUser({ isAnonymous: false })).toBe(true);
|
|
6
|
-
});
|
|
7
|
-
it('returns false for anonymous user', () => {
|
|
8
|
-
expect(isRealUser({ isAnonymous: true })).toBe(false);
|
|
9
|
-
});
|
|
10
|
-
it('returns false for null', () => {
|
|
11
|
-
expect(isRealUser(null)).toBe(false);
|
|
12
|
-
});
|
|
13
|
-
it('returns false for undefined', () => {
|
|
14
|
-
expect(isRealUser(undefined)).toBe(false);
|
|
15
|
-
});
|
|
16
|
-
it('returns true when isAnonymous is undefined (real user assumed)', () => {
|
|
17
|
-
expect(isRealUser({})).toBe(true);
|
|
18
|
-
});
|
|
19
|
-
});
|
|
20
|
-
describe('isRealUserServer', () => {
|
|
21
|
-
const makeUser = (overrides = {}) => ({
|
|
22
|
-
uid: 'u1',
|
|
23
|
-
email: 'a@b.com',
|
|
24
|
-
displayName: null,
|
|
25
|
-
photoURL: null,
|
|
26
|
-
emailVerified: true,
|
|
27
|
-
isAnonymous: false,
|
|
28
|
-
...overrides,
|
|
29
|
-
});
|
|
30
|
-
it('returns true for non-anonymous AuthUser', () => {
|
|
31
|
-
expect(isRealUserServer(makeUser())).toBe(true);
|
|
32
|
-
});
|
|
33
|
-
it('returns false for anonymous AuthUser', () => {
|
|
34
|
-
expect(isRealUserServer(makeUser({ isAnonymous: true }))).toBe(false);
|
|
35
|
-
});
|
|
36
|
-
it('returns false for null', () => {
|
|
37
|
-
expect(isRealUserServer(null)).toBe(false);
|
|
38
|
-
});
|
|
39
|
-
it('returns false for undefined', () => {
|
|
40
|
-
expect(isRealUserServer(undefined)).toBe(false);
|
|
41
|
-
});
|
|
42
|
-
});
|
|
43
|
-
//# sourceMappingURL=helpers.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.test.js","sourceRoot":"","sources":["../../../src/lib/auth/helpers.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAE3D,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,CAAC,UAAU,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACvD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,CAAC,UAAU,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACvD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;QAChC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACtC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACrC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC3C,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,gEAAgE,EAAE,GAAG,EAAE;QACxE,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACnC,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,MAAM,QAAQ,GAAG,CAAC,SAAS,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;QACpC,GAAG,EAAE,IAAI;QACT,KAAK,EAAE,SAAS;QAChB,WAAW,EAAE,IAAI;QACjB,QAAQ,EAAE,IAAI;QACd,aAAa,EAAE,IAAI;QACnB,WAAW,EAAE,KAAK;QAClB,GAAG,SAAS;KACb,CAAC,CAAA;IAEF,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACjD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACvE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;QAChC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC5C,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACrC,MAAM,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACjD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session.test.d.ts","sourceRoot":"","sources":["../../../src/lib/auth/session.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
|
-
const { mockVerifySessionCookie, mockVerifyIdToken, mockCreateFirebaseSessionCookie } = vi.hoisted(() => ({
|
|
3
|
-
mockVerifySessionCookie: vi.fn(),
|
|
4
|
-
mockVerifyIdToken: vi.fn(),
|
|
5
|
-
mockCreateFirebaseSessionCookie: vi.fn(),
|
|
6
|
-
}));
|
|
7
|
-
vi.mock('@prmichaelsen/firebase-admin-sdk-v8', () => ({
|
|
8
|
-
verifySessionCookie: mockVerifySessionCookie,
|
|
9
|
-
verifyIdToken: mockVerifyIdToken,
|
|
10
|
-
createSessionCookie: mockCreateFirebaseSessionCookie,
|
|
11
|
-
}));
|
|
12
|
-
// Suppress console output in tests
|
|
13
|
-
vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
14
|
-
vi.spyOn(console, 'warn').mockImplementation(() => { });
|
|
15
|
-
vi.spyOn(console, 'error').mockImplementation(() => { });
|
|
16
|
-
vi.spyOn(console, 'debug').mockImplementation(() => { });
|
|
17
|
-
import { getServerSession, isAuthenticated, createSessionCookie, revokeSession } from './session.js';
|
|
18
|
-
function makeRequest(cookie) {
|
|
19
|
-
const headers = new Headers();
|
|
20
|
-
if (cookie)
|
|
21
|
-
headers.set('cookie', cookie);
|
|
22
|
-
return new Request('https://example.com', { headers });
|
|
23
|
-
}
|
|
24
|
-
const decodedToken = {
|
|
25
|
-
sub: 'user-123',
|
|
26
|
-
email: 'test@example.com',
|
|
27
|
-
name: 'Test User',
|
|
28
|
-
picture: 'https://photo.url',
|
|
29
|
-
email_verified: true,
|
|
30
|
-
firebase: { sign_in_provider: 'password' },
|
|
31
|
-
};
|
|
32
|
-
describe('getServerSession', () => {
|
|
33
|
-
beforeEach(() => {
|
|
34
|
-
vi.clearAllMocks();
|
|
35
|
-
});
|
|
36
|
-
it('returns session for valid session cookie', async () => {
|
|
37
|
-
mockVerifySessionCookie.mockResolvedValue(decodedToken);
|
|
38
|
-
const session = await getServerSession(makeRequest('session=valid-cookie'));
|
|
39
|
-
expect(session).toEqual({
|
|
40
|
-
user: {
|
|
41
|
-
uid: 'user-123',
|
|
42
|
-
email: 'test@example.com',
|
|
43
|
-
displayName: 'Test User',
|
|
44
|
-
photoURL: 'https://photo.url',
|
|
45
|
-
emailVerified: true,
|
|
46
|
-
isAnonymous: false,
|
|
47
|
-
},
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
it('returns null when no cookie header', async () => {
|
|
51
|
-
const session = await getServerSession(makeRequest());
|
|
52
|
-
expect(session).toBeNull();
|
|
53
|
-
});
|
|
54
|
-
it('returns null when no session cookie in header', async () => {
|
|
55
|
-
const session = await getServerSession(makeRequest('other=value'));
|
|
56
|
-
expect(session).toBeNull();
|
|
57
|
-
});
|
|
58
|
-
it('falls back to verifyIdToken on session cookie failure', async () => {
|
|
59
|
-
mockVerifySessionCookie.mockRejectedValue(new Error('invalid'));
|
|
60
|
-
mockVerifyIdToken.mockResolvedValue(decodedToken);
|
|
61
|
-
const session = await getServerSession(makeRequest('session=id-token'));
|
|
62
|
-
expect(session).not.toBeNull();
|
|
63
|
-
expect(mockVerifyIdToken).toHaveBeenCalledWith('id-token');
|
|
64
|
-
});
|
|
65
|
-
it('maps anonymous provider correctly', async () => {
|
|
66
|
-
mockVerifySessionCookie.mockResolvedValue({
|
|
67
|
-
...decodedToken,
|
|
68
|
-
email: undefined,
|
|
69
|
-
firebase: { sign_in_provider: 'anonymous' },
|
|
70
|
-
});
|
|
71
|
-
const session = await getServerSession(makeRequest('session=anon-cookie'));
|
|
72
|
-
expect(session.user.isAnonymous).toBe(true);
|
|
73
|
-
expect(session.user.email).toBeNull();
|
|
74
|
-
});
|
|
75
|
-
it('returns null on complete verification failure', async () => {
|
|
76
|
-
mockVerifySessionCookie.mockRejectedValue(new Error('fail'));
|
|
77
|
-
mockVerifyIdToken.mockRejectedValue(new Error('fail'));
|
|
78
|
-
const session = await getServerSession(makeRequest('session=bad'));
|
|
79
|
-
expect(session).toBeNull();
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
describe('isAuthenticated', () => {
|
|
83
|
-
it('returns true for authenticated request', async () => {
|
|
84
|
-
mockVerifySessionCookie.mockResolvedValue(decodedToken);
|
|
85
|
-
expect(await isAuthenticated(makeRequest('session=valid'))).toBe(true);
|
|
86
|
-
});
|
|
87
|
-
it('returns false for unauthenticated request', async () => {
|
|
88
|
-
expect(await isAuthenticated(makeRequest())).toBe(false);
|
|
89
|
-
});
|
|
90
|
-
});
|
|
91
|
-
describe('createSessionCookie', () => {
|
|
92
|
-
it('calls Firebase admin with correct params', async () => {
|
|
93
|
-
mockCreateFirebaseSessionCookie.mockResolvedValue('session-cookie-value');
|
|
94
|
-
const result = await createSessionCookie('id-token-123');
|
|
95
|
-
expect(mockCreateFirebaseSessionCookie).toHaveBeenCalledWith('id-token-123', {
|
|
96
|
-
expiresIn: 60 * 60 * 24 * 14 * 1000,
|
|
97
|
-
});
|
|
98
|
-
expect(result).toBe('session-cookie-value');
|
|
99
|
-
});
|
|
100
|
-
it('throws on failure', async () => {
|
|
101
|
-
mockCreateFirebaseSessionCookie.mockRejectedValue(new Error('nope'));
|
|
102
|
-
await expect(createSessionCookie('bad')).rejects.toThrow('Failed to create session cookie');
|
|
103
|
-
});
|
|
104
|
-
});
|
|
105
|
-
describe('revokeSession', () => {
|
|
106
|
-
it('does not throw for valid session', async () => {
|
|
107
|
-
mockVerifySessionCookie.mockResolvedValue(decodedToken);
|
|
108
|
-
await expect(revokeSession(makeRequest('session=valid'))).resolves.toBeUndefined();
|
|
109
|
-
});
|
|
110
|
-
it('does not throw for no session', async () => {
|
|
111
|
-
await expect(revokeSession(makeRequest())).resolves.toBeUndefined();
|
|
112
|
-
});
|
|
113
|
-
});
|
|
114
|
-
//# sourceMappingURL=session.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session.test.js","sourceRoot":"","sources":["../../../src/lib/auth/session.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-admin.test.d.ts","sourceRoot":"","sources":["../../src/lib/firebase-admin.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
2
|
-
const mockInitializeApp = vi.fn();
|
|
3
|
-
vi.mock('@prmichaelsen/firebase-admin-sdk-v8', () => ({
|
|
4
|
-
initializeApp: mockInitializeApp,
|
|
5
|
-
}));
|
|
6
|
-
describe('initFirebaseAdmin', () => {
|
|
7
|
-
const originalEnv = { ...process.env };
|
|
8
|
-
beforeEach(() => {
|
|
9
|
-
vi.clearAllMocks();
|
|
10
|
-
process.env.FIREBASE_ADMIN_SERVICE_ACCOUNT_KEY = '{"type":"service_account"}';
|
|
11
|
-
process.env.FIREBASE_PROJECT_ID = 'test-project';
|
|
12
|
-
});
|
|
13
|
-
afterEach(() => {
|
|
14
|
-
process.env = { ...originalEnv };
|
|
15
|
-
vi.resetModules();
|
|
16
|
-
});
|
|
17
|
-
it('calls initializeApp with correct config from env vars', async () => {
|
|
18
|
-
const { initFirebaseAdmin } = await import('./firebase-admin.js');
|
|
19
|
-
initFirebaseAdmin();
|
|
20
|
-
expect(mockInitializeApp).toHaveBeenCalledWith({
|
|
21
|
-
serviceAccount: '{"type":"service_account"}',
|
|
22
|
-
projectId: 'test-project',
|
|
23
|
-
});
|
|
24
|
-
});
|
|
25
|
-
it('passes undefined when env vars not set', async () => {
|
|
26
|
-
delete process.env.FIREBASE_ADMIN_SERVICE_ACCOUNT_KEY;
|
|
27
|
-
delete process.env.FIREBASE_PROJECT_ID;
|
|
28
|
-
const { initFirebaseAdmin } = await import('./firebase-admin.js');
|
|
29
|
-
initFirebaseAdmin();
|
|
30
|
-
expect(mockInitializeApp).toHaveBeenCalledWith({
|
|
31
|
-
serviceAccount: undefined,
|
|
32
|
-
projectId: undefined,
|
|
33
|
-
});
|
|
34
|
-
});
|
|
35
|
-
});
|
|
36
|
-
//# sourceMappingURL=firebase-admin.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-admin.test.js","sourceRoot":"","sources":["../../src/lib/firebase-admin.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAExE,MAAM,iBAAiB,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;AAEjC,EAAE,CAAC,IAAI,CAAC,qCAAqC,EAAE,GAAG,EAAE,CAAC,CAAC;IACpD,aAAa,EAAE,iBAAiB;CACjC,CAAC,CAAC,CAAA;AAEH,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,MAAM,WAAW,GAAG,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE,CAAA;IAEtC,UAAU,CAAC,GAAG,EAAE;QACd,EAAE,CAAC,aAAa,EAAE,CAAA;QAClB,OAAO,CAAC,GAAG,CAAC,kCAAkC,GAAG,4BAA4B,CAAA;QAC7E,OAAO,CAAC,GAAG,CAAC,mBAAmB,GAAG,cAAc,CAAA;IAClD,CAAC,CAAC,CAAA;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,CAAC,GAAG,GAAG,EAAE,GAAG,WAAW,EAAE,CAAA;QAChC,EAAE,CAAC,YAAY,EAAE,CAAA;IACnB,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACrE,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,MAAM,CAAC,qBAAqB,CAAC,CAAA;QACjE,iBAAiB,EAAE,CAAA;QACnB,MAAM,CAAC,iBAAiB,CAAC,CAAC,oBAAoB,CAAC;YAC7C,cAAc,EAAE,4BAA4B;YAC5C,SAAS,EAAE,cAAc;SAC1B,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,OAAO,OAAO,CAAC,GAAG,CAAC,kCAAkC,CAAA;QACrD,OAAO,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAA;QACtC,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,MAAM,CAAC,qBAAqB,CAAC,CAAA;QACjE,iBAAiB,EAAE,CAAA;QACnB,MAAM,CAAC,iBAAiB,CAAC,CAAC,oBAAoB,CAAC;YAC7C,cAAc,EAAE,SAAS;YACzB,SAAS,EAAE,SAAS;SACrB,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"firebase-client.test.d.ts","sourceRoot":"","sources":["../../src/lib/firebase-client.test.ts"],"names":[],"mappings":""}
|