@robelest/convex-auth 0.0.4-preview.13 → 0.0.4-preview.15

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 (323) hide show
  1. package/README.md +140 -9
  2. package/dist/bin.cjs +5957 -5478
  3. package/dist/client/index.d.ts +3 -7
  4. package/dist/client/index.d.ts.map +1 -1
  5. package/dist/client/index.js +27 -26
  6. package/dist/client/index.js.map +1 -1
  7. package/dist/component/_generated/api.d.ts +14 -0
  8. package/dist/component/_generated/api.d.ts.map +1 -1
  9. package/dist/component/_generated/api.js.map +1 -1
  10. package/dist/component/_generated/component.d.ts +1513 -3
  11. package/dist/component/_generated/component.d.ts.map +1 -1
  12. package/dist/component/convex.config.d.ts +2 -2
  13. package/dist/component/convex.config.d.ts.map +1 -1
  14. package/dist/component/model.d.ts +153 -0
  15. package/dist/component/model.d.ts.map +1 -0
  16. package/dist/component/model.js +327 -0
  17. package/dist/component/model.js.map +1 -0
  18. package/dist/component/providers/sso.d.ts +1 -1
  19. package/dist/component/public/enterprise.d.ts +49 -0
  20. package/dist/component/public/enterprise.d.ts.map +1 -0
  21. package/dist/component/public/enterprise.js +450 -0
  22. package/dist/component/public/enterprise.js.map +1 -0
  23. package/dist/component/public/factors.d.ts +52 -0
  24. package/dist/component/public/factors.d.ts.map +1 -0
  25. package/dist/component/public/factors.js +285 -0
  26. package/dist/component/public/factors.js.map +1 -0
  27. package/dist/component/public/groups.d.ts +118 -0
  28. package/dist/component/public/groups.d.ts.map +1 -0
  29. package/dist/component/public/groups.js +599 -0
  30. package/dist/component/public/groups.js.map +1 -0
  31. package/dist/component/public/identity.d.ts +93 -0
  32. package/dist/component/public/identity.d.ts.map +1 -0
  33. package/dist/component/public/identity.js +426 -0
  34. package/dist/component/public/identity.js.map +1 -0
  35. package/dist/component/public/keys.d.ts +41 -0
  36. package/dist/component/public/keys.d.ts.map +1 -0
  37. package/dist/component/public/keys.js +157 -0
  38. package/dist/component/public/keys.js.map +1 -0
  39. package/dist/component/public/shared.d.ts +26 -0
  40. package/dist/component/public/shared.d.ts.map +1 -0
  41. package/dist/component/public/shared.js +32 -0
  42. package/dist/component/public/shared.js.map +1 -0
  43. package/dist/component/public.d.ts +9 -321
  44. package/dist/component/public.d.ts.map +1 -1
  45. package/dist/component/public.js +6 -2145
  46. package/dist/component/schema.d.ts +368 -258
  47. package/dist/component/schema.js +23 -27
  48. package/dist/component/schema.js.map +1 -1
  49. package/dist/component/server/auth.d.ts +42 -7
  50. package/dist/component/server/auth.d.ts.map +1 -1
  51. package/dist/component/server/auth.js +70 -6
  52. package/dist/component/server/auth.js.map +1 -1
  53. package/dist/component/server/cookies.js +3 -0
  54. package/dist/component/server/cookies.js.map +1 -1
  55. package/dist/component/server/db.js +1 -0
  56. package/dist/component/server/db.js.map +1 -1
  57. package/dist/component/server/device.js +3 -1
  58. package/dist/component/server/device.js.map +1 -1
  59. package/dist/component/server/domains/core.js +466 -0
  60. package/dist/component/server/domains/core.js.map +1 -0
  61. package/dist/component/server/domains/sso.js +689 -0
  62. package/dist/component/server/domains/sso.js.map +1 -0
  63. package/dist/component/server/factory.d.ts +136 -0
  64. package/dist/component/server/factory.d.ts.map +1 -0
  65. package/dist/component/server/factory.js +1128 -0
  66. package/dist/component/server/factory.js.map +1 -0
  67. package/dist/component/server/fx.js +2 -1
  68. package/dist/component/server/fx.js.map +1 -1
  69. package/dist/component/server/http.js +287 -0
  70. package/dist/component/server/http.js.map +1 -0
  71. package/dist/component/server/identity.js +13 -0
  72. package/dist/component/server/identity.js.map +1 -0
  73. package/dist/component/server/keys.js +4 -0
  74. package/dist/component/server/keys.js.map +1 -1
  75. package/dist/component/server/mutations/account.js +1 -1
  76. package/dist/component/server/mutations/index.js +2 -2
  77. package/dist/component/server/mutations/index.js.map +1 -1
  78. package/dist/component/server/mutations/invalidate.js +1 -1
  79. package/dist/component/server/mutations/oauth.js +10 -7
  80. package/dist/component/server/mutations/oauth.js.map +1 -1
  81. package/dist/component/server/mutations/refresh.js +1 -1
  82. package/dist/component/server/mutations/register.js +1 -1
  83. package/dist/component/server/mutations/retrieve.js +1 -1
  84. package/dist/component/server/mutations/signature.js +1 -1
  85. package/dist/component/server/mutations/store.js +6 -3
  86. package/dist/component/server/mutations/store.js.map +1 -1
  87. package/dist/component/server/mutations/verify.js +1 -1
  88. package/dist/component/server/oauth.js +3 -0
  89. package/dist/component/server/oauth.js.map +1 -1
  90. package/dist/component/server/passkey.js +3 -2
  91. package/dist/component/server/passkey.js.map +1 -1
  92. package/dist/component/server/provider.js +2 -0
  93. package/dist/component/server/provider.js.map +1 -1
  94. package/dist/component/server/providers.js +3 -0
  95. package/dist/component/server/providers.js.map +1 -1
  96. package/dist/component/server/ratelimit.js +3 -0
  97. package/dist/component/server/ratelimit.js.map +1 -1
  98. package/dist/component/server/redirects.js +2 -0
  99. package/dist/component/server/redirects.js.map +1 -1
  100. package/dist/component/server/refresh.js +5 -0
  101. package/dist/component/server/refresh.js.map +1 -1
  102. package/dist/component/server/sessions.js +5 -0
  103. package/dist/component/server/sessions.js.map +1 -1
  104. package/dist/component/server/signin.js +2 -1
  105. package/dist/component/server/signin.js.map +1 -1
  106. package/dist/component/server/sso.js +166 -19
  107. package/dist/component/server/sso.js.map +1 -1
  108. package/dist/component/server/tokens.js +1 -0
  109. package/dist/component/server/tokens.js.map +1 -1
  110. package/dist/component/server/totp.js +4 -2
  111. package/dist/component/server/totp.js.map +1 -1
  112. package/dist/component/server/types.d.ts +50 -35
  113. package/dist/component/server/types.d.ts.map +1 -1
  114. package/dist/component/server/types.js.map +1 -1
  115. package/dist/component/server/users.js +1 -0
  116. package/dist/component/server/users.js.map +1 -1
  117. package/dist/component/server/utils.js +44 -2
  118. package/dist/component/server/utils.js.map +1 -1
  119. package/dist/providers/anonymous.d.ts +1 -1
  120. package/dist/providers/credentials.d.ts +1 -1
  121. package/dist/providers/password.d.ts +1 -1
  122. package/dist/providers/sso.d.ts +1 -1
  123. package/dist/providers/sso.js.map +1 -1
  124. package/dist/server/auth.d.ts +44 -9
  125. package/dist/server/auth.d.ts.map +1 -1
  126. package/dist/server/auth.js +70 -6
  127. package/dist/server/auth.js.map +1 -1
  128. package/dist/server/cookies.d.ts +1 -38
  129. package/dist/server/cookies.js +3 -0
  130. package/dist/server/cookies.js.map +1 -1
  131. package/dist/server/db.d.ts +1 -125
  132. package/dist/server/db.js +1 -0
  133. package/dist/server/db.js.map +1 -1
  134. package/dist/server/device.d.ts +1 -24
  135. package/dist/server/device.js +3 -1
  136. package/dist/server/device.js.map +1 -1
  137. package/dist/server/domains/core.d.ts +320 -0
  138. package/dist/server/domains/core.d.ts.map +1 -0
  139. package/dist/server/domains/core.js +466 -0
  140. package/dist/server/domains/core.js.map +1 -0
  141. package/dist/server/domains/sso.d.ts +340 -0
  142. package/dist/server/domains/sso.d.ts.map +1 -0
  143. package/dist/server/domains/sso.js +689 -0
  144. package/dist/server/domains/sso.js.map +1 -0
  145. package/dist/server/enterpriseValidators.d.ts +1 -0
  146. package/dist/server/enterpriseValidators.js +56 -0
  147. package/dist/server/enterpriseValidators.js.map +1 -0
  148. package/dist/server/factory.d.ts +136 -0
  149. package/dist/server/factory.d.ts.map +1 -0
  150. package/dist/server/factory.js +1128 -0
  151. package/dist/server/factory.js.map +1 -0
  152. package/dist/server/fx.d.ts +1 -16
  153. package/dist/server/fx.d.ts.map +1 -1
  154. package/dist/server/fx.js +1 -0
  155. package/dist/server/fx.js.map +1 -1
  156. package/dist/server/http.d.ts +59 -0
  157. package/dist/server/http.d.ts.map +1 -0
  158. package/dist/server/http.js +287 -0
  159. package/dist/server/http.js.map +1 -0
  160. package/dist/server/identity.d.ts +1 -0
  161. package/dist/server/identity.js +13 -0
  162. package/dist/server/identity.js.map +1 -0
  163. package/dist/server/index.d.ts +432 -1
  164. package/dist/server/index.d.ts.map +1 -1
  165. package/dist/server/index.js +486 -36
  166. package/dist/server/index.js.map +1 -1
  167. package/dist/server/keys.d.ts +1 -57
  168. package/dist/server/keys.js +4 -0
  169. package/dist/server/keys.js.map +1 -1
  170. package/dist/server/mutations/account.d.ts +7 -7
  171. package/dist/server/mutations/account.d.ts.map +1 -1
  172. package/dist/server/mutations/code.d.ts +13 -13
  173. package/dist/server/mutations/index.d.ts +107 -107
  174. package/dist/server/mutations/index.d.ts.map +1 -1
  175. package/dist/server/mutations/index.js +1 -1
  176. package/dist/server/mutations/index.js.map +1 -1
  177. package/dist/server/mutations/invalidate.d.ts +5 -5
  178. package/dist/server/mutations/oauth.d.ts +10 -10
  179. package/dist/server/mutations/oauth.d.ts.map +1 -1
  180. package/dist/server/mutations/oauth.js +9 -6
  181. package/dist/server/mutations/oauth.js.map +1 -1
  182. package/dist/server/mutations/refresh.d.ts +4 -4
  183. package/dist/server/mutations/register.d.ts +12 -12
  184. package/dist/server/mutations/register.d.ts.map +1 -1
  185. package/dist/server/mutations/retrieve.d.ts +1 -1
  186. package/dist/server/mutations/signature.d.ts +5 -5
  187. package/dist/server/mutations/signature.d.ts.map +1 -1
  188. package/dist/server/mutations/signin.d.ts +1 -1
  189. package/dist/server/mutations/signout.d.ts +1 -1
  190. package/dist/server/mutations/store.d.ts +3 -2
  191. package/dist/server/mutations/store.d.ts.map +1 -1
  192. package/dist/server/mutations/store.js +6 -3
  193. package/dist/server/mutations/store.js.map +1 -1
  194. package/dist/server/mutations/verifier.d.ts +1 -1
  195. package/dist/server/mutations/verify.d.ts +4 -4
  196. package/dist/server/oauth.d.ts +1 -59
  197. package/dist/server/oauth.js +3 -0
  198. package/dist/server/oauth.js.map +1 -1
  199. package/dist/server/passkey.d.ts.map +1 -1
  200. package/dist/server/passkey.js +3 -2
  201. package/dist/server/passkey.js.map +1 -1
  202. package/dist/server/provider.d.ts +1 -14
  203. package/dist/server/provider.d.ts.map +1 -1
  204. package/dist/server/provider.js +2 -0
  205. package/dist/server/provider.js.map +1 -1
  206. package/dist/server/providers.js +3 -0
  207. package/dist/server/providers.js.map +1 -1
  208. package/dist/server/ratelimit.d.ts +1 -22
  209. package/dist/server/ratelimit.js +3 -0
  210. package/dist/server/ratelimit.js.map +1 -1
  211. package/dist/server/redirects.d.ts +1 -10
  212. package/dist/server/redirects.js +2 -0
  213. package/dist/server/redirects.js.map +1 -1
  214. package/dist/server/refresh.d.ts +1 -37
  215. package/dist/server/refresh.js +5 -0
  216. package/dist/server/refresh.js.map +1 -1
  217. package/dist/server/sessions.d.ts +1 -28
  218. package/dist/server/sessions.js +5 -0
  219. package/dist/server/sessions.js.map +1 -1
  220. package/dist/server/signin.d.ts +1 -55
  221. package/dist/server/signin.js +2 -1
  222. package/dist/server/signin.js.map +1 -1
  223. package/dist/server/sso.d.ts +1 -348
  224. package/dist/server/sso.js +165 -18
  225. package/dist/server/sso.js.map +1 -1
  226. package/dist/server/templates.d.ts +1 -21
  227. package/dist/server/templates.js +1 -0
  228. package/dist/server/templates.js.map +1 -1
  229. package/dist/server/tokens.d.ts +1 -11
  230. package/dist/server/tokens.js +1 -0
  231. package/dist/server/tokens.js.map +1 -1
  232. package/dist/server/totp.d.ts +1 -23
  233. package/dist/server/totp.js +4 -2
  234. package/dist/server/totp.js.map +1 -1
  235. package/dist/server/types.d.ts +55 -71
  236. package/dist/server/types.d.ts.map +1 -1
  237. package/dist/server/types.js.map +1 -1
  238. package/dist/server/users.d.ts +1 -31
  239. package/dist/server/users.js +1 -0
  240. package/dist/server/users.js.map +1 -1
  241. package/dist/server/utils.d.ts +1 -27
  242. package/dist/server/utils.js +44 -2
  243. package/dist/server/utils.js.map +1 -1
  244. package/dist/server/version.d.ts +1 -1
  245. package/dist/server/version.js +1 -1
  246. package/dist/server/version.js.map +1 -1
  247. package/package.json +4 -5
  248. package/src/cli/bin.ts +5 -0
  249. package/src/cli/index.ts +22 -9
  250. package/src/cli/keys.ts +3 -0
  251. package/src/client/index.ts +36 -37
  252. package/src/component/_generated/api.ts +14 -0
  253. package/src/component/_generated/component.ts +1920 -3
  254. package/src/component/index.ts +2 -0
  255. package/src/component/model.ts +424 -0
  256. package/src/component/public/enterprise.ts +654 -0
  257. package/src/component/public/factors.ts +332 -0
  258. package/src/component/public/groups.ts +951 -0
  259. package/src/component/public/identity.ts +566 -0
  260. package/src/component/public/keys.ts +209 -0
  261. package/src/component/public/shared.ts +117 -0
  262. package/src/component/public.ts +5 -2965
  263. package/src/component/schema.ts +47 -57
  264. package/src/providers/sso.ts +1 -1
  265. package/src/server/auth.ts +192 -9
  266. package/src/server/cookies.ts +3 -0
  267. package/src/server/db.ts +3 -0
  268. package/src/server/device.ts +3 -1
  269. package/src/server/domains/core.ts +916 -0
  270. package/src/server/domains/sso.ts +1462 -0
  271. package/src/server/enterpriseValidators.ts +88 -0
  272. package/src/server/factory.ts +2168 -0
  273. package/src/server/fx.ts +1 -0
  274. package/src/server/http.ts +529 -0
  275. package/src/server/identity.ts +18 -0
  276. package/src/server/index.ts +712 -40
  277. package/src/server/keys.ts +4 -0
  278. package/src/server/mutations/index.ts +1 -1
  279. package/src/server/mutations/oauth.ts +36 -8
  280. package/src/server/mutations/store.ts +6 -3
  281. package/src/server/oauth.ts +6 -0
  282. package/src/server/passkey.ts +3 -2
  283. package/src/server/provider.ts +2 -0
  284. package/src/server/providers.ts +3 -0
  285. package/src/server/ratelimit.ts +3 -0
  286. package/src/server/redirects.ts +2 -0
  287. package/src/server/refresh.ts +5 -0
  288. package/src/server/sessions.ts +5 -0
  289. package/src/server/signin.ts +1 -0
  290. package/src/server/sso.ts +251 -17
  291. package/src/server/templates.ts +1 -0
  292. package/src/server/tokens.ts +1 -0
  293. package/src/server/totp.ts +4 -2
  294. package/src/server/types.ts +85 -77
  295. package/src/server/users.ts +1 -0
  296. package/src/server/utils.ts +71 -1
  297. package/src/server/version.ts +1 -1
  298. package/dist/component/public.js.map +0 -1
  299. package/dist/component/server/implementation.d.ts +0 -1264
  300. package/dist/component/server/implementation.d.ts.map +0 -1
  301. package/dist/component/server/implementation.js +0 -2365
  302. package/dist/component/server/implementation.js.map +0 -1
  303. package/dist/server/cookies.d.ts.map +0 -1
  304. package/dist/server/db.d.ts.map +0 -1
  305. package/dist/server/device.d.ts.map +0 -1
  306. package/dist/server/implementation.d.ts +0 -1264
  307. package/dist/server/implementation.d.ts.map +0 -1
  308. package/dist/server/implementation.js +0 -2365
  309. package/dist/server/implementation.js.map +0 -1
  310. package/dist/server/keys.d.ts.map +0 -1
  311. package/dist/server/oauth.d.ts.map +0 -1
  312. package/dist/server/ratelimit.d.ts.map +0 -1
  313. package/dist/server/redirects.d.ts.map +0 -1
  314. package/dist/server/refresh.d.ts.map +0 -1
  315. package/dist/server/sessions.d.ts.map +0 -1
  316. package/dist/server/signin.d.ts.map +0 -1
  317. package/dist/server/sso.d.ts.map +0 -1
  318. package/dist/server/templates.d.ts.map +0 -1
  319. package/dist/server/tokens.d.ts.map +0 -1
  320. package/dist/server/totp.d.ts.map +0 -1
  321. package/dist/server/users.d.ts.map +0 -1
  322. package/dist/server/utils.d.ts.map +0 -1
  323. package/src/server/implementation.ts +0 -5336
@@ -0,0 +1,340 @@
1
+ import { EnterprisePolicyPatch } from "../types.js";
2
+ import { GenericActionCtx, GenericDataModel } from "convex/server";
3
+
4
+ //#region src/server/domains/sso.d.ts
5
+ type ComponentCtx = Pick<GenericActionCtx<GenericDataModel>, "runQuery" | "runMutation">;
6
+ type ComponentReadCtx = Pick<GenericActionCtx<GenericDataModel>, "runQuery">;
7
+ /**
8
+ * Build the enterprise and SSO management domain.
9
+ */
10
+ declare function createSsoDomain(deps: any): {
11
+ connection: {
12
+ create: (ctx: ComponentCtx, data: {
13
+ groupId: string;
14
+ slug?: string;
15
+ name?: string;
16
+ status?: "draft" | "active" | "disabled";
17
+ policy?: EnterprisePolicyPatch;
18
+ config?: Record<string, unknown>;
19
+ extend?: Record<string, unknown>;
20
+ }) => Promise<string>;
21
+ get: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<any>;
22
+ getByGroup: (ctx: ComponentReadCtx, groupId: string) => Promise<any>;
23
+ getByDomain: (ctx: ComponentReadCtx, domain: string) => Promise<any>;
24
+ list: (ctx: ComponentReadCtx, opts?: {
25
+ where?: {
26
+ groupId?: string;
27
+ slug?: string;
28
+ status?: "draft" | "active" | "disabled";
29
+ };
30
+ limit?: number;
31
+ cursor?: string | null;
32
+ orderBy?: "_creationTime" | "name" | "slug" | "status";
33
+ order?: "asc" | "desc";
34
+ }) => Promise<any>;
35
+ update: (ctx: ComponentCtx, enterpriseId: string, data: Record<string, unknown>) => Promise<void>;
36
+ delete: (ctx: ComponentCtx, enterpriseId: string) => Promise<void>;
37
+ /**
38
+ * Aggregate readiness status across all configured protocols for an
39
+ * enterprise connection.
40
+ *
41
+ * Returns a structured result indicating whether the connection is
42
+ * ready, with per-protocol checks so callers can surface actionable
43
+ * diagnostics without running full network validation.
44
+ */
45
+ status: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<{
46
+ enterpriseId: any;
47
+ status: any;
48
+ ready: boolean;
49
+ domainCount: number;
50
+ protocols: {
51
+ oidc: {
52
+ configured: boolean;
53
+ ready: boolean;
54
+ clientId: any;
55
+ issuer: any;
56
+ };
57
+ saml: {
58
+ configured: boolean;
59
+ ready: boolean;
60
+ entityId: any;
61
+ };
62
+ scim: {
63
+ configured: boolean;
64
+ ready: boolean;
65
+ basePath: any;
66
+ deprovisionMode: any;
67
+ };
68
+ };
69
+ }>;
70
+ };
71
+ domain: {
72
+ add: (ctx: ComponentCtx, data: {
73
+ enterpriseId: string;
74
+ groupId: string;
75
+ domain: string;
76
+ isPrimary?: boolean;
77
+ verifiedAt?: number;
78
+ }) => Promise<string>;
79
+ list: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<any>;
80
+ validate: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<{
81
+ enterpriseId: string;
82
+ ready: boolean;
83
+ summary: {
84
+ domainCount: any;
85
+ primaryCount: any;
86
+ verifiedCount: any;
87
+ };
88
+ domains: any;
89
+ warnings: string[];
90
+ }>;
91
+ remove: (ctx: ComponentCtx, domainId: string) => Promise<void>;
92
+ };
93
+ saml: {
94
+ configure: <DataModel extends GenericDataModel>(ctx: GenericActionCtx<DataModel>, data: {
95
+ enterpriseId: string;
96
+ metadataXml?: string;
97
+ metadataUrl?: string;
98
+ domains?: string[];
99
+ signAuthnRequests?: boolean;
100
+ attributeMapping?: {
101
+ subject?: string;
102
+ email?: string;
103
+ name?: string;
104
+ firstName?: string;
105
+ lastName?: string;
106
+ };
107
+ sp?: {
108
+ entityId?: string;
109
+ acsUrl?: string;
110
+ sloUrl?: string;
111
+ signingCert?: string | string[];
112
+ encryptCert?: string | string[];
113
+ privateKey?: string;
114
+ privateKeyPass?: string;
115
+ encPrivateKey?: string;
116
+ encPrivateKeyPass?: string;
117
+ };
118
+ }) => Promise<{
119
+ enterpriseId: any;
120
+ groupId: any;
121
+ }>;
122
+ metadata: <DataModel extends GenericDataModel>(ctx: GenericActionCtx<DataModel>, opts: {
123
+ enterpriseId: string;
124
+ entityId?: string;
125
+ acsUrl?: string;
126
+ sloUrl?: string;
127
+ }) => Promise<any>;
128
+ /**
129
+ * Validate the stored SAML config for an enterprise connection.
130
+ *
131
+ * Re-parses IdP metadata, checks signing cert presence, and verifies
132
+ * SP metadata can be generated. Returns a structured result with
133
+ * per-check details rather than throwing on first failure.
134
+ */
135
+ validate: <DataModel extends GenericDataModel>(ctx: GenericActionCtx<DataModel>, enterpriseId: string) => Promise<{
136
+ ok: boolean;
137
+ enterpriseId: any;
138
+ checks: {
139
+ name: string;
140
+ ok: boolean;
141
+ message?: string;
142
+ }[];
143
+ }>;
144
+ };
145
+ policy: {
146
+ get: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<any>;
147
+ update: (ctx: ComponentCtx, enterpriseId: string, patch: EnterprisePolicyPatch) => Promise<any>;
148
+ validate: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<{
149
+ ok: boolean;
150
+ enterpriseId: string;
151
+ checks: {
152
+ name: string;
153
+ ok: boolean;
154
+ message: any;
155
+ }[];
156
+ policy?: undefined;
157
+ } | {
158
+ ok: any;
159
+ enterpriseId: string;
160
+ policy: any;
161
+ checks: any;
162
+ }>;
163
+ };
164
+ oidc: {
165
+ /**
166
+ * Register or update enterprise OIDC connection settings.
167
+ *
168
+ * Persists protocol config under `enterprise.config.protocols.oidc` and
169
+ * records an `enterprise.oidc.registered` audit event.
170
+ */
171
+ configure: (ctx: ComponentCtx, data: {
172
+ enterpriseId: string;
173
+ issuer?: string;
174
+ discoveryUrl?: string;
175
+ clientId: string;
176
+ clientSecret?: string;
177
+ scopes?: string[];
178
+ authorizationParams?: Record<string, string>;
179
+ clockToleranceSeconds?: number;
180
+ strictIssuer?: boolean;
181
+ /**
182
+ * Map OIDC claim names to `user.extend` field names.
183
+ * Example: `{ department: "department", role: "job_title" }` means
184
+ * the OIDC `department` claim is stored as `user.extend.department`.
185
+ */
186
+ extraFields?: Record<string, string>;
187
+ }) => Promise<any>;
188
+ /**
189
+ * Fetch the stored OIDC config for an enterprise.
190
+ */
191
+ get: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<any>;
192
+ /**
193
+ * Resolve enterprise OIDC sign-in route from enterprise id, domain, or
194
+ * user email domain.
195
+ */
196
+ signIn: (ctx: ComponentReadCtx, data: {
197
+ enterpriseId?: string;
198
+ email?: string;
199
+ domain?: string;
200
+ redirectTo?: string;
201
+ }) => Promise<{
202
+ enterpriseId: any;
203
+ providerId: any;
204
+ signInPath: any;
205
+ callbackPath: any;
206
+ redirectTo: string | undefined;
207
+ }>;
208
+ /**
209
+ * Validate the stored OIDC config for an enterprise connection.
210
+ *
211
+ * Fetches the OIDC discovery document from the configured issuer or
212
+ * discoveryUrl, verifies required fields are present, and checks that
213
+ * clientId is set. Returns a structured result with per-check details.
214
+ */
215
+ validate: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<{
216
+ ok: boolean;
217
+ enterpriseId: any;
218
+ checks: {
219
+ name: string;
220
+ ok: boolean;
221
+ message?: string;
222
+ }[];
223
+ }>;
224
+ };
225
+ scim: {
226
+ configure: (ctx: ComponentCtx, data: {
227
+ enterpriseId: string;
228
+ basePath?: string;
229
+ status?: "draft" | "active" | "disabled";
230
+ }) => Promise<{
231
+ token: any;
232
+ configId: string;
233
+ }>;
234
+ get: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<any>;
235
+ getConfigByToken: (ctx: ComponentReadCtx, token: string) => Promise<any>;
236
+ /**
237
+ * Validate the stored SCIM config for an enterprise connection.
238
+ *
239
+ * Checks that a SCIM config record exists, is active, has a token
240
+ * hash set, and has a non-empty basePath. Returns a structured result
241
+ * with per-check details.
242
+ */
243
+ validate: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<{
244
+ ok: boolean;
245
+ enterpriseId: string;
246
+ checks: {
247
+ name: string;
248
+ ok: boolean;
249
+ message: string;
250
+ }[];
251
+ basePath?: undefined;
252
+ deprovisionMode?: undefined;
253
+ } | {
254
+ ok: boolean;
255
+ enterpriseId: any;
256
+ basePath: any;
257
+ deprovisionMode: any;
258
+ checks: {
259
+ name: string;
260
+ ok: boolean;
261
+ message?: string;
262
+ }[];
263
+ }>;
264
+ identity: {
265
+ get: (ctx: ComponentReadCtx, data: {
266
+ enterpriseId: string;
267
+ resourceType: "user" | "group";
268
+ externalId: string;
269
+ }) => Promise<any>;
270
+ upsert: (ctx: ComponentCtx, data: {
271
+ enterpriseId: string;
272
+ groupId: string;
273
+ resourceType: "user" | "group";
274
+ externalId: string;
275
+ userId?: string;
276
+ mappedGroupId?: string;
277
+ active?: boolean;
278
+ raw?: Record<string, unknown>;
279
+ }) => Promise<string>;
280
+ };
281
+ };
282
+ audit: {
283
+ record: (ctx: ComponentCtx, data: {
284
+ enterpriseId: string;
285
+ groupId: string;
286
+ eventType: string;
287
+ actorType: "user" | "system" | "scim" | "api_key" | "webhook";
288
+ actorId?: string;
289
+ subjectType: string;
290
+ subjectId?: string;
291
+ ok: boolean;
292
+ requestId?: string;
293
+ ip?: string;
294
+ metadata?: Record<string, unknown>;
295
+ }) => Promise<any>;
296
+ list: (ctx: ComponentReadCtx, data: {
297
+ enterpriseId?: string;
298
+ groupId?: string;
299
+ limit?: number;
300
+ }) => Promise<any>;
301
+ };
302
+ webhook: {
303
+ endpoint: {
304
+ create: (ctx: ComponentCtx, data: {
305
+ enterpriseId: string;
306
+ url: string;
307
+ secret: string;
308
+ subscriptions: string[];
309
+ createdByUserId?: string;
310
+ }) => Promise<{
311
+ endpointId: string;
312
+ }>;
313
+ list: (ctx: ComponentReadCtx, enterpriseId: string) => Promise<any>;
314
+ disable: (ctx: ComponentCtx, endpointId: string) => Promise<void>;
315
+ };
316
+ emit: (ctx: ComponentCtx, data: {
317
+ enterpriseId: string;
318
+ eventType: string;
319
+ payload: Record<string, unknown>;
320
+ auditEventId?: string;
321
+ }) => Promise<void>;
322
+ delivery: {
323
+ list: (ctx: ComponentReadCtx, data: {
324
+ enterpriseId: string;
325
+ limit?: number;
326
+ }) => Promise<any>;
327
+ listReady: (ctx: ComponentReadCtx, limit?: number) => Promise<any>;
328
+ markDelivered: (ctx: ComponentCtx, deliveryId: string, responseStatus?: number) => Promise<void>;
329
+ markFailed: (ctx: ComponentCtx, deliveryId: string, data: {
330
+ attemptCount: number;
331
+ responseStatus?: number;
332
+ error?: string;
333
+ retryAt?: number;
334
+ }) => Promise<void>;
335
+ };
336
+ };
337
+ };
338
+ //#endregion
339
+ export { createSsoDomain };
340
+ //# sourceMappingURL=sso.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sso.d.ts","names":[],"sources":["../../../src/server/domains/sso.ts"],"mappings":";;;;KAKK,YAAA,GAAe,IAAA,CAClB,gBAAA,CAAiB,gBAAA;AAAA,KAGd,gBAAA,GAAmB,IAAA,CAAK,gBAAA,CAAiB,gBAAA;AANQ;;;AAAA,iBAWtC,eAAA,CAAgB,IAAA;;kBAiCnB,YAAA,EAAY,IAAA;MAEf,OAAA;MACA,IAAA;MACA,IAAA;MACA,MAAA;MACA,MAAA,GAAS,qBAAA;MACT,MAAA,GAAS,MAAA;MACT,MAAA,GAAS,MAAA;IAAA,MAEV,OAAA;eASc,gBAAA,EAAgB,YAAA,aAAsB,OAAA;sBAK/B,gBAAA,EAAgB,OAAA,aAAiB,OAAA;uBAQhC,gBAAA,EAAgB,MAAA,aAAgB,OAAA;gBASlD,gBAAA,EAAgB,IAAA;MAEnB,KAAA;QACE,OAAA;QACA,IAAA;QACA,MAAA;MAAA;MAEF,KAAA;MACA,MAAA;MACA,OAAA;MACA,KAAA;IAAA,MACD,OAAA;kBAWI,YAAA,EAAY,YAAA,UACG,IAAA,EACd,MAAA,sBAAuB,OAAA;kBAOX,YAAA,EAAY,YAAA,aAAsB,OAAA;IAlEzC;;;;;;;;kBA+EO,gBAAA,EAAgB,YAAA,aAAsB,OAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;eA4EnD,YAAA,EAAY,IAAA;MAEf,YAAA;MACA,OAAA;MACA,MAAA;MACA,SAAA;MACA,UAAA;IAAA,MAED,OAAA;gBASe,gBAAA,EAAgB,YAAA,aAAsB,OAAA;oBAQlC,gBAAA,EAAgB,YAAA,aAAsB,OAAA;;;;;;;;;;;kBA2DxC,YAAA,EAAY,QAAA,aAAkB,OAAA;EAAA;;kCAOd,gBAAA,EAAgB,GAAA,EAC7C,gBAAA,CAAiB,SAAA,GAAU,IAAA;MAE9B,YAAA;MACA,WAAA;MACA,WAAA;MACA,OAAA;MACA,iBAAA;MACA,gBAAA;QACE,OAAA;QACA,KAAA;QACA,IAAA;QACA,SAAA;QACA,QAAA;MAAA;MAEF,EAAA;QACE,QAAA;QACA,MAAA;QACA,MAAA;QACA,WAAA;QACA,WAAA;QACA,UAAA;QACA,cAAA;QACA,aAAA;QACA,iBAAA;MAAA;IAAA,MAEH,OAAA;;;;iCAmKgC,gBAAA,EAAgB,GAAA,EAC5C,gBAAA,CAAiB,SAAA,GAAU,IAAA;MAE9B,YAAA;MACA,QAAA;MACA,MAAA;MACA,MAAA;IAAA,MACD,OAAA;IAk7BE;;;;;;;iCA/4B8B,gBAAA,EAAgB,GAAA,EAC5C,gBAAA,CAAiB,SAAA,GAAU,YAAA,aACZ,OAAA;;;;;;;;;;;eA4FL,gBAAA,EAAgB,YAAA,aAAsB,OAAA;kBAKhD,YAAA,EAAY,YAAA,UACG,KAAA,EACb,qBAAA,KAAqB,OAAA;oBAoBR,gBAAA,EAAgB,YAAA,aAAsB,OAAA;;;;;;;;;;;;;;;;;IAjjBxD;;;;;;qBAqlBG,YAAA,EAAY,IAAA;MAEf,YAAA;MACA,MAAA;MACA,YAAA;MACA,QAAA;MACA,YAAA;MACA,MAAA;MACA,mBAAA,GAAsB,MAAA;MACtB,qBAAA;MACA,YAAA;MAzkB2B;;;;;MA+kB3B,WAAA,GAAc,MAAA;IAAA,MACf,OAAA;IA5jBiB;;;eAisBH,gBAAA,EAAgB,YAAA,aAAsB,OAAA;;;;;kBAiDhD,gBAAA,EAAgB,IAAA;MAEnB,YAAA;MACA,KAAA;MACA,MAAA;MACA,UAAA;IAAA,MACD,OAAA;;;;;;;;;;;;;;oBA2GmB,gBAAA,EAAgB,YAAA,aAAsB,OAAA;;;;;;;;;;;qBAsHrD,YAAA,EAAY,IAAA;MAEf,YAAA;MACA,QAAA;MACA,MAAA;IAAA,MACD,OAAA;;;;eA8Cc,gBAAA,EAAgB,YAAA,aAAsB,OAAA;4BAMzB,gBAAA,EAAgB,KAAA,aAAe,OAAA;;;;;;;;oBAavC,gBAAA,EAAgB,YAAA,aAAsB,OAAA;;;;;;;;;;;;;;;;;;;;;;iBA+EnD,gBAAA,EAAgB,IAAA;QAEnB,YAAA;QACA,YAAA;QACA,UAAA;MAAA,MACD,OAAA;oBAQI,YAAA,EAAY,IAAA;QAEf,YAAA;QACA,OAAA;QACA,YAAA;QACA,UAAA;QACA,MAAA;QACA,aAAA;QACA,MAAA;QACA,GAAA,GAAM,MAAA;MAAA,MACP,OAAA;IAAA;EAAA;;kBAWE,YAAA,EAAY,IAAA;MAEf,YAAA;MACA,OAAA;MACA,SAAA;MACA,SAAA;MACA,OAAA;MACA,WAAA;MACA,SAAA;MACA,EAAA;MACA,SAAA;MACA,EAAA;MACA,QAAA,GAAW,MAAA;IAAA,MACZ,OAAA;gBAKI,gBAAA,EAAgB,IAAA;MACb,YAAA;MAAuB,OAAA;MAAkB,KAAA;IAAA,MAAgB,OAAA;EAAA;;;oBAW1D,YAAA,EAAY,IAAA;QAEf,YAAA;QACA,GAAA;QACA,MAAA;QACA,aAAA;QACA,eAAA;MAAA,MACD,OAAA;;;kBAsCe,gBAAA,EAAgB,YAAA,aAAsB,OAAA;qBAMnC,YAAA,EAAY,UAAA,aAAoB,OAAA;IAAA;gBAQhD,YAAA,EAAY,IAAA;MAEf,YAAA;MACA,SAAA;MACA,OAAA,EAAS,MAAA;MACT,YAAA;IAAA,MACD,OAAA;;kBAMM,gBAAA,EAAgB,IAAA;QACb,YAAA;QAAsB,KAAA;MAAA,MAAgB,OAAA;uBAOzB,gBAAA,EAAgB,KAAA,cAAgB,OAAA;2BAOhD,YAAA,EAAY,UAAA,UACC,cAAA,cACK,OAAA;wBAgBlB,YAAA,EAAY,UAAA,UACC,IAAA;QAEhB,YAAA;QACA,cAAA;QACA,KAAA;QACA,OAAA;MAAA,MACD,OAAA;IAAA;EAAA;AAAA"}