@civic/auth 0.3.6-beta.1 → 0.3.7

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 (773) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/README.md +2 -0
  3. package/dist/cjs/browser/storage.d.ts +10 -0
  4. package/dist/cjs/browser/storage.d.ts.map +1 -0
  5. package/dist/cjs/browser/storage.js +24 -0
  6. package/dist/cjs/browser/storage.js.map +1 -0
  7. package/dist/cjs/config.d.ts +3 -0
  8. package/dist/cjs/config.d.ts.map +1 -0
  9. package/dist/cjs/config.js +8 -0
  10. package/dist/cjs/config.js.map +1 -0
  11. package/dist/cjs/constants.d.ts +15 -0
  12. package/dist/cjs/constants.d.ts.map +1 -0
  13. package/dist/cjs/constants.js +44 -0
  14. package/dist/cjs/constants.js.map +1 -0
  15. package/dist/cjs/index.d.ts +8 -0
  16. package/dist/cjs/index.d.ts.map +1 -0
  17. package/dist/cjs/index.js +11 -0
  18. package/dist/cjs/index.js.map +1 -0
  19. package/dist/cjs/lib/cookies.d.ts +7 -0
  20. package/dist/cjs/lib/cookies.d.ts.map +1 -0
  21. package/dist/cjs/lib/cookies.js +29 -0
  22. package/dist/cjs/lib/cookies.js.map +1 -0
  23. package/dist/cjs/lib/jwt.d.ts +3 -0
  24. package/dist/cjs/lib/jwt.d.ts.map +1 -0
  25. package/dist/cjs/lib/jwt.js +13 -0
  26. package/dist/cjs/lib/jwt.js.map +1 -0
  27. package/dist/cjs/lib/logger.d.ts +26 -0
  28. package/dist/cjs/lib/logger.d.ts.map +1 -0
  29. package/dist/cjs/lib/logger.js +62 -0
  30. package/dist/cjs/lib/logger.js.map +1 -0
  31. package/dist/cjs/lib/oauth.d.ts +19 -0
  32. package/dist/cjs/lib/oauth.d.ts.map +1 -0
  33. package/dist/cjs/lib/oauth.js +74 -0
  34. package/dist/cjs/lib/oauth.js.map +1 -0
  35. package/dist/cjs/lib/obj.d.ts +3 -0
  36. package/dist/cjs/lib/obj.d.ts.map +1 -0
  37. package/dist/cjs/lib/obj.js +21 -0
  38. package/dist/cjs/lib/obj.js.map +1 -0
  39. package/dist/cjs/lib/postMessage.d.ts +4 -0
  40. package/dist/cjs/lib/postMessage.d.ts.map +1 -0
  41. package/dist/cjs/lib/postMessage.js +16 -0
  42. package/dist/cjs/lib/postMessage.js.map +1 -0
  43. package/dist/cjs/lib/windowUtil.d.ts +4 -0
  44. package/dist/cjs/lib/windowUtil.d.ts.map +1 -0
  45. package/dist/cjs/lib/windowUtil.js +35 -0
  46. package/dist/cjs/lib/windowUtil.js.map +1 -0
  47. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.d.ts +9 -0
  48. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.d.ts.map +1 -0
  49. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js +26 -0
  50. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js.map +1 -0
  51. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.d.ts +11 -0
  52. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +1 -0
  53. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.js +21 -0
  54. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.js.map +1 -0
  55. package/dist/cjs/nextjs/config.d.ts +209 -0
  56. package/dist/cjs/nextjs/config.d.ts.map +1 -0
  57. package/dist/cjs/nextjs/config.js +191 -0
  58. package/dist/cjs/nextjs/config.js.map +1 -0
  59. package/dist/cjs/nextjs/cookies.d.ts +16 -0
  60. package/dist/cjs/nextjs/cookies.d.ts.map +1 -0
  61. package/dist/cjs/nextjs/cookies.js +44 -0
  62. package/dist/cjs/nextjs/cookies.js.map +1 -0
  63. package/dist/cjs/nextjs/hooks/index.d.ts +2 -0
  64. package/dist/cjs/nextjs/hooks/index.d.ts.map +1 -0
  65. package/dist/cjs/nextjs/hooks/index.js +6 -0
  66. package/dist/cjs/nextjs/hooks/index.js.map +1 -0
  67. package/dist/cjs/nextjs/hooks/usePrevious.d.ts +2 -0
  68. package/dist/cjs/nextjs/hooks/usePrevious.d.ts.map +1 -0
  69. package/dist/cjs/nextjs/hooks/usePrevious.js +12 -0
  70. package/dist/cjs/nextjs/hooks/usePrevious.js.map +1 -0
  71. package/dist/cjs/nextjs/hooks/useRefresh.d.ts +4 -0
  72. package/dist/cjs/nextjs/hooks/useRefresh.d.ts.map +1 -0
  73. package/dist/cjs/nextjs/hooks/useRefresh.js +43 -0
  74. package/dist/cjs/nextjs/hooks/useRefresh.js.map +1 -0
  75. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts +8 -0
  76. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  77. package/dist/cjs/nextjs/hooks/useUserCookie.js +93 -0
  78. package/dist/cjs/nextjs/hooks/useUserCookie.js.map +1 -0
  79. package/dist/cjs/nextjs/index.d.ts +9 -0
  80. package/dist/cjs/nextjs/index.d.ts.map +1 -0
  81. package/dist/cjs/nextjs/index.js +27 -0
  82. package/dist/cjs/nextjs/index.js.map +1 -0
  83. package/dist/cjs/nextjs/middleware/index.d.ts +2 -0
  84. package/dist/cjs/nextjs/middleware/index.d.ts.map +1 -0
  85. package/dist/cjs/nextjs/middleware/index.js +10 -0
  86. package/dist/cjs/nextjs/middleware/index.js.map +1 -0
  87. package/dist/cjs/nextjs/middleware.d.ts +57 -0
  88. package/dist/cjs/nextjs/middleware.d.ts.map +1 -0
  89. package/dist/cjs/nextjs/middleware.js +110 -0
  90. package/dist/cjs/nextjs/middleware.js.map +1 -0
  91. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +9 -0
  92. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  93. package/dist/cjs/nextjs/providers/NextAuthProvider.js +102 -0
  94. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -0
  95. package/dist/cjs/nextjs/routeHandler.d.ts +19 -0
  96. package/dist/cjs/nextjs/routeHandler.d.ts.map +1 -0
  97. package/dist/cjs/nextjs/routeHandler.js +318 -0
  98. package/dist/cjs/nextjs/routeHandler.js.map +1 -0
  99. package/dist/cjs/nextjs/utils.d.ts +3 -0
  100. package/dist/cjs/nextjs/utils.d.ts.map +1 -0
  101. package/dist/cjs/nextjs/utils.js +9 -0
  102. package/dist/cjs/nextjs/utils.js.map +1 -0
  103. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts +17 -0
  104. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -0
  105. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js +40 -0
  106. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js.map +1 -0
  107. package/dist/cjs/reactjs/components/SignInButton.d.ts +9 -0
  108. package/dist/cjs/reactjs/components/SignInButton.d.ts.map +1 -0
  109. package/dist/cjs/reactjs/components/SignInButton.js +31 -0
  110. package/dist/cjs/reactjs/components/SignInButton.js.map +1 -0
  111. package/dist/cjs/reactjs/components/SignOutButton.d.ts +7 -0
  112. package/dist/cjs/reactjs/components/SignOutButton.d.ts.map +1 -0
  113. package/dist/cjs/reactjs/components/SignOutButton.js +27 -0
  114. package/dist/cjs/reactjs/components/SignOutButton.js.map +1 -0
  115. package/dist/cjs/reactjs/components/UserButton.d.ts +9 -0
  116. package/dist/cjs/reactjs/components/UserButton.d.ts.map +1 -0
  117. package/dist/cjs/reactjs/components/UserButton.js +145 -0
  118. package/dist/cjs/reactjs/components/UserButton.js.map +1 -0
  119. package/dist/cjs/reactjs/components/index.d.ts +6 -0
  120. package/dist/cjs/reactjs/components/index.d.ts.map +1 -0
  121. package/dist/cjs/reactjs/components/index.js +14 -0
  122. package/dist/cjs/reactjs/components/index.js.map +1 -0
  123. package/dist/cjs/reactjs/components/utils.d.ts +13 -0
  124. package/dist/cjs/reactjs/components/utils.d.ts.map +1 -0
  125. package/dist/cjs/reactjs/components/utils.js +31 -0
  126. package/dist/cjs/reactjs/components/utils.js.map +1 -0
  127. package/dist/cjs/reactjs/hooks/index.d.ts +3 -0
  128. package/dist/cjs/reactjs/hooks/index.d.ts.map +1 -0
  129. package/dist/cjs/reactjs/hooks/index.js +8 -0
  130. package/dist/cjs/reactjs/hooks/index.js.map +1 -0
  131. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  132. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  133. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js +16 -0
  134. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  135. package/dist/cjs/reactjs/hooks/useUser.d.ts +4 -0
  136. package/dist/cjs/reactjs/hooks/useUser.d.ts.map +1 -0
  137. package/dist/cjs/reactjs/hooks/useUser.js +15 -0
  138. package/dist/cjs/reactjs/hooks/useUser.js.map +1 -0
  139. package/dist/cjs/reactjs/index.d.ts +6 -0
  140. package/dist/cjs/reactjs/index.d.ts.map +1 -0
  141. package/dist/cjs/reactjs/index.js +32 -0
  142. package/dist/cjs/reactjs/index.js.map +1 -0
  143. package/dist/cjs/reactjs/providers/AuthProvider.d.ts +10 -0
  144. package/dist/cjs/reactjs/providers/AuthProvider.d.ts.map +1 -0
  145. package/dist/cjs/reactjs/providers/AuthProvider.js +91 -0
  146. package/dist/cjs/reactjs/providers/AuthProvider.js.map +1 -0
  147. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts +5 -0
  148. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  149. package/dist/cjs/reactjs/providers/CivicAuthProvider.js +29 -0
  150. package/dist/cjs/reactjs/providers/CivicAuthProvider.js.map +1 -0
  151. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  152. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  153. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js +147 -0
  154. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  155. package/dist/cjs/reactjs/providers/index.d.ts +8 -0
  156. package/dist/cjs/reactjs/providers/index.d.ts.map +1 -0
  157. package/dist/cjs/reactjs/providers/index.js +19 -0
  158. package/dist/cjs/reactjs/providers/index.js.map +1 -0
  159. package/dist/cjs/server/ServerAuthenticationResolver.d.ts +20 -0
  160. package/dist/cjs/server/ServerAuthenticationResolver.d.ts.map +1 -0
  161. package/dist/cjs/server/ServerAuthenticationResolver.js +71 -0
  162. package/dist/cjs/server/ServerAuthenticationResolver.js.map +1 -0
  163. package/dist/cjs/server/config.d.ts +11 -0
  164. package/dist/cjs/server/config.d.ts.map +1 -0
  165. package/dist/cjs/server/config.js +3 -0
  166. package/dist/cjs/server/config.js.map +1 -0
  167. package/dist/cjs/server/index.d.ts +9 -0
  168. package/dist/cjs/server/index.d.ts.map +1 -0
  169. package/dist/cjs/server/index.js +21 -0
  170. package/dist/cjs/server/index.js.map +1 -0
  171. package/dist/cjs/server/login.d.ts +17 -0
  172. package/dist/cjs/server/login.d.ts.map +1 -0
  173. package/dist/cjs/server/login.js +42 -0
  174. package/dist/cjs/server/login.js.map +1 -0
  175. package/dist/cjs/server/logout.d.ts +7 -0
  176. package/dist/cjs/server/logout.d.ts.map +1 -0
  177. package/dist/cjs/server/logout.js +26 -0
  178. package/dist/cjs/server/logout.js.map +1 -0
  179. package/dist/cjs/server/refresh.d.ts +7 -0
  180. package/dist/cjs/server/refresh.d.ts.map +1 -0
  181. package/dist/cjs/server/refresh.js +16 -0
  182. package/dist/cjs/server/refresh.js.map +1 -0
  183. package/dist/cjs/services/AuthenticationService.d.ts +93 -0
  184. package/dist/cjs/services/AuthenticationService.d.ts.map +1 -0
  185. package/dist/cjs/services/AuthenticationService.js +372 -0
  186. package/dist/cjs/services/AuthenticationService.js.map +1 -0
  187. package/dist/cjs/services/PKCE.d.ts +20 -0
  188. package/dist/cjs/services/PKCE.d.ts.map +1 -0
  189. package/dist/cjs/services/PKCE.js +50 -0
  190. package/dist/cjs/services/PKCE.js.map +1 -0
  191. package/dist/cjs/services/types.d.ts +24 -0
  192. package/dist/cjs/services/types.d.ts.map +1 -0
  193. package/dist/cjs/services/types.js +11 -0
  194. package/dist/cjs/services/types.js.map +1 -0
  195. package/dist/cjs/shared/components/BlockDisplay.d.ts +6 -0
  196. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +1 -0
  197. package/dist/cjs/shared/components/BlockDisplay.js +32 -0
  198. package/dist/cjs/shared/components/BlockDisplay.js.map +1 -0
  199. package/dist/cjs/shared/components/CivicAuthIframe.d.ts +9 -0
  200. package/dist/cjs/shared/components/CivicAuthIframe.d.ts.map +1 -0
  201. package/dist/cjs/shared/components/CivicAuthIframe.js +66 -0
  202. package/dist/cjs/shared/components/CivicAuthIframe.js.map +1 -0
  203. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts +14 -0
  204. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  205. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +158 -0
  206. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +1 -0
  207. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts +6 -0
  208. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  209. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js +21 -0
  210. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  211. package/dist/cjs/shared/components/CloseIcon.d.ts +3 -0
  212. package/dist/cjs/shared/components/CloseIcon.d.ts.map +1 -0
  213. package/dist/cjs/shared/components/CloseIcon.js +7 -0
  214. package/dist/cjs/shared/components/CloseIcon.js.map +1 -0
  215. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +7 -0
  216. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -0
  217. package/dist/cjs/shared/components/IFrameAndLoading.js +39 -0
  218. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -0
  219. package/dist/cjs/shared/components/LoadingIcon.d.ts +6 -0
  220. package/dist/cjs/shared/components/LoadingIcon.d.ts.map +1 -0
  221. package/dist/cjs/shared/components/LoadingIcon.js +28 -0
  222. package/dist/cjs/shared/components/LoadingIcon.js.map +1 -0
  223. package/dist/cjs/shared/components/SVGLoading.d.ts +4 -0
  224. package/dist/cjs/shared/components/SVGLoading.d.ts.map +1 -0
  225. package/dist/cjs/shared/components/SVGLoading.js +30 -0
  226. package/dist/cjs/shared/components/SVGLoading.js.map +1 -0
  227. package/dist/cjs/shared/hooks/index.d.ts +11 -0
  228. package/dist/cjs/shared/hooks/index.d.ts.map +1 -0
  229. package/dist/cjs/shared/hooks/index.js +24 -0
  230. package/dist/cjs/shared/hooks/index.js.map +1 -0
  231. package/dist/cjs/shared/hooks/useAuth.d.ts +3 -0
  232. package/dist/cjs/shared/hooks/useAuth.d.ts.map +1 -0
  233. package/dist/cjs/shared/hooks/useAuth.js +15 -0
  234. package/dist/cjs/shared/hooks/useAuth.js.map +1 -0
  235. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  236. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  237. package/dist/cjs/shared/hooks/useCivicAuthConfig.js +13 -0
  238. package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +1 -0
  239. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts +3 -0
  240. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  241. package/dist/cjs/shared/hooks/useCurrentUrl.js +27 -0
  242. package/dist/cjs/shared/hooks/useCurrentUrl.js.map +1 -0
  243. package/dist/cjs/shared/hooks/useIframe.d.ts +3 -0
  244. package/dist/cjs/shared/hooks/useIframe.d.ts.map +1 -0
  245. package/dist/cjs/shared/hooks/useIframe.js +16 -0
  246. package/dist/cjs/shared/hooks/useIframe.js.map +1 -0
  247. package/dist/cjs/shared/hooks/useIsInIframe.d.ts +3 -0
  248. package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +1 -0
  249. package/dist/cjs/shared/hooks/useIsInIframe.js +17 -0
  250. package/dist/cjs/shared/hooks/useIsInIframe.js.map +1 -0
  251. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  252. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  253. package/dist/cjs/shared/hooks/useOAuthEndpoints.js +17 -0
  254. package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +1 -0
  255. package/dist/cjs/shared/hooks/useRefresh.d.ts +4 -0
  256. package/dist/cjs/shared/hooks/useRefresh.d.ts.map +1 -0
  257. package/dist/cjs/shared/hooks/useRefresh.js +41 -0
  258. package/dist/cjs/shared/hooks/useRefresh.js.map +1 -0
  259. package/dist/cjs/shared/hooks/useSession.d.ts +3 -0
  260. package/dist/cjs/shared/hooks/useSession.d.ts.map +1 -0
  261. package/dist/cjs/shared/hooks/useSession.js +16 -0
  262. package/dist/cjs/shared/hooks/useSession.js.map +1 -0
  263. package/dist/cjs/shared/hooks/useSignIn.d.ts +17 -0
  264. package/dist/cjs/shared/hooks/useSignIn.d.ts.map +1 -0
  265. package/dist/cjs/shared/hooks/useSignIn.js +171 -0
  266. package/dist/cjs/shared/hooks/useSignIn.js.map +1 -0
  267. package/dist/cjs/shared/hooks/useToken.d.ts +3 -0
  268. package/dist/cjs/shared/hooks/useToken.d.ts.map +1 -0
  269. package/dist/cjs/shared/hooks/useToken.js +15 -0
  270. package/dist/cjs/shared/hooks/useToken.js.map +1 -0
  271. package/dist/cjs/shared/hooks/useWindowFocused.d.ts +5 -0
  272. package/dist/cjs/shared/hooks/useWindowFocused.d.ts.map +1 -0
  273. package/dist/cjs/shared/hooks/useWindowFocused.js +24 -0
  274. package/dist/cjs/shared/hooks/useWindowFocused.js.map +1 -0
  275. package/dist/cjs/shared/index.d.ts +7 -0
  276. package/dist/cjs/shared/index.d.ts.map +1 -0
  277. package/dist/cjs/shared/index.js +25 -0
  278. package/dist/cjs/shared/index.js.map +1 -0
  279. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts +14 -0
  280. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -0
  281. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js +52 -0
  282. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js.map +1 -0
  283. package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts +9 -0
  284. package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts.map +1 -0
  285. package/dist/cjs/shared/lib/BrowserCookieStorage.js +60 -0
  286. package/dist/cjs/shared/lib/BrowserCookieStorage.js.map +1 -0
  287. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts +16 -0
  288. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  289. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +65 -0
  290. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  291. package/dist/cjs/shared/lib/UserSession.d.ts +17 -0
  292. package/dist/cjs/shared/lib/UserSession.d.ts.map +1 -0
  293. package/dist/cjs/shared/lib/UserSession.js +27 -0
  294. package/dist/cjs/shared/lib/UserSession.js.map +1 -0
  295. package/dist/cjs/shared/lib/iframeUtils.d.ts +6 -0
  296. package/dist/cjs/shared/lib/iframeUtils.d.ts.map +1 -0
  297. package/dist/cjs/shared/lib/iframeUtils.js +11 -0
  298. package/dist/cjs/shared/lib/iframeUtils.js.map +1 -0
  299. package/dist/cjs/shared/lib/session.d.ts +4 -0
  300. package/dist/cjs/shared/lib/session.d.ts.map +1 -0
  301. package/dist/cjs/shared/lib/session.js +48 -0
  302. package/dist/cjs/shared/lib/session.js.map +1 -0
  303. package/dist/cjs/shared/lib/storage.d.ts +35 -0
  304. package/dist/cjs/shared/lib/storage.d.ts.map +1 -0
  305. package/dist/cjs/shared/lib/storage.js +21 -0
  306. package/dist/cjs/shared/lib/storage.js.map +1 -0
  307. package/dist/cjs/shared/lib/types.d.ts +39 -0
  308. package/dist/cjs/shared/lib/types.d.ts.map +1 -0
  309. package/dist/cjs/shared/lib/types.js +22 -0
  310. package/dist/cjs/shared/lib/types.js.map +1 -0
  311. package/dist/cjs/shared/lib/util.d.ts +40 -0
  312. package/dist/cjs/shared/lib/util.d.ts.map +1 -0
  313. package/dist/cjs/shared/lib/util.js +239 -0
  314. package/dist/cjs/shared/lib/util.js.map +1 -0
  315. package/dist/cjs/shared/providers/AuthContext.d.ts +12 -0
  316. package/dist/cjs/shared/providers/AuthContext.d.ts.map +1 -0
  317. package/dist/cjs/shared/providers/AuthContext.js +7 -0
  318. package/dist/cjs/shared/providers/AuthContext.js.map +1 -0
  319. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +19 -0
  320. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  321. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +59 -0
  322. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +1 -0
  323. package/dist/cjs/shared/providers/IframeProvider.d.ts +25 -0
  324. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +1 -0
  325. package/dist/cjs/shared/providers/IframeProvider.js +63 -0
  326. package/dist/cjs/shared/providers/IframeProvider.js.map +1 -0
  327. package/dist/cjs/shared/providers/SessionProvider.d.ts +19 -0
  328. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +1 -0
  329. package/dist/cjs/shared/providers/SessionProvider.js +28 -0
  330. package/dist/cjs/shared/providers/SessionProvider.js.map +1 -0
  331. package/dist/cjs/shared/providers/TokenProvider.d.ts +17 -0
  332. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -0
  333. package/dist/cjs/shared/providers/TokenProvider.js +39 -0
  334. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -0
  335. package/dist/cjs/shared/providers/UserProvider.d.ts +26 -0
  336. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -0
  337. package/dist/cjs/shared/providers/UserProvider.js +69 -0
  338. package/dist/cjs/shared/providers/UserProvider.js.map +1 -0
  339. package/dist/cjs/shared/providers/types.d.ts +15 -0
  340. package/dist/cjs/shared/providers/types.d.ts.map +1 -0
  341. package/dist/cjs/shared/providers/types.js +3 -0
  342. package/dist/cjs/shared/providers/types.js.map +1 -0
  343. package/dist/cjs/shared/version.d.ts +2 -0
  344. package/dist/cjs/shared/version.d.ts.map +1 -0
  345. package/dist/cjs/shared/version.js +6 -0
  346. package/dist/cjs/shared/version.js.map +1 -0
  347. package/dist/cjs/types.d.ts +163 -0
  348. package/dist/cjs/types.d.ts.map +1 -0
  349. package/dist/cjs/types.js +20 -0
  350. package/dist/cjs/types.js.map +1 -0
  351. package/dist/cjs/utils.d.ts +15 -0
  352. package/dist/cjs/utils.d.ts.map +1 -0
  353. package/dist/cjs/utils.js +47 -0
  354. package/dist/cjs/utils.js.map +1 -0
  355. package/dist/cjs/version.d.ts +2 -0
  356. package/dist/cjs/version.d.ts.map +1 -0
  357. package/dist/cjs/version.js +6 -0
  358. package/dist/cjs/version.js.map +1 -0
  359. package/dist/esm/browser/storage.d.ts +10 -0
  360. package/dist/esm/browser/storage.d.ts.map +1 -0
  361. package/dist/esm/browser/storage.js +20 -0
  362. package/dist/esm/browser/storage.js.map +1 -0
  363. package/dist/esm/config.d.ts +3 -0
  364. package/dist/esm/config.d.ts.map +1 -0
  365. package/dist/esm/config.js +5 -0
  366. package/dist/esm/config.js.map +1 -0
  367. package/dist/esm/constants.d.ts +15 -0
  368. package/dist/esm/constants.d.ts.map +1 -0
  369. package/dist/esm/constants.js +29 -0
  370. package/dist/esm/constants.js.map +1 -0
  371. package/dist/esm/index.d.ts +8 -0
  372. package/dist/esm/index.d.ts.map +1 -0
  373. package/dist/esm/index.js +6 -0
  374. package/dist/esm/index.js.map +1 -0
  375. package/dist/esm/lib/cookies.d.ts +7 -0
  376. package/dist/esm/lib/cookies.d.ts.map +1 -0
  377. package/dist/esm/lib/cookies.js +26 -0
  378. package/dist/esm/lib/cookies.js.map +1 -0
  379. package/dist/esm/lib/jwt.d.ts +3 -0
  380. package/dist/esm/lib/jwt.d.ts.map +1 -0
  381. package/dist/esm/lib/jwt.js +9 -0
  382. package/dist/esm/lib/jwt.js.map +1 -0
  383. package/dist/esm/lib/logger.d.ts +26 -0
  384. package/dist/esm/lib/logger.d.ts.map +1 -0
  385. package/dist/esm/lib/logger.js +55 -0
  386. package/dist/esm/lib/logger.js.map +1 -0
  387. package/dist/esm/lib/oauth.d.ts +19 -0
  388. package/dist/esm/lib/oauth.d.ts.map +1 -0
  389. package/dist/esm/lib/oauth.js +67 -0
  390. package/dist/esm/lib/oauth.js.map +1 -0
  391. package/dist/esm/lib/obj.d.ts +3 -0
  392. package/dist/esm/lib/obj.d.ts.map +1 -0
  393. package/dist/esm/lib/obj.js +18 -0
  394. package/dist/esm/lib/obj.js.map +1 -0
  395. package/dist/esm/lib/postMessage.d.ts +4 -0
  396. package/dist/esm/lib/postMessage.d.ts.map +1 -0
  397. package/dist/esm/lib/postMessage.js +13 -0
  398. package/dist/esm/lib/postMessage.js.map +1 -0
  399. package/dist/esm/lib/windowUtil.d.ts +4 -0
  400. package/dist/esm/lib/windowUtil.d.ts.map +1 -0
  401. package/dist/esm/lib/windowUtil.js +31 -0
  402. package/dist/esm/lib/windowUtil.js.map +1 -0
  403. package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts +9 -0
  404. package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts.map +1 -0
  405. package/dist/esm/nextjs/NextClientAuthenticationRefresher.js +22 -0
  406. package/dist/esm/nextjs/NextClientAuthenticationRefresher.js.map +1 -0
  407. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.d.ts +11 -0
  408. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +1 -0
  409. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.js +17 -0
  410. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.js.map +1 -0
  411. package/dist/esm/nextjs/config.d.ts +209 -0
  412. package/dist/esm/nextjs/config.d.ts.map +1 -0
  413. package/dist/esm/nextjs/config.js +186 -0
  414. package/dist/esm/nextjs/config.js.map +1 -0
  415. package/dist/esm/nextjs/cookies.d.ts +16 -0
  416. package/dist/esm/nextjs/cookies.d.ts.map +1 -0
  417. package/dist/esm/nextjs/cookies.js +41 -0
  418. package/dist/esm/nextjs/cookies.js.map +1 -0
  419. package/dist/esm/nextjs/hooks/index.d.ts +2 -0
  420. package/dist/esm/nextjs/hooks/index.d.ts.map +1 -0
  421. package/dist/esm/nextjs/hooks/index.js +2 -0
  422. package/dist/esm/nextjs/hooks/index.js.map +1 -0
  423. package/dist/esm/nextjs/hooks/usePrevious.d.ts +2 -0
  424. package/dist/esm/nextjs/hooks/usePrevious.d.ts.map +1 -0
  425. package/dist/esm/nextjs/hooks/usePrevious.js +9 -0
  426. package/dist/esm/nextjs/hooks/usePrevious.js.map +1 -0
  427. package/dist/esm/nextjs/hooks/useRefresh.d.ts +4 -0
  428. package/dist/esm/nextjs/hooks/useRefresh.d.ts.map +1 -0
  429. package/dist/esm/nextjs/hooks/useRefresh.js +40 -0
  430. package/dist/esm/nextjs/hooks/useRefresh.js.map +1 -0
  431. package/dist/esm/nextjs/hooks/useUserCookie.d.ts +8 -0
  432. package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  433. package/dist/esm/nextjs/hooks/useUserCookie.js +89 -0
  434. package/dist/esm/nextjs/hooks/useUserCookie.js.map +1 -0
  435. package/dist/esm/nextjs/index.d.ts +9 -0
  436. package/dist/esm/nextjs/index.d.ts.map +1 -0
  437. package/dist/esm/nextjs/index.js +17 -0
  438. package/dist/esm/nextjs/index.js.map +1 -0
  439. package/dist/esm/nextjs/middleware/index.d.ts +2 -0
  440. package/dist/esm/nextjs/middleware/index.d.ts.map +1 -0
  441. package/dist/esm/nextjs/middleware/index.js +4 -0
  442. package/dist/esm/nextjs/middleware/index.js.map +1 -0
  443. package/dist/esm/nextjs/middleware.d.ts +57 -0
  444. package/dist/esm/nextjs/middleware.d.ts.map +1 -0
  445. package/dist/esm/nextjs/middleware.js +101 -0
  446. package/dist/esm/nextjs/middleware.js.map +1 -0
  447. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +9 -0
  448. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  449. package/dist/esm/nextjs/providers/NextAuthProvider.js +99 -0
  450. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -0
  451. package/dist/esm/nextjs/routeHandler.d.ts +19 -0
  452. package/dist/esm/nextjs/routeHandler.d.ts.map +1 -0
  453. package/dist/esm/nextjs/routeHandler.js +312 -0
  454. package/dist/esm/nextjs/routeHandler.js.map +1 -0
  455. package/dist/esm/nextjs/utils.d.ts +3 -0
  456. package/dist/esm/nextjs/utils.d.ts.map +1 -0
  457. package/dist/esm/nextjs/utils.js +5 -0
  458. package/dist/esm/nextjs/utils.js.map +1 -0
  459. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts +17 -0
  460. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -0
  461. package/dist/esm/reactjs/components/ButtonContentOrLoader.js +37 -0
  462. package/dist/esm/reactjs/components/ButtonContentOrLoader.js.map +1 -0
  463. package/dist/esm/reactjs/components/SignInButton.d.ts +9 -0
  464. package/dist/esm/reactjs/components/SignInButton.d.ts.map +1 -0
  465. package/dist/esm/reactjs/components/SignInButton.js +28 -0
  466. package/dist/esm/reactjs/components/SignInButton.js.map +1 -0
  467. package/dist/esm/reactjs/components/SignOutButton.d.ts +7 -0
  468. package/dist/esm/reactjs/components/SignOutButton.d.ts.map +1 -0
  469. package/dist/esm/reactjs/components/SignOutButton.js +24 -0
  470. package/dist/esm/reactjs/components/SignOutButton.js.map +1 -0
  471. package/dist/esm/reactjs/components/UserButton.d.ts +9 -0
  472. package/dist/esm/reactjs/components/UserButton.d.ts.map +1 -0
  473. package/dist/esm/reactjs/components/UserButton.js +142 -0
  474. package/dist/esm/reactjs/components/UserButton.js.map +1 -0
  475. package/dist/esm/reactjs/components/index.d.ts +6 -0
  476. package/dist/esm/reactjs/components/index.d.ts.map +1 -0
  477. package/dist/esm/reactjs/components/index.js +6 -0
  478. package/dist/esm/reactjs/components/index.js.map +1 -0
  479. package/dist/esm/reactjs/components/utils.d.ts +13 -0
  480. package/dist/esm/reactjs/components/utils.d.ts.map +1 -0
  481. package/dist/esm/reactjs/components/utils.js +27 -0
  482. package/dist/esm/reactjs/components/utils.js.map +1 -0
  483. package/dist/esm/reactjs/hooks/index.d.ts +3 -0
  484. package/dist/esm/reactjs/hooks/index.d.ts.map +1 -0
  485. package/dist/esm/reactjs/hooks/index.js +3 -0
  486. package/dist/esm/reactjs/hooks/index.js.map +1 -0
  487. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  488. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  489. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js +13 -0
  490. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  491. package/dist/esm/reactjs/hooks/useUser.d.ts +4 -0
  492. package/dist/esm/reactjs/hooks/useUser.d.ts.map +1 -0
  493. package/dist/esm/reactjs/hooks/useUser.js +12 -0
  494. package/dist/esm/reactjs/hooks/useUser.js.map +1 -0
  495. package/dist/esm/reactjs/index.d.ts +6 -0
  496. package/dist/esm/reactjs/index.d.ts.map +1 -0
  497. package/dist/esm/reactjs/index.js +10 -0
  498. package/dist/esm/reactjs/index.js.map +1 -0
  499. package/dist/esm/reactjs/providers/AuthProvider.d.ts +10 -0
  500. package/dist/esm/reactjs/providers/AuthProvider.d.ts.map +1 -0
  501. package/dist/esm/reactjs/providers/AuthProvider.js +89 -0
  502. package/dist/esm/reactjs/providers/AuthProvider.js.map +1 -0
  503. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts +5 -0
  504. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  505. package/dist/esm/reactjs/providers/CivicAuthProvider.js +27 -0
  506. package/dist/esm/reactjs/providers/CivicAuthProvider.js.map +1 -0
  507. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  508. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  509. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js +143 -0
  510. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  511. package/dist/esm/reactjs/providers/index.d.ts +8 -0
  512. package/dist/esm/reactjs/providers/index.d.ts.map +1 -0
  513. package/dist/esm/reactjs/providers/index.js +7 -0
  514. package/dist/esm/reactjs/providers/index.js.map +1 -0
  515. package/dist/esm/server/ServerAuthenticationResolver.d.ts +20 -0
  516. package/dist/esm/server/ServerAuthenticationResolver.d.ts.map +1 -0
  517. package/dist/esm/server/ServerAuthenticationResolver.js +67 -0
  518. package/dist/esm/server/ServerAuthenticationResolver.js.map +1 -0
  519. package/dist/esm/server/config.d.ts +11 -0
  520. package/dist/esm/server/config.d.ts.map +1 -0
  521. package/dist/esm/server/config.js +2 -0
  522. package/dist/esm/server/config.js.map +1 -0
  523. package/dist/esm/server/index.d.ts +9 -0
  524. package/dist/esm/server/index.d.ts.map +1 -0
  525. package/dist/esm/server/index.js +9 -0
  526. package/dist/esm/server/index.js.map +1 -0
  527. package/dist/esm/server/login.d.ts +17 -0
  528. package/dist/esm/server/login.d.ts.map +1 -0
  529. package/dist/esm/server/login.js +37 -0
  530. package/dist/esm/server/login.js.map +1 -0
  531. package/dist/esm/server/logout.d.ts +7 -0
  532. package/dist/esm/server/logout.d.ts.map +1 -0
  533. package/dist/esm/server/logout.js +23 -0
  534. package/dist/esm/server/logout.js.map +1 -0
  535. package/dist/esm/server/refresh.d.ts +7 -0
  536. package/dist/esm/server/refresh.d.ts.map +1 -0
  537. package/dist/esm/server/refresh.js +13 -0
  538. package/dist/esm/server/refresh.js.map +1 -0
  539. package/dist/esm/services/AuthenticationService.d.ts +93 -0
  540. package/dist/esm/services/AuthenticationService.d.ts.map +1 -0
  541. package/dist/esm/services/AuthenticationService.js +366 -0
  542. package/dist/esm/services/AuthenticationService.js.map +1 -0
  543. package/dist/esm/services/PKCE.d.ts +20 -0
  544. package/dist/esm/services/PKCE.d.ts.map +1 -0
  545. package/dist/esm/services/PKCE.js +44 -0
  546. package/dist/esm/services/PKCE.js.map +1 -0
  547. package/dist/esm/services/types.d.ts +24 -0
  548. package/dist/esm/services/types.d.ts.map +1 -0
  549. package/dist/esm/services/types.js +7 -0
  550. package/dist/esm/services/types.js.map +1 -0
  551. package/dist/esm/shared/components/BlockDisplay.d.ts +6 -0
  552. package/dist/esm/shared/components/BlockDisplay.d.ts.map +1 -0
  553. package/dist/esm/shared/components/BlockDisplay.js +29 -0
  554. package/dist/esm/shared/components/BlockDisplay.js.map +1 -0
  555. package/dist/esm/shared/components/CivicAuthIframe.d.ts +9 -0
  556. package/dist/esm/shared/components/CivicAuthIframe.d.ts.map +1 -0
  557. package/dist/esm/shared/components/CivicAuthIframe.js +27 -0
  558. package/dist/esm/shared/components/CivicAuthIframe.js.map +1 -0
  559. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts +14 -0
  560. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  561. package/dist/esm/shared/components/CivicAuthIframeContainer.js +154 -0
  562. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +1 -0
  563. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts +6 -0
  564. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  565. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js +19 -0
  566. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  567. package/dist/esm/shared/components/CloseIcon.d.ts +3 -0
  568. package/dist/esm/shared/components/CloseIcon.d.ts.map +1 -0
  569. package/dist/esm/shared/components/CloseIcon.js +5 -0
  570. package/dist/esm/shared/components/CloseIcon.js.map +1 -0
  571. package/dist/esm/shared/components/IFrameAndLoading.d.ts +7 -0
  572. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -0
  573. package/dist/esm/shared/components/IFrameAndLoading.js +36 -0
  574. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -0
  575. package/dist/esm/shared/components/LoadingIcon.d.ts +6 -0
  576. package/dist/esm/shared/components/LoadingIcon.d.ts.map +1 -0
  577. package/dist/esm/shared/components/LoadingIcon.js +26 -0
  578. package/dist/esm/shared/components/LoadingIcon.js.map +1 -0
  579. package/dist/esm/shared/components/SVGLoading.d.ts +4 -0
  580. package/dist/esm/shared/components/SVGLoading.d.ts.map +1 -0
  581. package/dist/esm/shared/components/SVGLoading.js +28 -0
  582. package/dist/esm/shared/components/SVGLoading.js.map +1 -0
  583. package/dist/esm/shared/hooks/index.d.ts +11 -0
  584. package/dist/esm/shared/hooks/index.d.ts.map +1 -0
  585. package/dist/esm/shared/hooks/index.js +11 -0
  586. package/dist/esm/shared/hooks/index.js.map +1 -0
  587. package/dist/esm/shared/hooks/useAuth.d.ts +3 -0
  588. package/dist/esm/shared/hooks/useAuth.d.ts.map +1 -0
  589. package/dist/esm/shared/hooks/useAuth.js +12 -0
  590. package/dist/esm/shared/hooks/useAuth.js.map +1 -0
  591. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  592. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  593. package/dist/esm/shared/hooks/useCivicAuthConfig.js +10 -0
  594. package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +1 -0
  595. package/dist/esm/shared/hooks/useCurrentUrl.d.ts +3 -0
  596. package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  597. package/dist/esm/shared/hooks/useCurrentUrl.js +24 -0
  598. package/dist/esm/shared/hooks/useCurrentUrl.js.map +1 -0
  599. package/dist/esm/shared/hooks/useIframe.d.ts +3 -0
  600. package/dist/esm/shared/hooks/useIframe.d.ts.map +1 -0
  601. package/dist/esm/shared/hooks/useIframe.js +13 -0
  602. package/dist/esm/shared/hooks/useIframe.js.map +1 -0
  603. package/dist/esm/shared/hooks/useIsInIframe.d.ts +3 -0
  604. package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +1 -0
  605. package/dist/esm/shared/hooks/useIsInIframe.js +14 -0
  606. package/dist/esm/shared/hooks/useIsInIframe.js.map +1 -0
  607. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  608. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  609. package/dist/esm/shared/hooks/useOAuthEndpoints.js +14 -0
  610. package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +1 -0
  611. package/dist/esm/shared/hooks/useRefresh.d.ts +4 -0
  612. package/dist/esm/shared/hooks/useRefresh.d.ts.map +1 -0
  613. package/dist/esm/shared/hooks/useRefresh.js +38 -0
  614. package/dist/esm/shared/hooks/useRefresh.js.map +1 -0
  615. package/dist/esm/shared/hooks/useSession.d.ts +3 -0
  616. package/dist/esm/shared/hooks/useSession.d.ts.map +1 -0
  617. package/dist/esm/shared/hooks/useSession.js +13 -0
  618. package/dist/esm/shared/hooks/useSession.js.map +1 -0
  619. package/dist/esm/shared/hooks/useSignIn.d.ts +17 -0
  620. package/dist/esm/shared/hooks/useSignIn.d.ts.map +1 -0
  621. package/dist/esm/shared/hooks/useSignIn.js +168 -0
  622. package/dist/esm/shared/hooks/useSignIn.js.map +1 -0
  623. package/dist/esm/shared/hooks/useToken.d.ts +3 -0
  624. package/dist/esm/shared/hooks/useToken.d.ts.map +1 -0
  625. package/dist/esm/shared/hooks/useToken.js +12 -0
  626. package/dist/esm/shared/hooks/useToken.js.map +1 -0
  627. package/dist/esm/shared/hooks/useWindowFocused.d.ts +5 -0
  628. package/dist/esm/shared/hooks/useWindowFocused.d.ts.map +1 -0
  629. package/dist/esm/shared/hooks/useWindowFocused.js +21 -0
  630. package/dist/esm/shared/hooks/useWindowFocused.js.map +1 -0
  631. package/dist/esm/shared/index.d.ts +7 -0
  632. package/dist/esm/shared/index.d.ts.map +1 -0
  633. package/dist/esm/shared/index.js +18 -0
  634. package/dist/esm/shared/index.js.map +1 -0
  635. package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts +14 -0
  636. package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -0
  637. package/dist/esm/shared/lib/AuthenticationRefresherImpl.js +48 -0
  638. package/dist/esm/shared/lib/AuthenticationRefresherImpl.js.map +1 -0
  639. package/dist/esm/shared/lib/BrowserCookieStorage.d.ts +9 -0
  640. package/dist/esm/shared/lib/BrowserCookieStorage.d.ts.map +1 -0
  641. package/dist/esm/shared/lib/BrowserCookieStorage.js +56 -0
  642. package/dist/esm/shared/lib/BrowserCookieStorage.js.map +1 -0
  643. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +16 -0
  644. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  645. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js +61 -0
  646. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  647. package/dist/esm/shared/lib/UserSession.d.ts +17 -0
  648. package/dist/esm/shared/lib/UserSession.d.ts.map +1 -0
  649. package/dist/esm/shared/lib/UserSession.js +23 -0
  650. package/dist/esm/shared/lib/UserSession.js.map +1 -0
  651. package/dist/esm/shared/lib/iframeUtils.d.ts +6 -0
  652. package/dist/esm/shared/lib/iframeUtils.d.ts.map +1 -0
  653. package/dist/esm/shared/lib/iframeUtils.js +7 -0
  654. package/dist/esm/shared/lib/iframeUtils.js.map +1 -0
  655. package/dist/esm/shared/lib/session.d.ts +4 -0
  656. package/dist/esm/shared/lib/session.d.ts.map +1 -0
  657. package/dist/esm/shared/lib/session.js +44 -0
  658. package/dist/esm/shared/lib/session.js.map +1 -0
  659. package/dist/esm/shared/lib/storage.d.ts +35 -0
  660. package/dist/esm/shared/lib/storage.d.ts.map +1 -0
  661. package/dist/esm/shared/lib/storage.js +17 -0
  662. package/dist/esm/shared/lib/storage.js.map +1 -0
  663. package/dist/esm/shared/lib/types.d.ts +39 -0
  664. package/dist/esm/shared/lib/types.d.ts.map +1 -0
  665. package/dist/esm/shared/lib/types.js +19 -0
  666. package/dist/esm/shared/lib/types.js.map +1 -0
  667. package/dist/esm/shared/lib/util.d.ts +40 -0
  668. package/dist/esm/shared/lib/util.d.ts.map +1 -0
  669. package/dist/esm/shared/lib/util.js +187 -0
  670. package/dist/esm/shared/lib/util.js.map +1 -0
  671. package/dist/esm/shared/providers/AuthContext.d.ts +12 -0
  672. package/dist/esm/shared/providers/AuthContext.d.ts.map +1 -0
  673. package/dist/esm/shared/providers/AuthContext.js +4 -0
  674. package/dist/esm/shared/providers/AuthContext.js.map +1 -0
  675. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +19 -0
  676. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  677. package/dist/esm/shared/providers/CivicAuthConfigContext.js +55 -0
  678. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +1 -0
  679. package/dist/esm/shared/providers/IframeProvider.d.ts +25 -0
  680. package/dist/esm/shared/providers/IframeProvider.d.ts.map +1 -0
  681. package/dist/esm/shared/providers/IframeProvider.js +59 -0
  682. package/dist/esm/shared/providers/IframeProvider.js.map +1 -0
  683. package/dist/esm/shared/providers/SessionProvider.d.ts +19 -0
  684. package/dist/esm/shared/providers/SessionProvider.d.ts.map +1 -0
  685. package/dist/esm/shared/providers/SessionProvider.js +24 -0
  686. package/dist/esm/shared/providers/SessionProvider.js.map +1 -0
  687. package/dist/esm/shared/providers/TokenProvider.d.ts +17 -0
  688. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -0
  689. package/dist/esm/shared/providers/TokenProvider.js +35 -0
  690. package/dist/esm/shared/providers/TokenProvider.js.map +1 -0
  691. package/dist/esm/shared/providers/UserProvider.d.ts +26 -0
  692. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -0
  693. package/dist/esm/shared/providers/UserProvider.js +65 -0
  694. package/dist/esm/shared/providers/UserProvider.js.map +1 -0
  695. package/dist/esm/shared/providers/types.d.ts +15 -0
  696. package/dist/esm/shared/providers/types.d.ts.map +1 -0
  697. package/dist/esm/shared/providers/types.js +2 -0
  698. package/dist/esm/shared/providers/types.js.map +1 -0
  699. package/dist/esm/shared/version.d.ts +2 -0
  700. package/dist/esm/shared/version.d.ts.map +1 -0
  701. package/dist/esm/shared/version.js +3 -0
  702. package/dist/esm/shared/version.js.map +1 -0
  703. package/dist/esm/types.d.ts +163 -0
  704. package/dist/esm/types.d.ts.map +1 -0
  705. package/dist/esm/types.js +17 -0
  706. package/dist/esm/types.js.map +1 -0
  707. package/dist/esm/utils.d.ts +15 -0
  708. package/dist/esm/utils.d.ts.map +1 -0
  709. package/dist/esm/utils.js +42 -0
  710. package/dist/esm/utils.js.map +1 -0
  711. package/dist/esm/version.d.ts +2 -0
  712. package/dist/esm/version.d.ts.map +1 -0
  713. package/dist/esm/version.js +3 -0
  714. package/dist/esm/version.js.map +1 -0
  715. package/dist/nextjs/NextClientAuthenticationRefresher.d.ts +3 -4
  716. package/dist/nextjs/NextClientAuthenticationRefresher.d.ts.map +1 -1
  717. package/dist/nextjs/NextClientAuthenticationRefresher.js +14 -12
  718. package/dist/nextjs/NextClientAuthenticationRefresher.js.map +1 -1
  719. package/dist/nextjs/NextServerAuthenticationRefresherImpl.d.ts +2 -1
  720. package/dist/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +1 -1
  721. package/dist/nextjs/NextServerAuthenticationRefresherImpl.js +7 -2
  722. package/dist/nextjs/NextServerAuthenticationRefresherImpl.js.map +1 -1
  723. package/dist/nextjs/hooks/useRefresh.d.ts +3 -1
  724. package/dist/nextjs/hooks/useRefresh.d.ts.map +1 -1
  725. package/dist/nextjs/hooks/useRefresh.js +11 -2
  726. package/dist/nextjs/hooks/useRefresh.js.map +1 -1
  727. package/dist/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  728. package/dist/nextjs/providers/NextAuthProvider.js +7 -1
  729. package/dist/nextjs/providers/NextAuthProvider.js.map +1 -1
  730. package/dist/nextjs/routeHandler.d.ts.map +1 -1
  731. package/dist/nextjs/routeHandler.js +18 -11
  732. package/dist/nextjs/routeHandler.js.map +1 -1
  733. package/dist/reactjs/providers/AuthProvider.d.ts.map +1 -1
  734. package/dist/reactjs/providers/AuthProvider.js +8 -0
  735. package/dist/reactjs/providers/AuthProvider.js.map +1 -1
  736. package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -1
  737. package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.js +1 -2
  738. package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -1
  739. package/dist/server/refresh.d.ts.map +1 -1
  740. package/dist/server/refresh.js +4 -1
  741. package/dist/server/refresh.js.map +1 -1
  742. package/dist/services/AuthenticationService.d.ts.map +1 -1
  743. package/dist/services/AuthenticationService.js +1 -6
  744. package/dist/services/AuthenticationService.js.map +1 -1
  745. package/dist/shared/components/CivicAuthIframe.d.ts.map +1 -1
  746. package/dist/shared/components/CivicAuthIframe.js +8 -2
  747. package/dist/shared/components/CivicAuthIframe.js.map +1 -1
  748. package/dist/shared/hooks/useRefresh.d.ts +3 -1
  749. package/dist/shared/hooks/useRefresh.d.ts.map +1 -1
  750. package/dist/shared/hooks/useRefresh.js +11 -2
  751. package/dist/shared/hooks/useRefresh.js.map +1 -1
  752. package/dist/shared/lib/AuthenticationRefresherImpl.d.ts +2 -2
  753. package/dist/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -1
  754. package/dist/shared/lib/AuthenticationRefresherImpl.js +7 -6
  755. package/dist/shared/lib/AuthenticationRefresherImpl.js.map +1 -1
  756. package/dist/shared/lib/BrowserAuthenticationRefresher.d.ts +11 -0
  757. package/dist/shared/lib/BrowserAuthenticationRefresher.d.ts.map +1 -0
  758. package/dist/shared/lib/BrowserAuthenticationRefresher.js +58 -0
  759. package/dist/shared/lib/BrowserAuthenticationRefresher.js.map +1 -0
  760. package/dist/shared/lib/GenericAuthenticationRefresher.d.ts +2 -4
  761. package/dist/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  762. package/dist/shared/lib/GenericAuthenticationRefresher.js +10 -39
  763. package/dist/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  764. package/dist/shared/lib/util.d.ts.map +1 -1
  765. package/dist/shared/lib/util.js +12 -2
  766. package/dist/shared/lib/util.js.map +1 -1
  767. package/dist/shared/version.d.ts +1 -1
  768. package/dist/shared/version.d.ts.map +1 -1
  769. package/dist/shared/version.js +1 -1
  770. package/dist/shared/version.js.map +1 -1
  771. package/dist/tsconfig.cjs.tsbuildinfo +1 -0
  772. package/dist/tsconfig.esm.tsbuildinfo +1 -0
  773. package/package.json +1 -1
@@ -0,0 +1,65 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
3
+ import React, { createContext, useCallback, useEffect, useState } from "react";
4
+ import { useSession } from "../../shared/hooks/useSession.js";
5
+ import { GenericUserSession } from "../../shared/lib/UserSession.js";
6
+ import { useToken } from "../hooks/useToken.js";
7
+ const UserContext = createContext(null);
8
+ const UserProvider = ({ children, storage, user: inputUser, signOut, authStatus, signIn, displayMode, }) => {
9
+ const { error: authError, isLoading: authLoading } = useSession();
10
+ const { data: session } = useSession();
11
+ const tokens = useToken();
12
+ const [userLoading, setUserLoading] = useState(false);
13
+ const [userError, setUserError] = useState(null);
14
+ const [user, setUser] = useState(inputUser);
15
+ const fetchUser = useCallback(async () => {
16
+ if (!session?.idToken)
17
+ return null;
18
+ const userSession = new GenericUserSession(storage);
19
+ return userSession.get();
20
+ }, [session?.idToken, storage]);
21
+ useEffect(() => {
22
+ if (session?.idToken) {
23
+ setUserLoading(true);
24
+ fetchUser()
25
+ .then((user) => {
26
+ setUserLoading(false);
27
+ setUser((prevUser) => {
28
+ // we only want to update the user if it's set - if a user is passed in, don't assume it is wrong here
29
+ // it could be just the fetchUser returned null for some other reason.
30
+ // TODO consider cleaning this up in general to avoid needing context here.
31
+ return user ?? prevUser;
32
+ });
33
+ })
34
+ .catch((error) => {
35
+ setUserLoading(false);
36
+ setUserError(error);
37
+ });
38
+ }
39
+ else {
40
+ setUser(null);
41
+ }
42
+ }, [fetchUser, session?.idToken]);
43
+ const isLoading = authLoading || userLoading;
44
+ const error = authError ?? userError;
45
+ // While we are passing a user as a prop _and_ storing it in state,
46
+ // there is the case where the user is not set in the state yet
47
+ // (setState is called but the rerender has not yet happened), but
48
+ // is passed as a prop. In this case, we want to use the prop value.
49
+ // A better solution is to avoid having multiple layers of context.
50
+ // If the user is passed in, we just use that.
51
+ // We should not split user state management across multiple contexts
52
+ const userValue = user ?? inputUser;
53
+ return (_jsx(UserContext.Provider, { value: {
54
+ ...tokens,
55
+ user: userValue,
56
+ isLoading,
57
+ error,
58
+ signIn,
59
+ signOut,
60
+ authStatus,
61
+ displayMode: displayMode || "iframe",
62
+ }, children: children }));
63
+ };
64
+ export { UserProvider, UserContext };
65
+ //# sourceMappingURL=UserProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\n\nimport React, { createContext, useCallback, useEffect, useState } from \"react\";\nimport type { ReactNode } from \"react\";\nimport type {\n AuthStatus,\n AuthStorage,\n DisplayMode,\n ForwardedTokens,\n User,\n} from \"@/types.js\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { AuthContextType } from \"@/shared/providers/AuthContext.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport { useToken } from \"../hooks/useToken.js\";\nimport type { JWTPayload } from \"jose\";\n\ntype UserContent = Record<string, unknown> & JWTPayload;\ntype UserContextType<T extends UserContent = UserContent> = {\n user: User<T> | null;\n} & {\n accessToken?: string | null;\n idToken?: string | null;\n forwardedTokens?: ForwardedTokens;\n} & Omit<AuthContextType, \"isAuthenticated\">;\n\nconst UserContext = createContext<UserContextType | null>(null);\n\nconst UserProvider = <T extends UserContent>({\n children,\n storage,\n user: inputUser,\n signOut,\n authStatus,\n signIn,\n displayMode,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user: User<T> | null;\n signOut: () => Promise<void>;\n authStatus: AuthStatus;\n signIn: (displayMode?: DisplayMode) => Promise<void>;\n displayMode: DisplayMode;\n}) => {\n const { error: authError, isLoading: authLoading } = useSession();\n const { data: session } = useSession();\n const tokens = useToken();\n const [userLoading, setUserLoading] = useState<boolean>(false);\n const [userError, setUserError] = useState<Error | null>(null);\n const [user, setUser] = useState<User<T> | null>(inputUser);\n\n const fetchUser = useCallback(async (): Promise<User<T> | null> => {\n if (!session?.idToken) return null;\n const userSession = new GenericUserSession<T>(storage);\n return userSession.get();\n }, [session?.idToken, storage]);\n\n useEffect(() => {\n if (session?.idToken) {\n setUserLoading(true);\n fetchUser()\n .then((user) => {\n setUserLoading(false);\n setUser((prevUser) => {\n // we only want to update the user if it's set - if a user is passed in, don't assume it is wrong here\n // it could be just the fetchUser returned null for some other reason.\n // TODO consider cleaning this up in general to avoid needing context here.\n return user ?? prevUser;\n });\n })\n .catch((error) => {\n setUserLoading(false);\n setUserError(error);\n });\n } else {\n setUser(null);\n }\n }, [fetchUser, session?.idToken]);\n\n const isLoading = authLoading || userLoading;\n const error = authError ?? userError;\n\n // While we are passing a user as a prop _and_ storing it in state,\n // there is the case where the user is not set in the state yet\n // (setState is called but the rerender has not yet happened), but\n // is passed as a prop. In this case, we want to use the prop value.\n // A better solution is to avoid having multiple layers of context.\n // If the user is passed in, we just use that.\n // We should not split user state management across multiple contexts\n const userValue = user ?? inputUser;\n\n return (\n <UserContext.Provider\n value={{\n ...tokens,\n user: userValue,\n isLoading,\n error,\n signIn,\n signOut,\n authStatus,\n displayMode: displayMode || \"iframe\",\n }}\n >\n {children}\n </UserContext.Provider>\n );\n};\n\nexport type { UserContextType };\n\nexport { UserProvider, UserContext };\n"]}
@@ -0,0 +1,15 @@
1
+ import type { Config, DisplayMode, IframeMode } from "../../types.js";
2
+ import type { ReactNode } from "react";
3
+ export type AuthProviderProps = {
4
+ children: ReactNode;
5
+ clientId: string;
6
+ nonce?: string;
7
+ onSignIn?: (error?: Error) => void;
8
+ onSignOut?: () => Promise<void>;
9
+ iframeMode?: IframeMode;
10
+ config?: Config;
11
+ redirectUrl?: string;
12
+ logoutRedirectUrl?: string;
13
+ displayMode?: DisplayMode;
14
+ };
15
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,MAAM,MAAM,iBAAiB,GAAG;IAC9B,QAAQ,EAAE,SAAS,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,KAAK,IAAI,CAAC;IACnC,SAAS,CAAC,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAChC,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/shared/providers/types.ts"],"names":[],"mappings":"","sourcesContent":["import type { Config, DisplayMode, IframeMode } from \"@/types.js\";\nimport type { ReactNode } from \"react\";\n\nexport type AuthProviderProps = {\n children: ReactNode;\n clientId: string;\n nonce?: string;\n onSignIn?: (error?: Error) => void;\n onSignOut?: () => Promise<void>;\n iframeMode?: IframeMode;\n config?: Config;\n redirectUrl?: string;\n logoutRedirectUrl?: string;\n displayMode?: DisplayMode;\n};\n"]}
@@ -0,0 +1,2 @@
1
+ export declare const VERSION = "@civic/auth:0.3.5-beta.2";
2
+ //# sourceMappingURL=version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,OAAO,6BAA6B,CAAC"}
@@ -0,0 +1,3 @@
1
+ // This is an auto-generated file. Do not edit.
2
+ export const VERSION = "@civic/auth:0.3.5-beta.2";
3
+ //# sourceMappingURL=version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAE/C,MAAM,CAAC,MAAM,OAAO,GAAG,0BAA0B,CAAC","sourcesContent":["// This is an auto-generated file. Do not edit.\n\nexport const VERSION = \"@civic/auth:0.3.5-beta.2\";\n"]}
@@ -0,0 +1,163 @@
1
+ import type { TokenResponseBody } from "oslo/oauth2";
2
+ import type { JWTPayload } from "jose";
3
+ type UnknownObject = Record<string, unknown>;
4
+ type EmptyObject = Record<string, never>;
5
+ export declare enum AuthStatus {
6
+ AUTHENTICATED = "authenticated",
7
+ UNAUTHENTICATED = "unauthenticated",
8
+ AUTHENTICATING = "authenticating",
9
+ ERROR = "error",
10
+ SIGNING_OUT = "signing_out"
11
+ }
12
+ type DisplayMode = "iframe" | "redirect" | "new_tab" | "custom_tab";
13
+ type ColorMode = "light" | "dark" | "auto";
14
+ interface AuthSessionService {
15
+ loadAuthorizationUrl(authorizationURL: string, displayMode: DisplayMode): void;
16
+ getAuthorizationUrl(scopes: string[], overrideDisplayMode: DisplayMode, nonce?: string): Promise<string>;
17
+ signIn(displayMode: DisplayMode, scopes: string[], nonce?: string): Promise<void>;
18
+ tokenExchange(responseUrl: string): Promise<SessionData>;
19
+ getSessionData(): SessionData;
20
+ updateSessionData(data: SessionData): void;
21
+ getUserInfoService(): Promise<UserInfoService>;
22
+ }
23
+ interface TokenService {
24
+ exchangeCodeForTokens(authCode: string): Promise<Tokens>;
25
+ validateIdToken(idToken: string, nonce: string): boolean;
26
+ refreshAccessToken(refreshToken: string): Promise<Tokens>;
27
+ }
28
+ interface UserInfoService {
29
+ getUserInfo<T extends UnknownObject>(accessToken: string, idToken: string | null): Promise<User<T> | null>;
30
+ }
31
+ interface ResourceService {
32
+ getProtectedResource(accessToken: string): Promise<unknown>;
33
+ }
34
+ type AuthRequest = {
35
+ clientId: string;
36
+ redirectUri: string;
37
+ state: string;
38
+ nonce: string;
39
+ scope: string;
40
+ };
41
+ type Endpoints = {
42
+ jwks: string;
43
+ auth: string;
44
+ token: string;
45
+ userinfo: string;
46
+ challenge?: string;
47
+ endsession: string;
48
+ };
49
+ type Config = {
50
+ oauthServer: string;
51
+ endpoints?: Endpoints;
52
+ };
53
+ type SessionData = {
54
+ authenticated: boolean;
55
+ state?: string;
56
+ accessToken?: string;
57
+ refreshToken?: string;
58
+ idToken?: string;
59
+ accessTokenExpiresAt?: number;
60
+ codeVerifier?: string;
61
+ displayMode?: DisplayMode;
62
+ openerUrl?: string;
63
+ };
64
+ type OIDCTokenResponseBody = TokenResponseBody & {
65
+ id_token: string;
66
+ access_token_expires_at?: number;
67
+ };
68
+ type ParsedTokens = {
69
+ id_token: JWTPayload;
70
+ access_token: JWTPayload;
71
+ refresh_token?: string;
72
+ };
73
+ type ForwardedTokens = Record<string, {
74
+ idToken?: string;
75
+ accessToken?: string;
76
+ refreshToken?: string;
77
+ }>;
78
+ type ForwardedTokensJWT = Record<string, {
79
+ id_token?: string;
80
+ access_token?: string;
81
+ refresh_token?: string;
82
+ scope?: string;
83
+ }>;
84
+ type IdTokenPayload = JWTPayload & {
85
+ forwardedTokens?: ForwardedTokensJWT;
86
+ email?: string;
87
+ name?: string;
88
+ picture?: string;
89
+ nonce: string;
90
+ at_hash: string;
91
+ };
92
+ declare const tokenKeys: readonly ["sub", "idToken", "accessToken", "refreshToken", "forwardedTokens"];
93
+ export type OAuthTokens = {
94
+ idToken?: string;
95
+ accessToken?: string;
96
+ refreshToken?: string;
97
+ };
98
+ type Tokens = {
99
+ [K in (typeof tokenKeys)[number]]: K extends "forwardedTokens" ? ForwardedTokens : string;
100
+ };
101
+ type BaseUser = {
102
+ id: string;
103
+ email?: string;
104
+ name?: string;
105
+ given_name?: string;
106
+ family_name?: string;
107
+ picture?: string;
108
+ updated_at?: Date;
109
+ };
110
+ type User<T extends UnknownObject | EmptyObject = EmptyObject> = T extends EmptyObject ? BaseUser : BaseUser & T;
111
+ type OpenIdConfiguration = {
112
+ authorization_endpoint: string;
113
+ claims_parameter_supported: boolean;
114
+ claims_supported: string[];
115
+ code_challenge_methods_supported: string[];
116
+ end_session_endpoint: string;
117
+ grant_types_supported: string[];
118
+ issuer: string;
119
+ jwks_uri: string;
120
+ authorization_response_iss_parameter_supported: boolean;
121
+ response_modes_supported: string[];
122
+ response_types_supported: string[];
123
+ scopes_supported: string[];
124
+ subject_types_supported: string[];
125
+ token_endpoint_auth_methods_supported: string[];
126
+ token_endpoint_auth_signing_alg_values_supported: string[];
127
+ token_endpoint: string;
128
+ id_token_signing_alg_values_supported: string[];
129
+ pushed_authorization_request_endpoint: string;
130
+ request_parameter_supported: boolean;
131
+ request_uri_parameter_supported: boolean;
132
+ userinfo_endpoint: string;
133
+ claim_types_supported: string[];
134
+ };
135
+ type LoginPostMessage = {
136
+ source: string;
137
+ type: string;
138
+ clientId: string;
139
+ data: {
140
+ url: string;
141
+ } | LoginAppDesignOptions;
142
+ };
143
+ export type IframeAuthMessage = {
144
+ source: "civicloginApp";
145
+ type: "auth_error" | "auth_error_try_again";
146
+ clientId: string;
147
+ data: {
148
+ url?: string;
149
+ error?: string;
150
+ };
151
+ };
152
+ export type LoginAppDesignOptions = {
153
+ colorMode: ColorMode;
154
+ };
155
+ export type { LoginPostMessage, AuthSessionService, TokenService, UserInfoService, ResourceService, AuthRequest, Tokens, Endpoints, Config, SessionData, OIDCTokenResponseBody, ParsedTokens, BaseUser, User, DisplayMode, UnknownObject, EmptyObject, ForwardedTokens, ForwardedTokensJWT, IdTokenPayload, OpenIdConfiguration, ColorMode, };
156
+ export { tokenKeys };
157
+ export interface AuthStorage {
158
+ get(key: string): Promise<string | null>;
159
+ set(key: string, value: string): Promise<void>;
160
+ delete(key: string): Promise<void>;
161
+ }
162
+ export type IframeMode = "embedded" | "modal";
163
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ export var AuthStatus;
2
+ (function (AuthStatus) {
3
+ AuthStatus["AUTHENTICATED"] = "authenticated";
4
+ AuthStatus["UNAUTHENTICATED"] = "unauthenticated";
5
+ AuthStatus["AUTHENTICATING"] = "authenticating";
6
+ AuthStatus["ERROR"] = "error";
7
+ AuthStatus["SIGNING_OUT"] = "signing_out";
8
+ })(AuthStatus || (AuthStatus = {}));
9
+ const tokenKeys = [
10
+ "sub",
11
+ "idToken",
12
+ "accessToken",
13
+ "refreshToken",
14
+ "forwardedTokens",
15
+ ];
16
+ export { tokenKeys };
17
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAMA,MAAM,CAAN,IAAY,UAMX;AAND,WAAY,UAAU;IACpB,6CAA+B,CAAA;IAC/B,iDAAmC,CAAA;IACnC,+CAAiC,CAAA;IACjC,6BAAe,CAAA;IACf,yCAA2B,CAAA;AAC7B,CAAC,EANW,UAAU,KAAV,UAAU,QAMrB;AAiID,MAAM,SAAS,GAAG;IAChB,KAAK;IACL,SAAS;IACT,aAAa;IACb,cAAc;IACd,iBAAiB;CACT,CAAC;AAqGX,OAAO,EAAE,SAAS,EAAE,CAAC","sourcesContent":["import type { TokenResponseBody } from \"oslo/oauth2\";\nimport type { JWTPayload } from \"jose\";\n\ntype UnknownObject = Record<string, unknown>;\ntype EmptyObject = Record<string, never>;\n\nexport enum AuthStatus {\n AUTHENTICATED = \"authenticated\",\n UNAUTHENTICATED = \"unauthenticated\",\n AUTHENTICATING = \"authenticating\",\n ERROR = \"error\",\n SIGNING_OUT = \"signing_out\",\n}\n// Display modes for the auth flow\ntype DisplayMode = \"iframe\" | \"redirect\" | \"new_tab\" | \"custom_tab\";\n\ntype ColorMode = \"light\" | \"dark\" | \"auto\";\n// Combined Auth and Session Service\ninterface AuthSessionService {\n // TODO DK NOTES: Should be in BrowserAuthSessionService, not relevant on backend\n loadAuthorizationUrl(\n authorizationURL: string,\n displayMode: DisplayMode,\n ): void;\n // TODO DK NOTES: overrideDisplayMode parameter not appropriate here - also - do we need both this and the above in the interface?\n getAuthorizationUrl(\n scopes: string[],\n overrideDisplayMode: DisplayMode,\n nonce?: string,\n ): Promise<string>;\n // TODO DK NOTES: display mode should be in browser version only. Also, do we need this and the above two in the top-level interface?\n signIn(\n displayMode: DisplayMode,\n scopes: string[],\n nonce?: string,\n ): Promise<void>;\n // TODO DK NOTES: Input should be an auth code - do not assume it comes via an url\n tokenExchange(responseUrl: string): Promise<SessionData>;\n // TODO DK NOTES: Should be async for flexibility\n getSessionData(): SessionData;\n // TODO DK NOTES: Should be async for flexibility\n updateSessionData(data: SessionData): void;\n getUserInfoService(): Promise<UserInfoService>;\n}\n\n// Token Service\ninterface TokenService {\n exchangeCodeForTokens(authCode: string): Promise<Tokens>;\n validateIdToken(idToken: string, nonce: string): boolean;\n refreshAccessToken(refreshToken: string): Promise<Tokens>;\n}\n\n// User Info Service\ninterface UserInfoService {\n getUserInfo<T extends UnknownObject>(\n accessToken: string,\n idToken: string | null,\n ): Promise<User<T> | null>;\n}\n\n// Resource Service\ninterface ResourceService {\n getProtectedResource(accessToken: string): Promise<unknown>;\n}\n\n// Auth Request (for internal use in AuthSessionService)\ntype AuthRequest = {\n clientId: string;\n redirectUri: string;\n state: string;\n nonce: string;\n scope: string;\n};\n\ntype Endpoints = {\n jwks: string;\n auth: string;\n token: string;\n userinfo: string;\n challenge?: string;\n endsession: string;\n};\n\ntype Config = {\n oauthServer: string;\n endpoints?: Endpoints;\n};\n\ntype SessionData = {\n authenticated: boolean; // TODO can this be inferred from the presence of the tokens?\n state?: string;\n accessToken?: string;\n refreshToken?: string;\n idToken?: string;\n accessTokenExpiresAt?: number;\n codeVerifier?: string;\n displayMode?: DisplayMode;\n openerUrl?: string;\n};\n\ntype OIDCTokenResponseBody = TokenResponseBody & {\n id_token: string;\n access_token_expires_at?: number;\n};\n\ntype ParsedTokens = {\n id_token: JWTPayload;\n access_token: JWTPayload;\n refresh_token?: string;\n};\n\n// The format we expose to the frontend via hooks\ntype ForwardedTokens = Record<\n string,\n {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n }\n>;\n\n// The format in the JWT payload\ntype ForwardedTokensJWT = Record<\n string,\n {\n id_token?: string;\n access_token?: string;\n refresh_token?: string;\n scope?: string;\n }\n>;\n\ntype IdTokenPayload = JWTPayload & {\n forwardedTokens?: ForwardedTokensJWT;\n email?: string;\n name?: string;\n picture?: string;\n nonce: string;\n at_hash: string;\n};\n\nconst tokenKeys = [\n \"sub\",\n \"idToken\",\n \"accessToken\",\n \"refreshToken\",\n \"forwardedTokens\",\n] as const;\n\nexport type OAuthTokens = {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n};\n// Derive the Tokens type from the array\ntype Tokens = {\n [K in (typeof tokenKeys)[number]]: K extends \"forwardedTokens\"\n ? ForwardedTokens\n : string;\n};\n\n// Base user interface\ntype BaseUser = {\n id: string;\n email?: string;\n name?: string;\n given_name?: string;\n family_name?: string;\n picture?: string;\n updated_at?: Date;\n};\n\ntype User<T extends UnknownObject | EmptyObject = EmptyObject> =\n T extends EmptyObject ? BaseUser : BaseUser & T;\n\ntype OpenIdConfiguration = {\n authorization_endpoint: string;\n claims_parameter_supported: boolean;\n claims_supported: string[];\n code_challenge_methods_supported: string[];\n end_session_endpoint: string;\n grant_types_supported: string[];\n issuer: string;\n jwks_uri: string;\n authorization_response_iss_parameter_supported: boolean;\n response_modes_supported: string[];\n response_types_supported: string[];\n scopes_supported: string[];\n subject_types_supported: string[];\n token_endpoint_auth_methods_supported: string[];\n token_endpoint_auth_signing_alg_values_supported: string[];\n token_endpoint: string;\n id_token_signing_alg_values_supported: string[];\n pushed_authorization_request_endpoint: string;\n request_parameter_supported: boolean;\n request_uri_parameter_supported: boolean;\n userinfo_endpoint: string;\n claim_types_supported: string[];\n};\n\ntype LoginPostMessage = {\n source: string;\n type: string;\n clientId: string;\n data:\n | {\n url: string;\n }\n | LoginAppDesignOptions;\n};\n\nexport type IframeAuthMessage = {\n source: \"civicloginApp\";\n type: \"auth_error\" | \"auth_error_try_again\";\n clientId: string;\n data: {\n url?: string;\n error?: string;\n };\n};\n\nexport type LoginAppDesignOptions = {\n colorMode: ColorMode;\n};\nexport type {\n LoginPostMessage,\n AuthSessionService,\n TokenService,\n UserInfoService,\n ResourceService,\n AuthRequest,\n Tokens,\n Endpoints,\n Config,\n SessionData,\n OIDCTokenResponseBody,\n ParsedTokens,\n BaseUser,\n User,\n DisplayMode,\n UnknownObject,\n EmptyObject,\n ForwardedTokens,\n ForwardedTokensJWT,\n IdTokenPayload,\n OpenIdConfiguration,\n ColorMode,\n};\nexport { tokenKeys };\nexport interface AuthStorage {\n get(key: string): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n delete(key: string): Promise<void>;\n}\n\nexport type IframeMode = \"embedded\" | \"modal\";\n"]}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Checks if a popup window is blocked by the browser.
3
+ *
4
+ * This function attempts to open a small popup window and then checks if it was successfully created.
5
+ * If the popup is blocked by the browser, the function returns `true`. Otherwise, it returns `false`.
6
+ *
7
+ * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.
8
+ */
9
+ export declare const isPopupBlocked: () => boolean;
10
+ type WithoutUndefined<T> = {
11
+ [K in keyof T as undefined extends T[K] ? never : K]: T[K];
12
+ };
13
+ export declare const withoutUndefined: <T extends { [K in keyof T]: unknown; }>(obj: T) => WithoutUndefined<T>;
14
+ export {};
15
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,eAAO,MAAM,cAAc,QAAO,OAsBjC,CAAC;AAOF,KAAK,gBAAgB,CAAC,CAAC,IAAI;KACxB,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC3D,CAAC;AACF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,GAAG,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,GAAE,OAC/D,CAAC,KACL,gBAAgB,CAAC,CAAC,CAapB,CAAC"}
@@ -0,0 +1,42 @@
1
+ /**
2
+ * Checks if a popup window is blocked by the browser.
3
+ *
4
+ * This function attempts to open a small popup window and then checks if it was successfully created.
5
+ * If the popup is blocked by the browser, the function returns `true`. Otherwise, it returns `false`.
6
+ *
7
+ * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.
8
+ */
9
+ export const isPopupBlocked = () => {
10
+ // First we try to open a small popup window. It either returns a window object or null.
11
+ const popup = window.open("", "", "width=1,height=1");
12
+ // If window.open() returns null, popup is definitely blocked
13
+ if (!popup) {
14
+ return true;
15
+ }
16
+ try {
17
+ // Try to access a property of the popup to check if it's usable
18
+ if (typeof popup.closed === "undefined") {
19
+ throw new Error("Popup is blocked");
20
+ }
21
+ }
22
+ catch {
23
+ // Accessing the popup's properties throws an error if the popup is blocked
24
+ return true;
25
+ }
26
+ // Close the popup immediately if it was opened
27
+ popup.close();
28
+ return false;
29
+ };
30
+ export const withoutUndefined = (obj) => {
31
+ const result = {};
32
+ for (const key in obj) {
33
+ if (obj[key] !== undefined) {
34
+ // TypeScript needs assurance that key is a valid key in WithoutUndefined<T>
35
+ // We use type assertion here
36
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
37
+ result[key] = obj[key];
38
+ }
39
+ }
40
+ return result;
41
+ };
42
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,GAAY,EAAE;IAC1C,wFAAwF;IACxF,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC;IAEtD,6DAA6D;IAC7D,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,CAAC;QACH,gEAAgE;QAChE,IAAI,OAAO,KAAK,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;YACxC,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,2EAA2E;QAC3E,OAAO,IAAI,CAAC;IACd,CAAC;IAED,+CAA+C;IAC/C,KAAK,CAAC,KAAK,EAAE,CAAC;IACd,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAUF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,GAAM,EACe,EAAE;IACvB,MAAM,MAAM,GAAG,EAAyB,CAAC;IAEzC,KAAK,MAAM,GAAG,IAAI,GAAG,EAAE,CAAC;QACtB,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,SAAS,EAAE,CAAC;YAC3B,4EAA4E;YAC5E,6BAA6B;YAC7B,8DAA8D;YAC7D,MAAc,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC","sourcesContent":["/**\n * Checks if a popup window is blocked by the browser.\n *\n * This function attempts to open a small popup window and then checks if it was successfully created.\n * If the popup is blocked by the browser, the function returns `true`. Otherwise, it returns `false`.\n *\n * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.\n */\nexport const isPopupBlocked = (): boolean => {\n // First we try to open a small popup window. It either returns a window object or null.\n const popup = window.open(\"\", \"\", \"width=1,height=1\");\n\n // If window.open() returns null, popup is definitely blocked\n if (!popup) {\n return true;\n }\n\n try {\n // Try to access a property of the popup to check if it's usable\n if (typeof popup.closed === \"undefined\") {\n throw new Error(\"Popup is blocked\");\n }\n } catch {\n // Accessing the popup's properties throws an error if the popup is blocked\n return true;\n }\n\n // Close the popup immediately if it was opened\n popup.close();\n return false;\n};\n\n// This type narrows T as far as it can by:\n// - removing all keys where the value is `undefined`\n// - making keys that are not undefined required\n// So, for example: given { a: string | undefined, b: string | undefined },\n// if you pass in { a: \"foo\" }, it returns an object of type: { a: string }\ntype WithoutUndefined<T> = {\n [K in keyof T as undefined extends T[K] ? never : K]: T[K];\n};\nexport const withoutUndefined = <T extends { [K in keyof T]: unknown }>(\n obj: T,\n): WithoutUndefined<T> => {\n const result = {} as WithoutUndefined<T>;\n\n for (const key in obj) {\n if (obj[key] !== undefined) {\n // TypeScript needs assurance that key is a valid key in WithoutUndefined<T>\n // We use type assertion here\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (result as any)[key] = obj[key];\n }\n }\n\n return result;\n};\n"]}
@@ -0,0 +1,2 @@
1
+ export declare const VERSION = "@civic/auth:0.1.4-beta.5";
2
+ //# sourceMappingURL=version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../src/version.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,OAAO,6BAA6B,CAAC"}
@@ -0,0 +1,3 @@
1
+ // This is an auto-generated file. Do not edit.
2
+ export const VERSION = "@civic/auth:0.1.4-beta.5";
3
+ //# sourceMappingURL=version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.js","sourceRoot":"","sources":["../../src/version.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAE/C,MAAM,CAAC,MAAM,OAAO,GAAG,0BAA0B,CAAC","sourcesContent":["// This is an auto-generated file. Do not edit.\n\nexport const VERSION = \"@civic/auth:0.1.4-beta.5\";\n"]}
@@ -1,9 +1,8 @@
1
1
  import type { AuthConfig } from "../server/config.js";
2
2
  import type { AuthStorage, OIDCTokenResponseBody } from "../types.js";
3
- import { GenericAuthenticationRefresher } from "../shared/lib/GenericAuthenticationRefresher.js";
4
- export declare class NextClientAuthenticationRefresher extends GenericAuthenticationRefresher {
5
- private constructor();
6
- static build(authConfig: AuthConfig, storage: AuthStorage): Promise<NextClientAuthenticationRefresher>;
3
+ import { BrowserAuthenticationRefresher } from "../shared/lib/BrowserAuthenticationRefresher.js";
4
+ export declare class NextClientAuthenticationRefresher extends BrowserAuthenticationRefresher {
5
+ static build(authConfig: AuthConfig, storage: AuthStorage, onError: (error: Error) => Promise<void>): Promise<NextClientAuthenticationRefresher>;
7
6
  refreshAccessToken(): Promise<OIDCTokenResponseBody>;
8
7
  }
9
8
  //# sourceMappingURL=NextClientAuthenticationRefresher.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"NextClientAuthenticationRefresher.d.ts","sourceRoot":"","sources":["../../src/nextjs/NextClientAuthenticationRefresher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,KAAK,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACrE,OAAO,EAAE,8BAA8B,EAAE,MAAM,gDAAgD,CAAC;AAEhG,qBAAa,iCAAkC,SAAQ,8BAA8B;IACnF,OAAO;WAMM,KAAK,CAChB,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,iCAAiC,CAAC;IAQ9B,kBAAkB,IAAI,OAAO,CAAC,qBAAqB,CAAC;CASpE"}
1
+ {"version":3,"file":"NextClientAuthenticationRefresher.d.ts","sourceRoot":"","sources":["../../src/nextjs/NextClientAuthenticationRefresher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,KAAK,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACrE,OAAO,EAAE,8BAA8B,EAAE,MAAM,gDAAgD,CAAC;AAEhG,qBAAa,iCAAkC,SAAQ,8BAA8B;WAC7D,KAAK,CACzB,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,GACvC,OAAO,CAAC,iCAAiC,CAAC;IAS9B,kBAAkB,IAAI,OAAO,CAAC,qBAAqB,CAAC;CAkBpE"}
@@ -1,12 +1,7 @@
1
- import { GenericAuthenticationRefresher } from "../shared/lib/GenericAuthenticationRefresher.js";
2
- export class NextClientAuthenticationRefresher extends GenericAuthenticationRefresher {
3
- constructor(authConfig, storage) {
4
- super();
5
- this.authConfig = authConfig;
6
- this.storage = storage;
7
- }
8
- static async build(authConfig, storage) {
9
- const refresher = new NextClientAuthenticationRefresher(authConfig, storage);
1
+ import { BrowserAuthenticationRefresher } from "../shared/lib/BrowserAuthenticationRefresher.js";
2
+ export class NextClientAuthenticationRefresher extends BrowserAuthenticationRefresher {
3
+ static async build(authConfig, storage, onError) {
4
+ const refresher = new NextClientAuthenticationRefresher(authConfig, storage, onError);
10
5
  return refresher;
11
6
  }
12
7
  async refreshAccessToken() {
@@ -14,9 +9,16 @@ export class NextClientAuthenticationRefresher extends GenericAuthenticationRefr
14
9
  throw new Error("No auth config available");
15
10
  if (!this.authConfig.refreshUrl)
16
11
  throw new Error("No refresh URL available");
17
- const res = await fetch(`${this.authConfig?.refreshUrl}`);
18
- const json = await res.json();
19
- return json.tokens;
12
+ try {
13
+ const res = await fetch(`${this.authConfig?.refreshUrl}`);
14
+ const json = await res.json();
15
+ return json.tokens;
16
+ }
17
+ catch (error) {
18
+ console.error("NextClientAuthenticationRefresher refreshAccessToken: Failed to refresh tokens:", error);
19
+ this.onError(error);
20
+ throw error;
21
+ }
20
22
  }
21
23
  }
22
24
  //# sourceMappingURL=NextClientAuthenticationRefresher.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NextClientAuthenticationRefresher.js","sourceRoot":"","sources":["../../src/nextjs/NextClientAuthenticationRefresher.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,8BAA8B,EAAE,MAAM,gDAAgD,CAAC;AAEhG,MAAM,OAAO,iCAAkC,SAAQ,8BAA8B;IACnF,YAAoB,UAAsB,EAAE,OAAoB;QAC9D,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,KAAK,CAChB,UAAsB,EACtB,OAAoB;QAEpB,MAAM,SAAS,GAAG,IAAI,iCAAiC,CACrD,UAAU,EACV,OAAO,CACR,CAAC;QACF,OAAO,SAAS,CAAC;IACnB,CAAC;IAEQ,KAAK,CAAC,kBAAkB;QAC/B,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAClE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU;YAC7B,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAE9C,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;QAC1D,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,MAA+B,CAAC;IAC9C,CAAC;CACF","sourcesContent":["import type { AuthConfig } from \"@/server/config.js\";\nimport type { AuthStorage, OIDCTokenResponseBody } from \"@/types.js\";\nimport { GenericAuthenticationRefresher } from \"@/shared/lib/GenericAuthenticationRefresher.js\";\n\nexport class NextClientAuthenticationRefresher extends GenericAuthenticationRefresher {\n private constructor(authConfig: AuthConfig, storage: AuthStorage) {\n super();\n this.authConfig = authConfig;\n this.storage = storage;\n }\n\n static async build(\n authConfig: AuthConfig,\n storage: AuthStorage,\n ): Promise<NextClientAuthenticationRefresher> {\n const refresher = new NextClientAuthenticationRefresher(\n authConfig,\n storage,\n );\n return refresher;\n }\n\n override async refreshAccessToken(): Promise<OIDCTokenResponseBody> {\n if (!this.authConfig) throw new Error(\"No auth config available\");\n if (!this.authConfig.refreshUrl)\n throw new Error(\"No refresh URL available\");\n\n const res = await fetch(`${this.authConfig?.refreshUrl}`);\n const json = await res.json();\n return json.tokens as OIDCTokenResponseBody;\n }\n}\n"]}
1
+ {"version":3,"file":"NextClientAuthenticationRefresher.js","sourceRoot":"","sources":["../../src/nextjs/NextClientAuthenticationRefresher.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,8BAA8B,EAAE,MAAM,gDAAgD,CAAC;AAEhG,MAAM,OAAO,iCAAkC,SAAQ,8BAA8B;IACnF,MAAM,CAAU,KAAK,CAAC,KAAK,CACzB,UAAsB,EACtB,OAAoB,EACpB,OAAwC;QAExC,MAAM,SAAS,GAAG,IAAI,iCAAiC,CACrD,UAAU,EACV,OAAO,EACP,OAAO,CACR,CAAC;QACF,OAAO,SAAS,CAAC;IACnB,CAAC;IAEQ,KAAK,CAAC,kBAAkB;QAC/B,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAClE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU;YAC7B,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAE9C,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;YAC1D,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC,MAA+B,CAAC;QAC9C,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CACX,iFAAiF,EACjF,KAAK,CACN,CAAC;YACF,IAAI,CAAC,OAAO,CAAC,KAAc,CAAC,CAAC;YAC7B,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;CACF","sourcesContent":["import type { AuthConfig } from \"@/server/config.js\";\nimport type { AuthStorage, OIDCTokenResponseBody } from \"@/types.js\";\nimport { BrowserAuthenticationRefresher } from \"@/shared/lib/BrowserAuthenticationRefresher.js\";\n\nexport class NextClientAuthenticationRefresher extends BrowserAuthenticationRefresher {\n static override async build(\n authConfig: AuthConfig,\n storage: AuthStorage,\n onError: (error: Error) => Promise<void>,\n ): Promise<NextClientAuthenticationRefresher> {\n const refresher = new NextClientAuthenticationRefresher(\n authConfig,\n storage,\n onError,\n );\n return refresher;\n }\n\n override async refreshAccessToken(): Promise<OIDCTokenResponseBody> {\n if (!this.authConfig) throw new Error(\"No auth config available\");\n if (!this.authConfig.refreshUrl)\n throw new Error(\"No refresh URL available\");\n\n try {\n const res = await fetch(`${this.authConfig?.refreshUrl}`);\n const json = await res.json();\n return json.tokens as OIDCTokenResponseBody;\n } catch (error) {\n console.error(\n \"NextClientAuthenticationRefresher refreshAccessToken: Failed to refresh tokens:\",\n error,\n );\n this.onError(error as Error);\n throw error;\n }\n }\n}\n"]}
@@ -5,7 +5,8 @@ import type { CookieStorage } from "../server/index.js";
5
5
  export declare class NextServerAuthenticationRefresherImpl extends AuthenticationRefresherImpl {
6
6
  endpointOverrides?: Partial<Endpoints> | undefined;
7
7
  storage: CookieStorage | undefined;
8
- constructor(authConfig: AuthConfig, storage: CookieStorage, endpointOverrides?: Partial<Endpoints> | undefined);
8
+ constructor(authConfig: AuthConfig, storage: CookieStorage, onError: (error: Error) => Promise<void>, endpointOverrides?: Partial<Endpoints> | undefined);
9
9
  storeTokens(tokenResponseBody: OIDCTokenResponseBody): Promise<void>;
10
+ static build(authConfig: AuthConfig, storage: CookieStorage, onError: (error: Error) => Promise<void>, endpointOverrides?: Partial<Endpoints>): Promise<NextServerAuthenticationRefresherImpl>;
10
11
  }
11
12
  //# sourceMappingURL=NextServerAuthenticationRefresherImpl.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"NextServerAuthenticationRefresherImpl.d.ts","sourceRoot":"","sources":["../../src/nextjs/NextServerAuthenticationRefresherImpl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,6CAA6C,CAAC;AAC1F,OAAO,KAAK,EAAE,SAAS,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACnE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAEvD,qBAAa,qCAAsC,SAAQ,2BAA2B;IAKzE,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC;IAJxC,OAAO,EAAE,aAAa,GAAG,SAAS,CAAC;gBAE1C,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,aAAa,EACb,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,YAAA;IAMlC,WAAW,CACxB,iBAAiB,EAAE,qBAAqB,GACvC,OAAO,CAAC,IAAI,CAAC;CAIjB"}
1
+ {"version":3,"file":"NextServerAuthenticationRefresherImpl.d.ts","sourceRoot":"","sources":["../../src/nextjs/NextServerAuthenticationRefresherImpl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,6CAA6C,CAAC;AAC1F,OAAO,KAAK,EAAE,SAAS,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACnE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAEvD,qBAAa,qCAAsC,SAAQ,2BAA2B;IAMzE,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC;IALxC,OAAO,EAAE,aAAa,GAAG,SAAS,CAAC;gBAE1C,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,aAAa,EACtB,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,EAC/B,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,YAAA;IAMlC,WAAW,CACxB,iBAAiB,EAAE,qBAAqB,GACvC,OAAO,CAAC,IAAI,CAAC;WAKM,KAAK,CACzB,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,aAAa,EACtB,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,EACxC,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,GACrC,OAAO,CAAC,qCAAqC,CAAC;CAWlD"}
@@ -3,8 +3,8 @@ import { storeServerTokens } from "../shared/lib/util.js";
3
3
  export class NextServerAuthenticationRefresherImpl extends AuthenticationRefresherImpl {
4
4
  endpointOverrides;
5
5
  storage;
6
- constructor(authConfig, storage, endpointOverrides) {
7
- super(authConfig, storage, endpointOverrides);
6
+ constructor(authConfig, storage, onError, endpointOverrides) {
7
+ super(authConfig, storage, onError, endpointOverrides);
8
8
  this.endpointOverrides = endpointOverrides;
9
9
  this.storage = storage;
10
10
  }
@@ -13,5 +13,10 @@ export class NextServerAuthenticationRefresherImpl extends AuthenticationRefresh
13
13
  throw new Error("No storage available");
14
14
  await storeServerTokens(this.storage, tokenResponseBody);
15
15
  }
16
+ static async build(authConfig, storage, onError, endpointOverrides) {
17
+ const refresher = new NextServerAuthenticationRefresherImpl(authConfig, storage, onError, endpointOverrides);
18
+ await refresher.init();
19
+ return refresher;
20
+ }
16
21
  }
17
22
  //# sourceMappingURL=NextServerAuthenticationRefresherImpl.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NextServerAuthenticationRefresherImpl.js","sourceRoot":"","sources":["../../src/nextjs/NextServerAuthenticationRefresherImpl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,6CAA6C,CAAC;AAG1F,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAGzD,MAAM,OAAO,qCAAsC,SAAQ,2BAA2B;IAKzE;IAJF,OAAO,CAA4B;IAC5C,YACE,UAAsB,EACtB,OAAsB,EACb,iBAAsC;QAE/C,KAAK,CAAC,UAAU,EAAE,OAAO,EAAE,iBAAiB,CAAC,CAAC;QAFrC,sBAAiB,GAAjB,iBAAiB,CAAqB;QAG/C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAEQ,KAAK,CAAC,WAAW,CACxB,iBAAwC;QAExC,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC3D,MAAM,iBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;IAC3D,CAAC;CACF","sourcesContent":["import { AuthenticationRefresherImpl } from \"@/shared/lib/AuthenticationRefresherImpl.js\";\nimport type { Endpoints, OIDCTokenResponseBody } from \"@/types.js\";\nimport type { AuthConfig } from \"@/server/config.js\";\nimport { storeServerTokens } from \"@/shared/lib/util.js\";\nimport type { CookieStorage } from \"@/server/index.js\";\n\nexport class NextServerAuthenticationRefresherImpl extends AuthenticationRefresherImpl {\n override storage: CookieStorage | undefined;\n constructor(\n authConfig: AuthConfig,\n storage: CookieStorage,\n override endpointOverrides?: Partial<Endpoints>,\n ) {\n super(authConfig, storage, endpointOverrides);\n this.storage = storage;\n }\n\n override async storeTokens(\n tokenResponseBody: OIDCTokenResponseBody,\n ): Promise<void> {\n if (!this.storage) throw new Error(\"No storage available\");\n await storeServerTokens(this.storage, tokenResponseBody);\n }\n}\n"]}
1
+ {"version":3,"file":"NextServerAuthenticationRefresherImpl.js","sourceRoot":"","sources":["../../src/nextjs/NextServerAuthenticationRefresherImpl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,6CAA6C,CAAC;AAG1F,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAGzD,MAAM,OAAO,qCAAsC,SAAQ,2BAA2B;IAMzE;IALF,OAAO,CAA4B;IAC5C,YACE,UAAsB,EACtB,OAAsB,EACtB,OAAwC,EAC/B,iBAAsC;QAE/C,KAAK,CAAC,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,iBAAiB,CAAC,CAAC;QAF9C,sBAAiB,GAAjB,iBAAiB,CAAqB;QAG/C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAEQ,KAAK,CAAC,WAAW,CACxB,iBAAwC;QAExC,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC3D,MAAM,iBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;IAC3D,CAAC;IAED,MAAM,CAAU,KAAK,CAAC,KAAK,CACzB,UAAsB,EACtB,OAAsB,EACtB,OAAwC,EACxC,iBAAsC;QAEtC,MAAM,SAAS,GAAG,IAAI,qCAAqC,CACzD,UAAU,EACV,OAAO,EACP,OAAO,EACP,iBAAiB,CAClB,CAAC;QACF,MAAM,SAAS,CAAC,IAAI,EAAE,CAAC;QAEvB,OAAO,SAAS,CAAC;IACnB,CAAC;CACF","sourcesContent":["import { AuthenticationRefresherImpl } from \"@/shared/lib/AuthenticationRefresherImpl.js\";\nimport type { Endpoints, OIDCTokenResponseBody } from \"@/types.js\";\nimport type { AuthConfig } from \"@/server/config.js\";\nimport { storeServerTokens } from \"@/shared/lib/util.js\";\nimport type { CookieStorage } from \"@/server/index.js\";\n\nexport class NextServerAuthenticationRefresherImpl extends AuthenticationRefresherImpl {\n override storage: CookieStorage | undefined;\n constructor(\n authConfig: AuthConfig,\n storage: CookieStorage,\n onError: (error: Error) => Promise<void>,\n override endpointOverrides?: Partial<Endpoints>,\n ) {\n super(authConfig, storage, onError, endpointOverrides);\n this.storage = storage;\n }\n\n override async storeTokens(\n tokenResponseBody: OIDCTokenResponseBody,\n ): Promise<void> {\n if (!this.storage) throw new Error(\"No storage available\");\n await storeServerTokens(this.storage, tokenResponseBody);\n }\n\n static override async build(\n authConfig: AuthConfig,\n storage: CookieStorage,\n onError: (error: Error) => Promise<void>,\n endpointOverrides?: Partial<Endpoints>,\n ): Promise<NextServerAuthenticationRefresherImpl> {\n const refresher = new NextServerAuthenticationRefresherImpl(\n authConfig,\n storage,\n onError,\n endpointOverrides,\n );\n await refresher.init();\n\n return refresher;\n }\n}\n"]}
@@ -1,4 +1,6 @@
1
1
  import type { SessionData } from "../../types.js";
2
- declare const useRefresh: (session: SessionData | null) => void;
2
+ declare const useRefresh: (session: SessionData | null) => {
3
+ error: Error | undefined;
4
+ };
3
5
  export { useRefresh };
4
6
  //# sourceMappingURL=useRefresh.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useRefresh.d.ts","sourceRoot":"","sources":["../../../src/nextjs/hooks/useRefresh.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAM9C,QAAA,MAAM,UAAU,YAAa,WAAW,GAAG,IAAI,SA0C9C,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
1
+ {"version":3,"file":"useRefresh.d.ts","sourceRoot":"","sources":["../../../src/nextjs/hooks/useRefresh.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAM9C,QAAA,MAAM,UAAU,YAAa,WAAW,GAAG,IAAI;;CAqD9C,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -1,9 +1,10 @@
1
1
  import { useCivicAuthConfig } from "../../shared/hooks/useCivicAuthConfig.js";
2
2
  import { useEffect, useState } from "react";
3
- import { NextClientAuthenticationRefresher } from "../../nextjs/NextClientAuthenticationRefresher.js";
4
3
  import { BrowserCookieStorage } from "../../shared/index.js";
5
4
  import { resolveAuthConfig } from "../config.js";
5
+ import { NextClientAuthenticationRefresher } from "../NextClientAuthenticationRefresher.js";
6
6
  const useRefresh = (session) => {
7
+ const [error, setError] = useState();
7
8
  const authConfig = useCivicAuthConfig();
8
9
  // setup token autorefresh
9
10
  const [refresher, setRefresher] = useState(undefined);
@@ -14,7 +15,12 @@ const useRefresh = (session) => {
14
15
  const currentRefresher = refresher;
15
16
  const config = resolveAuthConfig(authConfig ?? {});
16
17
  const storage = new BrowserCookieStorage(config.cookies.tokens.access_token);
17
- NextClientAuthenticationRefresher.build({ ...authConfig }, storage).then((newRefresher) => {
18
+ const onError = async (error) => {
19
+ console.error("Error refreshing token", error);
20
+ refresher?.clearAutorefresh();
21
+ setError(error);
22
+ };
23
+ NextClientAuthenticationRefresher.build({ ...authConfig }, storage, onError).then((newRefresher) => {
18
24
  if (abortController.signal.aborted)
19
25
  return;
20
26
  currentRefresher?.clearAutorefresh();
@@ -35,6 +41,9 @@ const useRefresh = (session) => {
35
41
  }
36
42
  return () => refresher?.clearAutorefresh();
37
43
  }, [refresher, session?.authenticated]);
44
+ return {
45
+ error,
46
+ };
38
47
  };
39
48
  export { useRefresh };
40
49
  //# sourceMappingURL=useRefresh.js.map