keycloakify 9.6.6 → 10.0.0-rc.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 +1 -1
- package/account/Template.js +34 -14
- package/account/Template.js.map +1 -1
- package/account/i18n/baseMessages/de.d.ts +1 -1
- package/account/i18n/baseMessages/de.js +1 -1
- package/account/i18n/baseMessages/de.js.map +1 -1
- package/account/i18n/baseMessages/en.d.ts +2 -0
- package/account/i18n/baseMessages/en.js +2 -0
- package/account/i18n/baseMessages/en.js.map +1 -1
- package/account/i18n/baseMessages/es.d.ts +230 -0
- package/account/i18n/baseMessages/es.js +231 -1
- package/account/i18n/baseMessages/es.js.map +1 -1
- package/account/i18n/baseMessages/index.d.ts +353 -407
- package/account/i18n/baseMessages/index.js +1 -0
- package/account/i18n/baseMessages/index.js.map +1 -1
- package/account/i18n/baseMessages/pl.d.ts +115 -1
- package/account/i18n/baseMessages/pl.js +115 -1
- package/account/i18n/baseMessages/pl.js.map +1 -1
- package/account/i18n/baseMessages/tr.d.ts +1 -1
- package/account/i18n/baseMessages/tr.js +1 -1
- package/account/i18n/baseMessages/tr.js.map +1 -1
- package/account/i18n/baseMessages/uk.d.ts +337 -0
- package/account/i18n/baseMessages/uk.js +342 -0
- package/account/i18n/baseMessages/uk.js.map +1 -0
- package/account/i18n/baseMessages/zh-CN.d.ts +10 -0
- package/account/i18n/baseMessages/zh-CN.js +10 -0
- package/account/i18n/baseMessages/zh-CN.js.map +1 -1
- package/bin/constants.d.ts +0 -1
- package/bin/constants.js +1 -2
- package/bin/constants.js.map +1 -1
- package/bin/download-builtin-keycloak-theme.js +12 -2
- package/bin/download-builtin-keycloak-theme.js.map +1 -1
- package/bin/keycloakify/buildJars/buildJar.d.ts +14 -0
- package/bin/keycloakify/buildJars/buildJar.js +216 -0
- package/bin/keycloakify/buildJars/buildJar.js.map +1 -0
- package/bin/keycloakify/buildJars/buildJars.d.ts +10 -0
- package/bin/keycloakify/buildJars/buildJars.js +95 -0
- package/bin/keycloakify/buildJars/buildJars.js.map +1 -0
- package/bin/keycloakify/buildJars/extensionVersions.d.ts +12 -0
- package/bin/keycloakify/buildJars/extensionVersions.js +7 -0
- package/bin/keycloakify/buildJars/extensionVersions.js.map +1 -0
- package/bin/keycloakify/buildJars/generatePom.d.ts +13 -0
- package/bin/keycloakify/buildJars/generatePom.js +94 -0
- package/bin/keycloakify/buildJars/generatePom.js.map +1 -0
- package/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.d.ts +6 -0
- package/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.js +35 -0
- package/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.js.map +1 -0
- package/bin/keycloakify/buildJars/index.d.ts +1 -0
- package/bin/keycloakify/buildJars/index.js +18 -0
- package/bin/keycloakify/buildJars/index.js.map +1 -0
- package/bin/keycloakify/buildOptions/UserProvidedBuildOptions.d.ts +0 -8
- package/bin/keycloakify/buildOptions/UserProvidedBuildOptions.js +1 -3
- package/bin/keycloakify/buildOptions/UserProvidedBuildOptions.js.map +1 -1
- package/bin/keycloakify/buildOptions/buildOptions.d.ts +0 -2
- package/bin/keycloakify/buildOptions/buildOptions.js +3 -5
- package/bin/keycloakify/buildOptions/buildOptions.js.map +1 -1
- package/bin/keycloakify/buildOptions/getNpmWorkspaceRootDirPath.js +1 -1
- package/bin/keycloakify/buildOptions/getNpmWorkspaceRootDirPath.js.map +1 -1
- package/bin/keycloakify/generateFtl/ftl_object_to_js_code_declaring_an_object.ftl +103 -232
- package/bin/keycloakify/generateFtl/generateFtl.js +17 -39
- package/bin/keycloakify/generateFtl/generateFtl.js.map +1 -1
- package/bin/keycloakify/generateFtl/pageId.d.ts +1 -1
- package/bin/keycloakify/generateFtl/pageId.js +11 -3
- package/bin/keycloakify/generateFtl/pageId.js.map +1 -1
- package/bin/keycloakify/generateStartKeycloakTestingContainer.d.ts +0 -1
- package/bin/keycloakify/generateStartKeycloakTestingContainer.js +3 -6
- package/bin/keycloakify/generateStartKeycloakTestingContainer.js.map +1 -1
- package/bin/keycloakify/generateTheme/bringInAccountV1.d.ts +1 -1
- package/bin/keycloakify/generateTheme/bringInAccountV1.js +5 -9
- package/bin/keycloakify/generateTheme/bringInAccountV1.js.map +1 -1
- package/bin/keycloakify/generateTheme/generateSrcMainResources.d.ts +21 -0
- package/bin/keycloakify/generateTheme/generateSrcMainResources.js +340 -0
- package/bin/keycloakify/generateTheme/generateSrcMainResources.js.map +1 -0
- package/bin/keycloakify/generateTheme/generateTheme.d.ts +5 -13
- package/bin/keycloakify/generateTheme/generateTheme.js +30 -293
- package/bin/keycloakify/generateTheme/generateTheme.js.map +1 -1
- package/bin/keycloakify/generateTheme/generateThemeVariants.d.ts +5 -0
- package/bin/keycloakify/generateTheme/generateThemeVariants.js +67 -0
- package/bin/keycloakify/generateTheme/generateThemeVariants.js.map +1 -0
- package/bin/keycloakify/generateTheme/readFieldNameUsage.js +54 -18
- package/bin/keycloakify/generateTheme/readFieldNameUsage.js.map +1 -1
- package/bin/keycloakify/keycloakify.js +28 -104
- package/bin/keycloakify/keycloakify.js.map +1 -1
- package/lib/useGetClassName.js +2 -2
- package/lib/useGetClassName.js.map +1 -1
- package/login/Fallback.d.ts +7 -1
- package/login/Fallback.js +32 -8
- package/login/Fallback.js.map +1 -1
- package/login/Template.js +76 -20
- package/login/Template.js.map +1 -1
- package/login/TemplateProps.d.ts +4 -2
- package/login/UserProfileFormFields.d.ts +22 -0
- package/login/UserProfileFormFields.js +327 -0
- package/login/UserProfileFormFields.js.map +1 -0
- package/login/i18n/baseMessages/ar.d.ts +3 -0
- package/login/i18n/baseMessages/ar.js +3 -0
- package/login/i18n/baseMessages/ar.js.map +1 -1
- package/login/i18n/baseMessages/ca.d.ts +1 -0
- package/login/i18n/baseMessages/ca.js +1 -0
- package/login/i18n/baseMessages/ca.js.map +1 -1
- package/login/i18n/baseMessages/cs.d.ts +3 -0
- package/login/i18n/baseMessages/cs.js +3 -0
- package/login/i18n/baseMessages/cs.js.map +1 -1
- package/login/i18n/baseMessages/da.d.ts +1 -0
- package/login/i18n/baseMessages/da.js +1 -0
- package/login/i18n/baseMessages/da.js.map +1 -1
- package/login/i18n/baseMessages/de.d.ts +1 -0
- package/login/i18n/baseMessages/de.js +1 -0
- package/login/i18n/baseMessages/de.js.map +1 -1
- package/login/i18n/baseMessages/el.d.ts +1 -0
- package/login/i18n/baseMessages/el.js +1 -0
- package/login/i18n/baseMessages/el.js.map +1 -1
- package/login/i18n/baseMessages/en.d.ts +7 -0
- package/login/i18n/baseMessages/en.js +23 -16
- package/login/i18n/baseMessages/en.js.map +1 -1
- package/login/i18n/baseMessages/es.d.ts +239 -0
- package/login/i18n/baseMessages/es.js +240 -1
- package/login/i18n/baseMessages/es.js.map +1 -1
- package/login/i18n/baseMessages/fa.d.ts +1 -0
- package/login/i18n/baseMessages/fa.js +1 -0
- package/login/i18n/baseMessages/fa.js.map +1 -1
- package/login/i18n/baseMessages/fi.d.ts +1 -0
- package/login/i18n/baseMessages/fi.js +1 -0
- package/login/i18n/baseMessages/fi.js.map +1 -1
- package/login/i18n/baseMessages/fr.d.ts +1 -0
- package/login/i18n/baseMessages/fr.js +2 -1
- package/login/i18n/baseMessages/fr.js.map +1 -1
- package/login/i18n/baseMessages/hu.d.ts +1 -0
- package/login/i18n/baseMessages/hu.js +1 -0
- package/login/i18n/baseMessages/hu.js.map +1 -1
- package/login/i18n/baseMessages/index.d.ts +211 -416
- package/login/i18n/baseMessages/index.js +1 -0
- package/login/i18n/baseMessages/index.js.map +1 -1
- package/login/i18n/baseMessages/it.d.ts +1 -0
- package/login/i18n/baseMessages/it.js +1 -0
- package/login/i18n/baseMessages/it.js.map +1 -1
- package/login/i18n/baseMessages/ja.d.ts +1 -0
- package/login/i18n/baseMessages/ja.js +1 -0
- package/login/i18n/baseMessages/ja.js.map +1 -1
- package/login/i18n/baseMessages/lt.d.ts +1 -0
- package/login/i18n/baseMessages/lt.js +1 -0
- package/login/i18n/baseMessages/lt.js.map +1 -1
- package/login/i18n/baseMessages/lv.d.ts +1 -0
- package/login/i18n/baseMessages/lv.js +1 -0
- package/login/i18n/baseMessages/lv.js.map +1 -1
- package/login/i18n/baseMessages/nl.d.ts +1 -0
- package/login/i18n/baseMessages/nl.js +1 -0
- package/login/i18n/baseMessages/nl.js.map +1 -1
- package/login/i18n/baseMessages/no.d.ts +1 -0
- package/login/i18n/baseMessages/no.js +1 -0
- package/login/i18n/baseMessages/no.js.map +1 -1
- package/login/i18n/baseMessages/pl.d.ts +1 -0
- package/login/i18n/baseMessages/pl.js +1 -0
- package/login/i18n/baseMessages/pl.js.map +1 -1
- package/login/i18n/baseMessages/pt-BR.d.ts +1 -0
- package/login/i18n/baseMessages/pt-BR.js +1 -0
- package/login/i18n/baseMessages/pt-BR.js.map +1 -1
- package/login/i18n/baseMessages/ru.d.ts +1 -0
- package/login/i18n/baseMessages/ru.js +1 -0
- package/login/i18n/baseMessages/ru.js.map +1 -1
- package/login/i18n/baseMessages/sk.d.ts +2 -0
- package/login/i18n/baseMessages/sk.js +3 -1
- package/login/i18n/baseMessages/sk.js.map +1 -1
- package/login/i18n/baseMessages/sv.d.ts +1 -0
- package/login/i18n/baseMessages/sv.js +1 -0
- package/login/i18n/baseMessages/sv.js.map +1 -1
- package/login/i18n/baseMessages/th.d.ts +1 -0
- package/login/i18n/baseMessages/th.js +1 -0
- package/login/i18n/baseMessages/th.js.map +1 -1
- package/login/i18n/baseMessages/tr.d.ts +1 -0
- package/login/i18n/baseMessages/tr.js +1 -0
- package/login/i18n/baseMessages/tr.js.map +1 -1
- package/login/i18n/baseMessages/uk.d.ts +433 -0
- package/login/i18n/baseMessages/uk.js +438 -0
- package/login/i18n/baseMessages/uk.js.map +1 -0
- package/login/i18n/baseMessages/zh-CN.d.ts +273 -3
- package/login/i18n/baseMessages/zh-CN.js +325 -55
- package/login/i18n/baseMessages/zh-CN.js.map +1 -1
- package/login/i18n/i18n.d.ts +4 -0
- package/login/i18n/i18n.js +6 -2
- package/login/i18n/i18n.js.map +1 -1
- package/login/kcContext/KcContext.d.ts +181 -105
- package/login/kcContext/KcContext.js +1 -1
- package/login/kcContext/KcContext.js.map +1 -1
- package/login/kcContext/createGetKcContext.js +3 -9
- package/login/kcContext/createGetKcContext.js.map +1 -1
- package/login/kcContext/kcContextMocks.d.ts +1 -1
- package/login/kcContext/kcContextMocks.js +92 -198
- package/login/kcContext/kcContextMocks.js.map +1 -1
- package/login/lib/useDownloadTerms.d.ts +4 -1
- package/login/lib/useDownloadTerms.js +9 -4
- package/login/lib/useDownloadTerms.js.map +1 -1
- package/login/lib/useGetClassName.js +112 -73
- package/login/lib/useGetClassName.js.map +1 -1
- package/login/lib/useUserProfileForm.d.ts +74 -0
- package/login/lib/useUserProfileForm.js +868 -0
- package/login/lib/useUserProfileForm.js.map +1 -0
- package/login/pages/{UpdateUserProfile.d.ts → Code.d.ts} +2 -2
- package/login/pages/Code.js +13 -0
- package/login/pages/Code.js.map +1 -0
- package/login/pages/DeleteAccountConfirm.d.ts +7 -0
- package/login/pages/DeleteAccountConfirm.js +14 -0
- package/login/pages/DeleteAccountConfirm.js.map +1 -0
- package/login/pages/{RegisterUserProfile.d.ts → DeleteCredential.d.ts} +2 -2
- package/login/pages/DeleteCredential.js +14 -0
- package/login/pages/DeleteCredential.js.map +1 -0
- package/login/pages/Error.js +2 -2
- package/login/pages/Error.js.map +1 -1
- package/login/pages/FrontchannelLogout.d.ts +7 -0
- package/login/pages/FrontchannelLogout.js +14 -0
- package/login/pages/FrontchannelLogout.js.map +1 -0
- package/login/pages/IdpReviewUserProfile.d.ts +8 -2
- package/login/pages/IdpReviewUserProfile.js +3 -4
- package/login/pages/IdpReviewUserProfile.js.map +1 -1
- package/login/pages/Info.js +14 -1
- package/login/pages/Info.js.map +1 -1
- package/login/pages/Login.js +24 -38
- package/login/pages/Login.js.map +1 -1
- package/login/pages/LoginConfigTotp.js +8 -1
- package/login/pages/LoginConfigTotp.js.map +1 -1
- package/login/pages/{LoginDeviceVerifyUserCode.d.ts → LoginOauth2DeviceVerifyUserCode.d.ts} +1 -1
- package/login/pages/{LoginDeviceVerifyUserCode.js → LoginOauth2DeviceVerifyUserCode.js} +2 -2
- package/login/pages/LoginOauth2DeviceVerifyUserCode.js.map +1 -0
- package/login/pages/LoginOauthGrant.js +3 -2
- package/login/pages/LoginOauthGrant.js.map +1 -1
- package/login/pages/LoginOtp.js +4 -6
- package/login/pages/LoginOtp.js.map +1 -1
- package/login/pages/LoginPageExpired.js +1 -1
- package/login/pages/LoginPageExpired.js.map +1 -1
- package/login/pages/LoginPassword.d.ts +1 -1
- package/login/pages/LoginPassword.js +18 -11
- package/login/pages/LoginPassword.js.map +1 -1
- package/login/pages/LoginRecoveryAuthnCodeConfig.d.ts +7 -0
- package/login/pages/LoginRecoveryAuthnCodeConfig.js +147 -0
- package/login/pages/LoginRecoveryAuthnCodeConfig.js.map +1 -0
- package/login/pages/LoginRecoveryAuthnCodeInput.d.ts +7 -0
- package/login/pages/LoginRecoveryAuthnCodeInput.js +14 -0
- package/login/pages/LoginRecoveryAuthnCodeInput.js.map +1 -0
- package/login/pages/LoginResetOtp.d.ts +7 -0
- package/login/pages/LoginResetOtp.js +15 -0
- package/login/pages/LoginResetOtp.js.map +1 -0
- package/login/pages/LoginResetPassword.js +4 -3
- package/login/pages/LoginResetPassword.js.map +1 -1
- package/login/pages/LoginUpdatePassword.js +21 -3
- package/login/pages/LoginUpdatePassword.js.map +1 -1
- package/login/pages/LoginUpdateProfile.d.ts +8 -2
- package/login/pages/LoginUpdateProfile.js +11 -5
- package/login/pages/LoginUpdateProfile.js.map +1 -1
- package/login/pages/LoginUsername.js +11 -35
- package/login/pages/LoginUsername.js.map +1 -1
- package/login/pages/LoginVerifyEmail.js +1 -1
- package/login/pages/LoginVerifyEmail.js.map +1 -1
- package/login/pages/LoginX509Info.d.ts +7 -0
- package/login/pages/LoginX509Info.js +14 -0
- package/login/pages/LoginX509Info.js.map +1 -0
- package/login/pages/LogoutConfirm.js +1 -1
- package/login/pages/LogoutConfirm.js.map +1 -1
- package/login/pages/Register.d.ts +8 -2
- package/login/pages/Register.js +26 -4
- package/login/pages/Register.js.map +1 -1
- package/login/pages/SamlPostForm.js +1 -1
- package/login/pages/SamlPostForm.js.map +1 -1
- package/login/pages/SelectAuthenticator.js +5 -21
- package/login/pages/SelectAuthenticator.js.map +1 -1
- package/login/pages/Terms.js +4 -6
- package/login/pages/Terms.js.map +1 -1
- package/login/pages/UpdateEmail.d.ts +8 -2
- package/login/pages/UpdateEmail.js +16 -5
- package/login/pages/UpdateEmail.js.map +1 -1
- package/login/pages/WebauthnAuthenticate.js +121 -83
- package/login/pages/WebauthnAuthenticate.js.map +1 -1
- package/login/pages/WebauthnError.d.ts +7 -0
- package/login/pages/WebauthnError.js +21 -0
- package/login/pages/WebauthnError.js.map +1 -0
- package/login/pages/WebauthnRegister.d.ts +7 -0
- package/login/pages/WebauthnRegister.js +193 -0
- package/login/pages/WebauthnRegister.js.map +1 -0
- package/package.json +138 -43
- package/src/account/Template.tsx +41 -14
- package/src/account/i18n/baseMessages/de.ts +1 -1
- package/src/account/i18n/baseMessages/en.ts +2 -0
- package/src/account/i18n/baseMessages/es.ts +231 -1
- package/src/account/i18n/baseMessages/index.ts +1 -0
- package/src/account/i18n/baseMessages/pl.ts +115 -1
- package/src/account/i18n/baseMessages/tr.ts +1 -1
- package/src/account/i18n/baseMessages/uk.ts +343 -0
- package/src/account/i18n/baseMessages/zh-CN.ts +10 -0
- package/src/bin/constants.ts +0 -1
- package/src/bin/download-builtin-keycloak-theme.ts +14 -1
- package/src/bin/keycloakify/buildJars/buildJar.ts +163 -0
- package/src/bin/keycloakify/buildJars/buildJars.ts +62 -0
- package/src/bin/keycloakify/buildJars/extensionVersions.ts +16 -0
- package/src/bin/keycloakify/buildJars/generatePom.ts +86 -0
- package/src/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.ts +37 -0
- package/src/bin/keycloakify/buildJars/index.ts +1 -0
- package/src/bin/keycloakify/buildOptions/UserProvidedBuildOptions.ts +1 -5
- package/src/bin/keycloakify/buildOptions/buildOptions.ts +1 -5
- package/src/bin/keycloakify/buildOptions/getNpmWorkspaceRootDirPath.ts +1 -1
- package/src/bin/keycloakify/generateFtl/ftl_object_to_js_code_declaring_an_object.ftl +103 -232
- package/src/bin/keycloakify/generateFtl/generateFtl.ts +15 -31
- package/src/bin/keycloakify/generateFtl/pageId.ts +11 -3
- package/src/bin/keycloakify/generateStartKeycloakTestingContainer.ts +4 -8
- package/src/bin/keycloakify/generateTheme/bringInAccountV1.ts +5 -11
- package/src/bin/keycloakify/generateTheme/generateSrcMainResources.ts +267 -0
- package/src/bin/keycloakify/generateTheme/generateTheme.ts +22 -309
- package/src/bin/keycloakify/generateTheme/generateThemeVariants.ts +50 -0
- package/src/bin/keycloakify/generateTheme/readFieldNameUsage.ts +33 -8
- package/src/bin/keycloakify/keycloakify.ts +23 -56
- package/src/lib/useGetClassName.ts +2 -2
- package/src/login/Fallback.tsx +39 -9
- package/src/login/Template.tsx +160 -61
- package/src/login/TemplateProps.ts +113 -63
- package/src/login/UserProfileFormFields.tsx +750 -0
- package/src/login/i18n/baseMessages/ar.ts +3 -0
- package/src/login/i18n/baseMessages/ca.ts +1 -0
- package/src/login/i18n/baseMessages/cs.ts +3 -0
- package/src/login/i18n/baseMessages/da.ts +1 -0
- package/src/login/i18n/baseMessages/de.ts +1 -0
- package/src/login/i18n/baseMessages/el.ts +1 -0
- package/src/login/i18n/baseMessages/en.ts +23 -16
- package/src/login/i18n/baseMessages/es.ts +240 -1
- package/src/login/i18n/baseMessages/fa.ts +1 -0
- package/src/login/i18n/baseMessages/fi.ts +1 -0
- package/src/login/i18n/baseMessages/fr.ts +2 -1
- package/src/login/i18n/baseMessages/hu.ts +1 -0
- package/src/login/i18n/baseMessages/index.ts +1 -0
- package/src/login/i18n/baseMessages/it.ts +1 -0
- package/src/login/i18n/baseMessages/ja.ts +1 -0
- package/src/login/i18n/baseMessages/lt.ts +1 -0
- package/src/login/i18n/baseMessages/lv.ts +1 -0
- package/src/login/i18n/baseMessages/nl.ts +1 -0
- package/src/login/i18n/baseMessages/no.ts +1 -0
- package/src/login/i18n/baseMessages/pl.ts +1 -0
- package/src/login/i18n/baseMessages/pt-BR.ts +1 -0
- package/src/login/i18n/baseMessages/ru.ts +1 -0
- package/src/login/i18n/baseMessages/sk.ts +3 -1
- package/src/login/i18n/baseMessages/sv.ts +1 -0
- package/src/login/i18n/baseMessages/th.ts +1 -0
- package/src/login/i18n/baseMessages/tr.ts +1 -0
- package/src/login/i18n/baseMessages/uk.ts +439 -0
- package/src/login/i18n/baseMessages/zh-CN.ts +325 -55
- package/src/login/i18n/i18n.tsx +6 -2
- package/src/login/kcContext/KcContext.ts +216 -103
- package/src/login/kcContext/createGetKcContext.ts +11 -19
- package/src/login/kcContext/kcContextMocks.ts +165 -226
- package/src/login/lib/useDownloadTerms.ts +15 -7
- package/src/login/lib/useGetClassName.ts +112 -83
- package/src/login/lib/useUserProfileForm.tsx +1227 -0
- package/src/login/pages/Code.tsx +35 -0
- package/src/login/pages/DeleteAccountConfirm.tsx +53 -0
- package/src/login/pages/DeleteCredential.tsx +45 -0
- package/src/login/pages/Error.tsx +2 -2
- package/src/login/pages/FrontchannelLogout.tsx +41 -0
- package/src/login/pages/IdpReviewUserProfile.tsx +15 -5
- package/src/login/pages/Info.tsx +29 -19
- package/src/login/pages/Login.tsx +156 -117
- package/src/login/pages/LoginConfigTotp.tsx +26 -1
- package/src/login/pages/{LoginDeviceVerifyUserCode.tsx → LoginOauth2DeviceVerifyUserCode.tsx} +3 -1
- package/src/login/pages/LoginOauthGrant.tsx +38 -2
- package/src/login/pages/LoginOtp.tsx +73 -65
- package/src/login/pages/LoginPageExpired.tsx +1 -1
- package/src/login/pages/LoginPassword.tsx +77 -28
- package/src/login/pages/LoginRecoveryAuthnCodeConfig.tsx +260 -0
- package/src/login/pages/LoginRecoveryAuthnCodeInput.tsx +73 -0
- package/src/login/pages/LoginResetOtp.tsx +70 -0
- package/src/login/pages/LoginResetPassword.tsx +11 -4
- package/src/login/pages/LoginUpdatePassword.tsx +120 -81
- package/src/login/pages/LoginUpdateProfile.tsx +41 -115
- package/src/login/pages/LoginUsername.tsx +93 -101
- package/src/login/pages/LoginVerifyEmail.tsx +14 -8
- package/src/login/pages/LoginX509Info.tsx +94 -0
- package/src/login/pages/LogoutConfirm.tsx +2 -2
- package/src/login/pages/Register.tsx +83 -131
- package/src/login/pages/SamlPostForm.tsx +1 -1
- package/src/login/pages/SelectAuthenticator.tsx +29 -52
- package/src/login/pages/Terms.tsx +4 -7
- package/src/login/pages/UpdateEmail.tsx +69 -54
- package/src/login/pages/WebauthnAuthenticate.tsx +205 -165
- package/src/login/pages/WebauthnError.tsx +66 -0
- package/src/login/pages/WebauthnRegister.tsx +285 -0
- package/src/tools/formatNumber.ts +48 -0
- package/src/tools/useInsertLinkTags.ts +82 -0
- package/src/tools/useInsertScriptTags.ts +106 -0
- package/src/tools/useSetClassName.ts +21 -0
- package/tools/formatNumber.d.ts +1 -0
- package/tools/formatNumber.js +37 -0
- package/tools/formatNumber.js.map +1 -0
- package/tools/useInsertLinkTags.d.ts +7 -0
- package/tools/useInsertLinkTags.js +57 -0
- package/tools/useInsertLinkTags.js.map +1 -0
- package/tools/useInsertScriptTags.d.ts +20 -0
- package/tools/useInsertScriptTags.js +75 -0
- package/tools/useInsertScriptTags.js.map +1 -0
- package/tools/useSetClassName.d.ts +4 -0
- package/tools/useSetClassName.js +16 -0
- package/tools/useSetClassName.js.map +1 -0
- package/vite-plugin/tsconfig.tsbuildinfo +1 -1
- package/bin/keycloakify/generatePom.d.ts +0 -12
- package/bin/keycloakify/generatePom.js +0 -59
- package/bin/keycloakify/generatePom.js.map +0 -1
- package/lib/usePrepareTemplate.d.ts +0 -11
- package/lib/usePrepareTemplate.js +0 -80
- package/lib/usePrepareTemplate.js.map +0 -1
- package/login/lib/useFormValidation.d.ts +0 -47
- package/login/lib/useFormValidation.js +0 -316
- package/login/lib/useFormValidation.js.map +0 -1
- package/login/pages/LoginDeviceVerifyUserCode.js.map +0 -1
- package/login/pages/RegisterUserProfile.js +0 -18
- package/login/pages/RegisterUserProfile.js.map +0 -1
- package/login/pages/UpdateUserProfile.js +0 -17
- package/login/pages/UpdateUserProfile.js.map +0 -1
- package/login/pages/shared/UserProfileFormFields.d.ts +0 -18
- package/login/pages/shared/UserProfileFormFields.js +0 -58
- package/login/pages/shared/UserProfileFormFields.js.map +0 -1
- package/src/bin/keycloakify/generatePom.ts +0 -70
- package/src/lib/usePrepareTemplate.ts +0 -113
- package/src/login/lib/useFormValidation.tsx +0 -474
- package/src/login/pages/RegisterUserProfile.tsx +0 -72
- package/src/login/pages/UpdateUserProfile.tsx +0 -82
- package/src/login/pages/shared/UserProfileFormFields.tsx +0 -177
- package/src/tools/headInsert.ts +0 -73
- package/tools/headInsert.d.ts +0 -12
- package/tools/headInsert.js +0 -50
- package/tools/headInsert.js.map +0 -1
@@ -4,7 +4,6 @@ import { generateCssCodeToDefineGlobals } from "../replacers/replaceImportsInCss
|
|
4
4
|
import { replaceImportsInInlineCssCode } from "../replacers/replaceImportsInInlineCssCode";
|
5
5
|
import * as fs from "fs";
|
6
6
|
import { join as pathJoin } from "path";
|
7
|
-
import { objectKeys } from "tsafe/objectKeys";
|
8
7
|
import type { BuildOptions } from "../buildOptions";
|
9
8
|
import { assert } from "tsafe/assert";
|
10
9
|
import { type ThemeType, nameOfTheGlobal, basenameOfTheKeycloakifyResourcesDir, resources_common } from "../../constants";
|
@@ -96,35 +95,20 @@ export function generateFtlFilesCodeFactory(params: {
|
|
96
95
|
}
|
97
96
|
|
98
97
|
//FTL is no valid html, we can't insert with cheerio, we put placeholder for injecting later.
|
99
|
-
const
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
' <script src="${script}" type="text/javascript"></script>',
|
114
|
-
" </#list>",
|
115
|
-
"</#if>"
|
116
|
-
].join("\n")
|
117
|
-
};
|
118
|
-
|
119
|
-
$("head").prepend(
|
120
|
-
[
|
121
|
-
"<script>",
|
122
|
-
` window.${nameOfTheGlobal}= ${objectKeys(replaceValueBySearchValue)[0]};`,
|
123
|
-
"</script>",
|
124
|
-
"",
|
125
|
-
objectKeys(replaceValueBySearchValue)[1]
|
126
|
-
].join("\n")
|
127
|
-
);
|
98
|
+
const ftlObjectToJsCodeDeclaringAnObject = fs
|
99
|
+
.readFileSync(pathJoin(__dirname, "ftl_object_to_js_code_declaring_an_object.ftl"))
|
100
|
+
.toString("utf8")
|
101
|
+
.match(/^<script>const _=((?:.|\n)+)<\/script>[\n]?$/)![1]
|
102
|
+
.replace("FIELD_NAMES_eKsIY4ZsZ4xeM", fieldNames.map(name => `"${name}"`).join(", "))
|
103
|
+
.replace("KEYCLOAKIFY_VERSION_xEdKd3xEdr", keycloakifyVersion)
|
104
|
+
.replace("KEYCLOAKIFY_THEME_VERSION_sIgKd3xEdr3dx", buildOptions.themeVersion)
|
105
|
+
.replace("KEYCLOAKIFY_THEME_TYPE_dExKd3xEdr", themeType)
|
106
|
+
.replace("KEYCLOAKIFY_THEME_NAME_cXxKd3xEer", themeName)
|
107
|
+
.replace("RESOURCES_COMMON_cLsLsMrtDkpVv", resources_common);
|
108
|
+
|
109
|
+
const ftlObjectToJsCodeDeclaringAnObjectPlaceholder = '{ "x": "vIdLqMeOed9sdLdIdOxdK0d" }';
|
110
|
+
|
111
|
+
$("head").prepend(["<script>", ` window.${nameOfTheGlobal}= ${ftlObjectToJsCodeDeclaringAnObjectPlaceholder};`, "</script>"].join("\n"));
|
128
112
|
|
129
113
|
// Remove part of the document marked as ignored.
|
130
114
|
{
|
@@ -159,7 +143,7 @@ export function generateFtlFilesCodeFactory(params: {
|
|
159
143
|
let ftlCode = $.html();
|
160
144
|
|
161
145
|
Object.entries({
|
162
|
-
|
146
|
+
[ftlObjectToJsCodeDeclaringAnObjectPlaceholder]: ftlObjectToJsCodeDeclaringAnObject,
|
163
147
|
"PAGE_ID_xIgLsPgGId9D8e": pageId
|
164
148
|
}).map(([searchValue, replaceValue]) => (ftlCode = ftlCode.replace(searchValue, replaceValue)));
|
165
149
|
|
@@ -3,8 +3,8 @@ export const loginThemePageIds = [
|
|
3
3
|
"login-username.ftl",
|
4
4
|
"login-password.ftl",
|
5
5
|
"webauthn-authenticate.ftl",
|
6
|
+
"webauthn-register.ftl",
|
6
7
|
"register.ftl",
|
7
|
-
"register-user-profile.ftl",
|
8
8
|
"info.ftl",
|
9
9
|
"error.ftl",
|
10
10
|
"login-reset-password.ftl",
|
@@ -20,11 +20,19 @@ export const loginThemePageIds = [
|
|
20
20
|
"login-page-expired.ftl",
|
21
21
|
"login-config-totp.ftl",
|
22
22
|
"logout-confirm.ftl",
|
23
|
-
"update-user-profile.ftl",
|
24
23
|
"idp-review-user-profile.ftl",
|
25
24
|
"update-email.ftl",
|
26
25
|
"select-authenticator.ftl",
|
27
|
-
"saml-post-form.ftl"
|
26
|
+
"saml-post-form.ftl",
|
27
|
+
"delete-credential.ftl",
|
28
|
+
"code.ftl",
|
29
|
+
"delete-account-confirm.ftl",
|
30
|
+
"frontchannel-logout.ftl",
|
31
|
+
"login-recovery-authn-code-config.ftl",
|
32
|
+
"login-recovery-authn-code-input.ftl",
|
33
|
+
"login-reset-otp.ftl",
|
34
|
+
"login-x509-info.ftl",
|
35
|
+
"webauthn-error.ftl"
|
28
36
|
] as const;
|
29
37
|
|
30
38
|
export const accountThemePageIds = ["password.ftl", "account.ftl", "sessions.ftl", "totp.ftl", "applications.ftl", "log.ftl"] as const;
|
@@ -1,26 +1,22 @@
|
|
1
1
|
import * as fs from "fs";
|
2
2
|
import { join as pathJoin, relative as pathRelative, basename as pathBasename } from "path";
|
3
3
|
import { assert } from "tsafe/assert";
|
4
|
-
import { Reflect } from "tsafe/Reflect";
|
5
4
|
import type { BuildOptions } from "./buildOptions";
|
6
5
|
|
7
6
|
export type BuildOptionsLike = {
|
8
7
|
keycloakifyBuildDirPath: string;
|
9
8
|
};
|
10
9
|
|
11
|
-
|
12
|
-
const buildOptions = Reflect<BuildOptions>();
|
13
|
-
|
14
|
-
assert<typeof buildOptions extends BuildOptionsLike ? true : false>();
|
15
|
-
}
|
10
|
+
assert<BuildOptions extends BuildOptionsLike ? true : false>();
|
16
11
|
|
17
12
|
generateStartKeycloakTestingContainer.basename = "start_keycloak_testing_container.sh";
|
18
13
|
|
19
14
|
const containerName = "keycloak-testing-container";
|
15
|
+
const keycloakVersion = "24.0.4";
|
20
16
|
|
21
17
|
/** Files for being able to run a hot reload keycloak container */
|
22
|
-
export function generateStartKeycloakTestingContainer(params: { jarFilePath: string;
|
23
|
-
const { jarFilePath,
|
18
|
+
export function generateStartKeycloakTestingContainer(params: { jarFilePath: string; buildOptions: BuildOptionsLike }) {
|
19
|
+
const { jarFilePath, buildOptions } = params;
|
24
20
|
|
25
21
|
const themeRelativeDirPath = pathJoin("src", "main", "resources", "theme");
|
26
22
|
const themeDirPath = pathJoin(buildOptions.keycloakifyBuildDirPath, themeRelativeDirPath);
|
@@ -1,7 +1,6 @@
|
|
1
1
|
import * as fs from "fs";
|
2
2
|
import { join as pathJoin } from "path";
|
3
3
|
import { assert } from "tsafe/assert";
|
4
|
-
import { Reflect } from "tsafe/Reflect";
|
5
4
|
import type { BuildOptions } from "../buildOptions";
|
6
5
|
import { resources_common, lastKeycloakVersionWithAccountV1, accountV1ThemeName } from "../../constants";
|
7
6
|
import { downloadBuiltinKeycloakTheme } from "../../download-builtin-keycloak-theme";
|
@@ -9,21 +8,16 @@ import { transformCodebase } from "../../tools/transformCodebase";
|
|
9
8
|
import { rmSync } from "../../tools/fs.rmSync";
|
10
9
|
|
11
10
|
type BuildOptionsLike = {
|
12
|
-
keycloakifyBuildDirPath: string;
|
13
11
|
cacheDirPath: string;
|
14
12
|
npmWorkspaceRootDirPath: string;
|
15
13
|
};
|
16
14
|
|
17
|
-
|
18
|
-
const buildOptions = Reflect<BuildOptions>();
|
15
|
+
assert<BuildOptions extends BuildOptionsLike ? true : false>();
|
19
16
|
|
20
|
-
|
21
|
-
}
|
22
|
-
|
23
|
-
export async function bringInAccountV1(params: { buildOptions: BuildOptionsLike }) {
|
24
|
-
const { buildOptions } = params;
|
17
|
+
export async function bringInAccountV1(params: { buildOptions: BuildOptionsLike; srcMainResourcesDirPath: string }) {
|
18
|
+
const { buildOptions, srcMainResourcesDirPath } = params;
|
25
19
|
|
26
|
-
const builtinKeycloakThemeTmpDirPath = pathJoin(
|
20
|
+
const builtinKeycloakThemeTmpDirPath = pathJoin(srcMainResourcesDirPath, "..", "tmp_yxdE2_builtin_keycloak_theme");
|
27
21
|
|
28
22
|
await downloadBuiltinKeycloakTheme({
|
29
23
|
"destDirPath": builtinKeycloakThemeTmpDirPath,
|
@@ -31,7 +25,7 @@ export async function bringInAccountV1(params: { buildOptions: BuildOptionsLike
|
|
31
25
|
buildOptions
|
32
26
|
});
|
33
27
|
|
34
|
-
const accountV1DirPath = pathJoin(
|
28
|
+
const accountV1DirPath = pathJoin(srcMainResourcesDirPath, "theme", accountV1ThemeName, "account");
|
35
29
|
|
36
30
|
transformCodebase({
|
37
31
|
"srcDirPath": pathJoin(builtinKeycloakThemeTmpDirPath, "base", "account"),
|
@@ -0,0 +1,267 @@
|
|
1
|
+
import { transformCodebase } from "../../tools/transformCodebase";
|
2
|
+
import * as fs from "fs";
|
3
|
+
import { join as pathJoin, resolve as pathResolve, dirname as pathDirname } from "path";
|
4
|
+
import { replaceImportsInJsCode } from "../replacers/replaceImportsInJsCode";
|
5
|
+
import { replaceImportsInCssCode } from "../replacers/replaceImportsInCssCode";
|
6
|
+
import { generateFtlFilesCodeFactory, loginThemePageIds, accountThemePageIds } from "../generateFtl";
|
7
|
+
import {
|
8
|
+
type ThemeType,
|
9
|
+
lastKeycloakVersionWithAccountV1,
|
10
|
+
keycloak_resources,
|
11
|
+
accountV1ThemeName,
|
12
|
+
basenameOfTheKeycloakifyResourcesDir
|
13
|
+
} from "../../constants";
|
14
|
+
import { isInside } from "../../tools/isInside";
|
15
|
+
import type { BuildOptions } from "../buildOptions";
|
16
|
+
import { assert, type Equals } from "tsafe/assert";
|
17
|
+
import { downloadKeycloakStaticResources } from "./downloadKeycloakStaticResources";
|
18
|
+
import { readFieldNameUsage } from "./readFieldNameUsage";
|
19
|
+
import { readExtraPagesNames } from "./readExtraPageNames";
|
20
|
+
import { generateMessageProperties } from "./generateMessageProperties";
|
21
|
+
import { bringInAccountV1 } from "./bringInAccountV1";
|
22
|
+
import { rmSync } from "../../tools/fs.rmSync";
|
23
|
+
|
24
|
+
export type BuildOptionsLike = {
|
25
|
+
bundler: "vite" | "webpack";
|
26
|
+
extraThemeProperties: string[] | undefined;
|
27
|
+
themeVersion: string;
|
28
|
+
loginThemeResourcesFromKeycloakVersion: string;
|
29
|
+
reactAppBuildDirPath: string;
|
30
|
+
cacheDirPath: string;
|
31
|
+
assetsDirPath: string;
|
32
|
+
urlPathname: string | undefined;
|
33
|
+
npmWorkspaceRootDirPath: string;
|
34
|
+
};
|
35
|
+
|
36
|
+
assert<BuildOptions extends BuildOptionsLike ? true : false>();
|
37
|
+
|
38
|
+
export async function generateSrcMainResources(params: {
|
39
|
+
themeName: string;
|
40
|
+
themeSrcDirPath: string;
|
41
|
+
keycloakifySrcDirPath: string;
|
42
|
+
buildOptions: BuildOptionsLike;
|
43
|
+
keycloakifyVersion: string;
|
44
|
+
srcMainResourcesDirPath: string;
|
45
|
+
}): Promise<{ doesImplementAccountTheme: boolean }> {
|
46
|
+
const { themeName, themeSrcDirPath, keycloakifySrcDirPath, buildOptions, keycloakifyVersion, srcMainResourcesDirPath } = params;
|
47
|
+
|
48
|
+
const getThemeTypeDirPath = (params: { themeType: ThemeType | "email" }) => {
|
49
|
+
const { themeType } = params;
|
50
|
+
return pathJoin(srcMainResourcesDirPath, "theme", themeName, themeType);
|
51
|
+
};
|
52
|
+
|
53
|
+
const cssGlobalsToDefine: Record<string, string> = {};
|
54
|
+
|
55
|
+
const implementedThemeTypes: Record<ThemeType | "email", boolean> = {
|
56
|
+
"login": false,
|
57
|
+
"account": false,
|
58
|
+
"email": false
|
59
|
+
};
|
60
|
+
|
61
|
+
for (const themeType of ["login", "account"] as const) {
|
62
|
+
if (!fs.existsSync(pathJoin(themeSrcDirPath, themeType))) {
|
63
|
+
continue;
|
64
|
+
}
|
65
|
+
|
66
|
+
implementedThemeTypes[themeType] = true;
|
67
|
+
|
68
|
+
const themeTypeDirPath = getThemeTypeDirPath({ themeType });
|
69
|
+
|
70
|
+
apply_replacers_and_move_to_theme_resources: {
|
71
|
+
const destDirPath = pathJoin(themeTypeDirPath, "resources", basenameOfTheKeycloakifyResourcesDir);
|
72
|
+
|
73
|
+
// NOTE: Prevent accumulation of files in the assets dir, as names are hashed they pile up.
|
74
|
+
rmSync(destDirPath, { "recursive": true, "force": true });
|
75
|
+
|
76
|
+
if (themeType === "account" && implementedThemeTypes.login) {
|
77
|
+
// NOTE: We prevend doing it twice, it has been done for the login theme.
|
78
|
+
|
79
|
+
transformCodebase({
|
80
|
+
"srcDirPath": pathJoin(
|
81
|
+
getThemeTypeDirPath({
|
82
|
+
"themeType": "login"
|
83
|
+
}),
|
84
|
+
"resources",
|
85
|
+
basenameOfTheKeycloakifyResourcesDir
|
86
|
+
),
|
87
|
+
destDirPath
|
88
|
+
});
|
89
|
+
|
90
|
+
break apply_replacers_and_move_to_theme_resources;
|
91
|
+
}
|
92
|
+
|
93
|
+
transformCodebase({
|
94
|
+
"srcDirPath": buildOptions.reactAppBuildDirPath,
|
95
|
+
destDirPath,
|
96
|
+
"transformSourceCode": ({ filePath, sourceCode }) => {
|
97
|
+
//NOTE: Prevent cycles, excludes the folder we generated for debug in public/
|
98
|
+
// This should not happen if users follow the new instruction setup but we keep it for retrocompatibility.
|
99
|
+
if (
|
100
|
+
isInside({
|
101
|
+
"dirPath": pathJoin(buildOptions.reactAppBuildDirPath, keycloak_resources),
|
102
|
+
filePath
|
103
|
+
})
|
104
|
+
) {
|
105
|
+
return undefined;
|
106
|
+
}
|
107
|
+
|
108
|
+
if (/\.css?$/i.test(filePath)) {
|
109
|
+
const { cssGlobalsToDefine: cssGlobalsToDefineForThisFile, fixedCssCode } = replaceImportsInCssCode({
|
110
|
+
"cssCode": sourceCode.toString("utf8")
|
111
|
+
});
|
112
|
+
|
113
|
+
Object.entries(cssGlobalsToDefineForThisFile).forEach(([key, value]) => {
|
114
|
+
cssGlobalsToDefine[key] = value;
|
115
|
+
});
|
116
|
+
|
117
|
+
return { "modifiedSourceCode": Buffer.from(fixedCssCode, "utf8") };
|
118
|
+
}
|
119
|
+
|
120
|
+
if (/\.js?$/i.test(filePath)) {
|
121
|
+
const { fixedJsCode } = replaceImportsInJsCode({
|
122
|
+
"jsCode": sourceCode.toString("utf8"),
|
123
|
+
buildOptions
|
124
|
+
});
|
125
|
+
|
126
|
+
return { "modifiedSourceCode": Buffer.from(fixedJsCode, "utf8") };
|
127
|
+
}
|
128
|
+
|
129
|
+
return { "modifiedSourceCode": sourceCode };
|
130
|
+
}
|
131
|
+
});
|
132
|
+
}
|
133
|
+
|
134
|
+
const { generateFtlFilesCode } = generateFtlFilesCodeFactory({
|
135
|
+
themeName,
|
136
|
+
"indexHtmlCode": fs.readFileSync(pathJoin(buildOptions.reactAppBuildDirPath, "index.html")).toString("utf8"),
|
137
|
+
cssGlobalsToDefine,
|
138
|
+
buildOptions,
|
139
|
+
keycloakifyVersion,
|
140
|
+
themeType,
|
141
|
+
"fieldNames": readFieldNameUsage({
|
142
|
+
keycloakifySrcDirPath,
|
143
|
+
themeSrcDirPath,
|
144
|
+
themeType
|
145
|
+
})
|
146
|
+
});
|
147
|
+
|
148
|
+
[
|
149
|
+
...(() => {
|
150
|
+
switch (themeType) {
|
151
|
+
case "login":
|
152
|
+
return loginThemePageIds;
|
153
|
+
case "account":
|
154
|
+
return accountThemePageIds;
|
155
|
+
}
|
156
|
+
})(),
|
157
|
+
...readExtraPagesNames({
|
158
|
+
themeType,
|
159
|
+
themeSrcDirPath
|
160
|
+
})
|
161
|
+
].forEach(pageId => {
|
162
|
+
const { ftlCode } = generateFtlFilesCode({ pageId });
|
163
|
+
|
164
|
+
fs.mkdirSync(themeTypeDirPath, { "recursive": true });
|
165
|
+
|
166
|
+
fs.writeFileSync(pathJoin(themeTypeDirPath, pageId), Buffer.from(ftlCode, "utf8"));
|
167
|
+
});
|
168
|
+
|
169
|
+
generateMessageProperties({
|
170
|
+
themeSrcDirPath,
|
171
|
+
themeType
|
172
|
+
}).forEach(({ languageTag, propertiesFileSource }) => {
|
173
|
+
const messagesDirPath = pathJoin(themeTypeDirPath, "messages");
|
174
|
+
|
175
|
+
fs.mkdirSync(pathJoin(themeTypeDirPath, "messages"), { "recursive": true });
|
176
|
+
|
177
|
+
const propertiesFilePath = pathJoin(messagesDirPath, `messages_${languageTag}.properties`);
|
178
|
+
|
179
|
+
fs.writeFileSync(propertiesFilePath, Buffer.from(propertiesFileSource, "utf8"));
|
180
|
+
});
|
181
|
+
|
182
|
+
await downloadKeycloakStaticResources({
|
183
|
+
"keycloakVersion": (() => {
|
184
|
+
switch (themeType) {
|
185
|
+
case "account":
|
186
|
+
return lastKeycloakVersionWithAccountV1;
|
187
|
+
case "login":
|
188
|
+
return buildOptions.loginThemeResourcesFromKeycloakVersion;
|
189
|
+
}
|
190
|
+
})(),
|
191
|
+
"themeDirPath": pathResolve(pathJoin(themeTypeDirPath, "..")),
|
192
|
+
themeType,
|
193
|
+
buildOptions
|
194
|
+
});
|
195
|
+
|
196
|
+
fs.writeFileSync(
|
197
|
+
pathJoin(themeTypeDirPath, "theme.properties"),
|
198
|
+
Buffer.from(
|
199
|
+
[
|
200
|
+
`parent=${(() => {
|
201
|
+
switch (themeType) {
|
202
|
+
case "account":
|
203
|
+
return accountV1ThemeName;
|
204
|
+
case "login":
|
205
|
+
return "keycloak";
|
206
|
+
}
|
207
|
+
assert<Equals<typeof themeType, never>>(false);
|
208
|
+
})()}`,
|
209
|
+
...(buildOptions.extraThemeProperties ?? [])
|
210
|
+
].join("\n\n"),
|
211
|
+
"utf8"
|
212
|
+
)
|
213
|
+
);
|
214
|
+
}
|
215
|
+
|
216
|
+
email: {
|
217
|
+
const emailThemeSrcDirPath = pathJoin(themeSrcDirPath, "email");
|
218
|
+
|
219
|
+
if (!fs.existsSync(emailThemeSrcDirPath)) {
|
220
|
+
break email;
|
221
|
+
}
|
222
|
+
|
223
|
+
implementedThemeTypes.email = true;
|
224
|
+
|
225
|
+
transformCodebase({
|
226
|
+
"srcDirPath": emailThemeSrcDirPath,
|
227
|
+
"destDirPath": getThemeTypeDirPath({ "themeType": "email" })
|
228
|
+
});
|
229
|
+
}
|
230
|
+
|
231
|
+
const parsedKeycloakThemeJson: { themes: { name: string; types: string[] }[] } = { "themes": [] };
|
232
|
+
|
233
|
+
parsedKeycloakThemeJson.themes.push({
|
234
|
+
"name": themeName,
|
235
|
+
"types": Object.entries(implementedThemeTypes)
|
236
|
+
.filter(([, isImplemented]) => isImplemented)
|
237
|
+
.map(([themeType]) => themeType)
|
238
|
+
});
|
239
|
+
|
240
|
+
account_specific_extra_work: {
|
241
|
+
if (!implementedThemeTypes.account) {
|
242
|
+
break account_specific_extra_work;
|
243
|
+
}
|
244
|
+
|
245
|
+
await bringInAccountV1({
|
246
|
+
srcMainResourcesDirPath,
|
247
|
+
buildOptions
|
248
|
+
});
|
249
|
+
|
250
|
+
parsedKeycloakThemeJson.themes.push({
|
251
|
+
"name": accountV1ThemeName,
|
252
|
+
"types": ["account"]
|
253
|
+
});
|
254
|
+
}
|
255
|
+
|
256
|
+
{
|
257
|
+
const keycloakThemeJsonFilePath = pathJoin(srcMainResourcesDirPath, "META-INF", "keycloak-themes.json");
|
258
|
+
|
259
|
+
try {
|
260
|
+
fs.mkdirSync(pathDirname(keycloakThemeJsonFilePath));
|
261
|
+
} catch {}
|
262
|
+
|
263
|
+
fs.writeFileSync(keycloakThemeJsonFilePath, Buffer.from(JSON.stringify(parsedKeycloakThemeJson, null, 2), "utf8"));
|
264
|
+
}
|
265
|
+
|
266
|
+
return { "doesImplementAccountTheme": implementedThemeTypes.account };
|
267
|
+
}
|