@open-mercato/enterprise 0.4.6-develop-15c18897fc → 0.4.6-develop-34aa847ce6

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 (195) hide show
  1. package/dist/index.js +1 -1
  2. package/dist/index.js.map +2 -2
  3. package/dist/modules/sso/acl.js +11 -0
  4. package/dist/modules/sso/acl.js.map +7 -0
  5. package/dist/modules/sso/api/admin-context.js +27 -0
  6. package/dist/modules/sso/api/admin-context.js.map +7 -0
  7. package/dist/modules/sso/api/callback/oidc/route.js +103 -0
  8. package/dist/modules/sso/api/callback/oidc/route.js.map +7 -0
  9. package/dist/modules/sso/api/config/[id]/activate/route.js +49 -0
  10. package/dist/modules/sso/api/config/[id]/activate/route.js.map +7 -0
  11. package/dist/modules/sso/api/config/[id]/domains/route.js +96 -0
  12. package/dist/modules/sso/api/config/[id]/domains/route.js.map +7 -0
  13. package/dist/modules/sso/api/config/[id]/route.js +103 -0
  14. package/dist/modules/sso/api/config/[id]/route.js.map +7 -0
  15. package/dist/modules/sso/api/config/[id]/test/route.js +41 -0
  16. package/dist/modules/sso/api/config/[id]/test/route.js.map +7 -0
  17. package/dist/modules/sso/api/config/route.js +83 -0
  18. package/dist/modules/sso/api/config/route.js.map +7 -0
  19. package/dist/modules/sso/api/error-handler.js +28 -0
  20. package/dist/modules/sso/api/error-handler.js.map +7 -0
  21. package/dist/modules/sso/api/hrd/route.js +52 -0
  22. package/dist/modules/sso/api/hrd/route.js.map +7 -0
  23. package/dist/modules/sso/api/initiate/route.js +66 -0
  24. package/dist/modules/sso/api/initiate/route.js.map +7 -0
  25. package/dist/modules/sso/api/scim/context.js +68 -0
  26. package/dist/modules/sso/api/scim/context.js.map +7 -0
  27. package/dist/modules/sso/api/scim/logs/route.js +65 -0
  28. package/dist/modules/sso/api/scim/logs/route.js.map +7 -0
  29. package/dist/modules/sso/api/scim/tokens/[id]/route.js +42 -0
  30. package/dist/modules/sso/api/scim/tokens/[id]/route.js.map +7 -0
  31. package/dist/modules/sso/api/scim/tokens/route.js +83 -0
  32. package/dist/modules/sso/api/scim/tokens/route.js.map +7 -0
  33. package/dist/modules/sso/api/scim/v2/ServiceProviderConfig/route.js +42 -0
  34. package/dist/modules/sso/api/scim/v2/ServiceProviderConfig/route.js.map +7 -0
  35. package/dist/modules/sso/api/scim/v2/Users/[id]/route.js +94 -0
  36. package/dist/modules/sso/api/scim/v2/Users/[id]/route.js.map +7 -0
  37. package/dist/modules/sso/api/scim/v2/Users/route.js +86 -0
  38. package/dist/modules/sso/api/scim/v2/Users/route.js.map +7 -0
  39. package/dist/modules/sso/backend/page.js +173 -0
  40. package/dist/modules/sso/backend/page.js.map +7 -0
  41. package/dist/modules/sso/backend/page.meta.js +31 -0
  42. package/dist/modules/sso/backend/page.meta.js.map +7 -0
  43. package/dist/modules/sso/backend/sso/config/[id]/page.js +749 -0
  44. package/dist/modules/sso/backend/sso/config/[id]/page.js.map +7 -0
  45. package/dist/modules/sso/backend/sso/config/[id]/page.meta.js +19 -0
  46. package/dist/modules/sso/backend/sso/config/[id]/page.meta.js.map +7 -0
  47. package/dist/modules/sso/backend/sso/config/new/page.js +381 -0
  48. package/dist/modules/sso/backend/sso/config/new/page.js.map +7 -0
  49. package/dist/modules/sso/backend/sso/config/new/page.meta.js +19 -0
  50. package/dist/modules/sso/backend/sso/config/new/page.meta.js.map +7 -0
  51. package/dist/modules/sso/data/entities.js +299 -0
  52. package/dist/modules/sso/data/entities.js.map +7 -0
  53. package/dist/modules/sso/data/validators.js +114 -0
  54. package/dist/modules/sso/data/validators.js.map +7 -0
  55. package/dist/modules/sso/di.js +26 -0
  56. package/dist/modules/sso/di.js.map +7 -0
  57. package/dist/modules/sso/events.js +24 -0
  58. package/dist/modules/sso/events.js.map +7 -0
  59. package/dist/modules/sso/i18n/de.json +146 -0
  60. package/dist/modules/sso/i18n/en.json +146 -0
  61. package/dist/modules/sso/i18n/es.json +146 -0
  62. package/dist/modules/sso/i18n/pl.json +146 -0
  63. package/dist/modules/sso/index.js +11 -0
  64. package/dist/modules/sso/index.js.map +7 -0
  65. package/dist/modules/sso/lib/domains.js +30 -0
  66. package/dist/modules/sso/lib/domains.js.map +7 -0
  67. package/dist/modules/sso/lib/oidc-provider.js +140 -0
  68. package/dist/modules/sso/lib/oidc-provider.js.map +7 -0
  69. package/dist/modules/sso/lib/registry.js +15 -0
  70. package/dist/modules/sso/lib/registry.js.map +7 -0
  71. package/dist/modules/sso/lib/scim-filter.js +43 -0
  72. package/dist/modules/sso/lib/scim-filter.js.map +7 -0
  73. package/dist/modules/sso/lib/scim-mapper.js +49 -0
  74. package/dist/modules/sso/lib/scim-mapper.js.map +7 -0
  75. package/dist/modules/sso/lib/scim-patch.js +63 -0
  76. package/dist/modules/sso/lib/scim-patch.js.map +7 -0
  77. package/dist/modules/sso/lib/scim-response.js +34 -0
  78. package/dist/modules/sso/lib/scim-response.js.map +7 -0
  79. package/dist/modules/sso/lib/scim-utils.js +9 -0
  80. package/dist/modules/sso/lib/scim-utils.js.map +7 -0
  81. package/dist/modules/sso/lib/state-cookie.js +67 -0
  82. package/dist/modules/sso/lib/state-cookie.js.map +7 -0
  83. package/dist/modules/sso/lib/types.js +1 -0
  84. package/dist/modules/sso/lib/types.js.map +7 -0
  85. package/dist/modules/sso/migrations/Migration20260219000000_sso.js +20 -0
  86. package/dist/modules/sso/migrations/Migration20260219000000_sso.js.map +7 -0
  87. package/dist/modules/sso/migrations/Migration20260222000000_sso_add_name.js +13 -0
  88. package/dist/modules/sso/migrations/Migration20260222000000_sso_add_name.js.map +7 -0
  89. package/dist/modules/sso/migrations/Migration20260222000001_sso_partial_unique_org.js +15 -0
  90. package/dist/modules/sso/migrations/Migration20260222000001_sso_partial_unique_org.js.map +7 -0
  91. package/dist/modules/sso/migrations/Migration20260223000000_scim_tables.js +22 -0
  92. package/dist/modules/sso/migrations/Migration20260223000000_scim_tables.js.map +7 -0
  93. package/dist/modules/sso/migrations/Migration20260224000000_sso_external_id.js +15 -0
  94. package/dist/modules/sso/migrations/Migration20260224000000_sso_external_id.js.map +7 -0
  95. package/dist/modules/sso/migrations/Migration20260224100000_sso_role_grants.js +17 -0
  96. package/dist/modules/sso/migrations/Migration20260224100000_sso_role_grants.js.map +7 -0
  97. package/dist/modules/sso/migrations/Migration20260224200000_drop_default_role_id.js +13 -0
  98. package/dist/modules/sso/migrations/Migration20260224200000_drop_default_role_id.js.map +7 -0
  99. package/dist/modules/sso/migrations/Migration20260225000000_sso_identities_partial_unique.js +23 -0
  100. package/dist/modules/sso/migrations/Migration20260225000000_sso_identities_partial_unique.js.map +7 -0
  101. package/dist/modules/sso/migrations/Migration20260305000000_sso_role_grants_org_id.js +14 -0
  102. package/dist/modules/sso/migrations/Migration20260305000000_sso_role_grants_org_id.js.map +7 -0
  103. package/dist/modules/sso/services/accountLinkingService.js +298 -0
  104. package/dist/modules/sso/services/accountLinkingService.js.map +7 -0
  105. package/dist/modules/sso/services/hrdService.js +18 -0
  106. package/dist/modules/sso/services/hrdService.js.map +7 -0
  107. package/dist/modules/sso/services/scimService.js +372 -0
  108. package/dist/modules/sso/services/scimService.js.map +7 -0
  109. package/dist/modules/sso/services/scimTokenService.js +94 -0
  110. package/dist/modules/sso/services/scimTokenService.js.map +7 -0
  111. package/dist/modules/sso/services/ssoConfigService.js +254 -0
  112. package/dist/modules/sso/services/ssoConfigService.js.map +7 -0
  113. package/dist/modules/sso/services/ssoService.js +125 -0
  114. package/dist/modules/sso/services/ssoService.js.map +7 -0
  115. package/dist/modules/sso/setup.js +47 -0
  116. package/dist/modules/sso/setup.js.map +7 -0
  117. package/dist/modules/sso/subscribers/user-deleted-cleanup.js +21 -0
  118. package/dist/modules/sso/subscribers/user-deleted-cleanup.js.map +7 -0
  119. package/dist/modules/sso/widgets/injection/login-sso/widget.client.js +106 -0
  120. package/dist/modules/sso/widgets/injection/login-sso/widget.client.js.map +7 -0
  121. package/dist/modules/sso/widgets/injection/login-sso/widget.js +16 -0
  122. package/dist/modules/sso/widgets/injection/login-sso/widget.js.map +7 -0
  123. package/dist/modules/sso/widgets/injection-table.js +14 -0
  124. package/dist/modules/sso/widgets/injection-table.js.map +7 -0
  125. package/package.json +5 -4
  126. package/src/index.ts +1 -1
  127. package/src/modules/sso/acl.ts +7 -0
  128. package/src/modules/sso/api/admin-context.ts +36 -0
  129. package/src/modules/sso/api/callback/oidc/route.ts +115 -0
  130. package/src/modules/sso/api/config/[id]/activate/route.ts +53 -0
  131. package/src/modules/sso/api/config/[id]/domains/route.ts +107 -0
  132. package/src/modules/sso/api/config/[id]/route.ts +114 -0
  133. package/src/modules/sso/api/config/[id]/test/route.ts +44 -0
  134. package/src/modules/sso/api/config/route.ts +88 -0
  135. package/src/modules/sso/api/error-handler.ts +36 -0
  136. package/src/modules/sso/api/hrd/route.ts +55 -0
  137. package/src/modules/sso/api/initiate/route.ts +70 -0
  138. package/src/modules/sso/api/scim/context.ts +85 -0
  139. package/src/modules/sso/api/scim/logs/route.ts +69 -0
  140. package/src/modules/sso/api/scim/tokens/[id]/route.ts +45 -0
  141. package/src/modules/sso/api/scim/tokens/route.ts +89 -0
  142. package/src/modules/sso/api/scim/v2/ServiceProviderConfig/route.ts +40 -0
  143. package/src/modules/sso/api/scim/v2/Users/[id]/route.ts +103 -0
  144. package/src/modules/sso/api/scim/v2/Users/route.ts +94 -0
  145. package/src/modules/sso/backend/page.meta.ts +29 -0
  146. package/src/modules/sso/backend/page.tsx +232 -0
  147. package/src/modules/sso/backend/sso/config/[id]/page.meta.ts +15 -0
  148. package/src/modules/sso/backend/sso/config/[id]/page.tsx +1024 -0
  149. package/src/modules/sso/backend/sso/config/new/page.meta.ts +15 -0
  150. package/src/modules/sso/backend/sso/config/new/page.tsx +463 -0
  151. package/src/modules/sso/data/entities.ts +240 -0
  152. package/src/modules/sso/data/validators.ts +140 -0
  153. package/src/modules/sso/di.ts +25 -0
  154. package/src/modules/sso/docs/entra-id-setup.md +281 -0
  155. package/src/modules/sso/docs/google-workspace-setup.md +174 -0
  156. package/src/modules/sso/docs/sso-overview.md +218 -0
  157. package/src/modules/sso/docs/sso-security-audit-2026-02-27.md +118 -0
  158. package/src/modules/sso/docs/zitadel-setup.md +195 -0
  159. package/src/modules/sso/events.ts +21 -0
  160. package/src/modules/sso/i18n/de.json +146 -0
  161. package/src/modules/sso/i18n/en.json +146 -0
  162. package/src/modules/sso/i18n/es.json +146 -0
  163. package/src/modules/sso/i18n/pl.json +146 -0
  164. package/src/modules/sso/index.ts +7 -0
  165. package/src/modules/sso/lib/domains.ts +31 -0
  166. package/src/modules/sso/lib/oidc-provider.ts +196 -0
  167. package/src/modules/sso/lib/registry.ts +13 -0
  168. package/src/modules/sso/lib/scim-filter.ts +62 -0
  169. package/src/modules/sso/lib/scim-mapper.ts +88 -0
  170. package/src/modules/sso/lib/scim-patch.ts +88 -0
  171. package/src/modules/sso/lib/scim-response.ts +40 -0
  172. package/src/modules/sso/lib/scim-utils.ts +5 -0
  173. package/src/modules/sso/lib/state-cookie.ts +79 -0
  174. package/src/modules/sso/lib/types.ts +50 -0
  175. package/src/modules/sso/migrations/.snapshot-open-mercato.json +912 -0
  176. package/src/modules/sso/migrations/Migration20260219000000_sso.ts +21 -0
  177. package/src/modules/sso/migrations/Migration20260222000000_sso_add_name.ts +13 -0
  178. package/src/modules/sso/migrations/Migration20260222000001_sso_partial_unique_org.ts +15 -0
  179. package/src/modules/sso/migrations/Migration20260223000000_scim_tables.ts +24 -0
  180. package/src/modules/sso/migrations/Migration20260224000000_sso_external_id.ts +15 -0
  181. package/src/modules/sso/migrations/Migration20260224100000_sso_role_grants.ts +18 -0
  182. package/src/modules/sso/migrations/Migration20260224200000_drop_default_role_id.ts +13 -0
  183. package/src/modules/sso/migrations/Migration20260225000000_sso_identities_partial_unique.ts +25 -0
  184. package/src/modules/sso/migrations/Migration20260305000000_sso_role_grants_org_id.ts +14 -0
  185. package/src/modules/sso/services/accountLinkingService.ts +386 -0
  186. package/src/modules/sso/services/hrdService.ts +22 -0
  187. package/src/modules/sso/services/scimService.ts +461 -0
  188. package/src/modules/sso/services/scimTokenService.ts +136 -0
  189. package/src/modules/sso/services/ssoConfigService.ts +337 -0
  190. package/src/modules/sso/services/ssoService.ts +167 -0
  191. package/src/modules/sso/setup.ts +56 -0
  192. package/src/modules/sso/subscribers/user-deleted-cleanup.ts +33 -0
  193. package/src/modules/sso/widgets/injection/login-sso/widget.client.tsx +130 -0
  194. package/src/modules/sso/widgets/injection/login-sso/widget.ts +16 -0
  195. package/src/modules/sso/widgets/injection-table.ts +12 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../src/modules/sso/backend/sso/config/new/page.tsx"],
4
+ "sourcesContent": ["'use client'\n\nimport React from 'react'\nimport { useRouter } from 'next/navigation'\nimport { Page, PageBody } from '@open-mercato/ui/backend/Page'\nimport { Button } from '@open-mercato/ui/primitives/button'\nimport { apiCall, apiCallOrThrow } from '@open-mercato/ui/backend/utils/apiCall'\nimport { flash } from '@open-mercato/ui/backend/FlashMessages'\nimport { useT } from '@open-mercato/shared/lib/i18n/context'\nimport { useGuardedMutation } from '@open-mercato/ui/backend/injection/useGuardedMutation'\n\ntype WizardStep = 'protocol' | 'credentials' | 'domains' | 'options' | 'review'\n\nconst STEPS: WizardStep[] = ['protocol', 'credentials', 'domains', 'options', 'review']\n\ninterface WizardState {\n name: string\n protocol: 'oidc'\n issuer: string\n clientId: string\n clientSecret: string\n domains: string[]\n jitEnabled: boolean\n autoLinkByEmail: boolean\n}\n\nconst initialState: WizardState = {\n name: '',\n protocol: 'oidc',\n issuer: '',\n clientId: '',\n clientSecret: '',\n domains: [],\n jitEnabled: true,\n autoLinkByEmail: true,\n}\n\nexport default function SsoConfigCreateWizard() {\n const router = useRouter()\n const t = useT()\n const [step, setStep] = React.useState<WizardStep>('protocol')\n const [state, setState] = React.useState<WizardState>(initialState)\n const [domainInput, setDomainInput] = React.useState('')\n const [domainError, setDomainError] = React.useState('')\n const [isSubmitting, setIsSubmitting] = React.useState(false)\n const [testResult, setTestResult] = React.useState<{ ok: boolean; error?: string } | null>(null)\n const [isTesting, setIsTesting] = React.useState(false)\n\n const { runMutation, retryLastMutation } = useGuardedMutation<Record<string, unknown>>({\n contextId: 'sso-config-create',\n })\n const runMutationWithContext = React.useCallback(\n async <T,>(operation: () => Promise<T>, mutationPayload?: Record<string, unknown>): Promise<T> => {\n return runMutation({\n operation,\n mutationPayload,\n context: { retryLastMutation },\n })\n },\n [retryLastMutation, runMutation],\n )\n\n React.useEffect(() => {\n const checkExisting = async () => {\n const call = await apiCall<{ items: { id: string }[] }>('/api/sso/config?pageSize=1')\n if (call.ok && call.result && call.result.items.length > 0) {\n flash(t('sso.admin.error.alreadyExists', 'An SSO configuration already exists for this organization'), 'error')\n router.replace(`/backend/sso/config/${call.result.items[0].id}`)\n }\n }\n checkExisting()\n }, [router, t])\n\n const currentStepIndex = STEPS.indexOf(step)\n\n const callbackUrl = typeof window !== 'undefined'\n ? `${window.location.origin}/api/sso/callback/oidc`\n : '/api/sso/callback/oidc'\n\n const goNext = () => {\n const nextIndex = currentStepIndex + 1\n if (nextIndex < STEPS.length) setStep(STEPS[nextIndex])\n }\n\n const goBack = () => {\n const prevIndex = currentStepIndex - 1\n if (prevIndex >= 0) setStep(STEPS[prevIndex])\n }\n\n const handleAddDomain = () => {\n const normalized = domainInput.trim().toLowerCase()\n if (!normalized) return\n\n const domainRegex = /^[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?(\\.[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/\n if (!domainRegex.test(normalized) || !normalized.includes('.')) {\n setDomainError(t('sso.admin.wizard.domain.invalid', 'Invalid domain format'))\n return\n }\n\n if (state.domains.includes(normalized)) {\n setDomainError(t('sso.admin.wizard.domain.duplicate', 'Domain already added'))\n return\n }\n\n if (state.domains.length >= 20) {\n setDomainError(t('sso.admin.wizard.domain.limit', 'Maximum 20 domains per configuration'))\n return\n }\n\n setState((prev) => ({ ...prev, domains: [...prev.domains, normalized] }))\n setDomainInput('')\n setDomainError('')\n }\n\n const handleRemoveDomain = (domain: string) => {\n setState((prev) => ({ ...prev, domains: prev.domains.filter((d) => d !== domain) }))\n }\n\n const handleSubmit = async () => {\n setIsSubmitting(true)\n try {\n const payload = {\n name: state.name,\n protocol: state.protocol,\n issuer: state.issuer,\n clientId: state.clientId,\n clientSecret: state.clientSecret,\n allowedDomains: state.domains,\n jitEnabled: state.jitEnabled,\n autoLinkByEmail: state.autoLinkByEmail,\n }\n const call = await runMutationWithContext(\n () => apiCallOrThrow<{ id: string }>(\n '/api/sso/config',\n {\n method: 'POST',\n headers: { 'content-type': 'application/json' },\n body: JSON.stringify(payload),\n },\n { errorMessage: t('sso.admin.error.createFailed', 'Failed to create SSO configuration') },\n ),\n payload,\n )\n flash(t('sso.admin.created', 'SSO configuration created'), 'success')\n router.push(`/backend/sso/config/${call.result?.id}?created=1`)\n } catch {\n // apiCallOrThrow handles the error\n } finally {\n setIsSubmitting(false)\n }\n }\n\n const handleTestConnection = async () => {\n setIsTesting(true)\n setTestResult(null)\n try {\n // Raw fetch is intentional: this is a pre-save OIDC discovery probe against an\n // external IdP URL, not an internal API call, so apiCall is not applicable here.\n const response = await fetch(state.issuer + '/.well-known/openid-configuration')\n if (response.ok) {\n setTestResult({ ok: true })\n flash(t('sso.admin.test.success', 'Discovery successful \u2014 issuer is reachable'), 'success')\n } else {\n setTestResult({ ok: false, error: `HTTP ${response.status}` })\n flash(t('sso.admin.test.failed', 'Discovery failed'), 'error')\n }\n } catch (err) {\n setTestResult({ ok: false, error: String(err) })\n flash(t('sso.admin.test.failed', 'Discovery failed \u2014 issuer is not reachable'), 'error')\n } finally {\n setIsTesting(false)\n }\n }\n\n const canProceed = (): boolean => {\n switch (step) {\n case 'protocol': return true\n case 'credentials': return !!(state.name && state.issuer && state.clientId && state.clientSecret)\n case 'domains': return true\n case 'options': return true\n case 'review': return !isSubmitting\n default: return false\n }\n }\n\n return (\n <Page>\n <PageBody>\n <div className=\"max-w-2xl mx-auto\">\n {/* Step indicator */}\n <div className=\"flex items-center gap-2 mb-8\">\n {STEPS.map((s, i) => (\n <React.Fragment key={s}>\n <div\n className={`flex items-center justify-center w-8 h-8 rounded-full text-sm font-medium ${\n i <= currentStepIndex\n ? 'bg-primary text-primary-foreground'\n : 'bg-muted text-muted-foreground'\n }`}\n >\n {i + 1}\n </div>\n {i < STEPS.length - 1 && (\n <div className={`flex-1 h-0.5 ${i < currentStepIndex ? 'bg-primary' : 'bg-muted'}`} />\n )}\n </React.Fragment>\n ))}\n </div>\n\n {/* Step content */}\n {step === 'protocol' && (\n <div>\n <h2 className=\"text-lg font-semibold mb-4\">{t('sso.admin.wizard.protocol.title', 'Select Protocol')}</h2>\n <div className=\"space-y-3\">\n <label className=\"flex items-center gap-3 p-4 border rounded-lg cursor-pointer bg-accent/50 border-primary\">\n <input type=\"radio\" name=\"protocol\" value=\"oidc\" checked readOnly className=\"accent-primary\" />\n <div>\n <div className=\"font-medium\">OpenID Connect (OIDC)</div>\n <div className=\"text-sm text-muted-foreground\">\n {t('sso.admin.wizard.protocol.oidcDesc', 'Works with Zitadel, Microsoft Entra ID, Google Workspace, Okta, and more')}\n </div>\n </div>\n </label>\n <div className=\"flex items-center gap-3 p-4 border rounded-lg opacity-50 cursor-not-allowed bg-muted/30\">\n <input type=\"radio\" name=\"protocol\" value=\"saml\" disabled className=\"accent-primary\" />\n <div>\n <div className=\"font-medium\">SAML 2.0</div>\n <div className=\"text-sm text-muted-foreground\">\n {t('sso.admin.wizard.protocol.samlDesc', 'Coming soon')}\n </div>\n </div>\n </div>\n </div>\n </div>\n )}\n\n {step === 'credentials' && (\n <div>\n <h2 className=\"text-lg font-semibold mb-4\">{t('sso.admin.wizard.credentials.title', 'OIDC Credentials')}</h2>\n <div className=\"space-y-4\">\n <div>\n <label className=\"block text-sm font-medium mb-1\">{t('sso.admin.field.name', 'Configuration Name')}</label>\n <input\n type=\"text\"\n className=\"w-full rounded-md border px-3 py-2 text-sm\"\n placeholder={t('sso.admin.wizard.credentials.namePlaceholder', 'e.g., Zitadel Production')}\n value={state.name}\n onChange={(e) => setState((prev) => ({ ...prev, name: e.target.value }))}\n />\n </div>\n <div>\n <label className=\"block text-sm font-medium mb-1\">{t('sso.admin.field.issuer', 'Issuer URL')}</label>\n <input\n type=\"url\"\n className=\"w-full rounded-md border px-3 py-2 text-sm\"\n placeholder=\"https://your-idp.example.com\"\n value={state.issuer}\n onChange={(e) => setState((prev) => ({ ...prev, issuer: e.target.value }))}\n />\n </div>\n <div>\n <label className=\"block text-sm font-medium mb-1\">{t('sso.admin.field.clientId', 'Client ID')}</label>\n <input\n type=\"text\"\n className=\"w-full rounded-md border px-3 py-2 text-sm\"\n value={state.clientId}\n onChange={(e) => setState((prev) => ({ ...prev, clientId: e.target.value }))}\n />\n </div>\n <div>\n <label className=\"block text-sm font-medium mb-1\">{t('sso.admin.field.clientSecret', 'Client Secret')}</label>\n <input\n type=\"password\"\n className=\"w-full rounded-md border px-3 py-2 text-sm\"\n value={state.clientSecret}\n onChange={(e) => setState((prev) => ({ ...prev, clientSecret: e.target.value }))}\n />\n </div>\n <div className=\"rounded-md bg-muted/50 p-3\">\n <label className=\"block text-sm font-medium mb-1\">{t('sso.admin.wizard.credentials.callbackUrl', 'Redirect URI (copy to your IdP)')}</label>\n <div className=\"flex items-center gap-2\">\n <code className=\"flex-1 text-sm bg-background p-2 rounded border font-mono break-all\">{callbackUrl}</code>\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={() => {\n navigator.clipboard.writeText(callbackUrl)\n flash(t('common.copied', 'Copied to clipboard'), 'success')\n }}\n >\n {t('common.copy', 'Copy')}\n </Button>\n </div>\n </div>\n </div>\n </div>\n )}\n\n {step === 'domains' && (\n <div>\n <h2 className=\"text-lg font-semibold mb-4\">{t('sso.admin.wizard.domains.title', 'Allowed Email Domains')}</h2>\n <p className=\"text-sm text-muted-foreground mb-4\">\n {t('sso.admin.wizard.domains.description', 'Users with email addresses matching these domains will be redirected to your SSO provider.')}\n </p>\n <div className=\"flex items-center gap-2 mb-4\">\n <input\n type=\"text\"\n className=\"flex-1 rounded-md border px-3 py-2 text-sm\"\n placeholder={t('sso.admin.wizard.domains.placeholder', 'example.com')}\n value={domainInput}\n onChange={(e) => { setDomainInput(e.target.value); setDomainError('') }}\n onKeyDown={(e) => { if (e.key === 'Enter') { e.preventDefault(); handleAddDomain() } }}\n />\n <Button variant=\"outline\" onClick={handleAddDomain}>\n {t('common.add', 'Add')}\n </Button>\n </div>\n {domainError && <p className=\"text-sm text-destructive mb-2\">{domainError}</p>}\n {state.domains.length > 0 && (\n <div className=\"space-y-2\">\n {state.domains.map((domain) => (\n <div key={domain} className=\"flex items-center justify-between p-2 border rounded-md\">\n <code className=\"text-sm font-mono\">{domain}</code>\n <Button variant=\"ghost\" size=\"sm\" onClick={() => handleRemoveDomain(domain)}>\n {t('common.remove', 'Remove')}\n </Button>\n </div>\n ))}\n </div>\n )}\n </div>\n )}\n\n {step === 'options' && (\n <div>\n <h2 className=\"text-lg font-semibold mb-4\">{t('sso.admin.wizard.options.title', 'Options')}</h2>\n <div className=\"space-y-4\">\n <label className=\"flex items-center gap-3\">\n <input\n type=\"checkbox\"\n checked={state.jitEnabled}\n onChange={(e) => setState((prev) => ({ ...prev, jitEnabled: e.target.checked }))}\n className=\"accent-primary\"\n />\n <div>\n <div className=\"font-medium text-sm\">{t('sso.admin.field.jitEnabled', 'Just-in-Time Provisioning')}</div>\n <div className=\"text-xs text-muted-foreground\">\n {t('sso.admin.field.jitEnabledDesc', 'Automatically create user accounts on first SSO login')}\n </div>\n </div>\n </label>\n <label className=\"flex items-center gap-3\">\n <input\n type=\"checkbox\"\n checked={state.autoLinkByEmail}\n onChange={(e) => setState((prev) => ({ ...prev, autoLinkByEmail: e.target.checked }))}\n className=\"accent-primary\"\n />\n <div>\n <div className=\"font-medium text-sm\">{t('sso.admin.field.autoLinkByEmail', 'Auto-link by Email')}</div>\n <div className=\"text-xs text-muted-foreground\">\n {t('sso.admin.field.autoLinkByEmailDesc', 'Automatically link existing users by matching email address')}\n </div>\n </div>\n </label>\n </div>\n </div>\n )}\n\n {step === 'review' && (\n <div>\n <h2 className=\"text-lg font-semibold mb-4\">{t('sso.admin.wizard.review.title', 'Review & Save')}</h2>\n <div className=\"space-y-4\">\n <div className=\"border rounded-lg divide-y\">\n <div className=\"flex justify-between p-3\">\n <span className=\"text-sm text-muted-foreground\">{t('sso.admin.field.name', 'Name')}</span>\n <span className=\"text-sm font-medium\">{state.name}</span>\n </div>\n <div className=\"flex justify-between p-3\">\n <span className=\"text-sm text-muted-foreground\">{t('sso.admin.field.protocol', 'Protocol')}</span>\n <span className=\"text-sm font-medium\">{state.protocol.toUpperCase()}</span>\n </div>\n <div className=\"flex justify-between p-3\">\n <span className=\"text-sm text-muted-foreground\">{t('sso.admin.field.issuer', 'Issuer')}</span>\n <span className=\"text-sm font-medium break-all\">{state.issuer}</span>\n </div>\n <div className=\"flex justify-between p-3\">\n <span className=\"text-sm text-muted-foreground\">{t('sso.admin.field.clientId', 'Client ID')}</span>\n <span className=\"text-sm font-medium\">{state.clientId}</span>\n </div>\n <div className=\"flex justify-between p-3\">\n <span className=\"text-sm text-muted-foreground\">{t('sso.admin.wizard.domains.title', 'Domains')}</span>\n <span className=\"text-sm font-medium\">{state.domains.join(', ') || '\u2014'}</span>\n </div>\n <div className=\"flex justify-between p-3\">\n <span className=\"text-sm text-muted-foreground\">{t('sso.admin.field.jitEnabled', 'JIT Provisioning')}</span>\n <span className=\"text-sm font-medium\">{state.jitEnabled ? t('common.enabled', 'Enabled') : t('common.disabled', 'Disabled')}</span>\n </div>\n <div className=\"flex justify-between p-3\">\n <span className=\"text-sm text-muted-foreground\">{t('sso.admin.field.autoLinkByEmail', 'Auto-link')}</span>\n <span className=\"text-sm font-medium\">{state.autoLinkByEmail ? t('common.enabled', 'Enabled') : t('common.disabled', 'Disabled')}</span>\n </div>\n </div>\n\n {/* Test connection before saving */}\n <div className=\"flex items-center gap-3 p-4 border rounded-lg bg-muted/30\">\n <Button\n variant=\"outline\"\n onClick={handleTestConnection}\n disabled={isTesting}\n >\n {isTesting\n ? t('sso.admin.wizard.review.testing', 'Testing...')\n : t('sso.admin.action.test', 'Verify Discovery')}\n </Button>\n {testResult && (\n <span className={`text-sm ${testResult.ok ? 'text-green-600' : 'text-destructive'}`}>\n {testResult.ok\n ? t('sso.admin.test.success', 'Discovery successful')\n : testResult.error || t('sso.admin.test.failed', 'Discovery failed')}\n </span>\n )}\n </div>\n\n <p className=\"text-sm text-muted-foreground\">\n {t('sso.admin.wizard.review.note', 'The configuration will be created as inactive. You can activate it from the detail page after verifying everything is correct.')}\n </p>\n </div>\n </div>\n )}\n\n {/* Navigation */}\n <div className=\"flex justify-between mt-8 pt-4 border-t\">\n <div>\n {currentStepIndex > 0 ? (\n <Button variant=\"outline\" onClick={goBack}>\n {t('common.back', 'Back')}\n </Button>\n ) : (\n <Button variant=\"outline\" onClick={() => router.push('/backend/sso')}>\n {t('common.cancel', 'Cancel')}\n </Button>\n )}\n </div>\n <div>\n {step === 'review' ? (\n <Button onClick={handleSubmit} disabled={!canProceed()}>\n {isSubmitting\n ? t('common.saving', 'Saving...')\n : t('sso.admin.wizard.review.save', 'Create Configuration')}\n </Button>\n ) : (\n <Button onClick={goNext} disabled={!canProceed()}>\n {t('common.next', 'Next')}\n </Button>\n )}\n </div>\n </div>\n </div>\n </PageBody>\n </Page>\n )\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,19 @@
1
+ const metadata = {
2
+ requireAuth: true,
3
+ requireFeatures: ["sso.config.manage"],
4
+ pageTitle: "Configure SSO",
5
+ pageTitleKey: "sso.admin.create.title",
6
+ pageGroup: "Auth",
7
+ pageGroupKey: "settings.sections.auth",
8
+ pageOrder: 521,
9
+ pageContext: "settings",
10
+ navHidden: true,
11
+ breadcrumb: [
12
+ { label: "Single Sign-On", labelKey: "sso.admin.title", href: "/backend/sso" },
13
+ { label: "Configure SSO", labelKey: "sso.admin.create.title" }
14
+ ]
15
+ };
16
+ export {
17
+ metadata
18
+ };
19
+ //# sourceMappingURL=page.meta.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../src/modules/sso/backend/sso/config/new/page.meta.ts"],
4
+ "sourcesContent": ["export const metadata = {\n requireAuth: true,\n requireFeatures: ['sso.config.manage'],\n pageTitle: 'Configure SSO',\n pageTitleKey: 'sso.admin.create.title',\n pageGroup: 'Auth',\n pageGroupKey: 'settings.sections.auth',\n pageOrder: 521,\n pageContext: 'settings' as const,\n navHidden: true,\n breadcrumb: [\n { label: 'Single Sign-On', labelKey: 'sso.admin.title', href: '/backend/sso' },\n { label: 'Configure SSO', labelKey: 'sso.admin.create.title' },\n ],\n}\n"],
5
+ "mappings": "AAAO,MAAM,WAAW;AAAA,EACtB,aAAa;AAAA,EACb,iBAAiB,CAAC,mBAAmB;AAAA,EACrC,WAAW;AAAA,EACX,cAAc;AAAA,EACd,WAAW;AAAA,EACX,cAAc;AAAA,EACd,WAAW;AAAA,EACX,aAAa;AAAA,EACb,WAAW;AAAA,EACX,YAAY;AAAA,IACV,EAAE,OAAO,kBAAkB,UAAU,mBAAmB,MAAM,eAAe;AAAA,IAC7E,EAAE,OAAO,iBAAiB,UAAU,yBAAyB;AAAA,EAC/D;AACF;",
6
+ "names": []
7
+ }
@@ -0,0 +1,299 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __decorateClass = (decorators, target, key, kind) => {
4
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
5
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
6
+ if (decorator = decorators[i])
7
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
8
+ if (kind && result) __defProp(target, key, result);
9
+ return result;
10
+ };
11
+ import { Entity, PrimaryKey, Property, Unique, Index } from "@mikro-orm/core";
12
+ let SsoConfig = class {
13
+ constructor() {
14
+ this.allowedDomains = [];
15
+ this.jitEnabled = true;
16
+ this.autoLinkByEmail = true;
17
+ this.isActive = false;
18
+ this.ssoRequired = false;
19
+ this.appRoleMappings = {};
20
+ this.createdAt = /* @__PURE__ */ new Date();
21
+ this.updatedAt = /* @__PURE__ */ new Date();
22
+ }
23
+ };
24
+ __decorateClass([
25
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
26
+ ], SsoConfig.prototype, "id", 2);
27
+ __decorateClass([
28
+ Property({ name: "tenant_id", type: "uuid", nullable: true })
29
+ ], SsoConfig.prototype, "tenantId", 2);
30
+ __decorateClass([
31
+ Property({ name: "organization_id", type: "uuid" })
32
+ ], SsoConfig.prototype, "organizationId", 2);
33
+ __decorateClass([
34
+ Property({ type: "text", nullable: true })
35
+ ], SsoConfig.prototype, "name", 2);
36
+ __decorateClass([
37
+ Property({ type: "text" })
38
+ ], SsoConfig.prototype, "protocol", 2);
39
+ __decorateClass([
40
+ Property({ type: "text", nullable: true })
41
+ ], SsoConfig.prototype, "issuer", 2);
42
+ __decorateClass([
43
+ Property({ name: "client_id", type: "text", nullable: true })
44
+ ], SsoConfig.prototype, "clientId", 2);
45
+ __decorateClass([
46
+ Property({ name: "client_secret_enc", type: "text", nullable: true })
47
+ ], SsoConfig.prototype, "clientSecretEnc", 2);
48
+ __decorateClass([
49
+ Property({ name: "allowed_domains", type: "jsonb", default: "[]" })
50
+ ], SsoConfig.prototype, "allowedDomains", 2);
51
+ __decorateClass([
52
+ Property({ name: "jit_enabled", type: "boolean", default: true })
53
+ ], SsoConfig.prototype, "jitEnabled", 2);
54
+ __decorateClass([
55
+ Property({ name: "auto_link_by_email", type: "boolean", default: true })
56
+ ], SsoConfig.prototype, "autoLinkByEmail", 2);
57
+ __decorateClass([
58
+ Property({ name: "is_active", type: "boolean", default: false })
59
+ ], SsoConfig.prototype, "isActive", 2);
60
+ __decorateClass([
61
+ Property({ name: "sso_required", type: "boolean", default: false })
62
+ ], SsoConfig.prototype, "ssoRequired", 2);
63
+ __decorateClass([
64
+ Property({ name: "app_role_mappings", type: "jsonb", default: "{}" })
65
+ ], SsoConfig.prototype, "appRoleMappings", 2);
66
+ __decorateClass([
67
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
68
+ ], SsoConfig.prototype, "createdAt", 2);
69
+ __decorateClass([
70
+ Property({ name: "updated_at", type: Date, onCreate: () => /* @__PURE__ */ new Date(), onUpdate: () => /* @__PURE__ */ new Date() })
71
+ ], SsoConfig.prototype, "updatedAt", 2);
72
+ __decorateClass([
73
+ Property({ name: "deleted_at", type: Date, nullable: true })
74
+ ], SsoConfig.prototype, "deletedAt", 2);
75
+ SsoConfig = __decorateClass([
76
+ Entity({ tableName: "sso_configs" })
77
+ ], SsoConfig);
78
+ let SsoIdentity = class {
79
+ constructor() {
80
+ this.idpGroups = [];
81
+ this.createdAt = /* @__PURE__ */ new Date();
82
+ this.updatedAt = /* @__PURE__ */ new Date();
83
+ }
84
+ };
85
+ __decorateClass([
86
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
87
+ ], SsoIdentity.prototype, "id", 2);
88
+ __decorateClass([
89
+ Property({ name: "tenant_id", type: "uuid", nullable: true })
90
+ ], SsoIdentity.prototype, "tenantId", 2);
91
+ __decorateClass([
92
+ Property({ name: "organization_id", type: "uuid" })
93
+ ], SsoIdentity.prototype, "organizationId", 2);
94
+ __decorateClass([
95
+ Property({ name: "sso_config_id", type: "uuid" }),
96
+ Index({ name: "sso_identities_config_id_idx" })
97
+ ], SsoIdentity.prototype, "ssoConfigId", 2);
98
+ __decorateClass([
99
+ Property({ name: "user_id", type: "uuid" }),
100
+ Index({ name: "sso_identities_user_id_idx" })
101
+ ], SsoIdentity.prototype, "userId", 2);
102
+ __decorateClass([
103
+ Property({ name: "idp_subject", type: "text" })
104
+ ], SsoIdentity.prototype, "idpSubject", 2);
105
+ __decorateClass([
106
+ Property({ name: "idp_email", type: "text" })
107
+ ], SsoIdentity.prototype, "idpEmail", 2);
108
+ __decorateClass([
109
+ Property({ name: "idp_name", type: "text", nullable: true })
110
+ ], SsoIdentity.prototype, "idpName", 2);
111
+ __decorateClass([
112
+ Property({ name: "idp_groups", type: "jsonb", default: "[]" })
113
+ ], SsoIdentity.prototype, "idpGroups", 2);
114
+ __decorateClass([
115
+ Property({ name: "external_id", type: "text", nullable: true })
116
+ ], SsoIdentity.prototype, "externalId", 2);
117
+ __decorateClass([
118
+ Property({ name: "provisioning_method", type: "text" })
119
+ ], SsoIdentity.prototype, "provisioningMethod", 2);
120
+ __decorateClass([
121
+ Property({ name: "first_login_at", type: Date, nullable: true })
122
+ ], SsoIdentity.prototype, "firstLoginAt", 2);
123
+ __decorateClass([
124
+ Property({ name: "last_login_at", type: Date, nullable: true })
125
+ ], SsoIdentity.prototype, "lastLoginAt", 2);
126
+ __decorateClass([
127
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
128
+ ], SsoIdentity.prototype, "createdAt", 2);
129
+ __decorateClass([
130
+ Property({ name: "updated_at", type: Date, onCreate: () => /* @__PURE__ */ new Date(), onUpdate: () => /* @__PURE__ */ new Date() })
131
+ ], SsoIdentity.prototype, "updatedAt", 2);
132
+ __decorateClass([
133
+ Property({ name: "deleted_at", type: Date, nullable: true })
134
+ ], SsoIdentity.prototype, "deletedAt", 2);
135
+ SsoIdentity = __decorateClass([
136
+ Entity({ tableName: "sso_identities" })
137
+ ], SsoIdentity);
138
+ let ScimToken = class {
139
+ constructor() {
140
+ this.isActive = true;
141
+ this.createdAt = /* @__PURE__ */ new Date();
142
+ this.updatedAt = /* @__PURE__ */ new Date();
143
+ }
144
+ };
145
+ __decorateClass([
146
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
147
+ ], ScimToken.prototype, "id", 2);
148
+ __decorateClass([
149
+ Property({ name: "tenant_id", type: "uuid", nullable: true })
150
+ ], ScimToken.prototype, "tenantId", 2);
151
+ __decorateClass([
152
+ Property({ name: "organization_id", type: "uuid" })
153
+ ], ScimToken.prototype, "organizationId", 2);
154
+ __decorateClass([
155
+ Property({ name: "sso_config_id", type: "uuid" }),
156
+ Index({ name: "scim_tokens_sso_config_id_idx" })
157
+ ], ScimToken.prototype, "ssoConfigId", 2);
158
+ __decorateClass([
159
+ Property({ type: "text" })
160
+ ], ScimToken.prototype, "name", 2);
161
+ __decorateClass([
162
+ Property({ name: "token_hash", type: "text" })
163
+ ], ScimToken.prototype, "tokenHash", 2);
164
+ __decorateClass([
165
+ Property({ name: "token_prefix", type: "text" })
166
+ ], ScimToken.prototype, "tokenPrefix", 2);
167
+ __decorateClass([
168
+ Property({ name: "is_active", type: "boolean", default: true })
169
+ ], ScimToken.prototype, "isActive", 2);
170
+ __decorateClass([
171
+ Property({ name: "created_by", type: "uuid", nullable: true })
172
+ ], ScimToken.prototype, "createdBy", 2);
173
+ __decorateClass([
174
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
175
+ ], ScimToken.prototype, "createdAt", 2);
176
+ __decorateClass([
177
+ Property({ name: "updated_at", type: Date, onCreate: () => /* @__PURE__ */ new Date(), onUpdate: () => /* @__PURE__ */ new Date() })
178
+ ], ScimToken.prototype, "updatedAt", 2);
179
+ ScimToken = __decorateClass([
180
+ Entity({ tableName: "scim_tokens" }),
181
+ Index({ name: "scim_tokens_token_prefix_idx", properties: ["tokenPrefix"] })
182
+ ], ScimToken);
183
+ let SsoUserDeactivation = class {
184
+ constructor() {
185
+ this.deactivatedAt = /* @__PURE__ */ new Date();
186
+ this.createdAt = /* @__PURE__ */ new Date();
187
+ }
188
+ };
189
+ __decorateClass([
190
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
191
+ ], SsoUserDeactivation.prototype, "id", 2);
192
+ __decorateClass([
193
+ Property({ name: "tenant_id", type: "uuid", nullable: true })
194
+ ], SsoUserDeactivation.prototype, "tenantId", 2);
195
+ __decorateClass([
196
+ Property({ name: "organization_id", type: "uuid" })
197
+ ], SsoUserDeactivation.prototype, "organizationId", 2);
198
+ __decorateClass([
199
+ Property({ name: "user_id", type: "uuid" }),
200
+ Index({ name: "sso_user_deactivations_user_id_idx" })
201
+ ], SsoUserDeactivation.prototype, "userId", 2);
202
+ __decorateClass([
203
+ Property({ name: "sso_config_id", type: "uuid" })
204
+ ], SsoUserDeactivation.prototype, "ssoConfigId", 2);
205
+ __decorateClass([
206
+ Property({ name: "deactivated_at", type: Date })
207
+ ], SsoUserDeactivation.prototype, "deactivatedAt", 2);
208
+ __decorateClass([
209
+ Property({ name: "reactivated_at", type: Date, nullable: true })
210
+ ], SsoUserDeactivation.prototype, "reactivatedAt", 2);
211
+ __decorateClass([
212
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
213
+ ], SsoUserDeactivation.prototype, "createdAt", 2);
214
+ SsoUserDeactivation = __decorateClass([
215
+ Entity({ tableName: "sso_user_deactivations" }),
216
+ Unique({ properties: ["userId", "ssoConfigId"], name: "sso_user_deactivations_user_config_unique" })
217
+ ], SsoUserDeactivation);
218
+ let ScimProvisioningLog = class {
219
+ constructor() {
220
+ this.createdAt = /* @__PURE__ */ new Date();
221
+ }
222
+ };
223
+ __decorateClass([
224
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
225
+ ], ScimProvisioningLog.prototype, "id", 2);
226
+ __decorateClass([
227
+ Property({ name: "tenant_id", type: "uuid", nullable: true })
228
+ ], ScimProvisioningLog.prototype, "tenantId", 2);
229
+ __decorateClass([
230
+ Property({ name: "organization_id", type: "uuid" })
231
+ ], ScimProvisioningLog.prototype, "organizationId", 2);
232
+ __decorateClass([
233
+ Property({ name: "sso_config_id", type: "uuid" })
234
+ ], ScimProvisioningLog.prototype, "ssoConfigId", 2);
235
+ __decorateClass([
236
+ Property({ type: "text" })
237
+ ], ScimProvisioningLog.prototype, "operation", 2);
238
+ __decorateClass([
239
+ Property({ name: "resource_type", type: "text" })
240
+ ], ScimProvisioningLog.prototype, "resourceType", 2);
241
+ __decorateClass([
242
+ Property({ name: "resource_id", type: "uuid", nullable: true })
243
+ ], ScimProvisioningLog.prototype, "resourceId", 2);
244
+ __decorateClass([
245
+ Property({ name: "scim_external_id", type: "text", nullable: true })
246
+ ], ScimProvisioningLog.prototype, "scimExternalId", 2);
247
+ __decorateClass([
248
+ Property({ name: "response_status", type: "integer" })
249
+ ], ScimProvisioningLog.prototype, "responseStatus", 2);
250
+ __decorateClass([
251
+ Property({ name: "error_message", type: "text", nullable: true })
252
+ ], ScimProvisioningLog.prototype, "errorMessage", 2);
253
+ __decorateClass([
254
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
255
+ ], ScimProvisioningLog.prototype, "createdAt", 2);
256
+ ScimProvisioningLog = __decorateClass([
257
+ Entity({ tableName: "scim_provisioning_log" }),
258
+ Index({ name: "scim_provisioning_log_config_created_idx", properties: ["ssoConfigId", "createdAt"] })
259
+ ], ScimProvisioningLog);
260
+ let SsoRoleGrant = class {
261
+ constructor() {
262
+ this.createdAt = /* @__PURE__ */ new Date();
263
+ }
264
+ };
265
+ __decorateClass([
266
+ PrimaryKey({ type: "uuid", defaultRaw: "gen_random_uuid()" })
267
+ ], SsoRoleGrant.prototype, "id", 2);
268
+ __decorateClass([
269
+ Property({ name: "tenant_id", type: "uuid", nullable: true })
270
+ ], SsoRoleGrant.prototype, "tenantId", 2);
271
+ __decorateClass([
272
+ Property({ name: "organization_id", type: "uuid" })
273
+ ], SsoRoleGrant.prototype, "organizationId", 2);
274
+ __decorateClass([
275
+ Property({ name: "user_id", type: "uuid" }),
276
+ Index({ name: "sso_role_grants_user_id_idx" })
277
+ ], SsoRoleGrant.prototype, "userId", 2);
278
+ __decorateClass([
279
+ Property({ name: "role_id", type: "uuid" })
280
+ ], SsoRoleGrant.prototype, "roleId", 2);
281
+ __decorateClass([
282
+ Property({ name: "sso_config_id", type: "uuid" })
283
+ ], SsoRoleGrant.prototype, "ssoConfigId", 2);
284
+ __decorateClass([
285
+ Property({ name: "created_at", type: Date, onCreate: () => /* @__PURE__ */ new Date() })
286
+ ], SsoRoleGrant.prototype, "createdAt", 2);
287
+ SsoRoleGrant = __decorateClass([
288
+ Entity({ tableName: "sso_role_grants" }),
289
+ Unique({ properties: ["userId", "roleId", "ssoConfigId"], name: "sso_role_grants_user_role_config_unique" })
290
+ ], SsoRoleGrant);
291
+ export {
292
+ ScimProvisioningLog,
293
+ ScimToken,
294
+ SsoConfig,
295
+ SsoIdentity,
296
+ SsoRoleGrant,
297
+ SsoUserDeactivation
298
+ };
299
+ //# sourceMappingURL=entities.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/modules/sso/data/entities.ts"],
4
+ "sourcesContent": ["import { Entity, PrimaryKey, Property, Unique, Index } from '@mikro-orm/core'\n\n@Entity({ tableName: 'sso_configs' })\n// Unique index on organization_id (partial: WHERE deleted_at IS NULL) \u2014 managed by migration\nexport class SsoConfig {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid', nullable: true })\n tenantId?: string | null\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ type: 'text', nullable: true })\n name?: string | null\n\n @Property({ type: 'text' })\n protocol!: string\n\n @Property({ type: 'text', nullable: true })\n issuer?: string | null\n\n @Property({ name: 'client_id', type: 'text', nullable: true })\n clientId?: string | null\n\n @Property({ name: 'client_secret_enc', type: 'text', nullable: true })\n clientSecretEnc?: string | null\n\n @Property({ name: 'allowed_domains', type: 'jsonb', default: '[]' })\n allowedDomains: string[] = []\n\n @Property({ name: 'jit_enabled', type: 'boolean', default: true })\n jitEnabled: boolean = true\n\n @Property({ name: 'auto_link_by_email', type: 'boolean', default: true })\n autoLinkByEmail: boolean = true\n\n @Property({ name: 'is_active', type: 'boolean', default: false })\n isActive: boolean = false\n\n @Property({ name: 'sso_required', type: 'boolean', default: false })\n ssoRequired: boolean = false\n\n @Property({ name: 'app_role_mappings', type: 'jsonb', default: '{}' })\n appRoleMappings: Record<string, string> = {}\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'sso_identities' })\n// Unique indexes (partial: WHERE deleted_at IS NULL) \u2014 managed by migration\nexport class SsoIdentity {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid', nullable: true })\n tenantId?: string | null\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'sso_config_id', type: 'uuid' })\n @Index({ name: 'sso_identities_config_id_idx' })\n ssoConfigId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n @Index({ name: 'sso_identities_user_id_idx' })\n userId!: string\n\n @Property({ name: 'idp_subject', type: 'text' })\n idpSubject!: string\n\n @Property({ name: 'idp_email', type: 'text' })\n idpEmail!: string\n\n @Property({ name: 'idp_name', type: 'text', nullable: true })\n idpName?: string | null\n\n @Property({ name: 'idp_groups', type: 'jsonb', default: '[]' })\n idpGroups: string[] = []\n\n @Property({ name: 'external_id', type: 'text', nullable: true })\n externalId?: string | null\n\n @Property({ name: 'provisioning_method', type: 'text' })\n provisioningMethod!: string\n\n @Property({ name: 'first_login_at', type: Date, nullable: true })\n firstLoginAt?: Date | null\n\n @Property({ name: 'last_login_at', type: Date, nullable: true })\n lastLoginAt?: Date | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'scim_tokens' })\n@Index({ name: 'scim_tokens_token_prefix_idx', properties: ['tokenPrefix'] })\nexport class ScimToken {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid', nullable: true })\n tenantId?: string | null\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'sso_config_id', type: 'uuid' })\n @Index({ name: 'scim_tokens_sso_config_id_idx' })\n ssoConfigId!: string\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ name: 'token_hash', type: 'text' })\n tokenHash!: string\n\n @Property({ name: 'token_prefix', type: 'text' })\n tokenPrefix!: string\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_by', type: 'uuid', nullable: true })\n createdBy?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'sso_user_deactivations' })\n@Unique({ properties: ['userId', 'ssoConfigId'], name: 'sso_user_deactivations_user_config_unique' })\nexport class SsoUserDeactivation {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid', nullable: true })\n tenantId?: string | null\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n @Index({ name: 'sso_user_deactivations_user_id_idx' })\n userId!: string\n\n @Property({ name: 'sso_config_id', type: 'uuid' })\n ssoConfigId!: string\n\n @Property({ name: 'deactivated_at', type: Date })\n deactivatedAt: Date = new Date()\n\n @Property({ name: 'reactivated_at', type: Date, nullable: true })\n reactivatedAt?: Date | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n}\n\n@Entity({ tableName: 'scim_provisioning_log' })\n@Index({ name: 'scim_provisioning_log_config_created_idx', properties: ['ssoConfigId', 'createdAt'] })\nexport class ScimProvisioningLog {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid', nullable: true })\n tenantId?: string | null\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'sso_config_id', type: 'uuid' })\n ssoConfigId!: string\n\n @Property({ type: 'text' })\n operation!: string\n\n @Property({ name: 'resource_type', type: 'text' })\n resourceType!: string\n\n @Property({ name: 'resource_id', type: 'uuid', nullable: true })\n resourceId?: string | null\n\n @Property({ name: 'scim_external_id', type: 'text', nullable: true })\n scimExternalId?: string | null\n\n @Property({ name: 'response_status', type: 'integer' })\n responseStatus!: number\n\n @Property({ name: 'error_message', type: 'text', nullable: true })\n errorMessage?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n}\n\n@Entity({ tableName: 'sso_role_grants' })\n@Unique({ properties: ['userId', 'roleId', 'ssoConfigId'], name: 'sso_role_grants_user_role_config_unique' })\nexport class SsoRoleGrant {\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'tenant_id', type: 'uuid', nullable: true })\n tenantId?: string | null\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n @Index({ name: 'sso_role_grants_user_id_idx' })\n userId!: string\n\n @Property({ name: 'role_id', type: 'uuid' })\n roleId!: string\n\n @Property({ name: 'sso_config_id', type: 'uuid' })\n ssoConfigId!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,114 @@
1
+ import { z } from "zod";
2
+ import { validateDomain } from "../lib/domains.js";
3
+ const uuid = () => z.string().uuid();
4
+ const domainString = () => z.string().trim().min(1).max(253).refine(
5
+ (val) => validateDomain(val).valid,
6
+ { message: "Invalid domain format \u2014 only valid DNS hostnames with at least one dot are accepted" }
7
+ );
8
+ const ssoConfigCreateSchema = z.object({
9
+ organizationId: uuid(),
10
+ tenantId: uuid().optional(),
11
+ protocol: z.enum(["oidc", "saml"]),
12
+ issuer: z.string().url().optional(),
13
+ clientId: z.string().min(1).optional(),
14
+ clientSecret: z.string().min(1).optional(),
15
+ allowedDomains: z.array(domainString()).default([]),
16
+ jitEnabled: z.boolean().default(true),
17
+ autoLinkByEmail: z.boolean().default(true),
18
+ isActive: z.boolean().default(false),
19
+ ssoRequired: z.boolean().default(false),
20
+ appRoleMappings: z.record(z.string().min(1).max(255), z.string().min(1).max(255)).default({})
21
+ });
22
+ const ssoConfigUpdateSchema = z.object({
23
+ id: uuid()
24
+ }).merge(ssoConfigCreateSchema.partial().omit({ organizationId: true, tenantId: true }));
25
+ const hrdRequestSchema = z.object({
26
+ email: z.string().email()
27
+ });
28
+ const ssoInitiateSchema = z.object({
29
+ configId: uuid(),
30
+ returnUrl: z.string().max(2048).refine(
31
+ (val) => val.startsWith("/") && !val.startsWith("//"),
32
+ { message: "returnUrl must be a relative path starting with / and must not start with //" }
33
+ ).optional()
34
+ });
35
+ const oidcCallbackSchema = z.object({
36
+ code: z.string().min(1),
37
+ state: z.string().min(1)
38
+ });
39
+ const ssoConfigAdminCreateSchema = z.object({
40
+ name: z.string().min(1).max(255),
41
+ organizationId: uuid().optional(),
42
+ tenantId: uuid().optional(),
43
+ protocol: z.enum(["oidc", "saml"]),
44
+ issuer: z.string().url(),
45
+ clientId: z.string().min(1),
46
+ clientSecret: z.string().min(1),
47
+ allowedDomains: z.array(domainString()).default([]),
48
+ jitEnabled: z.boolean().default(true),
49
+ autoLinkByEmail: z.boolean().default(true),
50
+ appRoleMappings: z.record(z.string().min(1).max(255), z.string().min(1).max(255)).default({})
51
+ });
52
+ const ssoConfigAdminUpdateSchema = z.object({
53
+ name: z.string().min(1).max(255).optional(),
54
+ protocol: z.enum(["oidc", "saml"]).optional(),
55
+ issuer: z.string().url().optional(),
56
+ clientId: z.string().min(1).optional(),
57
+ clientSecret: z.string().min(1).optional(),
58
+ jitEnabled: z.boolean().optional(),
59
+ autoLinkByEmail: z.boolean().optional(),
60
+ appRoleMappings: z.record(z.string().min(1).max(255), z.string().min(1).max(255)).optional()
61
+ });
62
+ const ssoConfigListQuerySchema = z.object({
63
+ page: z.coerce.number().min(1).default(1),
64
+ pageSize: z.coerce.number().min(1).max(100).default(50),
65
+ search: z.string().optional(),
66
+ organizationId: uuid().optional(),
67
+ tenantId: uuid().optional()
68
+ });
69
+ const ssoDomainAddSchema = z.object({
70
+ domain: domainString()
71
+ });
72
+ const ssoActivateSchema = z.object({
73
+ active: z.boolean()
74
+ });
75
+ const scimUserPayloadSchema = z.object({
76
+ schemas: z.array(z.string()).optional(),
77
+ userName: z.string().min(1).max(255),
78
+ externalId: z.string().max(255).optional(),
79
+ displayName: z.string().max(255).optional(),
80
+ active: z.union([z.boolean(), z.string()]).optional(),
81
+ name: z.object({
82
+ givenName: z.string().max(255).optional(),
83
+ familyName: z.string().max(255).optional(),
84
+ formatted: z.string().max(512).optional()
85
+ }).optional(),
86
+ emails: z.array(z.object({
87
+ value: z.string().email(),
88
+ primary: z.boolean().optional(),
89
+ type: z.string().optional()
90
+ })).optional()
91
+ }).passthrough();
92
+ const createScimTokenSchema = z.object({
93
+ ssoConfigId: uuid(),
94
+ name: z.string().min(1).max(100)
95
+ });
96
+ const scimTokenListSchema = z.object({
97
+ ssoConfigId: uuid()
98
+ });
99
+ export {
100
+ createScimTokenSchema,
101
+ hrdRequestSchema,
102
+ oidcCallbackSchema,
103
+ scimTokenListSchema,
104
+ scimUserPayloadSchema,
105
+ ssoActivateSchema,
106
+ ssoConfigAdminCreateSchema,
107
+ ssoConfigAdminUpdateSchema,
108
+ ssoConfigCreateSchema,
109
+ ssoConfigListQuerySchema,
110
+ ssoConfigUpdateSchema,
111
+ ssoDomainAddSchema,
112
+ ssoInitiateSchema
113
+ };
114
+ //# sourceMappingURL=validators.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/modules/sso/data/validators.ts"],
4
+ "sourcesContent": ["import { z } from 'zod'\nimport { validateDomain } from '../lib/domains'\n\nconst uuid = () => z.string().uuid()\n\nconst domainString = () =>\n z.string().trim().min(1).max(253).refine(\n (val) => validateDomain(val).valid,\n { message: 'Invalid domain format \u2014 only valid DNS hostnames with at least one dot are accepted' },\n )\n\n// --- SSO Config schema (for internal use / seeding) ---\n\nexport const ssoConfigCreateSchema = z.object({\n organizationId: uuid(),\n tenantId: uuid().optional(),\n protocol: z.enum(['oidc', 'saml']),\n issuer: z.string().url().optional(),\n clientId: z.string().min(1).optional(),\n clientSecret: z.string().min(1).optional(),\n allowedDomains: z.array(domainString()).default([]),\n jitEnabled: z.boolean().default(true),\n autoLinkByEmail: z.boolean().default(true),\n isActive: z.boolean().default(false),\n ssoRequired: z.boolean().default(false),\n appRoleMappings: z.record(z.string().min(1).max(255), z.string().min(1).max(255)).default({}),\n})\n\nexport const ssoConfigUpdateSchema = z\n .object({\n id: uuid(),\n })\n .merge(ssoConfigCreateSchema.partial().omit({ organizationId: true, tenantId: true }))\n\n// --- API request schemas ---\n\nexport const hrdRequestSchema = z.object({\n email: z.string().email(),\n})\n\nexport const ssoInitiateSchema = z.object({\n configId: uuid(),\n returnUrl: z.string().max(2048).refine(\n (val) => val.startsWith('/') && !val.startsWith('//'),\n { message: 'returnUrl must be a relative path starting with / and must not start with //' },\n ).optional(),\n})\n\nexport const oidcCallbackSchema = z.object({\n code: z.string().min(1),\n state: z.string().min(1),\n})\n\n// --- Admin API schemas ---\n\nexport const ssoConfigAdminCreateSchema = z.object({\n name: z.string().min(1).max(255),\n organizationId: uuid().optional(),\n tenantId: uuid().optional(),\n protocol: z.enum(['oidc', 'saml']),\n issuer: z.string().url(),\n clientId: z.string().min(1),\n clientSecret: z.string().min(1),\n allowedDomains: z.array(domainString()).default([]),\n jitEnabled: z.boolean().default(true),\n autoLinkByEmail: z.boolean().default(true),\n appRoleMappings: z.record(z.string().min(1).max(255), z.string().min(1).max(255)).default({}),\n})\n\nexport const ssoConfigAdminUpdateSchema = z.object({\n name: z.string().min(1).max(255).optional(),\n protocol: z.enum(['oidc', 'saml']).optional(),\n issuer: z.string().url().optional(),\n clientId: z.string().min(1).optional(),\n clientSecret: z.string().min(1).optional(),\n jitEnabled: z.boolean().optional(),\n autoLinkByEmail: z.boolean().optional(),\n appRoleMappings: z.record(z.string().min(1).max(255), z.string().min(1).max(255)).optional(),\n})\n\nexport const ssoConfigListQuerySchema = z.object({\n page: z.coerce.number().min(1).default(1),\n pageSize: z.coerce.number().min(1).max(100).default(50),\n search: z.string().optional(),\n organizationId: uuid().optional(),\n tenantId: uuid().optional(),\n})\n\nexport const ssoDomainAddSchema = z.object({\n domain: domainString(),\n})\n\nexport const ssoActivateSchema = z.object({\n active: z.boolean(),\n})\n\n// --- SCIM User payload schema ---\n\nexport const scimUserPayloadSchema = z.object({\n schemas: z.array(z.string()).optional(),\n userName: z.string().min(1).max(255),\n externalId: z.string().max(255).optional(),\n displayName: z.string().max(255).optional(),\n active: z.union([z.boolean(), z.string()]).optional(),\n name: z.object({\n givenName: z.string().max(255).optional(),\n familyName: z.string().max(255).optional(),\n formatted: z.string().max(512).optional(),\n }).optional(),\n emails: z.array(z.object({\n value: z.string().email(),\n primary: z.boolean().optional(),\n type: z.string().optional(),\n })).optional(),\n}).passthrough()\n\n// --- SCIM Token schemas ---\n\nexport const createScimTokenSchema = z.object({\n ssoConfigId: uuid(),\n name: z.string().min(1).max(100),\n})\n\nexport const scimTokenListSchema = z.object({\n ssoConfigId: uuid(),\n})\n\n// --- Type exports ---\n\nexport type SsoConfigCreateInput = z.infer<typeof ssoConfigCreateSchema>\nexport type SsoConfigUpdateInput = z.infer<typeof ssoConfigUpdateSchema>\nexport type SsoConfigAdminCreateInput = z.infer<typeof ssoConfigAdminCreateSchema>\nexport type SsoConfigAdminUpdateInput = z.infer<typeof ssoConfigAdminUpdateSchema>\nexport type SsoConfigListQuery = z.infer<typeof ssoConfigListQuerySchema>\nexport type HrdRequestInput = z.infer<typeof hrdRequestSchema>\nexport type SsoInitiateInput = z.infer<typeof ssoInitiateSchema>\nexport type OidcCallbackInput = z.infer<typeof oidcCallbackSchema>\nexport type ScimUserPayloadInput = z.infer<typeof scimUserPayloadSchema>\nexport type CreateScimTokenInput = z.infer<typeof createScimTokenSchema>\nexport type ScimTokenListInput = z.infer<typeof scimTokenListSchema>\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,26 @@
1
+ import { asClass, asValue } from "awilix";
2
+ import { SsoProviderRegistry } from "./lib/registry.js";
3
+ import { OidcProvider } from "./lib/oidc-provider.js";
4
+ import { SsoService } from "./services/ssoService.js";
5
+ import { AccountLinkingService } from "./services/accountLinkingService.js";
6
+ import { SsoConfigService } from "./services/ssoConfigService.js";
7
+ import { HrdService } from "./services/hrdService.js";
8
+ import { ScimTokenService } from "./services/scimTokenService.js";
9
+ import { ScimService } from "./services/scimService.js";
10
+ function register(container) {
11
+ const registry = new SsoProviderRegistry();
12
+ registry.register(new OidcProvider());
13
+ container.register({
14
+ ssoProviderRegistry: asValue(registry),
15
+ ssoService: asClass(SsoService).scoped(),
16
+ accountLinkingService: asClass(AccountLinkingService).scoped(),
17
+ ssoConfigService: asClass(SsoConfigService).scoped(),
18
+ hrdService: asClass(HrdService).scoped(),
19
+ scimTokenService: asClass(ScimTokenService).scoped(),
20
+ scimService: asClass(ScimService).scoped()
21
+ });
22
+ }
23
+ export {
24
+ register
25
+ };
26
+ //# sourceMappingURL=di.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/modules/sso/di.ts"],
4
+ "sourcesContent": ["import { asClass, asValue } from 'awilix'\nimport type { AppContainer } from '@open-mercato/shared/lib/di/container'\nimport { SsoProviderRegistry } from './lib/registry'\nimport { OidcProvider } from './lib/oidc-provider'\nimport { SsoService } from './services/ssoService'\nimport { AccountLinkingService } from './services/accountLinkingService'\nimport { SsoConfigService } from './services/ssoConfigService'\nimport { HrdService } from './services/hrdService'\nimport { ScimTokenService } from './services/scimTokenService'\nimport { ScimService } from './services/scimService'\n\nexport function register(container: AppContainer) {\n const registry = new SsoProviderRegistry()\n registry.register(new OidcProvider())\n\n container.register({\n ssoProviderRegistry: asValue(registry),\n ssoService: asClass(SsoService).scoped(),\n accountLinkingService: asClass(AccountLinkingService).scoped(),\n ssoConfigService: asClass(SsoConfigService).scoped(),\n hrdService: asClass(HrdService).scoped(),\n scimTokenService: asClass(ScimTokenService).scoped(),\n scimService: asClass(ScimService).scoped(),\n })\n}\n"],
5
+ "mappings": "AAAA,SAAS,SAAS,eAAe;AAEjC,SAAS,2BAA2B;AACpC,SAAS,oBAAoB;AAC7B,SAAS,kBAAkB;AAC3B,SAAS,6BAA6B;AACtC,SAAS,wBAAwB;AACjC,SAAS,kBAAkB;AAC3B,SAAS,wBAAwB;AACjC,SAAS,mBAAmB;AAErB,SAAS,SAAS,WAAyB;AAChD,QAAM,WAAW,IAAI,oBAAoB;AACzC,WAAS,SAAS,IAAI,aAAa,CAAC;AAEpC,YAAU,SAAS;AAAA,IACjB,qBAAqB,QAAQ,QAAQ;AAAA,IACrC,YAAY,QAAQ,UAAU,EAAE,OAAO;AAAA,IACvC,uBAAuB,QAAQ,qBAAqB,EAAE,OAAO;AAAA,IAC7D,kBAAkB,QAAQ,gBAAgB,EAAE,OAAO;AAAA,IACnD,YAAY,QAAQ,UAAU,EAAE,OAAO;AAAA,IACvC,kBAAkB,QAAQ,gBAAgB,EAAE,OAAO;AAAA,IACnD,aAAa,QAAQ,WAAW,EAAE,OAAO;AAAA,EAC3C,CAAC;AACH;",
6
+ "names": []
7
+ }