@ackplus/nest-auth 0.1.51 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -513
- package/eslint.config.mjs +59 -0
- package/jest.config.ts +10 -0
- package/package.json +14 -44
- package/project.json +86 -0
- package/src/index.ts +30 -0
- package/src/lib/admin-console/admin-console.module.ts +62 -0
- package/src/lib/admin-console/controllers/admin-auth.controller.ts +339 -0
- package/src/lib/admin-console/controllers/admin-console.controller.ts +82 -0
- package/src/lib/admin-console/controllers/admin-permissions.controller.ts +180 -0
- package/src/lib/admin-console/controllers/admin-roles.controller.ts +89 -0
- package/src/lib/admin-console/controllers/admin-tenants.controller.ts +68 -0
- package/src/lib/admin-console/controllers/admin-users.controller.ts +379 -0
- package/src/lib/admin-console/decorators/current-admin.decorator.ts +9 -0
- package/src/lib/admin-console/dto/admin-permission.dto.ts +106 -0
- package/src/lib/admin-console/dto/admin-role.dto.ts +45 -0
- package/src/lib/admin-console/dto/admin-tenant.dto.ts +43 -0
- package/src/lib/admin-console/dto/admin-user.dto.ts +87 -0
- package/src/lib/admin-console/dto/create-dashboard-admin.dto.ts +34 -0
- package/src/lib/admin-console/dto/login.dto.ts +10 -0
- package/src/lib/admin-console/dto/reset-password.dto.ts +21 -0
- package/src/lib/admin-console/dto/setup-admin.dto.ts +23 -0
- package/src/lib/admin-console/dto/signup.dto.ts +51 -0
- package/src/lib/admin-console/entities/admin-user.entity.ts +74 -0
- package/src/lib/admin-console/guards/admin-session.guard.ts +47 -0
- package/src/lib/admin-console/services/admin-auth.service.ts +82 -0
- package/src/lib/admin-console/services/admin-console-config.service.ts +62 -0
- package/src/lib/admin-console/services/admin-session.service.ts +106 -0
- package/src/lib/admin-console/services/admin-user.service.ts +96 -0
- package/src/lib/admin-console/static/index.html +771 -0
- package/src/lib/auth/auth.module.ts +58 -0
- package/src/lib/auth/controllers/auth.controller.ts +393 -0
- package/src/lib/auth/controllers/mfa.controller.ts +200 -0
- package/src/lib/auth/dto/credentials/email-credentials.dto.ts +24 -0
- package/src/lib/auth/dto/credentials/phone-credentials.dto.ts +24 -0
- package/src/lib/auth/dto/credentials/social-credentials.dto.ts +15 -0
- package/src/lib/auth/dto/index.ts +1 -0
- package/src/lib/auth/dto/requests/change-password.request.dto.ts +34 -0
- package/src/lib/auth/dto/requests/forgot-password.request.dto.ts +30 -0
- package/src/lib/auth/dto/requests/initialize-admin.request.dto.ts +51 -0
- package/src/lib/auth/dto/requests/login.request.dto.ts +65 -0
- package/src/lib/auth/dto/requests/refresh-token.request.dto.ts +12 -0
- package/src/lib/auth/dto/requests/reset-password-with-token.request.dto.ts +22 -0
- package/src/lib/auth/dto/requests/reset-password.request.dto.ts +50 -0
- package/src/lib/auth/dto/requests/send-email-verification.request.dto.ts +12 -0
- package/src/lib/auth/dto/requests/send-mfa-code.request.dto.ts +19 -0
- package/src/lib/auth/dto/requests/signup.request.dto.ts +42 -0
- package/src/lib/auth/dto/requests/toggle-mfa.request.dto.ts +12 -0
- package/src/lib/auth/dto/requests/verify-2fa.request.dto.ts +24 -0
- package/src/lib/auth/dto/requests/verify-email.request.dto.ts +22 -0
- package/src/lib/auth/dto/requests/verify-forgot-password-otp-request-dto.ts +41 -0
- package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.ts +22 -0
- package/src/lib/auth/dto/responses/auth-cookie.response.dto.ts +58 -0
- package/src/lib/auth/dto/responses/auth-success.response.dto.ts +58 -0
- package/src/lib/auth/dto/responses/auth.response.dto.ts +99 -0
- package/src/lib/auth/dto/responses/client-config.response.dto.ts +153 -0
- package/src/lib/auth/dto/responses/initialize-admin.response.dto.ts +22 -0
- package/src/lib/auth/dto/responses/mfa-code-response.dto.ts +27 -0
- package/src/lib/auth/dto/responses/mfa-status.response.dto.ts +89 -0
- package/src/lib/auth/dto/responses/verify-otp.response.dto.ts +9 -0
- package/src/lib/auth/entities/mfa-secret.entity.ts +33 -0
- package/src/lib/auth/entities/otp.entity.ts +33 -0
- package/src/lib/auth/events/{logged-out-all.event.d.ts → logged-out-all.event.ts} +6 -3
- package/src/lib/auth/events/{logged-out.event.d.ts → logged-out.event.ts} +5 -3
- package/src/lib/auth/events/{password-reset-requested.event.d.ts → password-reset-requested.event.ts} +6 -3
- package/src/lib/auth/events/{password-reset.event.d.ts → password-reset.event.ts} +6 -3
- package/src/lib/auth/events/{user-2fa-verified.event.d.ts → user-2fa-verified.event.ts} +6 -3
- package/src/lib/auth/events/{user-logged-in.event.d.ts → user-logged-in.event.ts} +7 -3
- package/src/lib/auth/events/{user-refresh-token.event.d.ts → user-refresh-token.event.ts} +6 -3
- package/src/lib/auth/events/{user-registered.event.d.ts → user-registered.event.ts} +7 -3
- package/src/lib/auth/guards/auth.guard.ts +386 -0
- package/src/lib/auth/{index.d.ts → index.ts} +28 -1
- package/src/lib/auth/interceptors/refresh-token.interceptor.ts +117 -0
- package/src/lib/auth/services/auth.service.ts +947 -0
- package/src/lib/auth/services/client-config.service.ts +157 -0
- package/src/lib/auth/services/cookie.service.ts +43 -0
- package/src/lib/auth/services/mfa.service.ts +391 -0
- package/src/lib/auth.constants.ts +63 -0
- package/src/lib/core/core.module.ts +50 -0
- package/src/lib/core/decorators/auth.decorator.ts +38 -0
- package/src/lib/core/decorators/permissions.decorator.ts +17 -0
- package/src/lib/core/decorators/public.decorator.ts +33 -0
- package/src/lib/core/decorators/role.decorator.ts +12 -0
- package/src/lib/core/decorators/skip-mfa.decorator.ts +4 -0
- package/src/lib/core/dto/message.response.dto.ts +6 -0
- package/src/lib/core/{entities.d.ts → entities.ts} +18 -1
- package/src/lib/core/{index.d.ts → index.ts} +17 -0
- package/src/lib/core/interfaces/auth-module-options.interface.ts +211 -0
- package/src/lib/core/interfaces/mfa-options.interface.ts +46 -0
- package/src/lib/core/interfaces/otp.interface.ts +6 -0
- package/src/lib/core/interfaces/session-options.interface.ts +19 -0
- package/src/lib/core/interfaces/{token-payload.interface.d.ts → token-payload.interface.ts} +4 -1
- package/src/lib/core/providers/apple-auth.provider.ts +61 -0
- package/src/lib/core/providers/base-auth.provider.ts +74 -0
- package/src/lib/core/providers/email-auth.provider.ts +71 -0
- package/src/lib/core/providers/facebook-auth.provider.ts +55 -0
- package/src/lib/core/providers/github-auth.provider.ts +79 -0
- package/src/lib/core/providers/google-auth.provider.ts +61 -0
- package/src/lib/core/providers/jwt-auth.provider.ts +50 -0
- package/src/lib/core/providers/phone-auth.provider.ts +45 -0
- package/src/lib/core/services/auth-config.service.ts +184 -0
- package/src/lib/core/services/auth-provider-registry.service.ts +93 -0
- package/src/lib/core/services/{debug-logger.service.js → debug-logger.service.ts} +92 -59
- package/src/lib/core/services/initialization.service.ts +29 -0
- package/src/lib/core/services/jwt.service.ts +137 -0
- package/src/lib/nest-auth.module.ts +152 -0
- package/src/lib/permission/entities/permission.entity.ts +56 -0
- package/src/lib/permission/index.ts +4 -0
- package/src/lib/permission/permission.module.ts +14 -0
- package/src/lib/permission/services/permission.service.ts +233 -0
- package/src/lib/request-context/index.ts +2 -0
- package/src/lib/request-context/request-context.middleware.ts +13 -0
- package/src/lib/request-context/{request-context.js → request-context.ts} +51 -27
- package/src/lib/role/entities/role.entity.ts +103 -0
- package/src/lib/role/{index.d.ts → index.ts} +2 -0
- package/src/lib/role/role.module.ts +15 -0
- package/src/lib/role/services/{role.service.js → role.service.ts} +117 -52
- package/src/lib/session/entities/session.entity.ts +54 -0
- package/src/lib/session/index.ts +20 -0
- package/src/lib/session/interfaces/session-repository.interface.ts +58 -0
- package/src/lib/session/repositories/base-session.repository.ts +74 -0
- package/src/lib/session/repositories/memory-session.repository.ts +153 -0
- package/src/lib/session/repositories/redis-session.repository.ts +171 -0
- package/src/lib/session/repositories/typeorm-session.repository.ts +86 -0
- package/src/lib/session/services/session-manager.service.ts +261 -0
- package/src/lib/session/session.module.ts +102 -0
- package/src/lib/session/utils/session.util.ts +166 -0
- package/src/lib/tenant/entities/tenant.entity.ts +40 -0
- package/src/lib/tenant/events/tenant-created.event.ts +9 -0
- package/src/lib/tenant/events/tenant-deleted.event.ts +11 -0
- package/src/lib/tenant/events/{tenant-updated.event.d.ts → tenant-updated.event.ts} +6 -3
- package/src/lib/tenant/index.ts +9 -0
- package/src/lib/tenant/services/tenant.service.ts +336 -0
- package/src/lib/tenant/tenant.module.ts +19 -0
- package/src/lib/types/express.d.ts +14 -0
- package/src/lib/user/dto/requests/update-user.dto.ts +15 -0
- package/src/lib/user/entities/access-key.entity.ts +53 -0
- package/src/lib/user/entities/identity.entity.ts +31 -0
- package/src/lib/user/entities/user.entity.ts +212 -0
- package/src/lib/user/events/{user-created.event.d.ts → user-created.event.ts} +4 -3
- package/src/lib/user/events/{user-deleted.event.d.ts → user-deleted.event.ts} +6 -3
- package/src/lib/user/events/{user-updated.event.d.ts → user-updated.event.ts} +6 -3
- package/src/lib/user/index.ts +11 -0
- package/src/lib/user/services/access-key.service.ts +145 -0
- package/src/lib/user/services/{user.service.js → user.service.ts} +199 -95
- package/src/lib/user/user.module.ts +26 -0
- package/src/lib/utils/database.utils.ts +6 -0
- package/src/lib/utils/date.util.ts +106 -0
- package/src/lib/utils/device.util.ts +111 -0
- package/src/lib/utils/index.ts +6 -0
- package/src/lib/utils/otp.ts +3 -0
- package/src/lib/utils/security.util.ts +27 -0
- package/src/lib/utils/slug.util.ts +58 -0
- package/src/types/ms.d.ts +1 -0
- package/test/access-key.service.spec.ts +204 -0
- package/test/auth.service.spec.ts +541 -0
- package/test/mfa.service.spec.ts +359 -0
- package/test/role.service.spec.ts +418 -0
- package/test/tenant.service.spec.ts +218 -0
- package/test/test.setup.ts +66 -0
- package/test/user.service.spec.ts +374 -0
- package/tsconfig.json +17 -0
- package/tsconfig.lib.json +15 -0
- package/tsconfig.spec.json +15 -0
- package/tsconfig.tsbuildinfo +1 -1
- package/ui/.env +1 -0
- package/ui/.env.example +1 -0
- package/ui/.eslintignore +7 -0
- package/ui/README.md +288 -0
- package/ui/index.html +17 -0
- package/ui/package.json +34 -0
- package/ui/postcss.config.js +6 -0
- package/ui/src/App.tsx +245 -0
- package/ui/src/components/AuthGuard.tsx +59 -0
- package/ui/src/components/AuthProvider.tsx +76 -0
- package/ui/src/components/Button.tsx +37 -0
- package/ui/src/components/Card.tsx +37 -0
- package/ui/src/components/ErrorMessage.tsx +15 -0
- package/ui/src/components/FormDialog.tsx +61 -0
- package/ui/src/components/FormFooter.tsx +37 -0
- package/ui/src/components/Layout.tsx +112 -0
- package/ui/src/components/LoadingMessage.tsx +11 -0
- package/ui/src/components/Modal.tsx +97 -0
- package/ui/src/components/MultiSelect.tsx +145 -0
- package/ui/src/components/PageHeader.tsx +42 -0
- package/ui/src/components/PanelHeader.tsx +28 -0
- package/ui/src/components/PermissionInput.tsx +473 -0
- package/ui/src/components/SearchInput.tsx +69 -0
- package/ui/src/components/Select.tsx +51 -0
- package/ui/src/components/SwaggerUIWrapper.tsx +316 -0
- package/ui/src/components/Table.tsx +207 -0
- package/ui/src/components/Tag.tsx +9 -0
- package/ui/src/components/TagsInput.tsx +96 -0
- package/ui/src/components/admin/AdminForm.tsx +170 -0
- package/ui/src/components/admin/CreateAdminDialog.tsx +38 -0
- package/ui/src/components/auth/LoginFooter.tsx +17 -0
- package/ui/src/components/auth/LoginHeader.tsx +14 -0
- package/ui/src/components/auth/components/CodeBlock.tsx +43 -0
- package/ui/src/components/auth/components/CreateAccountCodeExamples.tsx +60 -0
- package/ui/src/components/auth/components/PasswordRequirements.tsx +16 -0
- package/ui/src/components/auth/components/PasswordStrengthIndicator.tsx +48 -0
- package/ui/src/components/auth/components/ResetPasswordCodeExamples.tsx +76 -0
- package/ui/src/components/auth/components/Tabs.tsx +32 -0
- package/ui/src/components/auth/dialogs/CreateAccountDialog.tsx +79 -0
- package/ui/src/components/auth/dialogs/ForgotPasswordDialog.tsx +79 -0
- package/ui/src/components/auth/forms/CreateAccountForm.tsx +226 -0
- package/ui/src/components/auth/forms/LoginForm.tsx +149 -0
- package/ui/src/components/auth/forms/ResetPasswordForm.tsx +202 -0
- package/ui/src/components/auth/types.ts +17 -0
- package/ui/src/components/auth/utils/security.ts +82 -0
- package/ui/src/components/auth/utils/utils.ts +25 -0
- package/ui/src/components/form/EmailField.tsx +25 -0
- package/ui/src/components/form/FormField.tsx +102 -0
- package/ui/src/components/form/FormMultiSelect.tsx +46 -0
- package/ui/src/components/form/FormSelect.tsx +60 -0
- package/ui/src/components/form/FormTagsInput.tsx +42 -0
- package/ui/src/components/form/FormTextarea.tsx +42 -0
- package/ui/src/components/form/PasswordField.tsx +93 -0
- package/ui/src/components/form/SecretKeyField.tsx +49 -0
- package/ui/src/components/permission/CreatePermissionDialog.tsx +44 -0
- package/ui/src/components/permission/EditPermissionDialog.tsx +55 -0
- package/ui/src/components/permission/PermissionForm.tsx +251 -0
- package/ui/src/components/role/CreateRoleDialog.tsx +45 -0
- package/ui/src/components/role/EditRoleDialog.tsx +55 -0
- package/ui/src/components/role/RoleDialog.tsx +252 -0
- package/ui/src/components/role/RoleForm.tsx +246 -0
- package/ui/src/components/tenant/CreateTenantDialog.tsx +41 -0
- package/ui/src/components/tenant/EditTenantDialog.tsx +52 -0
- package/ui/src/components/tenant/TenantForm.tsx +160 -0
- package/ui/src/components/user/CreateUserDialog.tsx +45 -0
- package/ui/src/components/user/UserDetailModal.tsx +815 -0
- package/ui/src/components/user/UserForm.tsx +191 -0
- package/ui/src/data/nest-auth.json +1687 -0
- package/ui/src/hooks/useApi.ts +69 -0
- package/ui/src/hooks/useAuth.ts +100 -0
- package/ui/src/hooks/useConfirm.tsx +105 -0
- package/ui/src/hooks/useFormFooter.tsx +42 -0
- package/ui/src/hooks/usePagination.ts +69 -0
- package/ui/src/index.css +59 -0
- package/ui/src/main.tsx +13 -0
- package/ui/src/pages/AdminsPage.tsx +178 -0
- package/ui/src/pages/ApiPage.tsx +89 -0
- package/ui/src/pages/DashboardPage.tsx +281 -0
- package/ui/src/pages/LoginPage.tsx +39 -0
- package/ui/src/pages/PermissionsPage.tsx +376 -0
- package/ui/src/pages/RolesPage.tsx +274 -0
- package/ui/src/pages/TenantsPage.tsx +221 -0
- package/ui/src/pages/UsersPage.tsx +387 -0
- package/ui/src/services/api.ts +115 -0
- package/ui/src/types/index.ts +136 -0
- package/ui/src/vite-env.d.ts +9 -0
- package/ui/tailwind.config.js +45 -0
- package/ui/tsconfig.json +24 -0
- package/ui/tsconfig.node.json +10 -0
- package/ui/vite.config.ts +37 -0
- package/ui/yarn.lock +3137 -0
- package/src/index.d.ts +0 -11
- package/src/index.js +0 -18
- package/src/index.js.map +0 -1
- package/src/lib/auth/auth.module.d.ts +0 -2
- package/src/lib/auth/auth.module.js +0 -54
- package/src/lib/auth/auth.module.js.map +0 -1
- package/src/lib/auth/controllers/auth.controller.d.ts +0 -29
- package/src/lib/auth/controllers/auth.controller.js +0 -206
- package/src/lib/auth/controllers/auth.controller.js.map +0 -1
- package/src/lib/auth/controllers/mfa.controller.d.ts +0 -23
- package/src/lib/auth/controllers/mfa.controller.js +0 -131
- package/src/lib/auth/controllers/mfa.controller.js.map +0 -1
- package/src/lib/auth/dto/index.d.ts +0 -0
- package/src/lib/auth/dto/index.js +0 -1
- package/src/lib/auth/dto/index.js.map +0 -1
- package/src/lib/auth/dto/requests/forgot-password.request.dto.d.ts +0 -5
- package/src/lib/auth/dto/requests/forgot-password.request.dto.js +0 -30
- package/src/lib/auth/dto/requests/forgot-password.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/login.request.dto.d.ts +0 -6
- package/src/lib/auth/dto/requests/login.request.dto.js +0 -38
- package/src/lib/auth/dto/requests/login.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/refresh-token.request.dto.d.ts +0 -3
- package/src/lib/auth/dto/requests/refresh-token.request.dto.js +0 -15
- package/src/lib/auth/dto/requests/refresh-token.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/reset-password.request.dto.d.ts +0 -7
- package/src/lib/auth/dto/requests/reset-password.request.dto.js +0 -42
- package/src/lib/auth/dto/requests/reset-password.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/send-mfa-code.request.dto.d.ts +0 -4
- package/src/lib/auth/dto/requests/send-mfa-code.request.dto.js +0 -16
- package/src/lib/auth/dto/requests/send-mfa-code.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/signup.request.dto.d.ts +0 -7
- package/src/lib/auth/dto/requests/signup.request.dto.js +0 -37
- package/src/lib/auth/dto/requests/signup.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/social-login.request.dto.d.ts +0 -3
- package/src/lib/auth/dto/requests/social-login.request.dto.js +0 -16
- package/src/lib/auth/dto/requests/social-login.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/verify-2fa.request.dto.d.ts +0 -5
- package/src/lib/auth/dto/requests/verify-2fa.request.dto.js +0 -21
- package/src/lib/auth/dto/requests/verify-2fa.request.dto.js.map +0 -1
- package/src/lib/auth/dto/requests/verify-forgot-password-otp-request-dto.d.ts +0 -6
- package/src/lib/auth/dto/requests/verify-forgot-password-otp-request-dto.js +0 -35
- package/src/lib/auth/dto/requests/verify-forgot-password-otp-request-dto.js.map +0 -1
- package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.d.ts +0 -4
- package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.js +0 -20
- package/src/lib/auth/dto/requests/verify-totp-setup.request.dto.js.map +0 -1
- package/src/lib/auth/dto/responses/auth.response.dto.d.ts +0 -16
- package/src/lib/auth/dto/responses/auth.response.dto.js +0 -50
- package/src/lib/auth/dto/responses/auth.response.dto.js.map +0 -1
- package/src/lib/auth/entities/mfa-secret.entity.d.ts +0 -12
- package/src/lib/auth/entities/mfa-secret.entity.js +0 -50
- package/src/lib/auth/entities/mfa-secret.entity.js.map +0 -1
- package/src/lib/auth/entities/otp.entity.d.ts +0 -13
- package/src/lib/auth/entities/otp.entity.js +0 -50
- package/src/lib/auth/entities/otp.entity.js.map +0 -1
- package/src/lib/auth/events/logged-out-all.event.js +0 -10
- package/src/lib/auth/events/logged-out-all.event.js.map +0 -1
- package/src/lib/auth/events/logged-out.event.js +0 -10
- package/src/lib/auth/events/logged-out.event.js.map +0 -1
- package/src/lib/auth/events/password-reset-requested.event.js +0 -10
- package/src/lib/auth/events/password-reset-requested.event.js.map +0 -1
- package/src/lib/auth/events/password-reset.event.js +0 -10
- package/src/lib/auth/events/password-reset.event.js.map +0 -1
- package/src/lib/auth/events/user-2fa-verified.event.js +0 -10
- package/src/lib/auth/events/user-2fa-verified.event.js.map +0 -1
- package/src/lib/auth/events/user-logged-in.event.js +0 -10
- package/src/lib/auth/events/user-logged-in.event.js.map +0 -1
- package/src/lib/auth/events/user-refresh-token.event.js +0 -10
- package/src/lib/auth/events/user-refresh-token.event.js.map +0 -1
- package/src/lib/auth/events/user-registered.event.js +0 -10
- package/src/lib/auth/events/user-registered.event.js.map +0 -1
- package/src/lib/auth/guards/auth.guard.d.ts +0 -28
- package/src/lib/auth/guards/auth.guard.js +0 -304
- package/src/lib/auth/guards/auth.guard.js.map +0 -1
- package/src/lib/auth/index.js +0 -31
- package/src/lib/auth/index.js.map +0 -1
- package/src/lib/auth/services/auth.service.d.ts +0 -53
- package/src/lib/auth/services/auth.service.js +0 -522
- package/src/lib/auth/services/auth.service.js.map +0 -1
- package/src/lib/auth/services/cookie.service.d.ts +0 -9
- package/src/lib/auth/services/cookie.service.js +0 -43
- package/src/lib/auth/services/cookie.service.js.map +0 -1
- package/src/lib/auth/services/mfa.service.d.ts +0 -38
- package/src/lib/auth/services/mfa.service.js +0 -254
- package/src/lib/auth/services/mfa.service.js.map +0 -1
- package/src/lib/auth.constants.d.ts +0 -39
- package/src/lib/auth.constants.js +0 -43
- package/src/lib/auth.constants.js.map +0 -1
- package/src/lib/core/core.module.d.ts +0 -2
- package/src/lib/core/core.module.js +0 -53
- package/src/lib/core/core.module.js.map +0 -1
- package/src/lib/core/decorators/auth.decorator.d.ts +0 -1
- package/src/lib/core/decorators/auth.decorator.js +0 -8
- package/src/lib/core/decorators/auth.decorator.js.map +0 -1
- package/src/lib/core/decorators/permissions.decorator.d.ts +0 -2
- package/src/lib/core/decorators/permissions.decorator.js +0 -14
- package/src/lib/core/decorators/permissions.decorator.js.map +0 -1
- package/src/lib/core/decorators/role.decorator.d.ts +0 -3
- package/src/lib/core/decorators/role.decorator.js +0 -14
- package/src/lib/core/decorators/role.decorator.js.map +0 -1
- package/src/lib/core/decorators/skip-mfa.decorator.d.ts +0 -2
- package/src/lib/core/decorators/skip-mfa.decorator.js +0 -8
- package/src/lib/core/decorators/skip-mfa.decorator.js.map +0 -1
- package/src/lib/core/dto/message.response.dto.d.ts +0 -3
- package/src/lib/core/dto/message.response.dto.js +0 -13
- package/src/lib/core/dto/message.response.dto.js.map +0 -1
- package/src/lib/core/entities.js +0 -31
- package/src/lib/core/entities.js.map +0 -1
- package/src/lib/core/index.js +0 -27
- package/src/lib/core/index.js.map +0 -1
- package/src/lib/core/interfaces/auth-module-options.interface.d.ts +0 -62
- package/src/lib/core/interfaces/auth-module-options.interface.js +0 -3
- package/src/lib/core/interfaces/auth-module-options.interface.js.map +0 -1
- package/src/lib/core/interfaces/mfa-options.interface.d.ts +0 -25
- package/src/lib/core/interfaces/mfa-options.interface.js +0 -10
- package/src/lib/core/interfaces/mfa-options.interface.js.map +0 -1
- package/src/lib/core/interfaces/otp.interface.d.ts +0 -5
- package/src/lib/core/interfaces/otp.interface.js +0 -10
- package/src/lib/core/interfaces/otp.interface.js.map +0 -1
- package/src/lib/core/interfaces/session-options.interface.d.ts +0 -12
- package/src/lib/core/interfaces/session-options.interface.js +0 -9
- package/src/lib/core/interfaces/session-options.interface.js.map +0 -1
- package/src/lib/core/interfaces/token-payload.interface.js +0 -3
- package/src/lib/core/interfaces/token-payload.interface.js.map +0 -1
- package/src/lib/core/providers/apple-auth.provider.d.ts +0 -18
- package/src/lib/core/providers/apple-auth.provider.js +0 -57
- package/src/lib/core/providers/apple-auth.provider.js.map +0 -1
- package/src/lib/core/providers/base-auth.provider.d.ts +0 -26
- package/src/lib/core/providers/base-auth.provider.js +0 -43
- package/src/lib/core/providers/base-auth.provider.js.map +0 -1
- package/src/lib/core/providers/email-auth.provider.d.ts +0 -17
- package/src/lib/core/providers/email-auth.provider.js +0 -40
- package/src/lib/core/providers/email-auth.provider.js.map +0 -1
- package/src/lib/core/providers/facebook-auth.provider.d.ts +0 -18
- package/src/lib/core/providers/facebook-auth.provider.js +0 -56
- package/src/lib/core/providers/facebook-auth.provider.js.map +0 -1
- package/src/lib/core/providers/google-auth.provider.d.ts +0 -21
- package/src/lib/core/providers/google-auth.provider.js +0 -58
- package/src/lib/core/providers/google-auth.provider.js.map +0 -1
- package/src/lib/core/providers/jwt-auth.provider.d.ts +0 -33
- package/src/lib/core/providers/jwt-auth.provider.js +0 -50
- package/src/lib/core/providers/jwt-auth.provider.js.map +0 -1
- package/src/lib/core/providers/phone-auth.provider.d.ts +0 -18
- package/src/lib/core/providers/phone-auth.provider.js +0 -43
- package/src/lib/core/providers/phone-auth.provider.js.map +0 -1
- package/src/lib/core/services/auth-config.service.d.ts +0 -12
- package/src/lib/core/services/auth-config.service.js +0 -79
- package/src/lib/core/services/auth-config.service.js.map +0 -1
- package/src/lib/core/services/auth-provider-registry.service.d.ts +0 -24
- package/src/lib/core/services/auth-provider-registry.service.js +0 -71
- package/src/lib/core/services/auth-provider-registry.service.js.map +0 -1
- package/src/lib/core/services/debug-logger.service.d.ts +0 -38
- package/src/lib/core/services/debug-logger.service.js.map +0 -1
- package/src/lib/core/services/initialization.service.d.ts +0 -10
- package/src/lib/core/services/initialization.service.js +0 -34
- package/src/lib/core/services/initialization.service.js.map +0 -1
- package/src/lib/core/services/jwt.service.d.ts +0 -14
- package/src/lib/core/services/jwt.service.js +0 -92
- package/src/lib/core/services/jwt.service.js.map +0 -1
- package/src/lib/nest-auth.module.d.ts +0 -11
- package/src/lib/nest-auth.module.js +0 -177
- package/src/lib/nest-auth.module.js.map +0 -1
- package/src/lib/request-context/request-context.d.ts +0 -22
- package/src/lib/request-context/request-context.js.map +0 -1
- package/src/lib/request-context/request-context.middleware.d.ts +0 -4
- package/src/lib/request-context/request-context.middleware.js +0 -16
- package/src/lib/request-context/request-context.middleware.js.map +0 -1
- package/src/lib/role/entities/role.entity.d.ts +0 -20
- package/src/lib/role/entities/role.entity.js +0 -110
- package/src/lib/role/entities/role.entity.js.map +0 -1
- package/src/lib/role/index.js +0 -5
- package/src/lib/role/index.js.map +0 -1
- package/src/lib/role/role.module.d.ts +0 -2
- package/src/lib/role/role.module.js +0 -23
- package/src/lib/role/role.module.js.map +0 -1
- package/src/lib/role/services/role.service.d.ts +0 -20
- package/src/lib/role/services/role.service.js.map +0 -1
- package/src/lib/session/entities/session.entity.d.ts +0 -16
- package/src/lib/session/entities/session.entity.js +0 -63
- package/src/lib/session/entities/session.entity.js.map +0 -1
- package/src/lib/session/index.d.ts +0 -3
- package/src/lib/session/index.js +0 -7
- package/src/lib/session/index.js.map +0 -1
- package/src/lib/session/services/base-session.service.d.ts +0 -23
- package/src/lib/session/services/base-session.service.js +0 -64
- package/src/lib/session/services/base-session.service.js.map +0 -1
- package/src/lib/session/services/database-session.service.d.ts +0 -17
- package/src/lib/session/services/database-session.service.js +0 -51
- package/src/lib/session/services/database-session.service.js.map +0 -1
- package/src/lib/session/services/redis-session.service.d.ts +0 -20
- package/src/lib/session/services/redis-session.service.js +0 -117
- package/src/lib/session/services/redis-session.service.js.map +0 -1
- package/src/lib/session/session.module.d.ts +0 -2
- package/src/lib/session/session.module.js +0 -33
- package/src/lib/session/session.module.js.map +0 -1
- package/src/lib/tenant/entities/tenant.entity.d.ts +0 -10
- package/src/lib/tenant/entities/tenant.entity.js +0 -44
- package/src/lib/tenant/entities/tenant.entity.js.map +0 -1
- package/src/lib/tenant/events/tenant-created.event.d.ts +0 -8
- package/src/lib/tenant/events/tenant-created.event.js +0 -10
- package/src/lib/tenant/events/tenant-created.event.js.map +0 -1
- package/src/lib/tenant/events/tenant-deleted.event.d.ts +0 -8
- package/src/lib/tenant/events/tenant-deleted.event.js +0 -10
- package/src/lib/tenant/events/tenant-deleted.event.js.map +0 -1
- package/src/lib/tenant/events/tenant-updated.event.js +0 -10
- package/src/lib/tenant/events/tenant-updated.event.js.map +0 -1
- package/src/lib/tenant/index.d.ts +0 -1
- package/src/lib/tenant/index.js +0 -5
- package/src/lib/tenant/index.js.map +0 -1
- package/src/lib/tenant/services/tenant.service.d.ts +0 -26
- package/src/lib/tenant/services/tenant.service.js +0 -200
- package/src/lib/tenant/services/tenant.service.js.map +0 -1
- package/src/lib/tenant/tenant.module.d.ts +0 -2
- package/src/lib/tenant/tenant.module.js +0 -27
- package/src/lib/tenant/tenant.module.js.map +0 -1
- package/src/lib/user/dto/requests/update-user.dto.d.ts +0 -5
- package/src/lib/user/dto/requests/update-user.dto.js +0 -24
- package/src/lib/user/dto/requests/update-user.dto.js.map +0 -1
- package/src/lib/user/entities/access-key.entity.d.ts +0 -16
- package/src/lib/user/entities/access-key.entity.js +0 -63
- package/src/lib/user/entities/access-key.entity.js.map +0 -1
- package/src/lib/user/entities/identity.entity.d.ts +0 -12
- package/src/lib/user/entities/identity.entity.js +0 -47
- package/src/lib/user/entities/identity.entity.js.map +0 -1
- package/src/lib/user/entities/user.entity.d.ts +0 -39
- package/src/lib/user/entities/user.entity.js +0 -201
- package/src/lib/user/entities/user.entity.js.map +0 -1
- package/src/lib/user/events/user-created.event.js +0 -10
- package/src/lib/user/events/user-created.event.js.map +0 -1
- package/src/lib/user/events/user-deleted.event.js +0 -10
- package/src/lib/user/events/user-deleted.event.js.map +0 -1
- package/src/lib/user/events/user-updated.event.js +0 -10
- package/src/lib/user/events/user-updated.event.js.map +0 -1
- package/src/lib/user/index.d.ts +0 -3
- package/src/lib/user/index.js +0 -7
- package/src/lib/user/index.js.map +0 -1
- package/src/lib/user/services/access-key.service.d.ts +0 -19
- package/src/lib/user/services/access-key.service.js +0 -119
- package/src/lib/user/services/access-key.service.js.map +0 -1
- package/src/lib/user/services/user.service.d.ts +0 -24
- package/src/lib/user/services/user.service.js.map +0 -1
- package/src/lib/user/user.module.d.ts +0 -2
- package/src/lib/user/user.module.js +0 -34
- package/src/lib/user/user.module.js.map +0 -1
- package/src/lib/utils/database.utils.d.ts +0 -2
- package/src/lib/utils/database.utils.js +0 -8
- package/src/lib/utils/database.utils.js.map +0 -1
- package/src/lib/utils/otp.d.ts +0 -1
- package/src/lib/utils/otp.js +0 -7
- package/src/lib/utils/otp.js.map +0 -1
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Gets the base URL for the auth admin console API.
|
|
3
|
+
* Priority:
|
|
4
|
+
* 1. Environment variable VITE_API_BASE_URL (origin only, useful for dev with different server)
|
|
5
|
+
* 2. Server-injected config (production)
|
|
6
|
+
* 3. Current location origin + default basePath (default)
|
|
7
|
+
*/
|
|
8
|
+
export const getAdminApiBaseUrl = (): string => {
|
|
9
|
+
// Check for server-injected config (production)
|
|
10
|
+
const serverBasePath = window.__NEST_AUTH_CONFIG__?.basePath;
|
|
11
|
+
const serverApiUrl = window.__NEST_AUTH_CONFIG__?.apiUrl;
|
|
12
|
+
if (serverApiUrl) {
|
|
13
|
+
return serverApiUrl;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
// Check for custom origin from environment (dev mode)
|
|
17
|
+
const envBaseUrl = import.meta.env.VITE_API_BASE_URL;
|
|
18
|
+
const origin = envBaseUrl ? envBaseUrl.replace(/\/$/, '') : window.location.origin;
|
|
19
|
+
const basePath = serverBasePath ?? '/api/auth/admin';
|
|
20
|
+
|
|
21
|
+
console.log('envBaseUrl', envBaseUrl);
|
|
22
|
+
console.log('basePath', basePath);
|
|
23
|
+
|
|
24
|
+
return `${origin}${basePath}`;
|
|
25
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Mail } from 'lucide-react';
|
|
3
|
+
import { FormField, FormFieldProps } from './FormField';
|
|
4
|
+
|
|
5
|
+
export interface EmailFieldProps extends Omit<FormFieldProps, 'type' | 'startIcon'> {
|
|
6
|
+
autoComplete?: 'username' | 'email';
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Email field wrapper - uses FormField with email type and Mail icon
|
|
11
|
+
* All rendering logic is in FormField (single source of truth)
|
|
12
|
+
*/
|
|
13
|
+
export const EmailField: React.FC<EmailFieldProps> = ({
|
|
14
|
+
autoComplete = 'email',
|
|
15
|
+
...props
|
|
16
|
+
}) => {
|
|
17
|
+
return (
|
|
18
|
+
<FormField
|
|
19
|
+
{...props}
|
|
20
|
+
type="email"
|
|
21
|
+
startIcon={<Mail className="h-5 w-5 text-gray-400" />}
|
|
22
|
+
autoComplete={autoComplete}
|
|
23
|
+
/>
|
|
24
|
+
);
|
|
25
|
+
};
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import React, { ReactNode, forwardRef } from 'react';
|
|
2
|
+
import { LucideIcon } from 'lucide-react';
|
|
3
|
+
|
|
4
|
+
export interface FormFieldProps {
|
|
5
|
+
id: string;
|
|
6
|
+
label: string;
|
|
7
|
+
value: string;
|
|
8
|
+
onChange: (event: React.ChangeEvent<HTMLInputElement>) => void;
|
|
9
|
+
onBlur?: (event: React.FocusEvent<HTMLInputElement>) => void;
|
|
10
|
+
type?: 'text' | 'email' | 'password' | 'tel' | 'url' | 'number' | 'search';
|
|
11
|
+
error?: string;
|
|
12
|
+
placeholder?: string;
|
|
13
|
+
disabled?: boolean;
|
|
14
|
+
required?: boolean;
|
|
15
|
+
autoComplete?: string;
|
|
16
|
+
maxLength?: number;
|
|
17
|
+
minLength?: number;
|
|
18
|
+
className?: string;
|
|
19
|
+
startIcon?: LucideIcon | ReactNode;
|
|
20
|
+
endActions?: ReactNode;
|
|
21
|
+
helpText?: string | ReactNode;
|
|
22
|
+
inputClassName?: string;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Standard form field component - single source of truth for all form inputs
|
|
27
|
+
* Use this component directly or use specialized wrappers (EmailField, PasswordField, etc.)
|
|
28
|
+
*/
|
|
29
|
+
export const FormField = forwardRef<HTMLInputElement, FormFieldProps>(({
|
|
30
|
+
id,
|
|
31
|
+
label,
|
|
32
|
+
value,
|
|
33
|
+
onChange,
|
|
34
|
+
onBlur,
|
|
35
|
+
type = 'text',
|
|
36
|
+
error,
|
|
37
|
+
placeholder,
|
|
38
|
+
disabled = false,
|
|
39
|
+
required = false,
|
|
40
|
+
autoComplete,
|
|
41
|
+
maxLength,
|
|
42
|
+
minLength,
|
|
43
|
+
className = '',
|
|
44
|
+
startIcon: StartIcon,
|
|
45
|
+
endActions,
|
|
46
|
+
helpText,
|
|
47
|
+
inputClassName = '',
|
|
48
|
+
}, ref) => {
|
|
49
|
+
const hasStartIcon = !!StartIcon;
|
|
50
|
+
const hasEndActions = !!endActions;
|
|
51
|
+
const paddingLeft = hasStartIcon ? 'pl-10' : 'pl-3';
|
|
52
|
+
const paddingRight = hasEndActions ? 'pr-20' : 'pr-3';
|
|
53
|
+
|
|
54
|
+
return (
|
|
55
|
+
<div className={className}>
|
|
56
|
+
<label htmlFor={id} className="block text-sm font-medium text-gray-700 mb-2">
|
|
57
|
+
{label}
|
|
58
|
+
</label>
|
|
59
|
+
<div className="relative">
|
|
60
|
+
{hasStartIcon && (
|
|
61
|
+
<div className="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none z-10">
|
|
62
|
+
{React.isValidElement(StartIcon) ? (
|
|
63
|
+
StartIcon
|
|
64
|
+
) : StartIcon && typeof StartIcon === 'function' ? (
|
|
65
|
+
React.createElement(StartIcon as React.ComponentType<any>, {
|
|
66
|
+
className: 'h-5 w-5 text-gray-400',
|
|
67
|
+
size: 20,
|
|
68
|
+
'aria-hidden': true
|
|
69
|
+
})
|
|
70
|
+
) : null}
|
|
71
|
+
</div>
|
|
72
|
+
)}
|
|
73
|
+
<input
|
|
74
|
+
ref={ref}
|
|
75
|
+
id={id}
|
|
76
|
+
type={type}
|
|
77
|
+
required={required}
|
|
78
|
+
autoComplete={autoComplete}
|
|
79
|
+
maxLength={maxLength}
|
|
80
|
+
minLength={minLength}
|
|
81
|
+
value={value}
|
|
82
|
+
onChange={onChange}
|
|
83
|
+
onBlur={onBlur}
|
|
84
|
+
className={`input-field ${paddingLeft} ${paddingRight} ${error ? 'border-red-300' : ''} ${inputClassName}`}
|
|
85
|
+
placeholder={placeholder}
|
|
86
|
+
disabled={disabled}
|
|
87
|
+
/>
|
|
88
|
+
{hasEndActions && (
|
|
89
|
+
<div className="absolute inset-y-0 right-0 flex items-center gap-1 pr-2">
|
|
90
|
+
{endActions}
|
|
91
|
+
</div>
|
|
92
|
+
)}
|
|
93
|
+
</div>
|
|
94
|
+
{helpText && !error && (
|
|
95
|
+
<div className="mt-1 text-xs text-gray-500">{helpText}</div>
|
|
96
|
+
)}
|
|
97
|
+
{error && <p className="mt-1 text-xs text-red-600">{error}</p>}
|
|
98
|
+
</div>
|
|
99
|
+
);
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
FormField.displayName = 'FormField';
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useFormContext, Controller } from 'react-hook-form';
|
|
3
|
+
import { MultiSelect } from '../MultiSelect';
|
|
4
|
+
|
|
5
|
+
interface FormMultiSelectProps {
|
|
6
|
+
name: string;
|
|
7
|
+
label?: string;
|
|
8
|
+
options: Array<{ value: string; label: string }>;
|
|
9
|
+
placeholder?: string;
|
|
10
|
+
helperText?: string;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export const FormMultiSelect: React.FC<FormMultiSelectProps> = ({
|
|
14
|
+
name,
|
|
15
|
+
label,
|
|
16
|
+
options,
|
|
17
|
+
placeholder = 'Select options...',
|
|
18
|
+
helperText,
|
|
19
|
+
}) => {
|
|
20
|
+
const { control, formState: { errors } } = useFormContext();
|
|
21
|
+
const error = errors[name];
|
|
22
|
+
|
|
23
|
+
return (
|
|
24
|
+
<div className="w-full">
|
|
25
|
+
<Controller
|
|
26
|
+
name={name}
|
|
27
|
+
control={control}
|
|
28
|
+
render={({ field }) => (
|
|
29
|
+
<MultiSelect
|
|
30
|
+
label={label}
|
|
31
|
+
value={field.value || []}
|
|
32
|
+
onChange={field.onChange}
|
|
33
|
+
options={options}
|
|
34
|
+
placeholder={placeholder}
|
|
35
|
+
/>
|
|
36
|
+
)}
|
|
37
|
+
/>
|
|
38
|
+
{error && (
|
|
39
|
+
<p className="text-sm text-red-600 mt-1">{error.message as string}</p>
|
|
40
|
+
)}
|
|
41
|
+
{helperText && !error && (
|
|
42
|
+
<p className="text-xs text-gray-500 mt-1">{helperText}</p>
|
|
43
|
+
)}
|
|
44
|
+
</div>
|
|
45
|
+
);
|
|
46
|
+
};
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useFormContext, Controller } from 'react-hook-form';
|
|
3
|
+
|
|
4
|
+
interface FormSelectProps {
|
|
5
|
+
name: string;
|
|
6
|
+
label?: string;
|
|
7
|
+
options: Array<{ value: string; label: string }>;
|
|
8
|
+
placeholder?: string;
|
|
9
|
+
helperText?: string;
|
|
10
|
+
required?: boolean;
|
|
11
|
+
allowEmpty?: boolean;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export const FormSelect: React.FC<FormSelectProps> = ({
|
|
15
|
+
name,
|
|
16
|
+
label,
|
|
17
|
+
options,
|
|
18
|
+
placeholder = 'Select an option...',
|
|
19
|
+
helperText,
|
|
20
|
+
required = false,
|
|
21
|
+
allowEmpty = true,
|
|
22
|
+
}) => {
|
|
23
|
+
const { control, formState: { errors } } = useFormContext();
|
|
24
|
+
const error = errors[name];
|
|
25
|
+
|
|
26
|
+
return (
|
|
27
|
+
<div className="w-full">
|
|
28
|
+
{label && (
|
|
29
|
+
<label htmlFor={name} className="block text-sm font-medium text-gray-700 mb-2">
|
|
30
|
+
{label}
|
|
31
|
+
{required && <span className="text-red-500 ml-1">*</span>}
|
|
32
|
+
</label>
|
|
33
|
+
)}
|
|
34
|
+
<Controller
|
|
35
|
+
name={name}
|
|
36
|
+
control={control}
|
|
37
|
+
render={({ field }) => (
|
|
38
|
+
<select
|
|
39
|
+
{...field}
|
|
40
|
+
id={name}
|
|
41
|
+
className={`input-field appearance-none bg-white cursor-pointer ${error ? 'border-red-500 focus:ring-red-500' : ''}`}
|
|
42
|
+
>
|
|
43
|
+
{allowEmpty && <option value="">{placeholder}</option>}
|
|
44
|
+
{options.map((option) => (
|
|
45
|
+
<option key={option.value} value={option.value}>
|
|
46
|
+
{option.label}
|
|
47
|
+
</option>
|
|
48
|
+
))}
|
|
49
|
+
</select>
|
|
50
|
+
)}
|
|
51
|
+
/>
|
|
52
|
+
{error && (
|
|
53
|
+
<p className="text-sm text-red-600 mt-1">{error.message as string}</p>
|
|
54
|
+
)}
|
|
55
|
+
{helperText && !error && (
|
|
56
|
+
<p className="text-xs text-gray-500 mt-1">{helperText}</p>
|
|
57
|
+
)}
|
|
58
|
+
</div>
|
|
59
|
+
);
|
|
60
|
+
};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useFormContext, Controller, FieldError } from 'react-hook-form';
|
|
3
|
+
import { TagsInput } from '../TagsInput';
|
|
4
|
+
|
|
5
|
+
interface FormTagsInputProps {
|
|
6
|
+
name: string;
|
|
7
|
+
label?: string;
|
|
8
|
+
placeholder?: string;
|
|
9
|
+
helperText?: string;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export const FormTagsInput: React.FC<FormTagsInputProps> = ({
|
|
13
|
+
name,
|
|
14
|
+
label,
|
|
15
|
+
placeholder = 'Type and press Enter...',
|
|
16
|
+
helperText,
|
|
17
|
+
}) => {
|
|
18
|
+
const { control, formState: { errors } } = useFormContext();
|
|
19
|
+
const error = errors[name] as FieldError | undefined;
|
|
20
|
+
const errorString = typeof error?.message === 'string' ? error.message : null;
|
|
21
|
+
|
|
22
|
+
return (
|
|
23
|
+
<div className="w-full">
|
|
24
|
+
<Controller
|
|
25
|
+
name={name}
|
|
26
|
+
control={control}
|
|
27
|
+
render={({ field }) => (
|
|
28
|
+
<TagsInput
|
|
29
|
+
label={label}
|
|
30
|
+
value={field.value || []}
|
|
31
|
+
onChange={field.onChange}
|
|
32
|
+
placeholder={placeholder}
|
|
33
|
+
helperText={helperText && !errorString ? helperText : undefined}
|
|
34
|
+
/>
|
|
35
|
+
)}
|
|
36
|
+
/>
|
|
37
|
+
{errorString && (
|
|
38
|
+
<p className="text-sm text-red-600 mt-1">{errorString}</p>
|
|
39
|
+
)}
|
|
40
|
+
</div>
|
|
41
|
+
);
|
|
42
|
+
};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useFormContext, FieldError } from 'react-hook-form';
|
|
3
|
+
|
|
4
|
+
interface FormTextareaProps extends React.TextareaHTMLAttributes<HTMLTextAreaElement> {
|
|
5
|
+
name: string;
|
|
6
|
+
label?: string;
|
|
7
|
+
helperText?: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export const FormTextarea: React.FC<FormTextareaProps> = ({
|
|
11
|
+
name,
|
|
12
|
+
label,
|
|
13
|
+
helperText,
|
|
14
|
+
className = '',
|
|
15
|
+
...props
|
|
16
|
+
}) => {
|
|
17
|
+
const { register, formState: { errors } } = useFormContext();
|
|
18
|
+
const error = errors[name] as FieldError | undefined;
|
|
19
|
+
|
|
20
|
+
return (
|
|
21
|
+
<div className="w-full">
|
|
22
|
+
{label && (
|
|
23
|
+
<label htmlFor={name} className="block text-sm font-medium text-gray-700 mb-2">
|
|
24
|
+
{label}
|
|
25
|
+
{props.required && <span className="text-red-500 ml-1">*</span>}
|
|
26
|
+
</label>
|
|
27
|
+
)}
|
|
28
|
+
<textarea
|
|
29
|
+
id={name}
|
|
30
|
+
{...register(name)}
|
|
31
|
+
{...props}
|
|
32
|
+
className={`input-field ${error ? 'border-red-500 focus:ring-red-500' : ''} ${className}`}
|
|
33
|
+
/>
|
|
34
|
+
{error?.message && (
|
|
35
|
+
<p className="text-sm text-red-600 mt-1">{error.message}</p>
|
|
36
|
+
)}
|
|
37
|
+
{helperText && !error && (
|
|
38
|
+
<p className="text-xs text-gray-500 mt-1">{helperText}</p>
|
|
39
|
+
)}
|
|
40
|
+
</div>
|
|
41
|
+
);
|
|
42
|
+
};
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Lock, Eye, EyeOff, RefreshCw } from 'lucide-react';
|
|
3
|
+
import { PasswordStrengthIndicator } from '../auth/components/PasswordStrengthIndicator';
|
|
4
|
+
import { generateRandomPassword } from '../auth/utils/security';
|
|
5
|
+
import { FormField, FormFieldProps } from './FormField';
|
|
6
|
+
|
|
7
|
+
export interface PasswordFieldProps extends Omit<FormFieldProps, 'type'> {
|
|
8
|
+
showGenerateButton?: boolean;
|
|
9
|
+
showStrengthIndicator?: boolean;
|
|
10
|
+
onGeneratePassword?: (password: string) => void;
|
|
11
|
+
startIcon?: React.ReactNode;
|
|
12
|
+
hideShowToggle?: boolean;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Password field wrapper - uses FormField with password type and optional features
|
|
17
|
+
* All rendering logic is in FormField (single source of truth)
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
export const PasswordField: React.FC<PasswordFieldProps> = ({
|
|
21
|
+
showGenerateButton = false,
|
|
22
|
+
showStrengthIndicator = false,
|
|
23
|
+
onGeneratePassword,
|
|
24
|
+
startIcon = <Lock className="h-5 w-5 text-gray-400" />,
|
|
25
|
+
hideShowToggle = false,
|
|
26
|
+
placeholder = '••••••••',
|
|
27
|
+
autoComplete = 'new-password',
|
|
28
|
+
maxLength = 128,
|
|
29
|
+
required = true,
|
|
30
|
+
...props
|
|
31
|
+
}) => {
|
|
32
|
+
const [showPassword, setShowPassword] = useState(false);
|
|
33
|
+
|
|
34
|
+
const handleGeneratePassword = () => {
|
|
35
|
+
const newPassword = generateRandomPassword(16);
|
|
36
|
+
const passwordEvent = {
|
|
37
|
+
target: { value: newPassword },
|
|
38
|
+
} as React.ChangeEvent<HTMLInputElement>;
|
|
39
|
+
|
|
40
|
+
if (onGeneratePassword) {
|
|
41
|
+
onGeneratePassword(newPassword);
|
|
42
|
+
} else {
|
|
43
|
+
props.onChange(passwordEvent);
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
const endActions = (
|
|
48
|
+
<>
|
|
49
|
+
{showGenerateButton && (
|
|
50
|
+
<button
|
|
51
|
+
type="button"
|
|
52
|
+
onClick={handleGeneratePassword}
|
|
53
|
+
className="p-1 hover:bg-gray-100 rounded transition-colors"
|
|
54
|
+
title="Generate random password"
|
|
55
|
+
disabled={props.disabled}
|
|
56
|
+
>
|
|
57
|
+
<RefreshCw className="h-5 w-5 text-gray-400 hover:text-primary-600 transition-colors" />
|
|
58
|
+
</button>
|
|
59
|
+
)}
|
|
60
|
+
{!hideShowToggle && (
|
|
61
|
+
<button
|
|
62
|
+
type="button"
|
|
63
|
+
onClick={() => setShowPassword(!showPassword)}
|
|
64
|
+
className="p-1 hover:bg-gray-100 rounded transition-colors"
|
|
65
|
+
title={showPassword ? 'Hide password' : 'Show password'}
|
|
66
|
+
disabled={props.disabled}
|
|
67
|
+
>
|
|
68
|
+
{showPassword ? (
|
|
69
|
+
<EyeOff className="h-5 w-5 text-gray-400 hover:text-primary-600 transition-colors" />
|
|
70
|
+
) : (
|
|
71
|
+
<Eye className="h-5 w-5 text-gray-400 hover:text-primary-600 transition-colors" />
|
|
72
|
+
)}
|
|
73
|
+
</button>
|
|
74
|
+
)}
|
|
75
|
+
</>
|
|
76
|
+
);
|
|
77
|
+
|
|
78
|
+
return (
|
|
79
|
+
<>
|
|
80
|
+
<FormField
|
|
81
|
+
{...props}
|
|
82
|
+
type={showPassword ? 'text' : 'password'}
|
|
83
|
+
startIcon={startIcon}
|
|
84
|
+
endActions={endActions}
|
|
85
|
+
placeholder={placeholder}
|
|
86
|
+
autoComplete={autoComplete}
|
|
87
|
+
maxLength={maxLength}
|
|
88
|
+
required={required}
|
|
89
|
+
/>
|
|
90
|
+
{showStrengthIndicator && <PasswordStrengthIndicator password={props.value} />}
|
|
91
|
+
</>
|
|
92
|
+
);
|
|
93
|
+
};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Key, Eye, EyeOff } from 'lucide-react';
|
|
3
|
+
import { FormField, FormFieldProps } from './FormField';
|
|
4
|
+
|
|
5
|
+
export interface SecretKeyFieldProps extends Omit<FormFieldProps, 'type' | 'startIcon'> {
|
|
6
|
+
helpText?: string | React.ReactNode;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Secret key field wrapper - uses FormField with password type and Key icon
|
|
11
|
+
* All rendering logic is in FormField (single source of truth)
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
export const SecretKeyField: React.FC<SecretKeyFieldProps> = ({
|
|
15
|
+
helpText,
|
|
16
|
+
maxLength = 512,
|
|
17
|
+
placeholder = 'your-nest-auth-secret-key',
|
|
18
|
+
...props
|
|
19
|
+
}) => {
|
|
20
|
+
const [showSecretKey, setShowSecretKey] = useState(false);
|
|
21
|
+
|
|
22
|
+
const endActions = (
|
|
23
|
+
<button
|
|
24
|
+
type="button"
|
|
25
|
+
onClick={() => setShowSecretKey(!showSecretKey)}
|
|
26
|
+
className="p-1 hover:bg-gray-100 rounded transition-colors"
|
|
27
|
+
title={showSecretKey ? 'Hide secret key' : 'Show secret key'}
|
|
28
|
+
disabled={props.disabled}
|
|
29
|
+
>
|
|
30
|
+
{showSecretKey ? (
|
|
31
|
+
<EyeOff className="h-5 w-5 text-gray-400 hover:text-primary-600 transition-colors" />
|
|
32
|
+
) : (
|
|
33
|
+
<Eye className="h-5 w-5 text-gray-400 hover:text-primary-600 transition-colors" />
|
|
34
|
+
)}
|
|
35
|
+
</button>
|
|
36
|
+
);
|
|
37
|
+
|
|
38
|
+
return (
|
|
39
|
+
<FormField
|
|
40
|
+
{...props}
|
|
41
|
+
type={showSecretKey ? 'text' : 'password'}
|
|
42
|
+
startIcon={Key}
|
|
43
|
+
endActions={endActions}
|
|
44
|
+
maxLength={maxLength}
|
|
45
|
+
placeholder={placeholder}
|
|
46
|
+
helpText={helpText}
|
|
47
|
+
/>
|
|
48
|
+
);
|
|
49
|
+
};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Key } from 'lucide-react';
|
|
3
|
+
import { FormDialog } from '../FormDialog';
|
|
4
|
+
import { PermissionForm, PermissionFormData } from './PermissionForm';
|
|
5
|
+
import type { FormFooterAction } from '../FormFooter';
|
|
6
|
+
|
|
7
|
+
export interface CreatePermissionDialogProps {
|
|
8
|
+
isOpen: boolean;
|
|
9
|
+
onClose: () => void;
|
|
10
|
+
onSubmit: (data: PermissionFormData) => Promise<void>;
|
|
11
|
+
categories: string[];
|
|
12
|
+
error?: string;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export const CreatePermissionDialog: React.FC<CreatePermissionDialogProps> = ({
|
|
16
|
+
isOpen,
|
|
17
|
+
onClose,
|
|
18
|
+
onSubmit,
|
|
19
|
+
categories,
|
|
20
|
+
error,
|
|
21
|
+
}) => {
|
|
22
|
+
const [actions, setActions] = useState<FormFooterAction[]>([]);
|
|
23
|
+
|
|
24
|
+
return (
|
|
25
|
+
<FormDialog
|
|
26
|
+
isOpen={isOpen}
|
|
27
|
+
onClose={onClose}
|
|
28
|
+
title="Create New Permission"
|
|
29
|
+
description="Add a permission to the registry for autocomplete suggestions"
|
|
30
|
+
icon={<Key className="w-5 h-5 text-primary-600" />}
|
|
31
|
+
maxWidth="lg"
|
|
32
|
+
actions={actions}
|
|
33
|
+
>
|
|
34
|
+
<PermissionForm
|
|
35
|
+
categories={categories}
|
|
36
|
+
onSubmit={onSubmit}
|
|
37
|
+
onCancel={onClose}
|
|
38
|
+
error={error}
|
|
39
|
+
submitLabel="Create Permission"
|
|
40
|
+
onActionsReady={setActions}
|
|
41
|
+
/>
|
|
42
|
+
</FormDialog>
|
|
43
|
+
);
|
|
44
|
+
};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Key } from 'lucide-react';
|
|
3
|
+
import { FormDialog } from '../FormDialog';
|
|
4
|
+
import { PermissionForm, PermissionFormData } from './PermissionForm';
|
|
5
|
+
import type { FormFooterAction } from '../FormFooter';
|
|
6
|
+
import type { Permission } from '../../types';
|
|
7
|
+
|
|
8
|
+
export interface EditPermissionDialogProps {
|
|
9
|
+
isOpen: boolean;
|
|
10
|
+
onClose: () => void;
|
|
11
|
+
onSubmit: (data: PermissionFormData) => Promise<void>;
|
|
12
|
+
permission: Permission;
|
|
13
|
+
categories: string[];
|
|
14
|
+
error?: string;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export const EditPermissionDialog: React.FC<EditPermissionDialogProps> = ({
|
|
18
|
+
isOpen,
|
|
19
|
+
onClose,
|
|
20
|
+
onSubmit,
|
|
21
|
+
permission,
|
|
22
|
+
categories,
|
|
23
|
+
error,
|
|
24
|
+
}) => {
|
|
25
|
+
const [actions, setActions] = useState<FormFooterAction[]>([]);
|
|
26
|
+
|
|
27
|
+
return (
|
|
28
|
+
<FormDialog
|
|
29
|
+
isOpen={isOpen}
|
|
30
|
+
onClose={onClose}
|
|
31
|
+
title="Edit Permission"
|
|
32
|
+
description="Update permission details"
|
|
33
|
+
icon={<Key className="w-5 h-5 text-primary-600" />}
|
|
34
|
+
maxWidth="lg"
|
|
35
|
+
actions={actions}
|
|
36
|
+
>
|
|
37
|
+
<PermissionForm
|
|
38
|
+
initialData={{
|
|
39
|
+
name: permission.name,
|
|
40
|
+
guard: permission.guard,
|
|
41
|
+
description: permission.description || '',
|
|
42
|
+
category: permission.category || '',
|
|
43
|
+
}}
|
|
44
|
+
categories={categories}
|
|
45
|
+
onSubmit={onSubmit}
|
|
46
|
+
onCancel={onClose}
|
|
47
|
+
error={error}
|
|
48
|
+
submitLabel="Update Permission"
|
|
49
|
+
isEdit={true}
|
|
50
|
+
originalName={permission.name}
|
|
51
|
+
onActionsReady={setActions}
|
|
52
|
+
/>
|
|
53
|
+
</FormDialog>
|
|
54
|
+
);
|
|
55
|
+
};
|