@atproto/oauth-provider 0.3.1 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (404) hide show
  1. package/.linguirc +57 -0
  2. package/CHANGELOG.md +29 -0
  3. package/LICENSE.txt +1 -1
  4. package/dist/account/account-manager.d.ts +17 -3
  5. package/dist/account/account-manager.d.ts.map +1 -1
  6. package/dist/account/account-manager.js +102 -8
  7. package/dist/account/account-manager.js.map +1 -1
  8. package/dist/account/account-store.d.ts +81 -15
  9. package/dist/account/account-store.d.ts.map +1 -1
  10. package/dist/account/account-store.js +70 -19
  11. package/dist/account/account-store.js.map +1 -1
  12. package/dist/account/sign-in-data.d.ts +28 -0
  13. package/dist/account/sign-in-data.d.ts.map +1 -0
  14. package/dist/account/sign-in-data.js +16 -0
  15. package/dist/account/sign-in-data.js.map +1 -0
  16. package/dist/account/sign-up-data.d.ts +26 -0
  17. package/dist/account/sign-up-data.d.ts.map +1 -0
  18. package/dist/account/sign-up-data.js +11 -0
  19. package/dist/account/sign-up-data.js.map +1 -0
  20. package/dist/assets/app/bundle-manifest.json +598 -6
  21. package/dist/assets/app/index-ItwwtJ8r.js +36 -0
  22. package/dist/assets/app/index-ItwwtJ8r.js.map +1 -0
  23. package/dist/assets/app/main-B_dNxQo_.js +4 -0
  24. package/dist/assets/app/main-B_dNxQo_.js.map +1 -0
  25. package/dist/assets/app/main-CSatvmRR.css +3 -0
  26. package/dist/assets/app/main-CSatvmRR.js +306 -0
  27. package/dist/assets/app/main-CSatvmRR.js.map +1 -0
  28. package/dist/assets/app/messages-BQeltXSF.js +4 -0
  29. package/dist/assets/app/messages-BQeltXSF.js.map +1 -0
  30. package/dist/assets/app/messages-BQkEhfjg.js +4 -0
  31. package/dist/assets/app/messages-BQkEhfjg.js.map +1 -0
  32. package/dist/assets/app/messages-BUjKj_UJ.js +4 -0
  33. package/dist/assets/app/messages-BUjKj_UJ.js.map +1 -0
  34. package/dist/assets/app/messages-BWIQa8fO.js +4 -0
  35. package/dist/assets/app/messages-BWIQa8fO.js.map +1 -0
  36. package/dist/assets/app/messages-BaNVb0bp.js +4 -0
  37. package/dist/assets/app/messages-BaNVb0bp.js.map +1 -0
  38. package/dist/assets/app/messages-BaizVXcF.js +4 -0
  39. package/dist/assets/app/messages-BaizVXcF.js.map +1 -0
  40. package/dist/assets/app/messages-BfoClA1Y.js +4 -0
  41. package/dist/assets/app/messages-BfoClA1Y.js.map +1 -0
  42. package/dist/assets/app/messages-BsKGDZnC.js +4 -0
  43. package/dist/assets/app/messages-BsKGDZnC.js.map +1 -0
  44. package/dist/assets/app/messages-Bu-TJhml.js +4 -0
  45. package/dist/assets/app/messages-Bu-TJhml.js.map +1 -0
  46. package/dist/assets/app/messages-BvOKnBQk.js +4 -0
  47. package/dist/assets/app/messages-BvOKnBQk.js.map +1 -0
  48. package/dist/assets/app/messages-BxDzCiWz.js +4 -0
  49. package/dist/assets/app/messages-BxDzCiWz.js.map +1 -0
  50. package/dist/assets/app/messages-CDgFOy4S.js +4 -0
  51. package/dist/assets/app/messages-CDgFOy4S.js.map +1 -0
  52. package/dist/assets/app/messages-CLbTz0o9.js +4 -0
  53. package/dist/assets/app/messages-CLbTz0o9.js.map +1 -0
  54. package/dist/assets/app/messages-CNwSh0t7.js +4 -0
  55. package/dist/assets/app/messages-CNwSh0t7.js.map +1 -0
  56. package/dist/assets/app/messages-CSMNJ6P8.js +4 -0
  57. package/dist/assets/app/messages-CSMNJ6P8.js.map +1 -0
  58. package/dist/assets/app/messages-CZQUw3mp.js +4 -0
  59. package/dist/assets/app/messages-CZQUw3mp.js.map +1 -0
  60. package/dist/assets/app/messages-CZT41oVp.js +4 -0
  61. package/dist/assets/app/messages-CZT41oVp.js.map +1 -0
  62. package/dist/assets/app/messages-C_b-d3t8.js +4 -0
  63. package/dist/assets/app/messages-C_b-d3t8.js.map +1 -0
  64. package/dist/assets/app/messages-C_u3MTc2.js +4 -0
  65. package/dist/assets/app/messages-C_u3MTc2.js.map +1 -0
  66. package/dist/assets/app/messages-Cn8nHZic.js +4 -0
  67. package/dist/assets/app/messages-Cn8nHZic.js.map +1 -0
  68. package/dist/assets/app/messages-CtDywJUm.js +4 -0
  69. package/dist/assets/app/messages-CtDywJUm.js.map +1 -0
  70. package/dist/assets/app/messages-CurtIjBF.js +4 -0
  71. package/dist/assets/app/messages-CurtIjBF.js.map +1 -0
  72. package/dist/assets/app/messages-Cv6zIbaP.js +4 -0
  73. package/dist/assets/app/messages-Cv6zIbaP.js.map +1 -0
  74. package/dist/assets/app/messages-D1eLQuPE.js +4 -0
  75. package/dist/assets/app/messages-D1eLQuPE.js.map +1 -0
  76. package/dist/assets/app/messages-D8vHEaYW.js +4 -0
  77. package/dist/assets/app/messages-D8vHEaYW.js.map +1 -0
  78. package/dist/assets/app/messages-DJ1Q4GeC.js +4 -0
  79. package/dist/assets/app/messages-DJ1Q4GeC.js.map +1 -0
  80. package/dist/assets/app/messages-DRL3exqd.js +4 -0
  81. package/dist/assets/app/messages-DRL3exqd.js.map +1 -0
  82. package/dist/assets/app/messages-DWLPQRTp.js +4 -0
  83. package/dist/assets/app/messages-DWLPQRTp.js.map +1 -0
  84. package/dist/assets/app/messages-DjVaE9YE.js +4 -0
  85. package/dist/assets/app/messages-DjVaE9YE.js.map +1 -0
  86. package/dist/assets/app/messages-DqpMfFJR.js +4 -0
  87. package/dist/assets/app/messages-DqpMfFJR.js.map +1 -0
  88. package/dist/assets/app/messages-ETjhJBEN.js +4 -0
  89. package/dist/assets/app/messages-ETjhJBEN.js.map +1 -0
  90. package/dist/assets/app/messages-EUKrgrGn.js +4 -0
  91. package/dist/assets/app/messages-EUKrgrGn.js.map +1 -0
  92. package/dist/assets/app/messages-QQrOUcPW.js +4 -0
  93. package/dist/assets/app/messages-QQrOUcPW.js.map +1 -0
  94. package/dist/assets/app/messages-e2QGqFL6.js +4 -0
  95. package/dist/assets/app/messages-e2QGqFL6.js.map +1 -0
  96. package/dist/assets/app/messages-p61py7gD.js +4 -0
  97. package/dist/assets/app/messages-p61py7gD.js.map +1 -0
  98. package/dist/assets/asset.d.ts +1 -0
  99. package/dist/assets/asset.d.ts.map +1 -1
  100. package/dist/assets/assets-middleware.d.ts.map +1 -1
  101. package/dist/assets/assets-middleware.js +12 -7
  102. package/dist/assets/assets-middleware.js.map +1 -1
  103. package/dist/assets/index.d.ts +3 -2
  104. package/dist/assets/index.d.ts.map +1 -1
  105. package/dist/assets/index.js +13 -1
  106. package/dist/assets/index.js.map +1 -1
  107. package/dist/client/client-store.d.ts +3 -3
  108. package/dist/client/client-store.d.ts.map +1 -1
  109. package/dist/client/client-store.js +6 -5
  110. package/dist/client/client-store.js.map +1 -1
  111. package/dist/device/device-manager.d.ts +12 -13
  112. package/dist/device/device-manager.d.ts.map +1 -1
  113. package/dist/device/device-manager.js +5 -3
  114. package/dist/device/device-manager.js.map +1 -1
  115. package/dist/device/device-store.d.ts +3 -3
  116. package/dist/device/device-store.d.ts.map +1 -1
  117. package/dist/device/device-store.js +10 -9
  118. package/dist/device/device-store.js.map +1 -1
  119. package/dist/dpop/dpop-manager.d.ts +15 -7
  120. package/dist/dpop/dpop-manager.d.ts.map +1 -1
  121. package/dist/dpop/dpop-manager.js +17 -3
  122. package/dist/dpop/dpop-manager.js.map +1 -1
  123. package/dist/dpop/dpop-nonce.d.ts +11 -5
  124. package/dist/dpop/dpop-nonce.d.ts.map +1 -1
  125. package/dist/dpop/dpop-nonce.js +47 -38
  126. package/dist/dpop/dpop-nonce.js.map +1 -1
  127. package/dist/errors/handle-unavailable-error.d.ts +11 -0
  128. package/dist/errors/handle-unavailable-error.d.ts.map +1 -0
  129. package/dist/errors/handle-unavailable-error.js +19 -0
  130. package/dist/errors/handle-unavailable-error.js.map +1 -0
  131. package/dist/errors/invalid-request-error.d.ts +6 -8
  132. package/dist/errors/invalid-request-error.d.ts.map +1 -1
  133. package/dist/errors/invalid-request-error.js +10 -8
  134. package/dist/errors/invalid-request-error.js.map +1 -1
  135. package/dist/lib/csp/index.d.ts +18 -0
  136. package/dist/lib/csp/index.d.ts.map +1 -0
  137. package/dist/lib/csp/index.js +72 -0
  138. package/dist/lib/csp/index.js.map +1 -0
  139. package/dist/lib/hcaptcha.d.ts +177 -0
  140. package/dist/lib/hcaptcha.d.ts.map +1 -0
  141. package/dist/lib/hcaptcha.js +155 -0
  142. package/dist/lib/hcaptcha.js.map +1 -0
  143. package/dist/lib/html/build-document.d.ts +11 -3
  144. package/dist/lib/html/build-document.d.ts.map +1 -1
  145. package/dist/lib/html/build-document.js +51 -15
  146. package/dist/lib/html/build-document.js.map +1 -1
  147. package/dist/lib/http/middleware.d.ts.map +1 -1
  148. package/dist/lib/http/middleware.js +4 -1
  149. package/dist/lib/http/middleware.js.map +1 -1
  150. package/dist/lib/http/request.d.ts +18 -3
  151. package/dist/lib/http/request.d.ts.map +1 -1
  152. package/dist/lib/http/request.js +56 -23
  153. package/dist/lib/http/request.js.map +1 -1
  154. package/dist/lib/http/response.d.ts +4 -2
  155. package/dist/lib/http/response.d.ts.map +1 -1
  156. package/dist/lib/http/response.js +23 -5
  157. package/dist/lib/http/response.js.map +1 -1
  158. package/dist/lib/locale.d.ts +15 -0
  159. package/dist/lib/locale.d.ts.map +1 -0
  160. package/dist/lib/locale.js +17 -0
  161. package/dist/lib/locale.js.map +1 -0
  162. package/dist/lib/util/function.d.ts +2 -2
  163. package/dist/lib/util/function.d.ts.map +1 -1
  164. package/dist/lib/util/function.js.map +1 -1
  165. package/dist/lib/util/type.d.ts +88 -1
  166. package/dist/lib/util/type.d.ts.map +1 -1
  167. package/dist/lib/util/type.js +41 -0
  168. package/dist/lib/util/type.js.map +1 -1
  169. package/dist/metadata/build-metadata.d.ts +2 -2
  170. package/dist/metadata/build-metadata.d.ts.map +1 -1
  171. package/dist/metadata/build-metadata.js.map +1 -1
  172. package/dist/oauth-errors.d.ts +1 -0
  173. package/dist/oauth-errors.d.ts.map +1 -1
  174. package/dist/oauth-errors.js +3 -1
  175. package/dist/oauth-errors.js.map +1 -1
  176. package/dist/oauth-hooks.d.ts +60 -3
  177. package/dist/oauth-hooks.d.ts.map +1 -1
  178. package/dist/oauth-hooks.js +3 -3
  179. package/dist/oauth-hooks.js.map +1 -1
  180. package/dist/oauth-provider.d.ts +28 -22
  181. package/dist/oauth-provider.d.ts.map +1 -1
  182. package/dist/oauth-provider.js +212 -211
  183. package/dist/oauth-provider.js.map +1 -1
  184. package/dist/oauth-verifier.d.ts +1 -1
  185. package/dist/oauth-verifier.d.ts.map +1 -1
  186. package/dist/oauth-verifier.js +2 -1
  187. package/dist/oauth-verifier.js.map +1 -1
  188. package/dist/output/build-authorize-data.d.ts +0 -1
  189. package/dist/output/build-authorize-data.d.ts.map +1 -1
  190. package/dist/output/build-authorize-data.js +0 -1
  191. package/dist/output/build-authorize-data.js.map +1 -1
  192. package/dist/output/build-customization-data.d.ts +232 -0
  193. package/dist/output/build-customization-data.d.ts.map +1 -0
  194. package/dist/output/build-customization-data.js +145 -0
  195. package/dist/output/build-customization-data.js.map +1 -0
  196. package/dist/output/output-manager.d.ts +16 -9
  197. package/dist/output/output-manager.d.ts.map +1 -1
  198. package/dist/output/output-manager.js +78 -42
  199. package/dist/output/output-manager.js.map +1 -1
  200. package/dist/output/send-authorize-redirect.d.ts +9 -6
  201. package/dist/output/send-authorize-redirect.d.ts.map +1 -1
  202. package/dist/output/send-authorize-redirect.js +20 -14
  203. package/dist/output/send-authorize-redirect.js.map +1 -1
  204. package/dist/output/send-web-page.d.ts +7 -2
  205. package/dist/output/send-web-page.d.ts.map +1 -1
  206. package/dist/output/send-web-page.js +37 -21
  207. package/dist/output/send-web-page.js.map +1 -1
  208. package/dist/request/request-manager.d.ts +1 -1
  209. package/dist/request/request-manager.d.ts.map +1 -1
  210. package/dist/request/request-manager.js +4 -4
  211. package/dist/request/request-manager.js.map +1 -1
  212. package/dist/request/request-store.d.ts +3 -3
  213. package/dist/request/request-store.d.ts.map +1 -1
  214. package/dist/request/request-store.js +11 -10
  215. package/dist/request/request-store.js.map +1 -1
  216. package/dist/token/token-store.d.ts +4 -4
  217. package/dist/token/token-store.d.ts.map +1 -1
  218. package/dist/token/token-store.js +13 -12
  219. package/dist/token/token-store.js.map +1 -1
  220. package/package.json +46 -21
  221. package/rollup.config.js +61 -17
  222. package/src/account/account-manager.ts +159 -8
  223. package/src/account/account-store.ts +127 -32
  224. package/src/account/sign-in-data.ts +15 -0
  225. package/src/account/sign-up-data.ts +11 -0
  226. package/src/assets/app/app.tsx +31 -16
  227. package/src/assets/app/backend-data.ts +15 -60
  228. package/src/assets/app/backend-types.ts +66 -0
  229. package/src/assets/app/components/forms/button-toggle-visibility.tsx +43 -0
  230. package/src/assets/app/components/forms/button.tsx +60 -0
  231. package/src/assets/app/components/forms/fieldset.tsx +55 -0
  232. package/src/assets/app/components/forms/form-card-async.tsx +103 -0
  233. package/src/assets/app/components/forms/form-card.tsx +49 -0
  234. package/src/assets/app/components/forms/input-checkbox.tsx +73 -0
  235. package/src/assets/app/components/forms/input-container.tsx +107 -0
  236. package/src/assets/app/components/forms/input-email-address.tsx +66 -0
  237. package/src/assets/app/components/forms/input-new-password.tsx +62 -0
  238. package/src/assets/app/components/forms/input-password.tsx +88 -0
  239. package/src/assets/app/components/forms/input-text.tsx +76 -0
  240. package/src/assets/app/components/forms/input-token.tsx +94 -0
  241. package/src/assets/app/components/forms/wizard-card.tsx +116 -0
  242. package/src/assets/app/components/layouts/layout-title-page.tsx +77 -0
  243. package/src/assets/app/components/layouts/layout-welcome.tsx +73 -0
  244. package/src/assets/app/components/utils/account-identifier.tsx +23 -0
  245. package/src/assets/app/components/utils/account-image.tsx +33 -0
  246. package/src/assets/app/components/utils/admonition.tsx +52 -0
  247. package/src/assets/app/components/utils/client-name.tsx +45 -0
  248. package/src/assets/app/components/utils/error-card.tsx +93 -0
  249. package/src/assets/app/components/utils/error-message.tsx +62 -0
  250. package/src/assets/app/components/utils/help-card.tsx +46 -0
  251. package/src/assets/app/components/utils/icons.tsx +88 -0
  252. package/src/assets/app/components/utils/link-anchor.tsx +28 -0
  253. package/src/assets/app/components/utils/link-title.tsx +26 -0
  254. package/src/assets/app/components/utils/multi-lang-string.tsx +56 -0
  255. package/src/assets/app/components/utils/password-strength-label.tsx +37 -0
  256. package/src/assets/app/components/utils/password-strength-meter.tsx +58 -0
  257. package/src/assets/app/components/{url-viewer.tsx → utils/url-viewer.tsx} +9 -6
  258. package/src/assets/app/hooks/use-api.ts +128 -55
  259. package/src/assets/app/hooks/use-async-action.ts +120 -0
  260. package/src/assets/app/hooks/use-browser-color-scheme.ts +31 -0
  261. package/src/assets/app/hooks/use-csrf-token.ts +1 -1
  262. package/src/assets/app/hooks/use-random-string.ts +37 -0
  263. package/src/assets/app/hooks/use-stepper.ts +87 -0
  264. package/src/assets/app/index.html +182 -0
  265. package/src/assets/app/lib/api.ts +248 -79
  266. package/src/assets/app/lib/clsx.ts +5 -8
  267. package/src/assets/app/lib/json-client.ts +94 -0
  268. package/src/assets/app/lib/password.ts +98 -0
  269. package/src/assets/app/lib/ref.ts +17 -0
  270. package/src/assets/app/locales/an/messages.po +492 -0
  271. package/src/assets/app/locales/ast/messages.po +492 -0
  272. package/src/assets/app/locales/ca/messages.po +492 -0
  273. package/src/assets/app/locales/da/messages.po +492 -0
  274. package/src/assets/app/locales/de/messages.po +492 -0
  275. package/src/assets/app/locales/el/messages.po +492 -0
  276. package/src/assets/app/locales/en/messages.po +492 -0
  277. package/src/assets/app/locales/en-GB/messages.po +492 -0
  278. package/src/assets/app/locales/es/messages.po +492 -0
  279. package/src/assets/app/locales/eu/messages.po +492 -0
  280. package/src/assets/app/locales/fi/messages.po +492 -0
  281. package/src/assets/app/locales/fr/messages.po +492 -0
  282. package/src/assets/app/locales/ga/messages.po +492 -0
  283. package/src/assets/app/locales/gl/messages.po +492 -0
  284. package/src/assets/app/locales/hi/messages.po +492 -0
  285. package/src/assets/app/locales/hu/messages.po +492 -0
  286. package/src/assets/app/locales/ia/messages.po +492 -0
  287. package/src/assets/app/locales/id/messages.po +492 -0
  288. package/src/assets/app/locales/it/messages.po +492 -0
  289. package/src/assets/app/locales/ja/messages.po +492 -0
  290. package/src/assets/app/locales/km/messages.po +492 -0
  291. package/src/assets/app/locales/ko/messages.po +492 -0
  292. package/src/assets/app/locales/load.ts +8 -0
  293. package/src/assets/app/locales/locale-context.ts +19 -0
  294. package/src/assets/app/locales/locale-provider.tsx +112 -0
  295. package/src/assets/app/locales/locale-selector.tsx +58 -0
  296. package/src/assets/app/locales/locales.ts +168 -0
  297. package/src/assets/app/locales/ne/messages.po +492 -0
  298. package/src/assets/app/locales/nl/messages.po +492 -0
  299. package/src/assets/app/locales/pl/messages.po +492 -0
  300. package/src/assets/app/locales/pt-BR/messages.po +492 -0
  301. package/src/assets/app/locales/ro/messages.po +492 -0
  302. package/src/assets/app/locales/ru/messages.po +492 -0
  303. package/src/assets/app/locales/sv/messages.po +492 -0
  304. package/src/assets/app/locales/th/messages.po +492 -0
  305. package/src/assets/app/locales/tr/messages.po +492 -0
  306. package/src/assets/app/locales/uk/messages.po +492 -0
  307. package/src/assets/app/locales/vi/messages.po +492 -0
  308. package/src/assets/app/locales/zh-CN/messages.po +492 -0
  309. package/src/assets/app/locales/zh-HK/messages.po +492 -0
  310. package/src/assets/app/locales/zh-TW/messages.po +492 -0
  311. package/src/assets/app/main.css +23 -2
  312. package/src/assets/app/main.tsx +24 -8
  313. package/src/assets/app/views/authorize/accept/accept-form.tsx +150 -0
  314. package/src/assets/app/views/authorize/accept/accept-view.tsx +70 -0
  315. package/src/assets/app/views/authorize/authorize-view.tsx +180 -0
  316. package/src/assets/app/views/authorize/reset-password/reset-password-confirm-form.tsx +88 -0
  317. package/src/assets/app/views/authorize/reset-password/reset-password-request-form.tsx +80 -0
  318. package/src/assets/app/views/authorize/reset-password/reset-password-view.tsx +127 -0
  319. package/src/assets/app/views/authorize/sign-in/sign-in-form.tsx +244 -0
  320. package/src/assets/app/views/authorize/sign-in/sign-in-picker.tsx +116 -0
  321. package/src/assets/app/views/authorize/sign-in/sign-in-view.tsx +145 -0
  322. package/src/assets/app/views/authorize/sign-up/sign-up-account-form.tsx +140 -0
  323. package/src/assets/app/views/authorize/sign-up/sign-up-disclaimer.tsx +51 -0
  324. package/src/assets/app/views/authorize/sign-up/sign-up-handle-form.tsx +289 -0
  325. package/src/assets/app/views/authorize/sign-up/sign-up-hcaptcha-form.tsx +108 -0
  326. package/src/assets/app/views/authorize/sign-up/sign-up-view.tsx +158 -0
  327. package/src/assets/app/views/authorize/welcome/welcome-view.tsx +56 -0
  328. package/src/assets/app/views/error/error-view.tsx +31 -0
  329. package/src/assets/asset.ts +1 -0
  330. package/src/assets/assets-middleware.ts +13 -8
  331. package/src/assets/index.ts +15 -2
  332. package/src/client/client-store.ts +10 -12
  333. package/src/device/device-manager.ts +14 -15
  334. package/src/device/device-store.ts +9 -15
  335. package/src/dpop/dpop-manager.ts +20 -8
  336. package/src/dpop/dpop-nonce.ts +58 -40
  337. package/src/errors/handle-unavailable-error.ts +18 -0
  338. package/src/errors/invalid-request-error.ts +10 -8
  339. package/src/lib/csp/index.ts +98 -0
  340. package/src/lib/hcaptcha.ts +182 -0
  341. package/src/lib/html/build-document.ts +60 -16
  342. package/src/lib/http/middleware.ts +4 -3
  343. package/src/lib/http/request.ts +81 -28
  344. package/src/lib/http/response.ts +22 -9
  345. package/src/lib/locale.ts +21 -0
  346. package/src/lib/util/function.ts +0 -3
  347. package/src/lib/util/type.ts +130 -1
  348. package/src/metadata/build-metadata.ts +2 -1
  349. package/src/oauth-errors.ts +1 -0
  350. package/src/oauth-hooks.ts +69 -3
  351. package/src/oauth-provider.ts +410 -315
  352. package/src/oauth-verifier.ts +3 -1
  353. package/src/output/build-authorize-data.ts +1 -3
  354. package/src/output/build-customization-data.ts +189 -0
  355. package/src/output/output-manager.ts +111 -48
  356. package/src/output/send-authorize-redirect.ts +43 -36
  357. package/src/output/send-web-page.ts +40 -26
  358. package/src/request/request-manager.ts +4 -4
  359. package/src/request/request-store.ts +12 -16
  360. package/src/token/token-store.ts +14 -18
  361. package/tailwind.config.js +5 -0
  362. package/tsconfig.backend.tsbuildinfo +1 -1
  363. package/tsconfig.frontend.tsbuildinfo +1 -1
  364. package/tsconfig.tools.tsbuildinfo +1 -1
  365. package/vite.config.mjs +16 -0
  366. package/.postcssrc.yml +0 -3
  367. package/dist/assets/app/main.css +0 -3
  368. package/dist/assets/app/main.js +0 -20
  369. package/dist/assets/app/main.js.map +0 -1
  370. package/dist/output/customization.d.ts +0 -27
  371. package/dist/output/customization.d.ts.map +0 -1
  372. package/dist/output/customization.js +0 -88
  373. package/dist/output/customization.js.map +0 -1
  374. package/src/assets/app/components/accept-form.tsx +0 -137
  375. package/src/assets/app/components/account-identifier.tsx +0 -18
  376. package/src/assets/app/components/account-picker.tsx +0 -127
  377. package/src/assets/app/components/button.tsx +0 -34
  378. package/src/assets/app/components/client-name.tsx +0 -37
  379. package/src/assets/app/components/fieldset.tsx +0 -26
  380. package/src/assets/app/components/form-card.tsx +0 -47
  381. package/src/assets/app/components/help-card.tsx +0 -42
  382. package/src/assets/app/components/icons/alert-icon.tsx +0 -5
  383. package/src/assets/app/components/icons/at-symbol-icon.tsx +0 -5
  384. package/src/assets/app/components/icons/caret-right-icon.tsx +0 -5
  385. package/src/assets/app/components/icons/lock-icon.tsx +0 -5
  386. package/src/assets/app/components/icons/token-icon.tsx +0 -5
  387. package/src/assets/app/components/icons/util.tsx +0 -17
  388. package/src/assets/app/components/info-card.tsx +0 -45
  389. package/src/assets/app/components/input-checkbox.tsx +0 -47
  390. package/src/assets/app/components/input-container.tsx +0 -37
  391. package/src/assets/app/components/input-layout.tsx +0 -47
  392. package/src/assets/app/components/input-text.tsx +0 -69
  393. package/src/assets/app/components/layout-title-page.tsx +0 -60
  394. package/src/assets/app/components/layout-welcome.tsx +0 -74
  395. package/src/assets/app/components/sign-in-form.tsx +0 -337
  396. package/src/assets/app/components/sign-up-account-form.tsx +0 -194
  397. package/src/assets/app/components/sign-up-disclaimer.tsx +0 -44
  398. package/src/assets/app/views/accept-view.tsx +0 -55
  399. package/src/assets/app/views/authorize-view.tsx +0 -106
  400. package/src/assets/app/views/error-view.tsx +0 -36
  401. package/src/assets/app/views/sign-in-view.tsx +0 -111
  402. package/src/assets/app/views/sign-up-view.tsx +0 -86
  403. package/src/assets/app/views/welcome-view.tsx +0 -54
  404. package/src/output/customization.ts +0 -118
@@ -1,337 +0,0 @@
1
- import { ReactNode, SyntheticEvent, useCallback, useState } from 'react'
2
-
3
- import {
4
- InvalidCredentialsError,
5
- SecondAuthenticationFactorRequiredError,
6
- } from '../lib/api'
7
- import { clsx } from '../lib/clsx'
8
- import { Override } from '../lib/util'
9
- import { Button } from './button'
10
- import { FormCard, FormCardProps } from './form-card'
11
- import { AtSymbolIcon } from './icons/at-symbol-icon'
12
- import { LockIcon } from './icons/lock-icon'
13
- import { InfoCard } from './info-card'
14
- import { InputCheckbox } from './input-checkbox'
15
- import { InputText } from './input-text'
16
- import { TokenIcon } from './icons/token-icon'
17
- import { Fieldset } from './fieldset'
18
-
19
- export type SignInFormOutput = {
20
- username: string
21
- password: string
22
- remember?: boolean
23
- }
24
-
25
- export type SignInFormProps = Override<
26
- FormCardProps,
27
- {
28
- onSubmit: (credentials: SignInFormOutput) => void | PromiseLike<void>
29
- submitLabel?: ReactNode
30
- submitAria?: string
31
-
32
- onCancel?: () => void
33
- cancelLabel?: ReactNode
34
- cancelAria?: string
35
-
36
- accountSection?: ReactNode
37
- sessionSection?: ReactNode
38
- secondFactorSection?: ReactNode
39
-
40
- usernameDefault?: string
41
- usernameReadonly?: boolean
42
- usernameLabel?: string
43
- usernamePlaceholder?: string
44
- usernameAria?: string
45
- usernamePattern?: string
46
- usernameFormat?: string
47
-
48
- passwordLabel?: string
49
- passwordPlaceholder?: string
50
- passwordWarning?: ReactNode
51
- passwordAria?: string
52
- passwordPattern?: string
53
- passwordFormat?: string
54
-
55
- secondFactorLabel?: string
56
- secondFactorPlaceholder?: string
57
- secondFactorAria?: string
58
- secondFactorPattern?: string
59
- secondFactorFormat?: string
60
- secondFactorHint?: string
61
- secondFactorParseValue?: (value: string) => string | false
62
-
63
- rememberVisible?: boolean
64
- rememberDefault?: boolean
65
- rememberLabel?: string
66
- rememberAria?: string
67
- }
68
- >
69
-
70
- export function SignInForm({
71
- onSubmit,
72
- submitAria = 'Next',
73
- submitLabel = submitAria,
74
-
75
- onCancel = undefined,
76
- cancelAria = 'Cancel',
77
- cancelLabel = cancelAria,
78
-
79
- accountSection = 'Account',
80
- sessionSection = 'Session',
81
- secondFactorSection = '2FA Confirmation',
82
-
83
- usernameDefault = '',
84
- usernameReadonly = false,
85
- usernameLabel = 'Username or email address',
86
- usernameAria = usernameLabel,
87
- usernamePlaceholder = usernameLabel,
88
- usernamePattern = undefined,
89
- usernameFormat = 'valid email address or username',
90
-
91
- passwordLabel = 'Password',
92
- passwordAria = passwordLabel,
93
- passwordPlaceholder = passwordLabel,
94
- passwordPattern = undefined,
95
- passwordFormat = 'non empty string',
96
- passwordWarning = (
97
- <>
98
- <p className="font-bold text-brand leading-8">Warning</p>
99
- <p>
100
- Please verify the domain name of the website before entering your
101
- password. Never enter your password on a domain you do not trust.
102
- </p>
103
- </>
104
- ),
105
-
106
- secondFactorLabel = 'Confirmation code',
107
- secondFactorAria = secondFactorLabel,
108
- secondFactorPlaceholder = secondFactorLabel,
109
- secondFactorPattern = '^[A-Z2-7]{5}-[A-Z2-7]{5}$',
110
- secondFactorFormat = 'XXXXX-XXXXX',
111
- secondFactorHint = 'Check your $1 email for a login code and enter it here.',
112
- secondFactorParseValue = checkAndFormatEmailOtpCode,
113
-
114
- rememberVisible = true,
115
- rememberDefault = false,
116
- rememberLabel = 'Remember this account on this device',
117
- rememberAria = rememberLabel,
118
-
119
- ...props
120
- }: SignInFormProps) {
121
- const [focused, setFocused] = useState(false)
122
- const [loading, setLoading] = useState(false)
123
- const [secondFactor, setSecondFactor] = useState<null | {
124
- type: 'emailOtp'
125
- hint: string
126
- }>(null)
127
-
128
- const [errorMessage, setErrorMessage] = useState<string | null>(null)
129
-
130
- const resetState = useCallback(() => {
131
- setSecondFactor(null)
132
- setErrorMessage(null)
133
- }, [])
134
-
135
- const passwordReadonly = secondFactor != null
136
-
137
- const doSubmit = useCallback(
138
- async (
139
- event: SyntheticEvent<
140
- HTMLFormElement & {
141
- username: HTMLInputElement
142
- password: HTMLInputElement
143
- remember?: HTMLInputElement
144
- secondFactor?: HTMLInputElement
145
- },
146
- SubmitEvent
147
- >,
148
- ) => {
149
- event.preventDefault()
150
-
151
- const credentials: SignInFormOutput = {
152
- username: event.currentTarget.username.value,
153
- password: event.currentTarget.password.value,
154
- remember: event.currentTarget.remember?.checked,
155
- }
156
-
157
- if (secondFactor) {
158
- const element = event.currentTarget.secondFactor
159
- if (!element) throw new Error('Second factor input not found')
160
- const value = secondFactorParseValue(element.value)
161
- if (!value) {
162
- setSecondFactor({
163
- type: secondFactor.type,
164
- hint: `Make sure to match the format: ${secondFactorFormat}`,
165
- })
166
- return
167
- }
168
- credentials[secondFactor.type] = value
169
- }
170
-
171
- setLoading(true)
172
- setErrorMessage(null)
173
- try {
174
- await onSubmit(credentials)
175
- } catch (err) {
176
- if (err instanceof SecondAuthenticationFactorRequiredError) {
177
- setSecondFactor({
178
- type: err.type,
179
- hint: err.hint,
180
- })
181
- } else {
182
- setErrorMessage(parseErrorMessage(err))
183
- }
184
- } finally {
185
- setLoading(false)
186
- }
187
- },
188
- [secondFactor, onSubmit],
189
- )
190
-
191
- return (
192
- <FormCard
193
- onSubmit={doSubmit}
194
- error={errorMessage}
195
- cancel={
196
- onCancel && (
197
- <Button aria-label={cancelAria} onClick={onCancel}>
198
- {cancelLabel}
199
- </Button>
200
- )
201
- }
202
- actions={
203
- <Button
204
- color="brand"
205
- type="submit"
206
- aria-label={submitAria}
207
- loading={loading}
208
- >
209
- {submitLabel}
210
- </Button>
211
- }
212
- {...props}
213
- >
214
- <Fieldset title={accountSection} disabled={loading}>
215
- <InputText
216
- icon={<AtSymbolIcon className="w-5" />}
217
- name="username"
218
- type="text"
219
- onChange={resetState}
220
- placeholder={usernamePlaceholder}
221
- aria-label={usernameAria}
222
- autoCapitalize="none"
223
- autoCorrect="off"
224
- autoComplete="username"
225
- spellCheck="false"
226
- dir="auto"
227
- enterKeyHint="next"
228
- required
229
- defaultValue={usernameDefault}
230
- readOnly={usernameReadonly}
231
- disabled={usernameReadonly}
232
- pattern={usernamePattern}
233
- title={usernameFormat}
234
- />
235
-
236
- <InputText
237
- icon={<LockIcon className="w-5" />}
238
- name="password"
239
- type="password"
240
- onChange={resetState}
241
- onFocus={() => setFocused(true)}
242
- onBlur={() => setTimeout(setFocused, 100, false)}
243
- placeholder={passwordPlaceholder}
244
- aria-label={passwordAria}
245
- autoCapitalize="none"
246
- autoCorrect="off"
247
- autoComplete="current-password"
248
- dir="auto"
249
- enterKeyHint="done"
250
- spellCheck="false"
251
- required
252
- readOnly={passwordReadonly}
253
- disabled={passwordReadonly}
254
- pattern={passwordPattern}
255
- title={passwordFormat}
256
- />
257
-
258
- {passwordWarning && (
259
- <div
260
- className={clsx(
261
- 'transition-all delay-300 duration-300 overflow-hidden',
262
- focused ? 'max-h-80' : 'max-h-0 -z-10 !mt-0',
263
- )}
264
- >
265
- <InfoCard role="status">{passwordWarning}</InfoCard>
266
- </div>
267
- )}
268
- </Fieldset>
269
-
270
- {rememberVisible && (
271
- <Fieldset key="remember" title={sessionSection} disabled={loading}>
272
- <InputCheckbox
273
- name="remember"
274
- defaultChecked={rememberDefault}
275
- aria-label={rememberAria}
276
- >
277
- {rememberLabel}
278
- </InputCheckbox>
279
- </Fieldset>
280
- )}
281
-
282
- {secondFactor && (
283
- <Fieldset key="2fa" title={secondFactorSection} disabled={loading}>
284
- <div>
285
- <InputText
286
- icon={<TokenIcon className="w-5" />}
287
- name="secondFactor"
288
- type="text"
289
- placeholder={secondFactorPlaceholder}
290
- aria-label={secondFactorAria}
291
- autoCapitalize="none"
292
- autoCorrect="off"
293
- autoComplete="off"
294
- spellCheck="false"
295
- dir="auto"
296
- enterKeyHint="done"
297
- required
298
- pattern={secondFactorPattern}
299
- title={secondFactorFormat}
300
- autoFocus={true}
301
- />
302
- <p className="text-slate-600 dark:text-slate-400 text-sm">
303
- {secondFactorHint.replaceAll('$1', secondFactor.hint)}
304
- </p>
305
- </div>
306
- </Fieldset>
307
- )}
308
- </FormCard>
309
- )
310
- }
311
-
312
- function parseErrorMessage(err: unknown): string {
313
- if (err instanceof InvalidCredentialsError) {
314
- return 'Invalid username or password'
315
- }
316
-
317
- return 'An unknown error occurred'
318
- }
319
-
320
- export function checkAndFormatEmailOtpCode(code: string): string | false {
321
- const EMAIL_CODE_REGEX = /^[A-Z2-7]{5}-[A-Z2-7]{5}$/
322
-
323
- // Trim the reset code
324
- let fixed = code.trim().toUpperCase()
325
-
326
- // Add a dash if needed
327
- if (fixed.length === 10) {
328
- fixed = `${fixed.slice(0, 5)}-${fixed.slice(5, 10)}`
329
- }
330
-
331
- // Check that it is a valid format
332
- if (!EMAIL_CODE_REGEX.test(fixed)) {
333
- return false
334
- }
335
-
336
- return fixed
337
- }
@@ -1,194 +0,0 @@
1
- import {
2
- FormHTMLAttributes,
3
- ReactNode,
4
- SyntheticEvent,
5
- useCallback,
6
- useState,
7
- } from 'react'
8
-
9
- import { Button } from './button'
10
- import { FormCard, FormCardProps } from './form-card'
11
- import { Override } from '../lib/util'
12
- import { Fieldset } from './fieldset'
13
-
14
- export type SignUpAccountFormOutput = {
15
- username: string
16
- password: string
17
- }
18
-
19
- export type SignUpAccountFormProps = Override<
20
- FormCardProps,
21
- {
22
- onSubmit: (credentials: SignUpAccountFormOutput) => void | PromiseLike<void>
23
- submitLabel?: ReactNode
24
- submitAria?: string
25
-
26
- onCancel?: () => void
27
- cancelLabel?: ReactNode
28
- cancelAria?: string
29
-
30
- username?: string
31
- usernamePlaceholder?: string
32
- usernameLabel?: string
33
- usernameAria?: string
34
- usernamePattern?: string
35
- usernameTitle?: string
36
-
37
- passwordPlaceholder?: string
38
- passwordLabel?: string
39
- passwordAria?: string
40
- passwordPattern?: string
41
- passwordTitle?: string
42
- }
43
- >
44
-
45
- export function SignUpAccountForm({
46
- onSubmit,
47
- submitAria = 'Next',
48
- submitLabel = submitAria,
49
-
50
- onCancel = undefined,
51
- cancelAria = 'Cancel',
52
- cancelLabel = cancelAria,
53
-
54
- username: defaultUsername = '',
55
- usernameLabel = 'Username',
56
- usernameAria = usernameLabel,
57
- usernamePlaceholder = usernameLabel,
58
- usernamePattern,
59
- usernameTitle,
60
-
61
- passwordLabel = 'Password',
62
- passwordAria = passwordLabel,
63
- passwordPlaceholder = passwordLabel,
64
- passwordPattern,
65
- passwordTitle,
66
-
67
- children,
68
- ...props
69
- }: SignUpAccountFormProps &
70
- Omit<FormHTMLAttributes<HTMLFormElement>, keyof SignUpAccountFormProps>) {
71
- const [loading, setLoading] = useState(false)
72
- const [errorMessage, setErrorMessage] = useState<string | null>(null)
73
-
74
- const doSubmit = useCallback(
75
- async (
76
- event: SyntheticEvent<
77
- HTMLFormElement & {
78
- username: HTMLInputElement
79
- password: HTMLInputElement
80
- },
81
- SubmitEvent
82
- >,
83
- ) => {
84
- event.preventDefault()
85
-
86
- const credentials = {
87
- username: event.currentTarget.username.value,
88
- password: event.currentTarget.password.value,
89
- }
90
-
91
- setLoading(true)
92
- setErrorMessage(null)
93
- try {
94
- await onSubmit(credentials)
95
- } catch (err) {
96
- setErrorMessage(parseErrorMessage(err))
97
- } finally {
98
- setLoading(false)
99
- }
100
- },
101
- [onSubmit, setErrorMessage, setLoading],
102
- )
103
-
104
- return (
105
- <FormCard
106
- append={children}
107
- error={errorMessage}
108
- onSubmit={doSubmit}
109
- cancel={
110
- onCancel && (
111
- <Button aria-label={cancelAria} onClick={onCancel}>
112
- {cancelLabel}
113
- </Button>
114
- )
115
- }
116
- actions={
117
- <Button
118
- color="brand"
119
- type="submit"
120
- aria-label={submitAria}
121
- disabled={loading}
122
- >
123
- {submitLabel}
124
- </Button>
125
- }
126
- {...props}
127
- >
128
- <Fieldset disabled={loading}>
129
- <label className="text-sm font-medium block">
130
- <p>{usernameLabel}</p>
131
-
132
- <div className="relative flex flex-wrap items-center justify-stretch rounded-md border border-solid border-slate-200 dark:border-slate-700 text-neutral-700 dark:text-neutral-100">
133
- <span className="w-6 ml-1 text-center text-base">@</span>
134
- <input
135
- name="username"
136
- type="text"
137
- onChange={() => setErrorMessage(null)}
138
- className="relative m-1 block w-[1px] min-w-0 flex-auto leading-[1.6] bg-transparent bg-clip-padding text-base text-inherit outline-none dark:placeholder:text-neutral-100 disabled:text-gray-500"
139
- placeholder={usernamePlaceholder}
140
- aria-label={usernameAria}
141
- autoCapitalize="none"
142
- autoCorrect="off"
143
- autoComplete="username"
144
- spellCheck="false"
145
- dir="auto"
146
- enterKeyHint="next"
147
- required
148
- defaultValue={defaultUsername}
149
- pattern={usernamePattern}
150
- title={usernameTitle}
151
- />
152
- </div>
153
- </label>
154
-
155
- <label className="text-sm font-medium block">
156
- <p>{passwordLabel}</p>
157
-
158
- <div className="relative flex flex-wrap items-center justify-stretch rounded-md border border-solid border-slate-200 dark:border-slate-700 text-neutral-700 dark:text-neutral-100">
159
- <span className="w-6 ml-1 text-center text-2xl font-light -mb-2">
160
- *
161
- </span>
162
- <input
163
- name="password"
164
- type="password"
165
- onChange={() => setErrorMessage(null)}
166
- className="relative m-1 block w-[1px] min-w-0 flex-auto leading-[1.6] bg-transparent bg-clip-padding text-base text-inherit outline-none dark:placeholder:text-neutral-100"
167
- placeholder={passwordPlaceholder}
168
- aria-label={passwordAria}
169
- autoCapitalize="none"
170
- autoCorrect="off"
171
- autoComplete="new-password"
172
- dir="auto"
173
- enterKeyHint="done"
174
- spellCheck="false"
175
- required
176
- pattern={passwordPattern}
177
- title={passwordTitle}
178
- />
179
- </div>
180
- </label>
181
- </Fieldset>
182
- </FormCard>
183
- )
184
- }
185
-
186
- function parseErrorMessage(err: unknown): string {
187
- switch ((err as any)?.message) {
188
- case 'Invalid credentials':
189
- return 'Invalid username or password'
190
- default:
191
- console.error(err)
192
- return 'An unknown error occurred'
193
- }
194
- }
@@ -1,44 +0,0 @@
1
- import { HTMLAttributes } from 'react'
2
- import { LinkDefinition } from '../backend-data'
3
- import { clsx } from '../lib/clsx'
4
-
5
- export type SignUpDisclaimerProps = {
6
- links?: readonly LinkDefinition[]
7
- }
8
-
9
- export function SignUpDisclaimer({
10
- links,
11
-
12
- className,
13
- ...attrs
14
- }: SignUpDisclaimerProps &
15
- Omit<
16
- HTMLAttributes<HTMLParagraphElement>,
17
- keyof SignUpDisclaimerProps | 'children'
18
- >) {
19
- const relevantLinks = links?.filter(
20
- (l) => l.rel === 'privacy-policy' || l.rel === 'terms-of-service',
21
- )
22
-
23
- return (
24
- <p className={clsx('text-sm text-slate-500', className)} {...attrs}>
25
- By creating an account you agree to the{' '}
26
- {relevantLinks && relevantLinks.length
27
- ? relevantLinks.map((l, i, a) => (
28
- <span key={i}>
29
- {i > 0 && (i < a.length - 1 ? ', ' : ' and ')}
30
- <a
31
- href={l.href}
32
- rel={l.rel}
33
- target="_blank"
34
- className="text-brand underline"
35
- >
36
- {l.title}
37
- </a>
38
- </span>
39
- ))
40
- : 'Terms of Service and Privacy Policy'}
41
- .
42
- </p>
43
- )
44
- }
@@ -1,55 +0,0 @@
1
- import { OAuthClientMetadata } from '@atproto/oauth-types'
2
-
3
- import { Account, ScopeDetail } from '../backend-data'
4
- import { AcceptForm } from '../components/accept-form'
5
- import { LayoutTitlePage } from '../components/layout-title-page'
6
-
7
- export type AcceptViewProps = {
8
- clientId: string
9
- clientMetadata: OAuthClientMetadata
10
- clientTrusted: boolean
11
-
12
- account: Account
13
- scopeDetails?: ScopeDetail[]
14
-
15
- onAccept: () => void
16
- onReject: () => void
17
- onBack?: () => void
18
- }
19
-
20
- export function AcceptView({
21
- clientId,
22
- clientMetadata,
23
- clientTrusted,
24
- account,
25
- scopeDetails,
26
- onAccept,
27
- onReject,
28
- onBack,
29
- }: AcceptViewProps) {
30
- return (
31
- <LayoutTitlePage
32
- title="Authorize"
33
- subtitle={
34
- <>
35
- Grant access to your{' '}
36
- <b className="text-black dark:text-white">
37
- {account.preferred_username || account.email || account.sub}
38
- </b>{' '}
39
- account
40
- </>
41
- }
42
- >
43
- <AcceptForm
44
- clientId={clientId}
45
- clientMetadata={clientMetadata}
46
- clientTrusted={clientTrusted}
47
- account={account}
48
- scopeDetails={scopeDetails}
49
- onBack={onBack}
50
- onAccept={onAccept}
51
- onReject={onReject}
52
- />
53
- </LayoutTitlePage>
54
- )
55
- }