@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.
Files changed (143) hide show
  1. package/README.md +204 -87
  2. package/dist/client/api-types.generated.d.ts +4024 -0
  3. package/dist/client/api-types.generated.d.ts.map +1 -0
  4. package/dist/client/api-types.generated.js +6 -0
  5. package/dist/client/api-types.generated.js.map +1 -0
  6. package/dist/client/app.d.ts +126 -0
  7. package/dist/client/app.d.ts.map +1 -0
  8. package/dist/client/app.js +107 -0
  9. package/dist/client/app.js.map +1 -0
  10. package/dist/client/http-transport.d.ts +42 -0
  11. package/dist/client/http-transport.d.ts.map +1 -0
  12. package/dist/client/http-transport.js +113 -0
  13. package/dist/client/http-transport.js.map +1 -0
  14. package/dist/client/index.d.ts +6 -0
  15. package/dist/client/index.d.ts.map +1 -0
  16. package/dist/client/index.js +9 -0
  17. package/dist/client/index.js.map +1 -0
  18. package/dist/client/oauth.d.ts +86 -0
  19. package/dist/client/oauth.d.ts.map +1 -0
  20. package/dist/client/oauth.js +148 -0
  21. package/dist/client/oauth.js.map +1 -0
  22. package/dist/client/svc.d.ts +511 -0
  23. package/dist/client/svc.d.ts.map +1 -0
  24. package/dist/client/svc.js +409 -0
  25. package/dist/client/svc.js.map +1 -0
  26. package/dist/config/index.d.ts +34 -0
  27. package/dist/config/index.d.ts.map +1 -0
  28. package/dist/config/index.js +50 -0
  29. package/dist/config/index.js.map +1 -0
  30. package/dist/errors/app-errors.d.ts +34 -0
  31. package/dist/errors/app-errors.d.ts.map +1 -0
  32. package/dist/errors/app-errors.js +34 -0
  33. package/dist/errors/app-errors.js.map +1 -0
  34. package/dist/errors/base.error.d.ts +8 -0
  35. package/dist/errors/base.error.d.ts.map +1 -0
  36. package/dist/errors/base.error.js +9 -0
  37. package/dist/errors/base.error.js.map +1 -0
  38. package/dist/errors/index.d.ts +6 -0
  39. package/dist/errors/index.d.ts.map +1 -0
  40. package/dist/errors/index.js +12 -0
  41. package/dist/errors/index.js.map +1 -0
  42. package/dist/index.d.ts +6 -0
  43. package/dist/index.d.ts.map +1 -1
  44. package/dist/index.js +5 -0
  45. package/dist/index.js.map +1 -1
  46. package/dist/lib/auth/error-handler.d.ts +6 -0
  47. package/dist/lib/auth/error-handler.d.ts.map +1 -0
  48. package/dist/lib/auth/error-handler.js +18 -0
  49. package/dist/lib/auth/error-handler.js.map +1 -0
  50. package/dist/lib/auth/guards.d.ts +5 -6
  51. package/dist/lib/auth/guards.d.ts.map +1 -1
  52. package/dist/lib/auth/guards.js +7 -18
  53. package/dist/lib/auth/guards.js.map +1 -1
  54. package/dist/lib/auth/index.d.ts +1 -0
  55. package/dist/lib/auth/index.d.ts.map +1 -1
  56. package/dist/lib/auth/index.js +1 -0
  57. package/dist/lib/auth/index.js.map +1 -1
  58. package/dist/lib/auth/session.d.ts.map +1 -1
  59. package/dist/lib/auth/session.js +8 -7
  60. package/dist/lib/auth/session.js.map +1 -1
  61. package/dist/lib/rate-limiter.d.ts.map +1 -1
  62. package/dist/lib/rate-limiter.js +2 -1
  63. package/dist/lib/rate-limiter.js.map +1 -1
  64. package/dist/services/auth.interface.d.ts +15 -0
  65. package/dist/services/auth.interface.d.ts.map +1 -0
  66. package/dist/services/auth.interface.js +2 -0
  67. package/dist/services/auth.interface.js.map +1 -0
  68. package/dist/services/base.service.d.ts +17 -1
  69. package/dist/services/base.service.d.ts.map +1 -1
  70. package/dist/services/base.service.js +26 -3
  71. package/dist/services/base.service.js.map +1 -1
  72. package/dist/services/confirmation-token.service.d.ts +5 -1
  73. package/dist/services/confirmation-token.service.d.ts.map +1 -1
  74. package/dist/services/confirmation-token.service.js.map +1 -1
  75. package/dist/services/index.d.ts +3 -2
  76. package/dist/services/index.d.ts.map +1 -1
  77. package/dist/services/index.js +1 -1
  78. package/dist/services/index.js.map +1 -1
  79. package/dist/types/branded.d.ts +24 -0
  80. package/dist/types/branded.d.ts.map +1 -0
  81. package/dist/types/branded.js +9 -0
  82. package/dist/types/branded.js.map +1 -0
  83. package/dist/types/index.d.ts +4 -0
  84. package/dist/types/index.d.ts.map +1 -1
  85. package/dist/types/index.js +3 -1
  86. package/dist/types/index.js.map +1 -1
  87. package/dist/types/result.d.ts +20 -0
  88. package/dist/types/result.d.ts.map +1 -0
  89. package/dist/types/result.js +44 -0
  90. package/dist/types/result.js.map +1 -0
  91. package/package.json +16 -2
  92. package/dist/lib/auth/guards.test.d.ts +0 -2
  93. package/dist/lib/auth/guards.test.d.ts.map +0 -1
  94. package/dist/lib/auth/guards.test.js +0 -105
  95. package/dist/lib/auth/guards.test.js.map +0 -1
  96. package/dist/lib/auth/helpers.test.d.ts +0 -2
  97. package/dist/lib/auth/helpers.test.d.ts.map +0 -1
  98. package/dist/lib/auth/helpers.test.js +0 -43
  99. package/dist/lib/auth/helpers.test.js.map +0 -1
  100. package/dist/lib/auth/session.test.d.ts +0 -2
  101. package/dist/lib/auth/session.test.d.ts.map +0 -1
  102. package/dist/lib/auth/session.test.js +0 -114
  103. package/dist/lib/auth/session.test.js.map +0 -1
  104. package/dist/lib/firebase-admin.test.d.ts +0 -2
  105. package/dist/lib/firebase-admin.test.d.ts.map +0 -1
  106. package/dist/lib/firebase-admin.test.js +0 -36
  107. package/dist/lib/firebase-admin.test.js.map +0 -1
  108. package/dist/lib/firebase-client.test.d.ts +0 -2
  109. package/dist/lib/firebase-client.test.d.ts.map +0 -1
  110. package/dist/lib/firebase-client.test.js +0 -167
  111. package/dist/lib/firebase-client.test.js.map +0 -1
  112. package/dist/lib/format-time.test.d.ts +0 -2
  113. package/dist/lib/format-time.test.d.ts.map +0 -1
  114. package/dist/lib/format-time.test.js +0 -41
  115. package/dist/lib/format-time.test.js.map +0 -1
  116. package/dist/lib/linkify.test.d.ts +0 -2
  117. package/dist/lib/linkify.test.d.ts.map +0 -1
  118. package/dist/lib/linkify.test.js +0 -40
  119. package/dist/lib/linkify.test.js.map +0 -1
  120. package/dist/lib/logger.test.d.ts +0 -2
  121. package/dist/lib/logger.test.d.ts.map +0 -1
  122. package/dist/lib/logger.test.js +0 -167
  123. package/dist/lib/logger.test.js.map +0 -1
  124. package/dist/lib/rate-limiter.test.d.ts +0 -2
  125. package/dist/lib/rate-limiter.test.d.ts.map +0 -1
  126. package/dist/lib/rate-limiter.test.js +0 -70
  127. package/dist/lib/rate-limiter.test.js.map +0 -1
  128. package/dist/lib/uuid.test.d.ts +0 -2
  129. package/dist/lib/uuid.test.d.ts.map +0 -1
  130. package/dist/lib/uuid.test.js +0 -22
  131. package/dist/lib/uuid.test.js.map +0 -1
  132. package/dist/services/base.service.test.d.ts +0 -2
  133. package/dist/services/base.service.test.d.ts.map +0 -1
  134. package/dist/services/base.service.test.js +0 -62
  135. package/dist/services/base.service.test.js.map +0 -1
  136. package/dist/services/confirmation-token.service.test.d.ts +0 -2
  137. package/dist/services/confirmation-token.service.test.d.ts.map +0 -1
  138. package/dist/services/confirmation-token.service.test.js +0 -65
  139. package/dist/services/confirmation-token.service.test.js.map +0 -1
  140. package/dist/smoke.test.d.ts +0 -2
  141. package/dist/smoke.test.d.ts.map +0 -1
  142. package/dist/smoke.test.js +0 -7
  143. 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.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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=guards.test.d.ts.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=helpers.test.d.ts.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=session.test.d.ts.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=firebase-admin.test.d.ts.map
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=firebase-client.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"firebase-client.test.d.ts","sourceRoot":"","sources":["../../src/lib/firebase-client.test.ts"],"names":[],"mappings":""}