keycloakify 10.0.0-rc.8 → 10.0.0-rc.80

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 (824) hide show
  1. package/PUBLIC_URL.d.ts +1 -1
  2. package/PUBLIC_URL.js +3 -3
  3. package/PUBLIC_URL.js.map +1 -1
  4. package/README.md +2 -3
  5. package/account/DefaultPage.d.ts +5 -0
  6. package/account/{Fallback.js → DefaultPage.js} +3 -3
  7. package/account/DefaultPage.js.map +1 -0
  8. package/account/{kcContext → KcContext}/KcContext.d.ts +13 -0
  9. package/account/KcContext/KcContext.js.map +1 -0
  10. package/account/KcContext/getKcContextMock.d.ts +24 -0
  11. package/account/KcContext/getKcContextMock.js +28 -0
  12. package/account/KcContext/getKcContextMock.js.map +1 -0
  13. package/account/KcContext/index.d.ts +2 -0
  14. package/account/KcContext/index.js +2 -0
  15. package/account/KcContext/index.js.map +1 -0
  16. package/account/{kcContext → KcContext}/kcContextMocks.d.ts +1 -1
  17. package/account/KcContext/kcContextMocks.js +143 -0
  18. package/account/KcContext/kcContextMocks.js.map +1 -0
  19. package/account/Template.d.ts +2 -2
  20. package/account/Template.js +12 -12
  21. package/account/Template.js.map +1 -1
  22. package/account/TemplateProps.d.ts +3 -5
  23. package/account/i18n/baseMessages/ar.d.ts +2 -0
  24. package/account/i18n/baseMessages/ar.js +3 -1
  25. package/account/i18n/baseMessages/ar.js.map +1 -1
  26. package/account/i18n/baseMessages/ca.d.ts +2 -0
  27. package/account/i18n/baseMessages/ca.js +3 -1
  28. package/account/i18n/baseMessages/ca.js.map +1 -1
  29. package/account/i18n/baseMessages/cs.d.ts +2 -0
  30. package/account/i18n/baseMessages/cs.js +3 -1
  31. package/account/i18n/baseMessages/cs.js.map +1 -1
  32. package/account/i18n/baseMessages/da.d.ts +2 -0
  33. package/account/i18n/baseMessages/da.js +3 -1
  34. package/account/i18n/baseMessages/da.js.map +1 -1
  35. package/account/i18n/baseMessages/de.d.ts +2 -0
  36. package/account/i18n/baseMessages/de.js +3 -1
  37. package/account/i18n/baseMessages/de.js.map +1 -1
  38. package/account/i18n/baseMessages/el.d.ts +2 -0
  39. package/account/i18n/baseMessages/el.js +3 -1
  40. package/account/i18n/baseMessages/el.js.map +1 -1
  41. package/account/i18n/baseMessages/en.d.ts +2 -0
  42. package/account/i18n/baseMessages/en.js +3 -1
  43. package/account/i18n/baseMessages/en.js.map +1 -1
  44. package/account/i18n/baseMessages/es.d.ts +2 -0
  45. package/account/i18n/baseMessages/es.js +3 -1
  46. package/account/i18n/baseMessages/es.js.map +1 -1
  47. package/account/i18n/baseMessages/fa.d.ts +2 -0
  48. package/account/i18n/baseMessages/fa.js +3 -1
  49. package/account/i18n/baseMessages/fa.js.map +1 -1
  50. package/account/i18n/baseMessages/fi.d.ts +2 -0
  51. package/account/i18n/baseMessages/fi.js +3 -1
  52. package/account/i18n/baseMessages/fi.js.map +1 -1
  53. package/account/i18n/baseMessages/fr.d.ts +2 -0
  54. package/account/i18n/baseMessages/fr.js +3 -1
  55. package/account/i18n/baseMessages/fr.js.map +1 -1
  56. package/account/i18n/baseMessages/hu.d.ts +2 -0
  57. package/account/i18n/baseMessages/hu.js +3 -1
  58. package/account/i18n/baseMessages/hu.js.map +1 -1
  59. package/account/i18n/baseMessages/index.d.ts +18 -0
  60. package/account/i18n/baseMessages/index.js.map +1 -1
  61. package/account/i18n/baseMessages/it.d.ts +2 -0
  62. package/account/i18n/baseMessages/it.js +3 -1
  63. package/account/i18n/baseMessages/it.js.map +1 -1
  64. package/account/i18n/baseMessages/ja.d.ts +2 -0
  65. package/account/i18n/baseMessages/ja.js +3 -1
  66. package/account/i18n/baseMessages/ja.js.map +1 -1
  67. package/account/i18n/baseMessages/lt.d.ts +2 -0
  68. package/account/i18n/baseMessages/lt.js +3 -1
  69. package/account/i18n/baseMessages/lt.js.map +1 -1
  70. package/account/i18n/baseMessages/lv.d.ts +2 -0
  71. package/account/i18n/baseMessages/lv.js +3 -1
  72. package/account/i18n/baseMessages/lv.js.map +1 -1
  73. package/account/i18n/baseMessages/nl.d.ts +2 -0
  74. package/account/i18n/baseMessages/nl.js +3 -1
  75. package/account/i18n/baseMessages/nl.js.map +1 -1
  76. package/account/i18n/baseMessages/no.d.ts +2 -0
  77. package/account/i18n/baseMessages/no.js +3 -1
  78. package/account/i18n/baseMessages/no.js.map +1 -1
  79. package/account/i18n/baseMessages/pl.d.ts +2 -0
  80. package/account/i18n/baseMessages/pl.js +3 -1
  81. package/account/i18n/baseMessages/pl.js.map +1 -1
  82. package/account/i18n/baseMessages/pt-BR.d.ts +2 -0
  83. package/account/i18n/baseMessages/pt-BR.js +3 -1
  84. package/account/i18n/baseMessages/pt-BR.js.map +1 -1
  85. package/account/i18n/baseMessages/ru.d.ts +2 -0
  86. package/account/i18n/baseMessages/ru.js +3 -1
  87. package/account/i18n/baseMessages/ru.js.map +1 -1
  88. package/account/i18n/baseMessages/sk.d.ts +2 -0
  89. package/account/i18n/baseMessages/sk.js +3 -1
  90. package/account/i18n/baseMessages/sk.js.map +1 -1
  91. package/account/i18n/baseMessages/sv.d.ts +2 -0
  92. package/account/i18n/baseMessages/sv.js +3 -1
  93. package/account/i18n/baseMessages/sv.js.map +1 -1
  94. package/account/i18n/baseMessages/th.d.ts +2 -0
  95. package/account/i18n/baseMessages/th.js +3 -1
  96. package/account/i18n/baseMessages/th.js.map +1 -1
  97. package/account/i18n/baseMessages/tr.d.ts +2 -0
  98. package/account/i18n/baseMessages/tr.js +3 -1
  99. package/account/i18n/baseMessages/tr.js.map +1 -1
  100. package/account/i18n/baseMessages/uk.d.ts +2 -0
  101. package/account/i18n/baseMessages/uk.js +3 -1
  102. package/account/i18n/baseMessages/uk.js.map +1 -1
  103. package/account/i18n/baseMessages/zh-CN.d.ts +2 -0
  104. package/account/i18n/baseMessages/zh-CN.js +3 -1
  105. package/account/i18n/baseMessages/zh-CN.js.map +1 -1
  106. package/account/i18n/i18n.d.ts +34 -35
  107. package/account/i18n/i18n.js +116 -97
  108. package/account/i18n/i18n.js.map +1 -1
  109. package/account/i18n/index.d.ts +5 -1
  110. package/account/i18n/index.js +2 -1
  111. package/account/i18n/index.js.map +1 -1
  112. package/account/i18n/useI18n.d.ts +13 -0
  113. package/account/i18n/useI18n.js +26 -0
  114. package/account/i18n/useI18n.js.map +1 -0
  115. package/account/index.d.ts +3 -7
  116. package/account/index.js +1 -5
  117. package/account/index.js.map +1 -1
  118. package/account/lib/kcClsx.d.ts +9 -0
  119. package/account/lib/kcClsx.js +19 -0
  120. package/account/lib/kcClsx.js.map +1 -0
  121. package/account/pages/Account.d.ts +1 -1
  122. package/account/pages/Account.js +7 -6
  123. package/account/pages/Account.js.map +1 -1
  124. package/account/pages/Applications.d.ts +1 -1
  125. package/account/pages/Applications.js +7 -8
  126. package/account/pages/Applications.js.map +1 -1
  127. package/account/pages/FederatedIdentity.d.ts +3 -3
  128. package/account/pages/FederatedIdentity.js +1 -1
  129. package/account/pages/FederatedIdentity.js.map +1 -1
  130. package/account/pages/Log.d.ts +1 -1
  131. package/account/pages/Log.js +3 -3
  132. package/account/pages/Log.js.map +1 -1
  133. package/account/pages/PageProps.d.ts +4 -6
  134. package/account/pages/Password.d.ts +1 -1
  135. package/account/pages/Password.js +16 -13
  136. package/account/pages/Password.js.map +1 -1
  137. package/account/pages/Sessions.d.ts +1 -1
  138. package/account/pages/Sessions.js +3 -4
  139. package/account/pages/Sessions.js.map +1 -1
  140. package/account/pages/Totp.d.ts +1 -1
  141. package/account/pages/Totp.js +5 -10
  142. package/account/pages/Totp.js.map +1 -1
  143. package/bin/180.index.js +4664 -0
  144. package/bin/193.index.js +160 -0
  145. package/bin/266.index.js +806 -0
  146. package/bin/304.index.js +1108 -0
  147. package/bin/36.index.js +9980 -0
  148. package/bin/430.index.js +1349 -0
  149. package/bin/440.index.js +1455 -0
  150. package/bin/453.index.js +769 -0
  151. package/bin/456.index.js +6200 -0
  152. package/bin/490.index.js +75195 -0
  153. package/bin/525.index.js +41826 -0
  154. package/bin/526.index.js +973 -0
  155. package/bin/538.index.js +108 -0
  156. package/bin/720.index.js +243 -0
  157. package/bin/751.index.js +732 -0
  158. package/bin/837.index.js +794 -0
  159. package/bin/877.index.js +275 -0
  160. package/bin/932.index.js +269 -0
  161. package/bin/97.index.js +676 -0
  162. package/bin/main.js +7679 -146380
  163. package/bin/shared/KeycloakVersionRange.d.ts +5 -0
  164. package/bin/shared/KeycloakVersionRange.js.map +1 -0
  165. package/bin/shared/buildContext.d.ts +67 -0
  166. package/bin/shared/buildContext.js.map +1 -0
  167. package/bin/shared/constants.d.ts +17 -0
  168. package/bin/shared/constants.js +58 -0
  169. package/bin/shared/constants.js.map +1 -0
  170. package/bin/shared/copyKeycloakResourcesToPublic.d.ts +8 -0
  171. package/bin/shared/copyKeycloakResourcesToPublic.js.map +1 -0
  172. package/bin/shared/downloadKeycloakDefaultTheme.d.ts +10 -0
  173. package/bin/shared/downloadKeycloakDefaultTheme.js.map +1 -0
  174. package/bin/shared/downloadKeycloakStaticResources.d.ts +9 -0
  175. package/bin/shared/downloadKeycloakStaticResources.js.map +1 -0
  176. package/bin/shared/generateKcGenTs.d.ts +12 -0
  177. package/bin/shared/generateKcGenTs.js.map +1 -0
  178. package/bin/shared/metaInfKeycloakThemes.d.ts +13 -0
  179. package/bin/shared/metaInfKeycloakThemes.js.map +1 -0
  180. package/bin/shared/promptKeycloakVersion.d.ts +7 -0
  181. package/bin/shared/promptKeycloakVersion.js.map +1 -0
  182. package/lib/BASE_URL.js.map +1 -1
  183. package/lib/getKcClsx.d.ts +11 -0
  184. package/lib/getKcClsx.js +55 -0
  185. package/lib/getKcClsx.js.map +1 -0
  186. package/login/{Fallback.d.ts → DefaultPage.d.ts} +7 -6
  187. package/login/{Fallback.js → DefaultPage.js} +2 -2
  188. package/login/DefaultPage.js.map +1 -0
  189. package/login/{kcContext → KcContext}/KcContext.d.ts +36 -17
  190. package/login/KcContext/KcContext.js.map +1 -0
  191. package/login/KcContext/getKcContextMock.d.ts +24 -0
  192. package/login/KcContext/getKcContextMock.js +28 -0
  193. package/login/KcContext/getKcContextMock.js.map +1 -0
  194. package/login/KcContext/index.d.ts +2 -0
  195. package/login/KcContext/index.js +2 -0
  196. package/login/KcContext/index.js.map +1 -0
  197. package/login/{kcContext → KcContext}/kcContextMocks.d.ts +1 -1
  198. package/login/KcContext/kcContextMocks.js +334 -0
  199. package/login/KcContext/kcContextMocks.js.map +1 -0
  200. package/login/Template.d.ts +2 -2
  201. package/login/Template.js +23 -23
  202. package/login/Template.js.map +1 -1
  203. package/login/TemplateProps.d.ts +3 -5
  204. package/login/UserProfileFormFields.d.ts +3 -20
  205. package/login/UserProfileFormFields.js +78 -122
  206. package/login/UserProfileFormFields.js.map +1 -1
  207. package/login/UserProfileFormFieldsProps.d.ts +24 -0
  208. package/login/UserProfileFormFieldsProps.js +2 -0
  209. package/login/UserProfileFormFieldsProps.js.map +1 -0
  210. package/login/i18n/baseMessages/ar.d.ts +9 -0
  211. package/login/i18n/baseMessages/ar.js +10 -1
  212. package/login/i18n/baseMessages/ar.js.map +1 -1
  213. package/login/i18n/baseMessages/ca.d.ts +10 -1
  214. package/login/i18n/baseMessages/ca.js +11 -2
  215. package/login/i18n/baseMessages/ca.js.map +1 -1
  216. package/login/i18n/baseMessages/cs.d.ts +9 -0
  217. package/login/i18n/baseMessages/cs.js +10 -1
  218. package/login/i18n/baseMessages/cs.js.map +1 -1
  219. package/login/i18n/baseMessages/da.d.ts +9 -0
  220. package/login/i18n/baseMessages/da.js +10 -1
  221. package/login/i18n/baseMessages/da.js.map +1 -1
  222. package/login/i18n/baseMessages/de.d.ts +9 -0
  223. package/login/i18n/baseMessages/de.js +10 -1
  224. package/login/i18n/baseMessages/de.js.map +1 -1
  225. package/login/i18n/baseMessages/el.d.ts +9 -1
  226. package/login/i18n/baseMessages/el.js +10 -2
  227. package/login/i18n/baseMessages/el.js.map +1 -1
  228. package/login/i18n/baseMessages/en.d.ts +10 -1
  229. package/login/i18n/baseMessages/en.js +11 -2
  230. package/login/i18n/baseMessages/en.js.map +1 -1
  231. package/login/i18n/baseMessages/es.d.ts +10 -1
  232. package/login/i18n/baseMessages/es.js +11 -2
  233. package/login/i18n/baseMessages/es.js.map +1 -1
  234. package/login/i18n/baseMessages/fa.d.ts +9 -1
  235. package/login/i18n/baseMessages/fa.js +10 -2
  236. package/login/i18n/baseMessages/fa.js.map +1 -1
  237. package/login/i18n/baseMessages/fi.d.ts +9 -0
  238. package/login/i18n/baseMessages/fi.js +10 -1
  239. package/login/i18n/baseMessages/fi.js.map +1 -1
  240. package/login/i18n/baseMessages/fr.d.ts +9 -0
  241. package/login/i18n/baseMessages/fr.js +10 -1
  242. package/login/i18n/baseMessages/fr.js.map +1 -1
  243. package/login/i18n/baseMessages/hu.d.ts +10 -1
  244. package/login/i18n/baseMessages/hu.js +11 -2
  245. package/login/i18n/baseMessages/hu.js.map +1 -1
  246. package/login/i18n/baseMessages/index.d.ts +109 -2
  247. package/login/i18n/baseMessages/index.js.map +1 -1
  248. package/login/i18n/baseMessages/it.d.ts +9 -0
  249. package/login/i18n/baseMessages/it.js +10 -1
  250. package/login/i18n/baseMessages/it.js.map +1 -1
  251. package/login/i18n/baseMessages/ja.d.ts +9 -0
  252. package/login/i18n/baseMessages/ja.js +10 -1
  253. package/login/i18n/baseMessages/ja.js.map +1 -1
  254. package/login/i18n/baseMessages/lt.d.ts +9 -0
  255. package/login/i18n/baseMessages/lt.js +10 -1
  256. package/login/i18n/baseMessages/lt.js.map +1 -1
  257. package/login/i18n/baseMessages/lv.d.ts +9 -0
  258. package/login/i18n/baseMessages/lv.js +10 -1
  259. package/login/i18n/baseMessages/lv.js.map +1 -1
  260. package/login/i18n/baseMessages/nl.d.ts +9 -0
  261. package/login/i18n/baseMessages/nl.js +10 -1
  262. package/login/i18n/baseMessages/nl.js.map +1 -1
  263. package/login/i18n/baseMessages/no.d.ts +9 -0
  264. package/login/i18n/baseMessages/no.js +10 -1
  265. package/login/i18n/baseMessages/no.js.map +1 -1
  266. package/login/i18n/baseMessages/pl.d.ts +9 -0
  267. package/login/i18n/baseMessages/pl.js +10 -1
  268. package/login/i18n/baseMessages/pl.js.map +1 -1
  269. package/login/i18n/baseMessages/pt-BR.d.ts +9 -0
  270. package/login/i18n/baseMessages/pt-BR.js +10 -1
  271. package/login/i18n/baseMessages/pt-BR.js.map +1 -1
  272. package/login/i18n/baseMessages/ru.d.ts +9 -0
  273. package/login/i18n/baseMessages/ru.js +10 -1
  274. package/login/i18n/baseMessages/ru.js.map +1 -1
  275. package/login/i18n/baseMessages/sk.d.ts +9 -0
  276. package/login/i18n/baseMessages/sk.js +10 -1
  277. package/login/i18n/baseMessages/sk.js.map +1 -1
  278. package/login/i18n/baseMessages/sv.d.ts +9 -0
  279. package/login/i18n/baseMessages/sv.js +10 -1
  280. package/login/i18n/baseMessages/sv.js.map +1 -1
  281. package/login/i18n/baseMessages/th.d.ts +9 -0
  282. package/login/i18n/baseMessages/th.js +10 -1
  283. package/login/i18n/baseMessages/th.js.map +1 -1
  284. package/login/i18n/baseMessages/tr.d.ts +9 -0
  285. package/login/i18n/baseMessages/tr.js +10 -1
  286. package/login/i18n/baseMessages/tr.js.map +1 -1
  287. package/login/i18n/baseMessages/uk.d.ts +9 -0
  288. package/login/i18n/baseMessages/uk.js +10 -1
  289. package/login/i18n/baseMessages/uk.js.map +1 -1
  290. package/login/i18n/baseMessages/zh-CN.d.ts +10 -1
  291. package/login/i18n/baseMessages/zh-CN.js +11 -2
  292. package/login/i18n/baseMessages/zh-CN.js.map +1 -1
  293. package/login/i18n/i18n.d.ts +38 -37
  294. package/login/i18n/i18n.js +132 -99
  295. package/login/i18n/i18n.js.map +1 -1
  296. package/login/i18n/index.d.ts +5 -1
  297. package/login/i18n/index.js +2 -1
  298. package/login/i18n/index.js.map +1 -1
  299. package/login/i18n/useI18n.d.ts +13 -0
  300. package/login/i18n/useI18n.js +26 -0
  301. package/login/i18n/useI18n.js.map +1 -0
  302. package/login/index.d.ts +3 -7
  303. package/login/index.js +1 -5
  304. package/login/index.js.map +1 -1
  305. package/login/lib/kcClsx.d.ts +9 -0
  306. package/login/lib/kcClsx.js +130 -0
  307. package/login/lib/kcClsx.js.map +1 -0
  308. package/login/lib/useDownloadTerms.d.ts +15 -5
  309. package/login/lib/useDownloadTerms.js +37 -21
  310. package/login/lib/useDownloadTerms.js.map +1 -1
  311. package/login/lib/useUserProfileForm.d.ts +20 -8
  312. package/login/lib/useUserProfileForm.js +402 -295
  313. package/login/lib/useUserProfileForm.js.map +1 -1
  314. package/login/pages/Code.d.ts +1 -1
  315. package/login/pages/Code.js +3 -3
  316. package/login/pages/Code.js.map +1 -1
  317. package/login/pages/DeleteAccountConfirm.d.ts +1 -1
  318. package/login/pages/DeleteAccountConfirm.js +7 -4
  319. package/login/pages/DeleteAccountConfirm.js.map +1 -1
  320. package/login/pages/DeleteCredential.d.ts +1 -1
  321. package/login/pages/DeleteCredential.js +3 -4
  322. package/login/pages/DeleteCredential.js.map +1 -1
  323. package/login/pages/Error.d.ts +1 -1
  324. package/login/pages/Error.js +1 -1
  325. package/login/pages/Error.js.map +1 -1
  326. package/login/pages/FrontchannelLogout.d.ts +1 -1
  327. package/login/pages/FrontchannelLogout.js +1 -1
  328. package/login/pages/FrontchannelLogout.js.map +1 -1
  329. package/login/pages/IdpReviewUserProfile.d.ts +4 -3
  330. package/login/pages/IdpReviewUserProfile.js +4 -5
  331. package/login/pages/IdpReviewUserProfile.js.map +1 -1
  332. package/login/pages/Info.d.ts +1 -1
  333. package/login/pages/Info.js +5 -7
  334. package/login/pages/Info.js.map +1 -1
  335. package/login/pages/Login.d.ts +1 -1
  336. package/login/pages/Login.js +7 -7
  337. package/login/pages/Login.js.map +1 -1
  338. package/login/pages/LoginConfigTotp.d.ts +1 -1
  339. package/login/pages/LoginConfigTotp.js +6 -7
  340. package/login/pages/LoginConfigTotp.js.map +1 -1
  341. package/login/pages/LoginIdpLinkConfirm.d.ts +1 -1
  342. package/login/pages/LoginIdpLinkConfirm.js +3 -4
  343. package/login/pages/LoginIdpLinkConfirm.js.map +1 -1
  344. package/login/pages/LoginIdpLinkEmail.d.ts +2 -2
  345. package/login/pages/LoginIdpLinkEmail.js +1 -1
  346. package/login/pages/LoginIdpLinkEmail.js.map +1 -1
  347. package/login/pages/LoginOauth2DeviceVerifyUserCode.d.ts +3 -3
  348. package/login/pages/LoginOauth2DeviceVerifyUserCode.js +3 -4
  349. package/login/pages/LoginOauth2DeviceVerifyUserCode.js.map +1 -1
  350. package/login/pages/LoginOauthGrant.d.ts +3 -3
  351. package/login/pages/LoginOauthGrant.js +4 -5
  352. package/login/pages/LoginOauthGrant.js.map +1 -1
  353. package/login/pages/LoginOtp.d.ts +1 -1
  354. package/login/pages/LoginOtp.js +3 -4
  355. package/login/pages/LoginOtp.js.map +1 -1
  356. package/login/pages/LoginPageExpired.d.ts +1 -1
  357. package/login/pages/LoginPageExpired.js +1 -1
  358. package/login/pages/LoginPageExpired.js.map +1 -1
  359. package/login/pages/LoginPassword.d.ts +1 -1
  360. package/login/pages/LoginPassword.js +6 -6
  361. package/login/pages/LoginPassword.js.map +1 -1
  362. package/login/pages/LoginRecoveryAuthnCodeConfig.d.ts +1 -1
  363. package/login/pages/LoginRecoveryAuthnCodeConfig.js +16 -16
  364. package/login/pages/LoginRecoveryAuthnCodeConfig.js.map +1 -1
  365. package/login/pages/LoginRecoveryAuthnCodeInput.d.ts +1 -1
  366. package/login/pages/LoginRecoveryAuthnCodeInput.js +3 -4
  367. package/login/pages/LoginRecoveryAuthnCodeInput.js.map +1 -1
  368. package/login/pages/LoginResetOtp.d.ts +1 -1
  369. package/login/pages/LoginResetOtp.js +3 -4
  370. package/login/pages/LoginResetOtp.js.map +1 -1
  371. package/login/pages/LoginResetPassword.d.ts +1 -1
  372. package/login/pages/LoginResetPassword.js +4 -5
  373. package/login/pages/LoginResetPassword.js.map +1 -1
  374. package/login/pages/LoginUpdatePassword.d.ts +1 -1
  375. package/login/pages/LoginUpdatePassword.js +7 -8
  376. package/login/pages/LoginUpdatePassword.js.map +1 -1
  377. package/login/pages/LoginUpdateProfile.d.ts +4 -3
  378. package/login/pages/LoginUpdateProfile.js +5 -9
  379. package/login/pages/LoginUpdateProfile.js.map +1 -1
  380. package/login/pages/LoginUsername.d.ts +1 -1
  381. package/login/pages/LoginUsername.js +5 -5
  382. package/login/pages/LoginUsername.js.map +1 -1
  383. package/login/pages/LoginVerifyEmail.d.ts +1 -1
  384. package/login/pages/LoginVerifyEmail.js +1 -1
  385. package/login/pages/LoginVerifyEmail.js.map +1 -1
  386. package/login/pages/LoginX509Info.d.ts +1 -1
  387. package/login/pages/LoginX509Info.js +3 -4
  388. package/login/pages/LoginX509Info.js.map +1 -1
  389. package/login/pages/LogoutConfirm.d.ts +1 -1
  390. package/login/pages/LogoutConfirm.js +3 -4
  391. package/login/pages/LogoutConfirm.js.map +1 -1
  392. package/login/pages/PageProps.d.ts +3 -5
  393. package/login/pages/Register.d.ts +4 -3
  394. package/login/pages/Register.js +12 -17
  395. package/login/pages/Register.js.map +1 -1
  396. package/login/pages/SamlPostForm.d.ts +1 -1
  397. package/login/pages/SamlPostForm.js +1 -1
  398. package/login/pages/SamlPostForm.js.map +1 -1
  399. package/login/pages/SelectAuthenticator.d.ts +2 -2
  400. package/login/pages/SelectAuthenticator.js +3 -7
  401. package/login/pages/SelectAuthenticator.js.map +1 -1
  402. package/login/pages/Terms.d.ts +2 -2
  403. package/login/pages/Terms.js +8 -7
  404. package/login/pages/Terms.js.map +1 -1
  405. package/login/pages/UpdateEmail.d.ts +3 -2
  406. package/login/pages/UpdateEmail.js +6 -10
  407. package/login/pages/UpdateEmail.js.map +1 -1
  408. package/login/pages/WebauthnAuthenticate.d.ts +1 -1
  409. package/login/pages/WebauthnAuthenticate.js +25 -22
  410. package/login/pages/WebauthnAuthenticate.js.map +1 -1
  411. package/login/pages/WebauthnError.d.ts +1 -1
  412. package/login/pages/WebauthnError.js +4 -5
  413. package/login/pages/WebauthnError.js.map +1 -1
  414. package/login/pages/WebauthnRegister.d.ts +1 -1
  415. package/login/pages/WebauthnRegister.js +15 -16
  416. package/login/pages/WebauthnRegister.js.map +1 -1
  417. package/package.json +433 -319
  418. package/src/PUBLIC_URL.ts +3 -3
  419. package/src/account/{Fallback.tsx → DefaultPage.tsx} +5 -5
  420. package/src/account/{kcContext → KcContext}/KcContext.ts +24 -2
  421. package/src/account/KcContext/getKcContextMock.ts +69 -0
  422. package/src/account/KcContext/index.ts +2 -0
  423. package/src/account/KcContext/kcContextMocks.ts +190 -0
  424. package/src/account/Template.tsx +14 -16
  425. package/src/account/TemplateProps.ts +4 -5
  426. package/src/account/i18n/baseMessages/ar.ts +3 -1
  427. package/src/account/i18n/baseMessages/ca.ts +3 -1
  428. package/src/account/i18n/baseMessages/cs.ts +3 -1
  429. package/src/account/i18n/baseMessages/da.ts +3 -1
  430. package/src/account/i18n/baseMessages/de.ts +3 -1
  431. package/src/account/i18n/baseMessages/el.ts +3 -1
  432. package/src/account/i18n/baseMessages/en.ts +3 -1
  433. package/src/account/i18n/baseMessages/es.ts +3 -1
  434. package/src/account/i18n/baseMessages/fa.ts +3 -1
  435. package/src/account/i18n/baseMessages/fi.ts +3 -1
  436. package/src/account/i18n/baseMessages/fr.ts +3 -1
  437. package/src/account/i18n/baseMessages/hu.ts +3 -1
  438. package/src/account/i18n/baseMessages/it.ts +3 -1
  439. package/src/account/i18n/baseMessages/ja.ts +3 -1
  440. package/src/account/i18n/baseMessages/lt.ts +3 -1
  441. package/src/account/i18n/baseMessages/lv.ts +3 -1
  442. package/src/account/i18n/baseMessages/nl.ts +3 -1
  443. package/src/account/i18n/baseMessages/no.ts +3 -1
  444. package/src/account/i18n/baseMessages/pl.ts +3 -1
  445. package/src/account/i18n/baseMessages/pt-BR.ts +3 -1
  446. package/src/account/i18n/baseMessages/ru.ts +3 -1
  447. package/src/account/i18n/baseMessages/sk.ts +3 -1
  448. package/src/account/i18n/baseMessages/sv.ts +3 -1
  449. package/src/account/i18n/baseMessages/th.ts +3 -1
  450. package/src/account/i18n/baseMessages/tr.ts +3 -1
  451. package/src/account/i18n/baseMessages/uk.ts +3 -1
  452. package/src/account/i18n/baseMessages/zh-CN.ts +3 -1
  453. package/src/account/i18n/i18n.tsx +201 -142
  454. package/src/account/i18n/index.ts +5 -1
  455. package/src/account/i18n/useI18n.ts +44 -0
  456. package/src/account/index.ts +3 -10
  457. package/src/account/lib/kcClsx.ts +25 -0
  458. package/src/account/pages/Account.tsx +12 -18
  459. package/src/account/pages/Applications.tsx +8 -9
  460. package/src/account/pages/FederatedIdentity.tsx +3 -3
  461. package/src/account/pages/Log.tsx +5 -5
  462. package/src/account/pages/PageProps.ts +4 -6
  463. package/src/account/pages/Password.tsx +17 -19
  464. package/src/account/pages/Sessions.tsx +5 -6
  465. package/src/account/pages/Totp.tsx +18 -38
  466. package/src/bin/add-story.ts +104 -0
  467. package/src/bin/copy-keycloak-resources-to-public.ts +3 -6
  468. package/src/bin/eject-page.ts +256 -0
  469. package/src/bin/initialize-email-theme.ts +30 -26
  470. package/src/bin/keycloakify/buildJars/buildJar.ts +138 -77
  471. package/src/bin/keycloakify/buildJars/buildJars.ts +35 -31
  472. package/src/bin/keycloakify/buildJars/extensionVersions.ts +3 -2
  473. package/src/bin/keycloakify/buildJars/generatePom.ts +19 -11
  474. package/src/bin/keycloakify/buildJars/getKeycloakVersionRangeForJar.ts +42 -10
  475. package/src/bin/keycloakify/generateFtl/generateFtl.ts +64 -42
  476. package/src/bin/keycloakify/generateFtl/{ftl_object_to_js_code_declaring_an_object.ftl → kcContextDeclarationTemplate.ftl} +232 -193
  477. package/src/bin/keycloakify/generateResources/bringInAccountV1.ts +89 -0
  478. package/src/bin/keycloakify/{generateSrcMainResources → generateResources}/generateMessageProperties.ts +47 -53
  479. package/src/bin/keycloakify/generateResources/generateResources.ts +42 -0
  480. package/src/bin/keycloakify/generateResources/generateResourcesForMainTheme.ts +299 -0
  481. package/src/bin/keycloakify/generateResources/generateResourcesForThemeVariant.ts +70 -0
  482. package/src/bin/keycloakify/generateResources/index.ts +1 -0
  483. package/src/bin/keycloakify/{generateSrcMainResources → generateResources}/readExtraPageNames.ts +21 -7
  484. package/src/bin/keycloakify/{generateSrcMainResources → generateResources}/readFieldNameUsage.ts +34 -7
  485. package/src/bin/keycloakify/keycloakify.ts +50 -16
  486. package/src/bin/keycloakify/replacers/replaceImportsInCssCode.ts +42 -46
  487. package/src/bin/keycloakify/replacers/replaceImportsInJsCode/replaceImportsInJsCode.ts +14 -11
  488. package/src/bin/keycloakify/replacers/replaceImportsInJsCode/vite.ts +31 -16
  489. package/src/bin/keycloakify/replacers/replaceImportsInJsCode/webpack.ts +53 -18
  490. package/src/bin/main.ts +96 -44
  491. package/src/bin/shared/KeycloakVersionRange.ts +4 -2
  492. package/src/bin/shared/buildContext.ts +768 -0
  493. package/src/bin/shared/constants.ts +8 -4
  494. package/src/bin/shared/copyKeycloakResourcesToPublic.ts +35 -21
  495. package/src/bin/shared/downloadKeycloakDefaultTheme.ts +276 -0
  496. package/src/bin/shared/downloadKeycloakStaticResources.ts +30 -26
  497. package/src/bin/shared/generateKcGenTs.ts +68 -0
  498. package/src/bin/shared/metaInfKeycloakThemes.ts +25 -19
  499. package/src/bin/shared/promptKeycloakVersion.ts +39 -15
  500. package/src/bin/start-keycloak/appBuild.ts +129 -0
  501. package/src/bin/start-keycloak/index.ts +1 -0
  502. package/src/bin/start-keycloak/keycloakifyBuild.ts +42 -0
  503. package/src/bin/start-keycloak/myrealm-realm-18.json +2155 -0
  504. package/src/bin/start-keycloak/myrealm-realm-19.json +2186 -0
  505. package/src/bin/start-keycloak/myrealm-realm-20.json +2197 -0
  506. package/src/bin/start-keycloak/myrealm-realm-21.json +2201 -0
  507. package/src/bin/start-keycloak/myrealm-realm-23.json +2150 -0
  508. package/src/bin/start-keycloak/myrealm-realm-24.json +2318 -0
  509. package/src/bin/start-keycloak/myrealm-realm-25.json +2400 -0
  510. package/src/bin/start-keycloak/start-keycloak.ts +451 -0
  511. package/src/bin/tools/SemVer.ts +32 -13
  512. package/src/bin/tools/String.prototype.replaceAll.ts +9 -2
  513. package/src/bin/tools/crawl.ts +4 -1
  514. package/src/bin/tools/crc32.ts +42 -24
  515. package/src/bin/tools/downloadAndExtractArchive/downloadAndExtractArchive.ts +262 -0
  516. package/src/bin/tools/{fetchProxyOptions.ts → downloadAndExtractArchive/fetchProxyOptions.ts} +39 -8
  517. package/src/bin/tools/downloadAndExtractArchive/index.ts +1 -0
  518. package/src/bin/tools/escapeStringForPropertiesFile.ts +64 -0
  519. package/src/bin/tools/extractArchive.ts +140 -0
  520. package/src/bin/tools/getAbsoluteAndInOsFormatPath.ts +10 -2
  521. package/src/bin/tools/getNpmWorkspaceRootDirPath.ts +52 -6
  522. package/src/bin/tools/octokit-addons/getLatestsSemVersionedTag.ts +8 -2
  523. package/src/bin/tools/octokit-addons/listTags.ts +15 -4
  524. package/src/bin/tools/partitionPromiseSettledResults.ts +12 -3
  525. package/src/bin/tools/readThisNpmPackageVersion.ts +5 -1
  526. package/src/bin/tools/transformCodebase.ts +29 -10
  527. package/src/bin/tools/trimIndent.ts +4 -1
  528. package/src/bin/tsconfig.json +4 -3
  529. package/src/bin/update-kc-gen.ts +13 -0
  530. package/src/lib/getKcClsx.ts +89 -0
  531. package/src/login/{Fallback.tsx → DefaultPage.tsx} +7 -6
  532. package/src/login/{kcContext → KcContext}/KcContext.ts +58 -30
  533. package/src/login/KcContext/getKcContextMock.ts +69 -0
  534. package/src/login/KcContext/index.ts +8 -0
  535. package/src/login/KcContext/kcContextMocks.ts +583 -0
  536. package/src/login/Template.tsx +54 -57
  537. package/src/login/TemplateProps.ts +3 -6
  538. package/src/login/UserProfileFormFields.tsx +125 -210
  539. package/src/login/UserProfileFormFieldsProps.tsx +22 -0
  540. package/src/login/i18n/baseMessages/ar.ts +10 -1
  541. package/src/login/i18n/baseMessages/ca.ts +11 -2
  542. package/src/login/i18n/baseMessages/cs.ts +10 -1
  543. package/src/login/i18n/baseMessages/da.ts +10 -1
  544. package/src/login/i18n/baseMessages/de.ts +10 -1
  545. package/src/login/i18n/baseMessages/el.ts +10 -2
  546. package/src/login/i18n/baseMessages/en.ts +11 -2
  547. package/src/login/i18n/baseMessages/es.ts +11 -2
  548. package/src/login/i18n/baseMessages/fa.ts +10 -2
  549. package/src/login/i18n/baseMessages/fi.ts +10 -1
  550. package/src/login/i18n/baseMessages/fr.ts +10 -1
  551. package/src/login/i18n/baseMessages/hu.ts +11 -2
  552. package/src/login/i18n/baseMessages/it.ts +10 -1
  553. package/src/login/i18n/baseMessages/ja.ts +10 -1
  554. package/src/login/i18n/baseMessages/lt.ts +10 -1
  555. package/src/login/i18n/baseMessages/lv.ts +10 -1
  556. package/src/login/i18n/baseMessages/nl.ts +10 -1
  557. package/src/login/i18n/baseMessages/no.ts +10 -1
  558. package/src/login/i18n/baseMessages/pl.ts +10 -1
  559. package/src/login/i18n/baseMessages/pt-BR.ts +10 -1
  560. package/src/login/i18n/baseMessages/ru.ts +10 -1
  561. package/src/login/i18n/baseMessages/sk.ts +10 -1
  562. package/src/login/i18n/baseMessages/sv.ts +10 -1
  563. package/src/login/i18n/baseMessages/th.ts +10 -1
  564. package/src/login/i18n/baseMessages/tr.ts +10 -1
  565. package/src/login/i18n/baseMessages/uk.ts +10 -1
  566. package/src/login/i18n/baseMessages/zh-CN.ts +11 -2
  567. package/src/login/i18n/i18n.tsx +231 -143
  568. package/src/login/i18n/index.ts +5 -1
  569. package/src/login/i18n/useI18n.ts +44 -0
  570. package/src/login/index.ts +3 -10
  571. package/src/login/lib/kcClsx.ts +143 -0
  572. package/src/login/lib/useDownloadTerms.tsx +88 -0
  573. package/src/login/lib/useUserProfileForm.tsx +480 -351
  574. package/src/login/pages/Code.tsx +8 -5
  575. package/src/login/pages/DeleteAccountConfirm.tsx +15 -10
  576. package/src/login/pages/DeleteCredential.tsx +9 -7
  577. package/src/login/pages/Error.tsx +9 -2
  578. package/src/login/pages/FrontchannelLogout.tsx +6 -3
  579. package/src/login/pages/IdpReviewUserProfile.tsx +20 -21
  580. package/src/login/pages/Info.tsx +5 -8
  581. package/src/login/pages/Login.tsx +34 -53
  582. package/src/login/pages/LoginConfigTotp.tsx +35 -39
  583. package/src/login/pages/LoginIdpLinkConfirm.tsx +7 -18
  584. package/src/login/pages/LoginIdpLinkEmail.tsx +9 -3
  585. package/src/login/pages/LoginOauth2DeviceVerifyUserCode.tsx +24 -23
  586. package/src/login/pages/LoginOauthGrant.tsx +14 -20
  587. package/src/login/pages/LoginOtp.tsx +27 -30
  588. package/src/login/pages/LoginPageExpired.tsx +2 -2
  589. package/src/login/pages/LoginPassword.tsx +21 -31
  590. package/src/login/pages/LoginRecoveryAuthnCodeConfig.tsx +34 -34
  591. package/src/login/pages/LoginRecoveryAuthnCodeInput.tsx +19 -22
  592. package/src/login/pages/LoginResetOtp.tsx +19 -22
  593. package/src/login/pages/LoginResetPassword.tsx +21 -24
  594. package/src/login/pages/LoginUpdatePassword.tsx +40 -50
  595. package/src/login/pages/LoginUpdateProfile.tsx +32 -30
  596. package/src/login/pages/LoginUsername.tsx +23 -34
  597. package/src/login/pages/LoginVerifyEmail.tsx +5 -2
  598. package/src/login/pages/LoginX509Info.tsx +24 -33
  599. package/src/login/pages/LogoutConfirm.tsx +8 -14
  600. package/src/login/pages/PageProps.ts +3 -5
  601. package/src/login/pages/Register.tsx +48 -59
  602. package/src/login/pages/SamlPostForm.tsx +2 -2
  603. package/src/login/pages/SelectAuthenticator.tsx +23 -24
  604. package/src/login/pages/Terms.tsx +25 -24
  605. package/src/login/pages/UpdateEmail.tsx +30 -33
  606. package/src/login/pages/WebauthnAuthenticate.tsx +40 -44
  607. package/src/login/pages/WebauthnError.tsx +15 -19
  608. package/src/login/pages/WebauthnRegister.tsx +28 -37
  609. package/src/tools/Array.prototype.every.ts +4 -1
  610. package/src/tools/ExtractAfterStartingWith.ts +4 -0
  611. package/src/tools/LazyOrNot.ts +3 -1
  612. package/src/tools/Object.fromEntries.ts +23 -0
  613. package/src/tools/StatefulObservable/README.md +16 -0
  614. package/src/tools/StatefulObservable/StatefulObservable.ts +58 -0
  615. package/src/tools/StatefulObservable/hooks/index.ts +2 -0
  616. package/src/tools/StatefulObservable/hooks/useObservable.ts +25 -0
  617. package/src/tools/StatefulObservable/hooks/useRerenderOnChange.ts +19 -0
  618. package/src/tools/StatefulObservable/index.ts +2 -0
  619. package/src/tools/ValueOf.ts +2 -0
  620. package/src/tools/clsx.ts +6 -42
  621. package/src/tools/clsx_withTransform.ts +55 -0
  622. package/src/tools/deepAssign.ts +57 -19
  623. package/src/tools/formatNumber.ts +7 -3
  624. package/src/tools/react-markdown.ts +3 -0
  625. package/src/tools/structuredCloneButFunctions.ts +24 -0
  626. package/src/tools/useConstCallback.ts +3 -1
  627. package/src/tools/useInsertLinkTags.ts +78 -74
  628. package/src/tools/useInsertScriptTags.ts +69 -73
  629. package/src/tools/useOnFirstMount.ts +18 -0
  630. package/src/tools/useSetClassName.ts +4 -1
  631. package/src/vite-plugin/vite-plugin.ts +73 -37
  632. package/stories/account/pages/Account.stories.tsx +18 -0
  633. package/stories/account/pages/FederatedIdentity.stories.tsx +38 -0
  634. package/stories/account/pages/Log.stories.tsx +356 -0
  635. package/stories/account/pages/Password.stories.tsx +28 -0
  636. package/stories/account/pages/Sessions.stories.tsx +59 -0
  637. package/stories/account/pages/Totp.stories.tsx +182 -0
  638. package/stories/login/pages/Code.stories.tsx +18 -0
  639. package/stories/login/pages/DeleteAccountConfirm.stories.tsx +18 -0
  640. package/stories/login/pages/DeleteCredential.stories.tsx +18 -0
  641. package/stories/login/pages/Error.stories.tsx +28 -0
  642. package/stories/login/pages/FrontchannelLogout.stories.tsx +18 -0
  643. package/stories/login/pages/IdpReviewUserProfile.stories.tsx +18 -0
  644. package/stories/login/pages/Info.stories.tsx +52 -0
  645. package/stories/login/pages/Login.stories.tsx +221 -0
  646. package/stories/login/pages/LoginConfigTotp.stories.tsx +43 -0
  647. package/stories/login/pages/LoginDeviceVerifyUserCode.stories.tsx +18 -0
  648. package/stories/login/pages/LoginIdpLinkConfirm.stories.tsx +18 -0
  649. package/stories/login/pages/LoginIdpLinkEmail.stories.tsx +18 -0
  650. package/stories/login/pages/LoginOauth2DeviceVerifyUserCode.stories.tsx +18 -0
  651. package/stories/login/pages/LoginOauthGrant.stories.tsx +18 -0
  652. package/stories/login/pages/LoginOtp.stories.tsx +18 -0
  653. package/stories/login/pages/LoginPageExpired.stories.tsx +18 -0
  654. package/stories/login/pages/LoginPassword.stories.tsx +18 -0
  655. package/stories/login/pages/LoginRecoveryAuthnCodeConfig.stories.tsx +18 -0
  656. package/stories/login/pages/LoginRecoveryAuthnCodeInput.stories.tsx +18 -0
  657. package/stories/login/pages/LoginResetOtp.stories.tsx +18 -0
  658. package/stories/login/pages/LoginResetPassword.stories.tsx +31 -0
  659. package/stories/login/pages/LoginUpdatePassword.stories.tsx +18 -0
  660. package/stories/login/pages/LoginUpdateProfile.stories.tsx +18 -0
  661. package/stories/login/pages/LoginUsername.stories.tsx +31 -0
  662. package/stories/login/pages/LoginVerifyEmail.stories.tsx +30 -0
  663. package/stories/login/pages/LoginX509Info.stories.tsx +18 -0
  664. package/stories/login/pages/LogoutConfirm.stories.tsx +18 -0
  665. package/stories/login/pages/Register.stories.tsx +135 -0
  666. package/stories/login/pages/SamlPostForm.stories.tsx +18 -0
  667. package/stories/login/pages/SelectAuthenticator.stories.tsx +43 -0
  668. package/stories/login/pages/Terms.stories.tsx +42 -0
  669. package/stories/login/pages/UpdateEmail.stories.tsx +18 -0
  670. package/stories/login/pages/WebauthnAuthenticate.stories.tsx +18 -0
  671. package/stories/login/pages/WebauthnError.stories.tsx +18 -0
  672. package/stories/login/pages/WebauthnRegister.stories.tsx +18 -0
  673. package/tools/Array.prototype.every.js +2 -1
  674. package/tools/Array.prototype.every.js.map +1 -1
  675. package/tools/ExtractAfterStartingWith.d.ts +1 -0
  676. package/tools/ExtractAfterStartingWith.js +2 -0
  677. package/tools/ExtractAfterStartingWith.js.map +1 -0
  678. package/tools/HTMLElement.prototype.prepend.js.map +1 -1
  679. package/tools/Object.fromEntries.d.ts +1 -0
  680. package/tools/Object.fromEntries.js +17 -0
  681. package/tools/Object.fromEntries.js.map +1 -0
  682. package/tools/StatefulObservable/StatefulObservable.d.ts +8 -0
  683. package/tools/StatefulObservable/StatefulObservable.js +36 -0
  684. package/tools/StatefulObservable/StatefulObservable.js.map +1 -0
  685. package/tools/StatefulObservable/hooks/index.d.ts +2 -0
  686. package/tools/StatefulObservable/hooks/index.js +3 -0
  687. package/tools/StatefulObservable/hooks/index.js.map +1 -0
  688. package/tools/StatefulObservable/hooks/useObservable.d.ts +8 -0
  689. package/tools/StatefulObservable/hooks/useObservable.js +17 -0
  690. package/tools/StatefulObservable/hooks/useObservable.js.map +1 -0
  691. package/tools/StatefulObservable/hooks/useRerenderOnChange.d.ts +5 -0
  692. package/tools/StatefulObservable/hooks/useRerenderOnChange.js +14 -0
  693. package/tools/StatefulObservable/hooks/useRerenderOnChange.js.map +1 -0
  694. package/tools/StatefulObservable/index.d.ts +2 -0
  695. package/tools/StatefulObservable/index.js +3 -0
  696. package/tools/StatefulObservable/index.js.map +1 -0
  697. package/tools/ValueOf.d.ts +2 -0
  698. package/tools/ValueOf.js +2 -0
  699. package/tools/ValueOf.js.map +1 -0
  700. package/tools/clsx.d.ts +3 -2
  701. package/tools/clsx.js +5 -41
  702. package/tools/clsx.js.map +1 -1
  703. package/tools/clsx_withTransform.d.ts +5 -0
  704. package/tools/clsx_withTransform.js +43 -0
  705. package/tools/clsx_withTransform.js.map +1 -0
  706. package/tools/deepAssign.d.ts +1 -0
  707. package/tools/deepAssign.js +41 -16
  708. package/tools/deepAssign.js.map +1 -1
  709. package/tools/formatNumber.js +2 -1
  710. package/tools/formatNumber.js.map +1 -1
  711. package/tools/react-markdown.d.ts +3 -0
  712. package/tools/react-markdown.js +4 -0
  713. package/tools/react-markdown.js.map +1 -0
  714. package/tools/structuredCloneButFunctions.d.ts +7 -0
  715. package/tools/structuredCloneButFunctions.js +19 -0
  716. package/tools/structuredCloneButFunctions.js.map +1 -0
  717. package/tools/useConstCallback.js.map +1 -1
  718. package/tools/useInsertLinkTags.d.ts +11 -6
  719. package/tools/useInsertLinkTags.js +53 -52
  720. package/tools/useInsertLinkTags.js.map +1 -1
  721. package/tools/useInsertScriptTags.d.ts +15 -6
  722. package/tools/useInsertScriptTags.js +56 -61
  723. package/tools/useInsertScriptTags.js.map +1 -1
  724. package/tools/useOnFirstMount.d.ts +2 -0
  725. package/tools/useOnFirstMount.js +15 -0
  726. package/tools/useOnFirstMount.js.map +1 -0
  727. package/tools/useSetClassName.js.map +1 -1
  728. package/vite-plugin/index.d.ts +1 -0
  729. package/vite-plugin/index.js +53394 -0
  730. package/vite-plugin/vite-plugin.d.ts +5 -0
  731. package/account/Fallback.d.ts +0 -5
  732. package/account/Fallback.js.map +0 -1
  733. package/account/kcContext/KcContext.js.map +0 -1
  734. package/account/kcContext/createGetKcContext.d.ts +0 -19
  735. package/account/kcContext/createGetKcContext.js +0 -73
  736. package/account/kcContext/createGetKcContext.js.map +0 -1
  737. package/account/kcContext/getKcContext.d.ts +0 -13
  738. package/account/kcContext/getKcContext.js +0 -13
  739. package/account/kcContext/getKcContext.js.map +0 -1
  740. package/account/kcContext/getKcContextFromWindow.d.ts +0 -8
  741. package/account/kcContext/getKcContextFromWindow.js +0 -5
  742. package/account/kcContext/getKcContextFromWindow.js.map +0 -1
  743. package/account/kcContext/index.d.ts +0 -1
  744. package/account/kcContext/index.js +0 -2
  745. package/account/kcContext/index.js.map +0 -1
  746. package/account/kcContext/kcContextMocks.js +0 -215
  747. package/account/kcContext/kcContextMocks.js.map +0 -1
  748. package/account/lib/useGetClassName.d.ts +0 -7
  749. package/account/lib/useGetClassName.js +0 -19
  750. package/account/lib/useGetClassName.js.map +0 -1
  751. package/lib/isStorybook.d.ts +0 -1
  752. package/lib/isStorybook.js +0 -2
  753. package/lib/isStorybook.js.map +0 -1
  754. package/lib/useGetClassName.d.ts +0 -10
  755. package/lib/useGetClassName.js +0 -14
  756. package/lib/useGetClassName.js.map +0 -1
  757. package/login/Fallback.js.map +0 -1
  758. package/login/kcContext/KcContext.js.map +0 -1
  759. package/login/kcContext/createGetKcContext.d.ts +0 -19
  760. package/login/kcContext/createGetKcContext.js +0 -109
  761. package/login/kcContext/createGetKcContext.js.map +0 -1
  762. package/login/kcContext/getKcContext.d.ts +0 -13
  763. package/login/kcContext/getKcContext.js +0 -13
  764. package/login/kcContext/getKcContext.js.map +0 -1
  765. package/login/kcContext/getKcContextFromWindow.d.ts +0 -8
  766. package/login/kcContext/getKcContextFromWindow.js +0 -5
  767. package/login/kcContext/getKcContextFromWindow.js.map +0 -1
  768. package/login/kcContext/index.d.ts +0 -1
  769. package/login/kcContext/index.js +0 -2
  770. package/login/kcContext/index.js.map +0 -1
  771. package/login/kcContext/kcContextMocks.js +0 -390
  772. package/login/kcContext/kcContextMocks.js.map +0 -1
  773. package/login/lib/useGetClassName.d.ts +0 -7
  774. package/login/lib/useGetClassName.js +0 -130
  775. package/login/lib/useGetClassName.js.map +0 -1
  776. package/src/account/kcContext/createGetKcContext.ts +0 -108
  777. package/src/account/kcContext/getKcContext.ts +0 -21
  778. package/src/account/kcContext/getKcContextFromWindow.ts +0 -11
  779. package/src/account/kcContext/index.ts +0 -1
  780. package/src/account/kcContext/kcContextMocks.ts +0 -260
  781. package/src/account/lib/useGetClassName.ts +0 -20
  782. package/src/bin/download-builtin-keycloak-theme.ts +0 -30
  783. package/src/bin/eject-keycloak-page.ts +0 -126
  784. package/src/bin/keycloakify/generateSrcMainResources/bringInAccountV1.ts +0 -79
  785. package/src/bin/keycloakify/generateSrcMainResources/generateSrcMainResources.ts +0 -32
  786. package/src/bin/keycloakify/generateSrcMainResources/generateSrcMainResourcesForMainTheme.ts +0 -261
  787. package/src/bin/keycloakify/generateSrcMainResources/generateSrcMainResourcesForThemeVariant.ts +0 -56
  788. package/src/bin/keycloakify/generateSrcMainResources/index.ts +0 -1
  789. package/src/bin/keycloakify/generateStartKeycloakTestingContainer.ts +0 -60
  790. package/src/bin/keycloakify/replacers/replaceImportsInInlineCssCode.ts +0 -24
  791. package/src/bin/shared/buildOptions.ts +0 -277
  792. package/src/bin/shared/downloadAndUnzip.ts +0 -203
  793. package/src/bin/shared/downloadBuiltinKeycloakTheme.ts +0 -264
  794. package/src/bin/shared/getJarFileBasename.ts +0 -9
  795. package/src/bin/shared/getThemeSrcDirPath.ts +0 -47
  796. package/src/bin/start-keycloak.ts +0 -236
  797. package/src/bin/tools/unzip.ts +0 -141
  798. package/src/lib/isStorybook.ts +0 -1
  799. package/src/lib/useGetClassName.ts +0 -18
  800. package/src/login/kcContext/createGetKcContext.ts +0 -159
  801. package/src/login/kcContext/getKcContext.ts +0 -21
  802. package/src/login/kcContext/getKcContextFromWindow.ts +0 -11
  803. package/src/login/kcContext/index.ts +0 -1
  804. package/src/login/kcContext/kcContextMocks.ts +0 -630
  805. package/src/login/lib/useDownloadTerms.ts +0 -57
  806. package/src/login/lib/useGetClassName.ts +0 -132
  807. package/src/tools/AndByDiscriminatingKey.ts +0 -25
  808. package/src/tools/Markdown.ts +0 -3
  809. package/src/tools/deepClone.ts +0 -17
  810. package/src/tools/memoize.ts +0 -55
  811. package/tools/AndByDiscriminatingKey.d.ts +0 -5
  812. package/tools/AndByDiscriminatingKey.js +0 -2
  813. package/tools/AndByDiscriminatingKey.js.map +0 -1
  814. package/tools/Markdown.d.ts +0 -2
  815. package/tools/Markdown.js +0 -3
  816. package/tools/Markdown.js.map +0 -1
  817. package/tools/deepClone.d.ts +0 -2
  818. package/tools/deepClone.js +0 -14
  819. package/tools/deepClone.js.map +0 -1
  820. package/tools/memoize.d.ts +0 -7
  821. package/tools/memoize.js +0 -38
  822. package/tools/memoize.js.map +0 -1
  823. /package/account/{kcContext → KcContext}/KcContext.js +0 -0
  824. /package/login/{kcContext → KcContext}/KcContext.js +0 -0
@@ -0,0 +1,1349 @@
1
+ exports.id = 430;
2
+ exports.ids = [430];
3
+ exports.modules = {
4
+
5
+ /***/ 84794:
6
+ /***/ ((module, __unused_webpack_exports, __webpack_require__) => {
7
+
8
+ var Buffer = (__webpack_require__(14300).Buffer);
9
+
10
+ var CRC_TABLE = [
11
+ 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419,
12
+ 0x706af48f, 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4,
13
+ 0xe0d5e91e, 0x97d2d988, 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07,
14
+ 0x90bf1d91, 0x1db71064, 0x6ab020f2, 0xf3b97148, 0x84be41de,
15
+ 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7, 0x136c9856,
16
+ 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9,
17
+ 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4,
18
+ 0xa2677172, 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b,
19
+ 0x35b5a8fa, 0x42b2986c, 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3,
20
+ 0x45df5c75, 0xdcd60dcf, 0xabd13d59, 0x26d930ac, 0x51de003a,
21
+ 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, 0xcfba9599,
22
+ 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924,
23
+ 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190,
24
+ 0x01db7106, 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f,
25
+ 0x9fbfe4a5, 0xe8b8d433, 0x7807c9a2, 0x0f00f934, 0x9609a88e,
26
+ 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, 0x91646c97, 0xe6635c01,
27
+ 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, 0x6c0695ed,
28
+ 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950,
29
+ 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3,
30
+ 0xfbd44c65, 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2,
31
+ 0x4adfa541, 0x3dd895d7, 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a,
32
+ 0x346ed9fc, 0xad678846, 0xda60b8d0, 0x44042d73, 0x33031de5,
33
+ 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa, 0xbe0b1010,
34
+ 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f,
35
+ 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17,
36
+ 0x2eb40d81, 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6,
37
+ 0x03b6e20c, 0x74b1d29a, 0xead54739, 0x9dd277af, 0x04db2615,
38
+ 0x73dc1683, 0xe3630b12, 0x94643b84, 0x0d6d6a3e, 0x7a6a5aa8,
39
+ 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1, 0xf00f9344,
40
+ 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb,
41
+ 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a,
42
+ 0x67dd4acc, 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5,
43
+ 0xd6d6a3e8, 0xa1d1937e, 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1,
44
+ 0xa6bc5767, 0x3fb506dd, 0x48b2364b, 0xd80d2bda, 0xaf0a1b4c,
45
+ 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, 0x316e8eef,
46
+ 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236,
47
+ 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe,
48
+ 0xb2bd0b28, 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31,
49
+ 0x2cd99e8b, 0x5bdeae1d, 0x9b64c2b0, 0xec63f226, 0x756aa39c,
50
+ 0x026d930a, 0x9c0906a9, 0xeb0e363f, 0x72076785, 0x05005713,
51
+ 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, 0x92d28e9b,
52
+ 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242,
53
+ 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1,
54
+ 0x18b74777, 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c,
55
+ 0x8f659eff, 0xf862ae69, 0x616bffd3, 0x166ccf45, 0xa00ae278,
56
+ 0xd70dd2ee, 0x4e048354, 0x3903b3c2, 0xa7672661, 0xd06016f7,
57
+ 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc, 0x40df0b66,
58
+ 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9,
59
+ 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605,
60
+ 0xcdd70693, 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8,
61
+ 0x5d681b02, 0x2a6f2b94, 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b,
62
+ 0x2d02ef8d
63
+ ];
64
+
65
+ if (typeof Int32Array !== 'undefined') {
66
+ CRC_TABLE = new Int32Array(CRC_TABLE);
67
+ }
68
+
69
+ function ensureBuffer(input) {
70
+ if (Buffer.isBuffer(input)) {
71
+ return input;
72
+ }
73
+
74
+ var hasNewBufferAPI =
75
+ typeof Buffer.alloc === "function" &&
76
+ typeof Buffer.from === "function";
77
+
78
+ if (typeof input === "number") {
79
+ return hasNewBufferAPI ? Buffer.alloc(input) : new Buffer(input);
80
+ }
81
+ else if (typeof input === "string") {
82
+ return hasNewBufferAPI ? Buffer.from(input) : new Buffer(input);
83
+ }
84
+ else {
85
+ throw new Error("input must be buffer, number, or string, received " +
86
+ typeof input);
87
+ }
88
+ }
89
+
90
+ function bufferizeInt(num) {
91
+ var tmp = ensureBuffer(4);
92
+ tmp.writeInt32BE(num, 0);
93
+ return tmp;
94
+ }
95
+
96
+ function _crc32(buf, previous) {
97
+ buf = ensureBuffer(buf);
98
+ if (Buffer.isBuffer(previous)) {
99
+ previous = previous.readUInt32BE(0);
100
+ }
101
+ var crc = ~~previous ^ -1;
102
+ for (var n = 0; n < buf.length; n++) {
103
+ crc = CRC_TABLE[(crc ^ buf[n]) & 0xff] ^ (crc >>> 8);
104
+ }
105
+ return (crc ^ -1);
106
+ }
107
+
108
+ function crc32() {
109
+ return bufferizeInt(_crc32.apply(null, arguments));
110
+ }
111
+ crc32.signed = function () {
112
+ return _crc32.apply(null, arguments);
113
+ };
114
+ crc32.unsigned = function () {
115
+ return _crc32.apply(null, arguments) >>> 0;
116
+ };
117
+
118
+ module.exports = crc32;
119
+
120
+
121
+ /***/ }),
122
+
123
+ /***/ 50689:
124
+ /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
125
+
126
+ "use strict";
127
+
128
+ var __extends = (this && this.__extends) || (function () {
129
+ var extendStatics = function (d, b) {
130
+ extendStatics = Object.setPrototypeOf ||
131
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
132
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
133
+ return extendStatics(d, b);
134
+ };
135
+ return function (d, b) {
136
+ if (typeof b !== "function" && b !== null)
137
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
138
+ extendStatics(d, b);
139
+ function __() { this.constructor = d; }
140
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
141
+ };
142
+ })();
143
+ Object.defineProperty(exports, "__esModule", ({ value: true }));
144
+ exports.VoidDeferred = exports.Deferred = void 0;
145
+ var overwriteReadonlyProp_1 = __webpack_require__(47803);
146
+ var Deferred = /** @class */ (function () {
147
+ function Deferred() {
148
+ var _this_1 = this;
149
+ this.isPending = true;
150
+ var resolve;
151
+ var reject;
152
+ this.pr = new Promise(function (resolve_, reject_) {
153
+ resolve = function (value) {
154
+ (0, overwriteReadonlyProp_1.overwriteReadonlyProp)(_this_1, "isPending", false);
155
+ resolve_(value);
156
+ };
157
+ reject = function (error) {
158
+ (0, overwriteReadonlyProp_1.overwriteReadonlyProp)(_this_1, "isPending", false);
159
+ reject_(error);
160
+ };
161
+ });
162
+ this.resolve = resolve;
163
+ this.reject = reject;
164
+ }
165
+ return Deferred;
166
+ }());
167
+ exports.Deferred = Deferred;
168
+ var VoidDeferred = /** @class */ (function (_super) {
169
+ __extends(VoidDeferred, _super);
170
+ function VoidDeferred() {
171
+ return _super !== null && _super.apply(this, arguments) || this;
172
+ }
173
+ return VoidDeferred;
174
+ }(Deferred));
175
+ exports.VoidDeferred = VoidDeferred;
176
+ //# sourceMappingURL=Deferred.js.map
177
+
178
+ /***/ }),
179
+
180
+ /***/ 65010:
181
+ /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
182
+
183
+ var fs = __webpack_require__(57147);
184
+ var util = __webpack_require__(73837);
185
+ var stream = __webpack_require__(12781);
186
+ var Readable = stream.Readable;
187
+ var Writable = stream.Writable;
188
+ var PassThrough = stream.PassThrough;
189
+ var Pend = __webpack_require__(54833);
190
+ var EventEmitter = (__webpack_require__(82361).EventEmitter);
191
+
192
+ exports.createFromBuffer = createFromBuffer;
193
+ exports.createFromFd = createFromFd;
194
+ exports.BufferSlicer = BufferSlicer;
195
+ exports.FdSlicer = FdSlicer;
196
+
197
+ util.inherits(FdSlicer, EventEmitter);
198
+ function FdSlicer(fd, options) {
199
+ options = options || {};
200
+ EventEmitter.call(this);
201
+
202
+ this.fd = fd;
203
+ this.pend = new Pend();
204
+ this.pend.max = 1;
205
+ this.refCount = 0;
206
+ this.autoClose = !!options.autoClose;
207
+ }
208
+
209
+ FdSlicer.prototype.read = function(buffer, offset, length, position, callback) {
210
+ var self = this;
211
+ self.pend.go(function(cb) {
212
+ fs.read(self.fd, buffer, offset, length, position, function(err, bytesRead, buffer) {
213
+ cb();
214
+ callback(err, bytesRead, buffer);
215
+ });
216
+ });
217
+ };
218
+
219
+ FdSlicer.prototype.write = function(buffer, offset, length, position, callback) {
220
+ var self = this;
221
+ self.pend.go(function(cb) {
222
+ fs.write(self.fd, buffer, offset, length, position, function(err, written, buffer) {
223
+ cb();
224
+ callback(err, written, buffer);
225
+ });
226
+ });
227
+ };
228
+
229
+ FdSlicer.prototype.createReadStream = function(options) {
230
+ return new ReadStream(this, options);
231
+ };
232
+
233
+ FdSlicer.prototype.createWriteStream = function(options) {
234
+ return new WriteStream(this, options);
235
+ };
236
+
237
+ FdSlicer.prototype.ref = function() {
238
+ this.refCount += 1;
239
+ };
240
+
241
+ FdSlicer.prototype.unref = function() {
242
+ var self = this;
243
+ self.refCount -= 1;
244
+
245
+ if (self.refCount > 0) return;
246
+ if (self.refCount < 0) throw new Error("invalid unref");
247
+
248
+ if (self.autoClose) {
249
+ fs.close(self.fd, onCloseDone);
250
+ }
251
+
252
+ function onCloseDone(err) {
253
+ if (err) {
254
+ self.emit('error', err);
255
+ } else {
256
+ self.emit('close');
257
+ }
258
+ }
259
+ };
260
+
261
+ util.inherits(ReadStream, Readable);
262
+ function ReadStream(context, options) {
263
+ options = options || {};
264
+ Readable.call(this, options);
265
+
266
+ this.context = context;
267
+ this.context.ref();
268
+
269
+ this.start = options.start || 0;
270
+ this.endOffset = options.end;
271
+ this.pos = this.start;
272
+ this.destroyed = false;
273
+ }
274
+
275
+ ReadStream.prototype._read = function(n) {
276
+ var self = this;
277
+ if (self.destroyed) return;
278
+
279
+ var toRead = Math.min(self._readableState.highWaterMark, n);
280
+ if (self.endOffset != null) {
281
+ toRead = Math.min(toRead, self.endOffset - self.pos);
282
+ }
283
+ if (toRead <= 0) {
284
+ self.destroyed = true;
285
+ self.push(null);
286
+ self.context.unref();
287
+ return;
288
+ }
289
+ self.context.pend.go(function(cb) {
290
+ if (self.destroyed) return cb();
291
+ var buffer = Buffer.allocUnsafe ? Buffer.allocUnsafe(toRead) : new Buffer(toRead);
292
+ fs.read(self.context.fd, buffer, 0, toRead, self.pos, function(err, bytesRead) {
293
+ if (err) {
294
+ self.destroy(err);
295
+ } else if (bytesRead === 0) {
296
+ self.destroyed = true;
297
+ self.push(null);
298
+ self.context.unref();
299
+ } else {
300
+ self.pos += bytesRead;
301
+ self.push(buffer.slice(0, bytesRead));
302
+ }
303
+ cb();
304
+ });
305
+ });
306
+ };
307
+
308
+ ReadStream.prototype.destroy = function(err) {
309
+ if (this.destroyed) return;
310
+ err = err || new Error("stream destroyed");
311
+ this.destroyed = true;
312
+ this.emit('error', err);
313
+ this.context.unref();
314
+ };
315
+
316
+ util.inherits(WriteStream, Writable);
317
+ function WriteStream(context, options) {
318
+ options = options || {};
319
+ Writable.call(this, options);
320
+
321
+ this.context = context;
322
+ this.context.ref();
323
+
324
+ this.start = options.start || 0;
325
+ this.endOffset = (options.end == null) ? Infinity : +options.end;
326
+ this.bytesWritten = 0;
327
+ this.pos = this.start;
328
+ this.destroyed = false;
329
+
330
+ this.on('finish', this.destroy.bind(this));
331
+ }
332
+
333
+ WriteStream.prototype._write = function(buffer, encoding, callback) {
334
+ var self = this;
335
+ if (self.destroyed) return;
336
+
337
+ if (self.pos + buffer.length > self.endOffset) {
338
+ var err = new Error("maximum file length exceeded");
339
+ err.code = 'ETOOBIG';
340
+ self.destroy();
341
+ callback(err);
342
+ return;
343
+ }
344
+ self.context.pend.go(function(cb) {
345
+ if (self.destroyed) return cb();
346
+ fs.write(self.context.fd, buffer, 0, buffer.length, self.pos, function(err, bytes) {
347
+ if (err) {
348
+ self.destroy();
349
+ cb();
350
+ callback(err);
351
+ } else {
352
+ self.bytesWritten += bytes;
353
+ self.pos += bytes;
354
+ self.emit('progress');
355
+ cb();
356
+ callback();
357
+ }
358
+ });
359
+ });
360
+ };
361
+
362
+ WriteStream.prototype.destroy = function() {
363
+ if (this.destroyed) return;
364
+ this.destroyed = true;
365
+ this.context.unref();
366
+ };
367
+
368
+ util.inherits(BufferSlicer, EventEmitter);
369
+ function BufferSlicer(buffer, options) {
370
+ EventEmitter.call(this);
371
+
372
+ options = options || {};
373
+ this.refCount = 0;
374
+ this.buffer = buffer;
375
+ this.maxChunkSize = options.maxChunkSize || Number.MAX_SAFE_INTEGER;
376
+ }
377
+
378
+ BufferSlicer.prototype.read = function(buffer, offset, length, position, callback) {
379
+ var end = position + length;
380
+ var delta = end - this.buffer.length;
381
+ var written = (delta > 0) ? delta : length;
382
+ this.buffer.copy(buffer, offset, position, end);
383
+ setImmediate(function() {
384
+ callback(null, written);
385
+ });
386
+ };
387
+
388
+ BufferSlicer.prototype.write = function(buffer, offset, length, position, callback) {
389
+ buffer.copy(this.buffer, position, offset, offset + length);
390
+ setImmediate(function() {
391
+ callback(null, length, buffer);
392
+ });
393
+ };
394
+
395
+ BufferSlicer.prototype.createReadStream = function(options) {
396
+ options = options || {};
397
+ var readStream = new PassThrough(options);
398
+ readStream.destroyed = false;
399
+ readStream.start = options.start || 0;
400
+ readStream.endOffset = options.end;
401
+ // by the time this function returns, we'll be done.
402
+ readStream.pos = readStream.endOffset || this.buffer.length;
403
+
404
+ // respect the maxChunkSize option to slice up the chunk into smaller pieces.
405
+ var entireSlice = this.buffer.slice(readStream.start, readStream.pos);
406
+ var offset = 0;
407
+ while (true) {
408
+ var nextOffset = offset + this.maxChunkSize;
409
+ if (nextOffset >= entireSlice.length) {
410
+ // last chunk
411
+ if (offset < entireSlice.length) {
412
+ readStream.write(entireSlice.slice(offset, entireSlice.length));
413
+ }
414
+ break;
415
+ }
416
+ readStream.write(entireSlice.slice(offset, nextOffset));
417
+ offset = nextOffset;
418
+ }
419
+
420
+ readStream.end();
421
+ readStream.destroy = function() {
422
+ readStream.destroyed = true;
423
+ };
424
+ return readStream;
425
+ };
426
+
427
+ BufferSlicer.prototype.createWriteStream = function(options) {
428
+ var bufferSlicer = this;
429
+ options = options || {};
430
+ var writeStream = new Writable(options);
431
+ writeStream.start = options.start || 0;
432
+ writeStream.endOffset = (options.end == null) ? this.buffer.length : +options.end;
433
+ writeStream.bytesWritten = 0;
434
+ writeStream.pos = writeStream.start;
435
+ writeStream.destroyed = false;
436
+ writeStream._write = function(buffer, encoding, callback) {
437
+ if (writeStream.destroyed) return;
438
+
439
+ var end = writeStream.pos + buffer.length;
440
+ if (end > writeStream.endOffset) {
441
+ var err = new Error("maximum file length exceeded");
442
+ err.code = 'ETOOBIG';
443
+ writeStream.destroyed = true;
444
+ callback(err);
445
+ return;
446
+ }
447
+ buffer.copy(bufferSlicer.buffer, writeStream.pos, 0, buffer.length);
448
+
449
+ writeStream.bytesWritten += buffer.length;
450
+ writeStream.pos = end;
451
+ writeStream.emit('progress');
452
+ callback();
453
+ };
454
+ writeStream.destroy = function() {
455
+ writeStream.destroyed = true;
456
+ };
457
+ return writeStream;
458
+ };
459
+
460
+ BufferSlicer.prototype.ref = function() {
461
+ this.refCount += 1;
462
+ };
463
+
464
+ BufferSlicer.prototype.unref = function() {
465
+ this.refCount -= 1;
466
+
467
+ if (this.refCount < 0) {
468
+ throw new Error("invalid unref");
469
+ }
470
+ };
471
+
472
+ function createFromBuffer(buffer, options) {
473
+ return new BufferSlicer(buffer, options);
474
+ }
475
+
476
+ function createFromFd(fd, options) {
477
+ return new FdSlicer(fd, options);
478
+ }
479
+
480
+
481
+ /***/ }),
482
+
483
+ /***/ 54833:
484
+ /***/ ((module) => {
485
+
486
+ module.exports = Pend;
487
+
488
+ function Pend() {
489
+ this.pending = 0;
490
+ this.max = Infinity;
491
+ this.listeners = [];
492
+ this.waiting = [];
493
+ this.error = null;
494
+ }
495
+
496
+ Pend.prototype.go = function(fn) {
497
+ if (this.pending < this.max) {
498
+ pendGo(this, fn);
499
+ } else {
500
+ this.waiting.push(fn);
501
+ }
502
+ };
503
+
504
+ Pend.prototype.wait = function(cb) {
505
+ if (this.pending === 0) {
506
+ cb(this.error);
507
+ } else {
508
+ this.listeners.push(cb);
509
+ }
510
+ };
511
+
512
+ Pend.prototype.hold = function() {
513
+ return pendHold(this);
514
+ };
515
+
516
+ function pendHold(self) {
517
+ self.pending += 1;
518
+ var called = false;
519
+ return onCb;
520
+ function onCb(err) {
521
+ if (called) throw new Error("callback called twice");
522
+ called = true;
523
+ self.error = self.error || err;
524
+ self.pending -= 1;
525
+ if (self.waiting.length > 0 && self.pending < self.max) {
526
+ pendGo(self, self.waiting.shift());
527
+ } else if (self.pending === 0) {
528
+ var listeners = self.listeners;
529
+ self.listeners = [];
530
+ listeners.forEach(cbListener);
531
+ }
532
+ }
533
+ function cbListener(listener) {
534
+ listener(self.error);
535
+ }
536
+ }
537
+
538
+ function pendGo(self, fn) {
539
+ fn(pendHold(self));
540
+ }
541
+
542
+
543
+ /***/ }),
544
+
545
+ /***/ 78781:
546
+ /***/ ((__unused_webpack_module, exports, __webpack_require__) => {
547
+
548
+ var fs = __webpack_require__(57147);
549
+ var zlib = __webpack_require__(59796);
550
+ var fd_slicer = __webpack_require__(65010);
551
+ var crc32 = __webpack_require__(84794);
552
+ var util = __webpack_require__(73837);
553
+ var EventEmitter = (__webpack_require__(82361).EventEmitter);
554
+ var Transform = (__webpack_require__(12781).Transform);
555
+ var PassThrough = (__webpack_require__(12781).PassThrough);
556
+ var Writable = (__webpack_require__(12781).Writable);
557
+
558
+ exports.open = open;
559
+ exports.fromFd = fromFd;
560
+ exports.fromBuffer = fromBuffer;
561
+ exports.fromRandomAccessReader = fromRandomAccessReader;
562
+ exports.dosDateTimeToDate = dosDateTimeToDate;
563
+ exports.validateFileName = validateFileName;
564
+ exports.ZipFile = ZipFile;
565
+ exports.Entry = Entry;
566
+ exports.RandomAccessReader = RandomAccessReader;
567
+
568
+ function open(path, options, callback) {
569
+ if (typeof options === "function") {
570
+ callback = options;
571
+ options = null;
572
+ }
573
+ if (options == null) options = {};
574
+ if (options.autoClose == null) options.autoClose = true;
575
+ if (options.lazyEntries == null) options.lazyEntries = false;
576
+ if (options.decodeStrings == null) options.decodeStrings = true;
577
+ if (options.validateEntrySizes == null) options.validateEntrySizes = true;
578
+ if (options.strictFileNames == null) options.strictFileNames = false;
579
+ if (callback == null) callback = defaultCallback;
580
+ fs.open(path, "r", function(err, fd) {
581
+ if (err) return callback(err);
582
+ fromFd(fd, options, function(err, zipfile) {
583
+ if (err) fs.close(fd, defaultCallback);
584
+ callback(err, zipfile);
585
+ });
586
+ });
587
+ }
588
+
589
+ function fromFd(fd, options, callback) {
590
+ if (typeof options === "function") {
591
+ callback = options;
592
+ options = null;
593
+ }
594
+ if (options == null) options = {};
595
+ if (options.autoClose == null) options.autoClose = false;
596
+ if (options.lazyEntries == null) options.lazyEntries = false;
597
+ if (options.decodeStrings == null) options.decodeStrings = true;
598
+ if (options.validateEntrySizes == null) options.validateEntrySizes = true;
599
+ if (options.strictFileNames == null) options.strictFileNames = false;
600
+ if (callback == null) callback = defaultCallback;
601
+ fs.fstat(fd, function(err, stats) {
602
+ if (err) return callback(err);
603
+ var reader = fd_slicer.createFromFd(fd, {autoClose: true});
604
+ fromRandomAccessReader(reader, stats.size, options, callback);
605
+ });
606
+ }
607
+
608
+ function fromBuffer(buffer, options, callback) {
609
+ if (typeof options === "function") {
610
+ callback = options;
611
+ options = null;
612
+ }
613
+ if (options == null) options = {};
614
+ options.autoClose = false;
615
+ if (options.lazyEntries == null) options.lazyEntries = false;
616
+ if (options.decodeStrings == null) options.decodeStrings = true;
617
+ if (options.validateEntrySizes == null) options.validateEntrySizes = true;
618
+ if (options.strictFileNames == null) options.strictFileNames = false;
619
+ // limit the max chunk size. see https://github.com/thejoshwolfe/yauzl/issues/87
620
+ var reader = fd_slicer.createFromBuffer(buffer, {maxChunkSize: 0x10000});
621
+ fromRandomAccessReader(reader, buffer.length, options, callback);
622
+ }
623
+
624
+ function fromRandomAccessReader(reader, totalSize, options, callback) {
625
+ if (typeof options === "function") {
626
+ callback = options;
627
+ options = null;
628
+ }
629
+ if (options == null) options = {};
630
+ if (options.autoClose == null) options.autoClose = true;
631
+ if (options.lazyEntries == null) options.lazyEntries = false;
632
+ if (options.decodeStrings == null) options.decodeStrings = true;
633
+ var decodeStrings = !!options.decodeStrings;
634
+ if (options.validateEntrySizes == null) options.validateEntrySizes = true;
635
+ if (options.strictFileNames == null) options.strictFileNames = false;
636
+ if (callback == null) callback = defaultCallback;
637
+ if (typeof totalSize !== "number") throw new Error("expected totalSize parameter to be a number");
638
+ if (totalSize > Number.MAX_SAFE_INTEGER) {
639
+ throw new Error("zip file too large. only file sizes up to 2^52 are supported due to JavaScript's Number type being an IEEE 754 double.");
640
+ }
641
+
642
+ // the matching unref() call is in zipfile.close()
643
+ reader.ref();
644
+
645
+ // eocdr means End of Central Directory Record.
646
+ // search backwards for the eocdr signature.
647
+ // the last field of the eocdr is a variable-length comment.
648
+ // the comment size is encoded in a 2-byte field in the eocdr, which we can't find without trudging backwards through the comment to find it.
649
+ // as a consequence of this design decision, it's possible to have ambiguous zip file metadata if a coherent eocdr was in the comment.
650
+ // we search backwards for a eocdr signature, and hope that whoever made the zip file was smart enough to forbid the eocdr signature in the comment.
651
+ var eocdrWithoutCommentSize = 22;
652
+ var maxCommentSize = 0xffff; // 2-byte size
653
+ var bufferSize = Math.min(eocdrWithoutCommentSize + maxCommentSize, totalSize);
654
+ var buffer = newBuffer(bufferSize);
655
+ var bufferReadStart = totalSize - buffer.length;
656
+ readAndAssertNoEof(reader, buffer, 0, bufferSize, bufferReadStart, function(err) {
657
+ if (err) return callback(err);
658
+ for (var i = bufferSize - eocdrWithoutCommentSize; i >= 0; i -= 1) {
659
+ if (buffer.readUInt32LE(i) !== 0x06054b50) continue;
660
+ // found eocdr
661
+ var eocdrBuffer = buffer.slice(i);
662
+
663
+ // 0 - End of central directory signature = 0x06054b50
664
+ // 4 - Number of this disk
665
+ var diskNumber = eocdrBuffer.readUInt16LE(4);
666
+ if (diskNumber !== 0) {
667
+ return callback(new Error("multi-disk zip files are not supported: found disk number: " + diskNumber));
668
+ }
669
+ // 6 - Disk where central directory starts
670
+ // 8 - Number of central directory records on this disk
671
+ // 10 - Total number of central directory records
672
+ var entryCount = eocdrBuffer.readUInt16LE(10);
673
+ // 12 - Size of central directory (bytes)
674
+ // 16 - Offset of start of central directory, relative to start of archive
675
+ var centralDirectoryOffset = eocdrBuffer.readUInt32LE(16);
676
+ // 20 - Comment length
677
+ var commentLength = eocdrBuffer.readUInt16LE(20);
678
+ var expectedCommentLength = eocdrBuffer.length - eocdrWithoutCommentSize;
679
+ if (commentLength !== expectedCommentLength) {
680
+ return callback(new Error("invalid comment length. expected: " + expectedCommentLength + ". found: " + commentLength));
681
+ }
682
+ // 22 - Comment
683
+ // the encoding is always cp437.
684
+ var comment = decodeStrings ? decodeBuffer(eocdrBuffer, 22, eocdrBuffer.length, false)
685
+ : eocdrBuffer.slice(22);
686
+
687
+ if (!(entryCount === 0xffff || centralDirectoryOffset === 0xffffffff)) {
688
+ return callback(null, new ZipFile(reader, centralDirectoryOffset, totalSize, entryCount, comment, options.autoClose, options.lazyEntries, decodeStrings, options.validateEntrySizes, options.strictFileNames));
689
+ }
690
+
691
+ // ZIP64 format
692
+
693
+ // ZIP64 Zip64 end of central directory locator
694
+ var zip64EocdlBuffer = newBuffer(20);
695
+ var zip64EocdlOffset = bufferReadStart + i - zip64EocdlBuffer.length;
696
+ readAndAssertNoEof(reader, zip64EocdlBuffer, 0, zip64EocdlBuffer.length, zip64EocdlOffset, function(err) {
697
+ if (err) return callback(err);
698
+
699
+ // 0 - zip64 end of central dir locator signature = 0x07064b50
700
+ if (zip64EocdlBuffer.readUInt32LE(0) !== 0x07064b50) {
701
+ return callback(new Error("invalid zip64 end of central directory locator signature"));
702
+ }
703
+ // 4 - number of the disk with the start of the zip64 end of central directory
704
+ // 8 - relative offset of the zip64 end of central directory record
705
+ var zip64EocdrOffset = readUInt64LE(zip64EocdlBuffer, 8);
706
+ // 16 - total number of disks
707
+
708
+ // ZIP64 end of central directory record
709
+ var zip64EocdrBuffer = newBuffer(56);
710
+ readAndAssertNoEof(reader, zip64EocdrBuffer, 0, zip64EocdrBuffer.length, zip64EocdrOffset, function(err) {
711
+ if (err) return callback(err);
712
+
713
+ // 0 - zip64 end of central dir signature 4 bytes (0x06064b50)
714
+ if (zip64EocdrBuffer.readUInt32LE(0) !== 0x06064b50) {
715
+ return callback(new Error("invalid zip64 end of central directory record signature"));
716
+ }
717
+ // 4 - size of zip64 end of central directory record 8 bytes
718
+ // 12 - version made by 2 bytes
719
+ // 14 - version needed to extract 2 bytes
720
+ // 16 - number of this disk 4 bytes
721
+ // 20 - number of the disk with the start of the central directory 4 bytes
722
+ // 24 - total number of entries in the central directory on this disk 8 bytes
723
+ // 32 - total number of entries in the central directory 8 bytes
724
+ entryCount = readUInt64LE(zip64EocdrBuffer, 32);
725
+ // 40 - size of the central directory 8 bytes
726
+ // 48 - offset of start of central directory with respect to the starting disk number 8 bytes
727
+ centralDirectoryOffset = readUInt64LE(zip64EocdrBuffer, 48);
728
+ // 56 - zip64 extensible data sector (variable size)
729
+ return callback(null, new ZipFile(reader, centralDirectoryOffset, totalSize, entryCount, comment, options.autoClose, options.lazyEntries, decodeStrings, options.validateEntrySizes, options.strictFileNames));
730
+ });
731
+ });
732
+ return;
733
+ }
734
+ callback(new Error("end of central directory record signature not found"));
735
+ });
736
+ }
737
+
738
+ util.inherits(ZipFile, EventEmitter);
739
+ function ZipFile(reader, centralDirectoryOffset, fileSize, entryCount, comment, autoClose, lazyEntries, decodeStrings, validateEntrySizes, strictFileNames) {
740
+ var self = this;
741
+ EventEmitter.call(self);
742
+ self.reader = reader;
743
+ // forward close events
744
+ self.reader.on("error", function(err) {
745
+ // error closing the fd
746
+ emitError(self, err);
747
+ });
748
+ self.reader.once("close", function() {
749
+ self.emit("close");
750
+ });
751
+ self.readEntryCursor = centralDirectoryOffset;
752
+ self.fileSize = fileSize;
753
+ self.entryCount = entryCount;
754
+ self.comment = comment;
755
+ self.entriesRead = 0;
756
+ self.autoClose = !!autoClose;
757
+ self.lazyEntries = !!lazyEntries;
758
+ self.decodeStrings = !!decodeStrings;
759
+ self.validateEntrySizes = !!validateEntrySizes;
760
+ self.strictFileNames = !!strictFileNames;
761
+ self.isOpen = true;
762
+ self.emittedError = false;
763
+
764
+ if (!self.lazyEntries) self._readEntry();
765
+ }
766
+ ZipFile.prototype.close = function() {
767
+ if (!this.isOpen) return;
768
+ this.isOpen = false;
769
+ this.reader.unref();
770
+ };
771
+
772
+ function emitErrorAndAutoClose(self, err) {
773
+ if (self.autoClose) self.close();
774
+ emitError(self, err);
775
+ }
776
+ function emitError(self, err) {
777
+ if (self.emittedError) return;
778
+ self.emittedError = true;
779
+ self.emit("error", err);
780
+ }
781
+
782
+ ZipFile.prototype.readEntry = function() {
783
+ if (!this.lazyEntries) throw new Error("readEntry() called without lazyEntries:true");
784
+ this._readEntry();
785
+ };
786
+ ZipFile.prototype._readEntry = function() {
787
+ var self = this;
788
+ if (self.entryCount === self.entriesRead) {
789
+ // done with metadata
790
+ setImmediate(function() {
791
+ if (self.autoClose) self.close();
792
+ if (self.emittedError) return;
793
+ self.emit("end");
794
+ });
795
+ return;
796
+ }
797
+ if (self.emittedError) return;
798
+ var buffer = newBuffer(46);
799
+ readAndAssertNoEof(self.reader, buffer, 0, buffer.length, self.readEntryCursor, function(err) {
800
+ if (err) return emitErrorAndAutoClose(self, err);
801
+ if (self.emittedError) return;
802
+ var entry = new Entry();
803
+ // 0 - Central directory file header signature
804
+ var signature = buffer.readUInt32LE(0);
805
+ if (signature !== 0x02014b50) return emitErrorAndAutoClose(self, new Error("invalid central directory file header signature: 0x" + signature.toString(16)));
806
+ // 4 - Version made by
807
+ entry.versionMadeBy = buffer.readUInt16LE(4);
808
+ // 6 - Version needed to extract (minimum)
809
+ entry.versionNeededToExtract = buffer.readUInt16LE(6);
810
+ // 8 - General purpose bit flag
811
+ entry.generalPurposeBitFlag = buffer.readUInt16LE(8);
812
+ // 10 - Compression method
813
+ entry.compressionMethod = buffer.readUInt16LE(10);
814
+ // 12 - File last modification time
815
+ entry.lastModFileTime = buffer.readUInt16LE(12);
816
+ // 14 - File last modification date
817
+ entry.lastModFileDate = buffer.readUInt16LE(14);
818
+ // 16 - CRC-32
819
+ entry.crc32 = buffer.readUInt32LE(16);
820
+ // 20 - Compressed size
821
+ entry.compressedSize = buffer.readUInt32LE(20);
822
+ // 24 - Uncompressed size
823
+ entry.uncompressedSize = buffer.readUInt32LE(24);
824
+ // 28 - File name length (n)
825
+ entry.fileNameLength = buffer.readUInt16LE(28);
826
+ // 30 - Extra field length (m)
827
+ entry.extraFieldLength = buffer.readUInt16LE(30);
828
+ // 32 - File comment length (k)
829
+ entry.fileCommentLength = buffer.readUInt16LE(32);
830
+ // 34 - Disk number where file starts
831
+ // 36 - Internal file attributes
832
+ entry.internalFileAttributes = buffer.readUInt16LE(36);
833
+ // 38 - External file attributes
834
+ entry.externalFileAttributes = buffer.readUInt32LE(38);
835
+ // 42 - Relative offset of local file header
836
+ entry.relativeOffsetOfLocalHeader = buffer.readUInt32LE(42);
837
+
838
+ if (entry.generalPurposeBitFlag & 0x40) return emitErrorAndAutoClose(self, new Error("strong encryption is not supported"));
839
+
840
+ self.readEntryCursor += 46;
841
+
842
+ buffer = newBuffer(entry.fileNameLength + entry.extraFieldLength + entry.fileCommentLength);
843
+ readAndAssertNoEof(self.reader, buffer, 0, buffer.length, self.readEntryCursor, function(err) {
844
+ if (err) return emitErrorAndAutoClose(self, err);
845
+ if (self.emittedError) return;
846
+ // 46 - File name
847
+ var isUtf8 = (entry.generalPurposeBitFlag & 0x800) !== 0;
848
+ entry.fileName = self.decodeStrings ? decodeBuffer(buffer, 0, entry.fileNameLength, isUtf8)
849
+ : buffer.slice(0, entry.fileNameLength);
850
+
851
+ // 46+n - Extra field
852
+ var fileCommentStart = entry.fileNameLength + entry.extraFieldLength;
853
+ var extraFieldBuffer = buffer.slice(entry.fileNameLength, fileCommentStart);
854
+ entry.extraFields = [];
855
+ var i = 0;
856
+ while (i < extraFieldBuffer.length - 3) {
857
+ var headerId = extraFieldBuffer.readUInt16LE(i + 0);
858
+ var dataSize = extraFieldBuffer.readUInt16LE(i + 2);
859
+ var dataStart = i + 4;
860
+ var dataEnd = dataStart + dataSize;
861
+ if (dataEnd > extraFieldBuffer.length) return emitErrorAndAutoClose(self, new Error("extra field length exceeds extra field buffer size"));
862
+ var dataBuffer = newBuffer(dataSize);
863
+ extraFieldBuffer.copy(dataBuffer, 0, dataStart, dataEnd);
864
+ entry.extraFields.push({
865
+ id: headerId,
866
+ data: dataBuffer,
867
+ });
868
+ i = dataEnd;
869
+ }
870
+
871
+ // 46+n+m - File comment
872
+ entry.fileComment = self.decodeStrings ? decodeBuffer(buffer, fileCommentStart, fileCommentStart + entry.fileCommentLength, isUtf8)
873
+ : buffer.slice(fileCommentStart, fileCommentStart + entry.fileCommentLength);
874
+ // compatibility hack for https://github.com/thejoshwolfe/yauzl/issues/47
875
+ entry.comment = entry.fileComment;
876
+
877
+ self.readEntryCursor += buffer.length;
878
+ self.entriesRead += 1;
879
+
880
+ if (entry.uncompressedSize === 0xffffffff ||
881
+ entry.compressedSize === 0xffffffff ||
882
+ entry.relativeOffsetOfLocalHeader === 0xffffffff) {
883
+ // ZIP64 format
884
+ // find the Zip64 Extended Information Extra Field
885
+ var zip64EiefBuffer = null;
886
+ for (var i = 0; i < entry.extraFields.length; i++) {
887
+ var extraField = entry.extraFields[i];
888
+ if (extraField.id === 0x0001) {
889
+ zip64EiefBuffer = extraField.data;
890
+ break;
891
+ }
892
+ }
893
+ if (zip64EiefBuffer == null) {
894
+ return emitErrorAndAutoClose(self, new Error("expected zip64 extended information extra field"));
895
+ }
896
+ var index = 0;
897
+ // 0 - Original Size 8 bytes
898
+ if (entry.uncompressedSize === 0xffffffff) {
899
+ if (index + 8 > zip64EiefBuffer.length) {
900
+ return emitErrorAndAutoClose(self, new Error("zip64 extended information extra field does not include uncompressed size"));
901
+ }
902
+ entry.uncompressedSize = readUInt64LE(zip64EiefBuffer, index);
903
+ index += 8;
904
+ }
905
+ // 8 - Compressed Size 8 bytes
906
+ if (entry.compressedSize === 0xffffffff) {
907
+ if (index + 8 > zip64EiefBuffer.length) {
908
+ return emitErrorAndAutoClose(self, new Error("zip64 extended information extra field does not include compressed size"));
909
+ }
910
+ entry.compressedSize = readUInt64LE(zip64EiefBuffer, index);
911
+ index += 8;
912
+ }
913
+ // 16 - Relative Header Offset 8 bytes
914
+ if (entry.relativeOffsetOfLocalHeader === 0xffffffff) {
915
+ if (index + 8 > zip64EiefBuffer.length) {
916
+ return emitErrorAndAutoClose(self, new Error("zip64 extended information extra field does not include relative header offset"));
917
+ }
918
+ entry.relativeOffsetOfLocalHeader = readUInt64LE(zip64EiefBuffer, index);
919
+ index += 8;
920
+ }
921
+ // 24 - Disk Start Number 4 bytes
922
+ }
923
+
924
+ // check for Info-ZIP Unicode Path Extra Field (0x7075)
925
+ // see https://github.com/thejoshwolfe/yauzl/issues/33
926
+ if (self.decodeStrings) {
927
+ for (var i = 0; i < entry.extraFields.length; i++) {
928
+ var extraField = entry.extraFields[i];
929
+ if (extraField.id === 0x7075) {
930
+ if (extraField.data.length < 6) {
931
+ // too short to be meaningful
932
+ continue;
933
+ }
934
+ // Version 1 byte version of this extra field, currently 1
935
+ if (extraField.data.readUInt8(0) !== 1) {
936
+ // > Changes may not be backward compatible so this extra
937
+ // > field should not be used if the version is not recognized.
938
+ continue;
939
+ }
940
+ // NameCRC32 4 bytes File Name Field CRC32 Checksum
941
+ var oldNameCrc32 = extraField.data.readUInt32LE(1);
942
+ if (crc32.unsigned(buffer.slice(0, entry.fileNameLength)) !== oldNameCrc32) {
943
+ // > If the CRC check fails, this UTF-8 Path Extra Field should be
944
+ // > ignored and the File Name field in the header should be used instead.
945
+ continue;
946
+ }
947
+ // UnicodeName Variable UTF-8 version of the entry File Name
948
+ entry.fileName = decodeBuffer(extraField.data, 5, extraField.data.length, true);
949
+ break;
950
+ }
951
+ }
952
+ }
953
+
954
+ // validate file size
955
+ if (self.validateEntrySizes && entry.compressionMethod === 0) {
956
+ var expectedCompressedSize = entry.uncompressedSize;
957
+ if (entry.isEncrypted()) {
958
+ // traditional encryption prefixes the file data with a header
959
+ expectedCompressedSize += 12;
960
+ }
961
+ if (entry.compressedSize !== expectedCompressedSize) {
962
+ var msg = "compressed/uncompressed size mismatch for stored file: " + entry.compressedSize + " != " + entry.uncompressedSize;
963
+ return emitErrorAndAutoClose(self, new Error(msg));
964
+ }
965
+ }
966
+
967
+ if (self.decodeStrings) {
968
+ if (!self.strictFileNames) {
969
+ // allow backslash
970
+ entry.fileName = entry.fileName.replace(/\\/g, "/");
971
+ }
972
+ var errorMessage = validateFileName(entry.fileName, self.validateFileNameOptions);
973
+ if (errorMessage != null) return emitErrorAndAutoClose(self, new Error(errorMessage));
974
+ }
975
+ self.emit("entry", entry);
976
+
977
+ if (!self.lazyEntries) self._readEntry();
978
+ });
979
+ });
980
+ };
981
+
982
+ ZipFile.prototype.openReadStream = function(entry, options, callback) {
983
+ var self = this;
984
+ // parameter validation
985
+ var relativeStart = 0;
986
+ var relativeEnd = entry.compressedSize;
987
+ if (callback == null) {
988
+ callback = options;
989
+ options = {};
990
+ } else {
991
+ // validate options that the caller has no excuse to get wrong
992
+ if (options.decrypt != null) {
993
+ if (!entry.isEncrypted()) {
994
+ throw new Error("options.decrypt can only be specified for encrypted entries");
995
+ }
996
+ if (options.decrypt !== false) throw new Error("invalid options.decrypt value: " + options.decrypt);
997
+ if (entry.isCompressed()) {
998
+ if (options.decompress !== false) throw new Error("entry is encrypted and compressed, and options.decompress !== false");
999
+ }
1000
+ }
1001
+ if (options.decompress != null) {
1002
+ if (!entry.isCompressed()) {
1003
+ throw new Error("options.decompress can only be specified for compressed entries");
1004
+ }
1005
+ if (!(options.decompress === false || options.decompress === true)) {
1006
+ throw new Error("invalid options.decompress value: " + options.decompress);
1007
+ }
1008
+ }
1009
+ if (options.start != null || options.end != null) {
1010
+ if (entry.isCompressed() && options.decompress !== false) {
1011
+ throw new Error("start/end range not allowed for compressed entry without options.decompress === false");
1012
+ }
1013
+ if (entry.isEncrypted() && options.decrypt !== false) {
1014
+ throw new Error("start/end range not allowed for encrypted entry without options.decrypt === false");
1015
+ }
1016
+ }
1017
+ if (options.start != null) {
1018
+ relativeStart = options.start;
1019
+ if (relativeStart < 0) throw new Error("options.start < 0");
1020
+ if (relativeStart > entry.compressedSize) throw new Error("options.start > entry.compressedSize");
1021
+ }
1022
+ if (options.end != null) {
1023
+ relativeEnd = options.end;
1024
+ if (relativeEnd < 0) throw new Error("options.end < 0");
1025
+ if (relativeEnd > entry.compressedSize) throw new Error("options.end > entry.compressedSize");
1026
+ if (relativeEnd < relativeStart) throw new Error("options.end < options.start");
1027
+ }
1028
+ }
1029
+ // any further errors can either be caused by the zipfile,
1030
+ // or were introduced in a minor version of yauzl,
1031
+ // so should be passed to the client rather than thrown.
1032
+ if (!self.isOpen) return callback(new Error("closed"));
1033
+ if (entry.isEncrypted()) {
1034
+ if (options.decrypt !== false) return callback(new Error("entry is encrypted, and options.decrypt !== false"));
1035
+ }
1036
+ // make sure we don't lose the fd before we open the actual read stream
1037
+ self.reader.ref();
1038
+ var buffer = newBuffer(30);
1039
+ readAndAssertNoEof(self.reader, buffer, 0, buffer.length, entry.relativeOffsetOfLocalHeader, function(err) {
1040
+ try {
1041
+ if (err) return callback(err);
1042
+ // 0 - Local file header signature = 0x04034b50
1043
+ var signature = buffer.readUInt32LE(0);
1044
+ if (signature !== 0x04034b50) {
1045
+ return callback(new Error("invalid local file header signature: 0x" + signature.toString(16)));
1046
+ }
1047
+ // all this should be redundant
1048
+ // 4 - Version needed to extract (minimum)
1049
+ // 6 - General purpose bit flag
1050
+ // 8 - Compression method
1051
+ // 10 - File last modification time
1052
+ // 12 - File last modification date
1053
+ // 14 - CRC-32
1054
+ // 18 - Compressed size
1055
+ // 22 - Uncompressed size
1056
+ // 26 - File name length (n)
1057
+ var fileNameLength = buffer.readUInt16LE(26);
1058
+ // 28 - Extra field length (m)
1059
+ var extraFieldLength = buffer.readUInt16LE(28);
1060
+ // 30 - File name
1061
+ // 30+n - Extra field
1062
+ var localFileHeaderEnd = entry.relativeOffsetOfLocalHeader + buffer.length + fileNameLength + extraFieldLength;
1063
+ var decompress;
1064
+ if (entry.compressionMethod === 0) {
1065
+ // 0 - The file is stored (no compression)
1066
+ decompress = false;
1067
+ } else if (entry.compressionMethod === 8) {
1068
+ // 8 - The file is Deflated
1069
+ decompress = options.decompress != null ? options.decompress : true;
1070
+ } else {
1071
+ return callback(new Error("unsupported compression method: " + entry.compressionMethod));
1072
+ }
1073
+ var fileDataStart = localFileHeaderEnd;
1074
+ var fileDataEnd = fileDataStart + entry.compressedSize;
1075
+ if (entry.compressedSize !== 0) {
1076
+ // bounds check now, because the read streams will probably not complain loud enough.
1077
+ // since we're dealing with an unsigned offset plus an unsigned size,
1078
+ // we only have 1 thing to check for.
1079
+ if (fileDataEnd > self.fileSize) {
1080
+ return callback(new Error("file data overflows file bounds: " +
1081
+ fileDataStart + " + " + entry.compressedSize + " > " + self.fileSize));
1082
+ }
1083
+ }
1084
+ var readStream = self.reader.createReadStream({
1085
+ start: fileDataStart + relativeStart,
1086
+ end: fileDataStart + relativeEnd,
1087
+ });
1088
+ var endpointStream = readStream;
1089
+ if (decompress) {
1090
+ var destroyed = false;
1091
+ var inflateFilter = zlib.createInflateRaw();
1092
+ readStream.on("error", function(err) {
1093
+ // setImmediate here because errors can be emitted during the first call to pipe()
1094
+ setImmediate(function() {
1095
+ if (!destroyed) inflateFilter.emit("error", err);
1096
+ });
1097
+ });
1098
+ readStream.pipe(inflateFilter);
1099
+
1100
+ if (self.validateEntrySizes) {
1101
+ endpointStream = new AssertByteCountStream(entry.uncompressedSize);
1102
+ inflateFilter.on("error", function(err) {
1103
+ // forward zlib errors to the client-visible stream
1104
+ setImmediate(function() {
1105
+ if (!destroyed) endpointStream.emit("error", err);
1106
+ });
1107
+ });
1108
+ inflateFilter.pipe(endpointStream);
1109
+ } else {
1110
+ // the zlib filter is the client-visible stream
1111
+ endpointStream = inflateFilter;
1112
+ }
1113
+ // this is part of yauzl's API, so implement this function on the client-visible stream
1114
+ endpointStream.destroy = function() {
1115
+ destroyed = true;
1116
+ if (inflateFilter !== endpointStream) inflateFilter.unpipe(endpointStream);
1117
+ readStream.unpipe(inflateFilter);
1118
+ // TODO: the inflateFilter may cause a memory leak. see Issue #27.
1119
+ readStream.destroy();
1120
+ };
1121
+ }
1122
+ callback(null, endpointStream);
1123
+ } finally {
1124
+ self.reader.unref();
1125
+ }
1126
+ });
1127
+ };
1128
+
1129
+ function Entry() {
1130
+ }
1131
+ Entry.prototype.getLastModDate = function() {
1132
+ return dosDateTimeToDate(this.lastModFileDate, this.lastModFileTime);
1133
+ };
1134
+ Entry.prototype.isEncrypted = function() {
1135
+ return (this.generalPurposeBitFlag & 0x1) !== 0;
1136
+ };
1137
+ Entry.prototype.isCompressed = function() {
1138
+ return this.compressionMethod === 8;
1139
+ };
1140
+
1141
+ function dosDateTimeToDate(date, time) {
1142
+ var day = date & 0x1f; // 1-31
1143
+ var month = (date >> 5 & 0xf) - 1; // 1-12, 0-11
1144
+ var year = (date >> 9 & 0x7f) + 1980; // 0-128, 1980-2108
1145
+
1146
+ var millisecond = 0;
1147
+ var second = (time & 0x1f) * 2; // 0-29, 0-58 (even numbers)
1148
+ var minute = time >> 5 & 0x3f; // 0-59
1149
+ var hour = time >> 11 & 0x1f; // 0-23
1150
+
1151
+ return new Date(year, month, day, hour, minute, second, millisecond);
1152
+ }
1153
+
1154
+ function validateFileName(fileName) {
1155
+ if (fileName.indexOf("\\") !== -1) {
1156
+ return "invalid characters in fileName: " + fileName;
1157
+ }
1158
+ if (/^[a-zA-Z]:/.test(fileName) || /^\//.test(fileName)) {
1159
+ return "absolute path: " + fileName;
1160
+ }
1161
+ if (fileName.split("/").indexOf("..") !== -1) {
1162
+ return "invalid relative path: " + fileName;
1163
+ }
1164
+ // all good
1165
+ return null;
1166
+ }
1167
+
1168
+ function readAndAssertNoEof(reader, buffer, offset, length, position, callback) {
1169
+ if (length === 0) {
1170
+ // fs.read will throw an out-of-bounds error if you try to read 0 bytes from a 0 byte file
1171
+ return setImmediate(function() { callback(null, newBuffer(0)); });
1172
+ }
1173
+ reader.read(buffer, offset, length, position, function(err, bytesRead) {
1174
+ if (err) return callback(err);
1175
+ if (bytesRead < length) {
1176
+ return callback(new Error("unexpected EOF"));
1177
+ }
1178
+ callback();
1179
+ });
1180
+ }
1181
+
1182
+ util.inherits(AssertByteCountStream, Transform);
1183
+ function AssertByteCountStream(byteCount) {
1184
+ Transform.call(this);
1185
+ this.actualByteCount = 0;
1186
+ this.expectedByteCount = byteCount;
1187
+ }
1188
+ AssertByteCountStream.prototype._transform = function(chunk, encoding, cb) {
1189
+ this.actualByteCount += chunk.length;
1190
+ if (this.actualByteCount > this.expectedByteCount) {
1191
+ var msg = "too many bytes in the stream. expected " + this.expectedByteCount + ". got at least " + this.actualByteCount;
1192
+ return cb(new Error(msg));
1193
+ }
1194
+ cb(null, chunk);
1195
+ };
1196
+ AssertByteCountStream.prototype._flush = function(cb) {
1197
+ if (this.actualByteCount < this.expectedByteCount) {
1198
+ var msg = "not enough bytes in the stream. expected " + this.expectedByteCount + ". got only " + this.actualByteCount;
1199
+ return cb(new Error(msg));
1200
+ }
1201
+ cb();
1202
+ };
1203
+
1204
+ util.inherits(RandomAccessReader, EventEmitter);
1205
+ function RandomAccessReader() {
1206
+ EventEmitter.call(this);
1207
+ this.refCount = 0;
1208
+ }
1209
+ RandomAccessReader.prototype.ref = function() {
1210
+ this.refCount += 1;
1211
+ };
1212
+ RandomAccessReader.prototype.unref = function() {
1213
+ var self = this;
1214
+ self.refCount -= 1;
1215
+
1216
+ if (self.refCount > 0) return;
1217
+ if (self.refCount < 0) throw new Error("invalid unref");
1218
+
1219
+ self.close(onCloseDone);
1220
+
1221
+ function onCloseDone(err) {
1222
+ if (err) return self.emit('error', err);
1223
+ self.emit('close');
1224
+ }
1225
+ };
1226
+ RandomAccessReader.prototype.createReadStream = function(options) {
1227
+ var start = options.start;
1228
+ var end = options.end;
1229
+ if (start === end) {
1230
+ var emptyStream = new PassThrough();
1231
+ setImmediate(function() {
1232
+ emptyStream.end();
1233
+ });
1234
+ return emptyStream;
1235
+ }
1236
+ var stream = this._readStreamForRange(start, end);
1237
+
1238
+ var destroyed = false;
1239
+ var refUnrefFilter = new RefUnrefFilter(this);
1240
+ stream.on("error", function(err) {
1241
+ setImmediate(function() {
1242
+ if (!destroyed) refUnrefFilter.emit("error", err);
1243
+ });
1244
+ });
1245
+ refUnrefFilter.destroy = function() {
1246
+ stream.unpipe(refUnrefFilter);
1247
+ refUnrefFilter.unref();
1248
+ stream.destroy();
1249
+ };
1250
+
1251
+ var byteCounter = new AssertByteCountStream(end - start);
1252
+ refUnrefFilter.on("error", function(err) {
1253
+ setImmediate(function() {
1254
+ if (!destroyed) byteCounter.emit("error", err);
1255
+ });
1256
+ });
1257
+ byteCounter.destroy = function() {
1258
+ destroyed = true;
1259
+ refUnrefFilter.unpipe(byteCounter);
1260
+ refUnrefFilter.destroy();
1261
+ };
1262
+
1263
+ return stream.pipe(refUnrefFilter).pipe(byteCounter);
1264
+ };
1265
+ RandomAccessReader.prototype._readStreamForRange = function(start, end) {
1266
+ throw new Error("not implemented");
1267
+ };
1268
+ RandomAccessReader.prototype.read = function(buffer, offset, length, position, callback) {
1269
+ var readStream = this.createReadStream({start: position, end: position + length});
1270
+ var writeStream = new Writable();
1271
+ var written = 0;
1272
+ writeStream._write = function(chunk, encoding, cb) {
1273
+ chunk.copy(buffer, offset + written, 0, chunk.length);
1274
+ written += chunk.length;
1275
+ cb();
1276
+ };
1277
+ writeStream.on("finish", callback);
1278
+ readStream.on("error", function(error) {
1279
+ callback(error);
1280
+ });
1281
+ readStream.pipe(writeStream);
1282
+ };
1283
+ RandomAccessReader.prototype.close = function(callback) {
1284
+ setImmediate(callback);
1285
+ };
1286
+
1287
+ util.inherits(RefUnrefFilter, PassThrough);
1288
+ function RefUnrefFilter(context) {
1289
+ PassThrough.call(this);
1290
+ this.context = context;
1291
+ this.context.ref();
1292
+ this.unreffedYet = false;
1293
+ }
1294
+ RefUnrefFilter.prototype._flush = function(cb) {
1295
+ this.unref();
1296
+ cb();
1297
+ };
1298
+ RefUnrefFilter.prototype.unref = function(cb) {
1299
+ if (this.unreffedYet) return;
1300
+ this.unreffedYet = true;
1301
+ this.context.unref();
1302
+ };
1303
+
1304
+ var cp437 = '\u0000☺☻♥♦♣♠•◘○◙♂♀♪♫☼►◄↕‼¶§▬↨↑↓→←∟↔▲▼ !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~⌂ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ ';
1305
+ function decodeBuffer(buffer, start, end, isUtf8) {
1306
+ if (isUtf8) {
1307
+ return buffer.toString("utf8", start, end);
1308
+ } else {
1309
+ var result = "";
1310
+ for (var i = start; i < end; i++) {
1311
+ result += cp437[buffer[i]];
1312
+ }
1313
+ return result;
1314
+ }
1315
+ }
1316
+
1317
+ function readUInt64LE(buffer, offset) {
1318
+ // there is no native function for this, because we can't actually store 64-bit integers precisely.
1319
+ // after 53 bits, JavaScript's Number type (IEEE 754 double) can't store individual integers anymore.
1320
+ // but since 53 bits is a whole lot more than 32 bits, we do our best anyway.
1321
+ var lower32 = buffer.readUInt32LE(offset);
1322
+ var upper32 = buffer.readUInt32LE(offset + 4);
1323
+ // we can't use bitshifting here, because JavaScript bitshifting only works on 32-bit integers.
1324
+ return upper32 * 0x100000000 + lower32;
1325
+ // as long as we're bounds checking the result of this function against the total file size,
1326
+ // we'll catch any overflow errors, because we already made sure the total file size was within reason.
1327
+ }
1328
+
1329
+ // Node 10 deprecated new Buffer().
1330
+ var newBuffer;
1331
+ if (typeof Buffer.allocUnsafe === "function") {
1332
+ newBuffer = function(len) {
1333
+ return Buffer.allocUnsafe(len);
1334
+ };
1335
+ } else {
1336
+ newBuffer = function(len) {
1337
+ return new Buffer(len);
1338
+ };
1339
+ }
1340
+
1341
+ function defaultCallback(err) {
1342
+ if (err) throw err;
1343
+ }
1344
+
1345
+
1346
+ /***/ })
1347
+
1348
+ };
1349
+ ;