@civic/auth 0.3.6 → 0.3.8-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (857) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/dist/cjs/browser/storage.d.ts +10 -0
  3. package/dist/cjs/browser/storage.d.ts.map +1 -0
  4. package/dist/cjs/browser/storage.js +24 -0
  5. package/dist/cjs/browser/storage.js.map +1 -0
  6. package/dist/cjs/config.d.ts +3 -0
  7. package/dist/cjs/config.d.ts.map +1 -0
  8. package/dist/cjs/config.js +8 -0
  9. package/dist/cjs/config.js.map +1 -0
  10. package/dist/cjs/constants.d.ts +15 -0
  11. package/dist/cjs/constants.d.ts.map +1 -0
  12. package/dist/cjs/constants.js +44 -0
  13. package/dist/cjs/constants.js.map +1 -0
  14. package/dist/cjs/index.d.ts +8 -0
  15. package/dist/cjs/index.d.ts.map +1 -0
  16. package/dist/cjs/index.js +11 -0
  17. package/dist/cjs/index.js.map +1 -0
  18. package/dist/cjs/lib/cookies.d.ts +7 -0
  19. package/dist/cjs/lib/cookies.d.ts.map +1 -0
  20. package/dist/cjs/lib/cookies.js +29 -0
  21. package/dist/cjs/lib/cookies.js.map +1 -0
  22. package/dist/cjs/lib/jwt.d.ts +3 -0
  23. package/dist/cjs/lib/jwt.d.ts.map +1 -0
  24. package/dist/cjs/lib/jwt.js +13 -0
  25. package/dist/cjs/lib/jwt.js.map +1 -0
  26. package/dist/cjs/lib/logger.d.ts +26 -0
  27. package/dist/cjs/lib/logger.d.ts.map +1 -0
  28. package/dist/cjs/lib/logger.js +62 -0
  29. package/dist/cjs/lib/logger.js.map +1 -0
  30. package/dist/cjs/lib/oauth.d.ts +19 -0
  31. package/dist/cjs/lib/oauth.d.ts.map +1 -0
  32. package/dist/cjs/lib/oauth.js +74 -0
  33. package/dist/cjs/lib/oauth.js.map +1 -0
  34. package/dist/cjs/lib/obj.d.ts +3 -0
  35. package/dist/cjs/lib/obj.d.ts.map +1 -0
  36. package/dist/cjs/lib/obj.js +21 -0
  37. package/dist/cjs/lib/obj.js.map +1 -0
  38. package/dist/cjs/lib/postMessage.d.ts +4 -0
  39. package/dist/cjs/lib/postMessage.d.ts.map +1 -0
  40. package/dist/cjs/lib/postMessage.js +16 -0
  41. package/dist/cjs/lib/postMessage.js.map +1 -0
  42. package/dist/cjs/lib/windowUtil.d.ts +4 -0
  43. package/dist/cjs/lib/windowUtil.d.ts.map +1 -0
  44. package/dist/cjs/lib/windowUtil.js +35 -0
  45. package/dist/cjs/lib/windowUtil.js.map +1 -0
  46. package/dist/cjs/nextjs/GetUser.d.ts +6 -0
  47. package/dist/cjs/nextjs/GetUser.d.ts.map +1 -0
  48. package/dist/cjs/nextjs/GetUser.js +11 -0
  49. package/dist/cjs/nextjs/GetUser.js.map +1 -0
  50. package/dist/cjs/nextjs/NextAuthenticationRefresherImpl.d.ts +11 -0
  51. package/dist/cjs/nextjs/NextAuthenticationRefresherImpl.d.ts.map +1 -0
  52. package/dist/cjs/nextjs/NextAuthenticationRefresherImpl.js +21 -0
  53. package/dist/cjs/nextjs/NextAuthenticationRefresherImpl.js.map +1 -0
  54. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.d.ts +8 -0
  55. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.d.ts.map +1 -0
  56. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js +28 -0
  57. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js.map +1 -0
  58. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.d.ts +12 -0
  59. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +1 -0
  60. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.js +29 -0
  61. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.js.map +1 -0
  62. package/dist/cjs/nextjs/config.d.ts +209 -0
  63. package/dist/cjs/nextjs/config.d.ts.map +1 -0
  64. package/dist/cjs/nextjs/config.js +191 -0
  65. package/dist/cjs/nextjs/config.js.map +1 -0
  66. package/dist/cjs/nextjs/cookies.d.ts +16 -0
  67. package/dist/cjs/nextjs/cookies.d.ts.map +1 -0
  68. package/dist/cjs/nextjs/cookies.js +44 -0
  69. package/dist/cjs/nextjs/cookies.js.map +1 -0
  70. package/dist/cjs/nextjs/hooks/index.d.ts +2 -0
  71. package/dist/cjs/nextjs/hooks/index.d.ts.map +1 -0
  72. package/dist/cjs/nextjs/hooks/index.js +6 -0
  73. package/dist/cjs/nextjs/hooks/index.js.map +1 -0
  74. package/dist/cjs/nextjs/hooks/usePrevious.d.ts +2 -0
  75. package/dist/cjs/nextjs/hooks/usePrevious.d.ts.map +1 -0
  76. package/dist/cjs/nextjs/hooks/usePrevious.js +12 -0
  77. package/dist/cjs/nextjs/hooks/usePrevious.js.map +1 -0
  78. package/dist/cjs/nextjs/hooks/useRefresh.d.ts +6 -0
  79. package/dist/cjs/nextjs/hooks/useRefresh.d.ts.map +1 -0
  80. package/dist/cjs/nextjs/hooks/useRefresh.js +51 -0
  81. package/dist/cjs/nextjs/hooks/useRefresh.js.map +1 -0
  82. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts +8 -0
  83. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  84. package/dist/cjs/nextjs/hooks/useUserCookie.js +93 -0
  85. package/dist/cjs/nextjs/hooks/useUserCookie.js.map +1 -0
  86. package/dist/cjs/nextjs/index.d.ts +9 -0
  87. package/dist/cjs/nextjs/index.d.ts.map +1 -0
  88. package/dist/cjs/nextjs/index.js +27 -0
  89. package/dist/cjs/nextjs/index.js.map +1 -0
  90. package/dist/cjs/nextjs/middleware/index.d.ts +2 -0
  91. package/dist/cjs/nextjs/middleware/index.d.ts.map +1 -0
  92. package/dist/cjs/nextjs/middleware/index.js +10 -0
  93. package/dist/cjs/nextjs/middleware/index.js.map +1 -0
  94. package/dist/cjs/nextjs/middleware.d.ts +57 -0
  95. package/dist/cjs/nextjs/middleware.d.ts.map +1 -0
  96. package/dist/cjs/nextjs/middleware.js +110 -0
  97. package/dist/cjs/nextjs/middleware.js.map +1 -0
  98. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +9 -0
  99. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  100. package/dist/cjs/nextjs/providers/NextAuthProvider.js +108 -0
  101. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -0
  102. package/dist/cjs/nextjs/routeHandler.d.ts +19 -0
  103. package/dist/cjs/nextjs/routeHandler.d.ts.map +1 -0
  104. package/dist/cjs/nextjs/routeHandler.js +325 -0
  105. package/dist/cjs/nextjs/routeHandler.js.map +1 -0
  106. package/dist/cjs/nextjs/utils.d.ts +3 -0
  107. package/dist/cjs/nextjs/utils.d.ts.map +1 -0
  108. package/dist/cjs/nextjs/utils.js +9 -0
  109. package/dist/cjs/nextjs/utils.js.map +1 -0
  110. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts +17 -0
  111. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -0
  112. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js +40 -0
  113. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js.map +1 -0
  114. package/dist/cjs/reactjs/components/LoadingSpinner.d.ts +7 -0
  115. package/dist/cjs/reactjs/components/LoadingSpinner.d.ts.map +1 -0
  116. package/dist/cjs/reactjs/components/LoadingSpinner.js +33 -0
  117. package/dist/cjs/reactjs/components/LoadingSpinner.js.map +1 -0
  118. package/dist/cjs/reactjs/components/SignInButton.d.ts +9 -0
  119. package/dist/cjs/reactjs/components/SignInButton.d.ts.map +1 -0
  120. package/dist/cjs/reactjs/components/SignInButton.js +31 -0
  121. package/dist/cjs/reactjs/components/SignInButton.js.map +1 -0
  122. package/dist/cjs/reactjs/components/SignOutButton.d.ts +7 -0
  123. package/dist/cjs/reactjs/components/SignOutButton.d.ts.map +1 -0
  124. package/dist/cjs/reactjs/components/SignOutButton.js +27 -0
  125. package/dist/cjs/reactjs/components/SignOutButton.js.map +1 -0
  126. package/dist/cjs/reactjs/components/UserButton.d.ts +9 -0
  127. package/dist/cjs/reactjs/components/UserButton.d.ts.map +1 -0
  128. package/dist/cjs/reactjs/components/UserButton.js +145 -0
  129. package/dist/cjs/reactjs/components/UserButton.js.map +1 -0
  130. package/dist/cjs/reactjs/components/index.d.ts +6 -0
  131. package/dist/cjs/reactjs/components/index.d.ts.map +1 -0
  132. package/dist/cjs/reactjs/components/index.js +14 -0
  133. package/dist/cjs/reactjs/components/index.js.map +1 -0
  134. package/dist/cjs/reactjs/components/utils.d.ts +13 -0
  135. package/dist/cjs/reactjs/components/utils.d.ts.map +1 -0
  136. package/dist/cjs/reactjs/components/utils.js +31 -0
  137. package/dist/cjs/reactjs/components/utils.js.map +1 -0
  138. package/dist/cjs/reactjs/hooks/index.d.ts +3 -0
  139. package/dist/cjs/reactjs/hooks/index.d.ts.map +1 -0
  140. package/dist/cjs/reactjs/hooks/index.js +8 -0
  141. package/dist/cjs/reactjs/hooks/index.js.map +1 -0
  142. package/dist/cjs/reactjs/hooks/useAuth.d.ts +3 -0
  143. package/dist/cjs/reactjs/hooks/useAuth.d.ts.map +1 -0
  144. package/dist/cjs/reactjs/hooks/useAuth.js +15 -0
  145. package/dist/cjs/reactjs/hooks/useAuth.js.map +1 -0
  146. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  147. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  148. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js +16 -0
  149. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  150. package/dist/cjs/reactjs/hooks/useSignIn.d.ts +6 -0
  151. package/dist/cjs/reactjs/hooks/useSignIn.d.ts.map +1 -0
  152. package/dist/cjs/reactjs/hooks/useSignIn.js +38 -0
  153. package/dist/cjs/reactjs/hooks/useSignIn.js.map +1 -0
  154. package/dist/cjs/reactjs/hooks/useUser.d.ts +4 -0
  155. package/dist/cjs/reactjs/hooks/useUser.d.ts.map +1 -0
  156. package/dist/cjs/reactjs/hooks/useUser.js +15 -0
  157. package/dist/cjs/reactjs/hooks/useUser.js.map +1 -0
  158. package/dist/cjs/reactjs/index.d.ts +6 -0
  159. package/dist/cjs/reactjs/index.d.ts.map +1 -0
  160. package/dist/cjs/reactjs/index.js +32 -0
  161. package/dist/cjs/reactjs/index.js.map +1 -0
  162. package/dist/cjs/reactjs/providers/AuthProvider.d.ts +10 -0
  163. package/dist/cjs/reactjs/providers/AuthProvider.d.ts.map +1 -0
  164. package/dist/cjs/reactjs/providers/AuthProvider.js +99 -0
  165. package/dist/cjs/reactjs/providers/AuthProvider.js.map +1 -0
  166. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts +5 -0
  167. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  168. package/dist/cjs/reactjs/providers/CivicAuthProvider.js +29 -0
  169. package/dist/cjs/reactjs/providers/CivicAuthProvider.js.map +1 -0
  170. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  171. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  172. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js +146 -0
  173. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  174. package/dist/cjs/reactjs/providers/index.d.ts +8 -0
  175. package/dist/cjs/reactjs/providers/index.d.ts.map +1 -0
  176. package/dist/cjs/reactjs/providers/index.js +19 -0
  177. package/dist/cjs/reactjs/providers/index.js.map +1 -0
  178. package/dist/cjs/server/ServerAuthenticationResolver.d.ts +20 -0
  179. package/dist/cjs/server/ServerAuthenticationResolver.d.ts.map +1 -0
  180. package/dist/cjs/server/ServerAuthenticationResolver.js +71 -0
  181. package/dist/cjs/server/ServerAuthenticationResolver.js.map +1 -0
  182. package/dist/cjs/server/config.d.ts +11 -0
  183. package/dist/cjs/server/config.d.ts.map +1 -0
  184. package/dist/cjs/server/config.js +3 -0
  185. package/dist/cjs/server/config.js.map +1 -0
  186. package/dist/cjs/server/index.d.ts +9 -0
  187. package/dist/cjs/server/index.d.ts.map +1 -0
  188. package/dist/cjs/server/index.js +21 -0
  189. package/dist/cjs/server/index.js.map +1 -0
  190. package/dist/cjs/server/login.d.ts +17 -0
  191. package/dist/cjs/server/login.d.ts.map +1 -0
  192. package/dist/cjs/server/login.js +42 -0
  193. package/dist/cjs/server/login.js.map +1 -0
  194. package/dist/cjs/server/logout.d.ts +7 -0
  195. package/dist/cjs/server/logout.d.ts.map +1 -0
  196. package/dist/cjs/server/logout.js +26 -0
  197. package/dist/cjs/server/logout.js.map +1 -0
  198. package/dist/cjs/server/refresh.d.ts +7 -0
  199. package/dist/cjs/server/refresh.d.ts.map +1 -0
  200. package/dist/cjs/server/refresh.js +19 -0
  201. package/dist/cjs/server/refresh.js.map +1 -0
  202. package/dist/cjs/services/AuthenticationService.d.ts +93 -0
  203. package/dist/cjs/services/AuthenticationService.d.ts.map +1 -0
  204. package/dist/cjs/services/AuthenticationService.js +367 -0
  205. package/dist/cjs/services/AuthenticationService.js.map +1 -0
  206. package/dist/cjs/services/PKCE.d.ts +20 -0
  207. package/dist/cjs/services/PKCE.d.ts.map +1 -0
  208. package/dist/cjs/services/PKCE.js +50 -0
  209. package/dist/cjs/services/PKCE.js.map +1 -0
  210. package/dist/cjs/services/types.d.ts +24 -0
  211. package/dist/cjs/services/types.d.ts.map +1 -0
  212. package/dist/cjs/services/types.js +11 -0
  213. package/dist/cjs/services/types.js.map +1 -0
  214. package/dist/cjs/shared/components/BlockDisplay.d.ts +6 -0
  215. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +1 -0
  216. package/dist/cjs/shared/components/BlockDisplay.js +32 -0
  217. package/dist/cjs/shared/components/BlockDisplay.js.map +1 -0
  218. package/dist/cjs/shared/components/CivicAuthIframe.d.ts +9 -0
  219. package/dist/cjs/shared/components/CivicAuthIframe.d.ts.map +1 -0
  220. package/dist/cjs/shared/components/CivicAuthIframe.js +72 -0
  221. package/dist/cjs/shared/components/CivicAuthIframe.js.map +1 -0
  222. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts +14 -0
  223. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  224. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +158 -0
  225. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +1 -0
  226. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts +6 -0
  227. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  228. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js +21 -0
  229. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  230. package/dist/cjs/shared/components/CloseIcon.d.ts +3 -0
  231. package/dist/cjs/shared/components/CloseIcon.d.ts.map +1 -0
  232. package/dist/cjs/shared/components/CloseIcon.js +7 -0
  233. package/dist/cjs/shared/components/CloseIcon.js.map +1 -0
  234. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +7 -0
  235. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -0
  236. package/dist/cjs/shared/components/IFrameAndLoading.js +39 -0
  237. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -0
  238. package/dist/cjs/shared/components/LoadingIcon.d.ts +6 -0
  239. package/dist/cjs/shared/components/LoadingIcon.d.ts.map +1 -0
  240. package/dist/cjs/shared/components/LoadingIcon.js +28 -0
  241. package/dist/cjs/shared/components/LoadingIcon.js.map +1 -0
  242. package/dist/cjs/shared/components/SVGLoading.d.ts +4 -0
  243. package/dist/cjs/shared/components/SVGLoading.d.ts.map +1 -0
  244. package/dist/cjs/shared/components/SVGLoading.js +30 -0
  245. package/dist/cjs/shared/components/SVGLoading.js.map +1 -0
  246. package/dist/cjs/shared/hooks/index.d.ts +11 -0
  247. package/dist/cjs/shared/hooks/index.d.ts.map +1 -0
  248. package/dist/cjs/shared/hooks/index.js +24 -0
  249. package/dist/cjs/shared/hooks/index.js.map +1 -0
  250. package/dist/cjs/shared/hooks/useAuth.d.ts +3 -0
  251. package/dist/cjs/shared/hooks/useAuth.d.ts.map +1 -0
  252. package/dist/cjs/shared/hooks/useAuth.js +15 -0
  253. package/dist/cjs/shared/hooks/useAuth.js.map +1 -0
  254. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  255. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  256. package/dist/cjs/shared/hooks/useCivicAuthConfig.js +13 -0
  257. package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +1 -0
  258. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  259. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  260. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +16 -0
  261. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  262. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts +3 -0
  263. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  264. package/dist/cjs/shared/hooks/useCurrentUrl.js +27 -0
  265. package/dist/cjs/shared/hooks/useCurrentUrl.js.map +1 -0
  266. package/dist/cjs/shared/hooks/useIframe.d.ts +3 -0
  267. package/dist/cjs/shared/hooks/useIframe.d.ts.map +1 -0
  268. package/dist/cjs/shared/hooks/useIframe.js +16 -0
  269. package/dist/cjs/shared/hooks/useIframe.js.map +1 -0
  270. package/dist/cjs/shared/hooks/useIsInIframe.d.ts +3 -0
  271. package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +1 -0
  272. package/dist/cjs/shared/hooks/useIsInIframe.js +17 -0
  273. package/dist/cjs/shared/hooks/useIsInIframe.js.map +1 -0
  274. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  275. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  276. package/dist/cjs/shared/hooks/useOAuthEndpoints.js +17 -0
  277. package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +1 -0
  278. package/dist/cjs/shared/hooks/useRefresh.d.ts +6 -0
  279. package/dist/cjs/shared/hooks/useRefresh.d.ts.map +1 -0
  280. package/dist/cjs/shared/hooks/useRefresh.js +49 -0
  281. package/dist/cjs/shared/hooks/useRefresh.js.map +1 -0
  282. package/dist/cjs/shared/hooks/useSession.d.ts +3 -0
  283. package/dist/cjs/shared/hooks/useSession.d.ts.map +1 -0
  284. package/dist/cjs/shared/hooks/useSession.js +16 -0
  285. package/dist/cjs/shared/hooks/useSession.js.map +1 -0
  286. package/dist/cjs/shared/hooks/useSignIn.d.ts +17 -0
  287. package/dist/cjs/shared/hooks/useSignIn.d.ts.map +1 -0
  288. package/dist/cjs/shared/hooks/useSignIn.js +171 -0
  289. package/dist/cjs/shared/hooks/useSignIn.js.map +1 -0
  290. package/dist/cjs/shared/hooks/useToken.d.ts +3 -0
  291. package/dist/cjs/shared/hooks/useToken.d.ts.map +1 -0
  292. package/dist/cjs/shared/hooks/useToken.js +15 -0
  293. package/dist/cjs/shared/hooks/useToken.js.map +1 -0
  294. package/dist/cjs/shared/hooks/useWindowFocused.d.ts +5 -0
  295. package/dist/cjs/shared/hooks/useWindowFocused.d.ts.map +1 -0
  296. package/dist/cjs/shared/hooks/useWindowFocused.js +24 -0
  297. package/dist/cjs/shared/hooks/useWindowFocused.js.map +1 -0
  298. package/dist/cjs/shared/index.d.ts +7 -0
  299. package/dist/cjs/shared/index.d.ts.map +1 -0
  300. package/dist/cjs/shared/index.js +25 -0
  301. package/dist/cjs/shared/index.js.map +1 -0
  302. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts +14 -0
  303. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -0
  304. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js +55 -0
  305. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js.map +1 -0
  306. package/dist/cjs/shared/lib/BrowserAuthenticationRefresher.d.ts +11 -0
  307. package/dist/cjs/shared/lib/BrowserAuthenticationRefresher.d.ts.map +1 -0
  308. package/dist/cjs/shared/lib/BrowserAuthenticationRefresher.js +63 -0
  309. package/dist/cjs/shared/lib/BrowserAuthenticationRefresher.js.map +1 -0
  310. package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts +9 -0
  311. package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts.map +1 -0
  312. package/dist/cjs/shared/lib/BrowserCookieStorage.js +60 -0
  313. package/dist/cjs/shared/lib/BrowserCookieStorage.js.map +1 -0
  314. package/dist/cjs/shared/lib/GenericAuthenticationRefresher copy.d.ts +18 -0
  315. package/dist/cjs/shared/lib/GenericAuthenticationRefresher copy.d.ts.map +1 -0
  316. package/dist/cjs/shared/lib/GenericAuthenticationRefresher copy.js +85 -0
  317. package/dist/cjs/shared/lib/GenericAuthenticationRefresher copy.js.map +1 -0
  318. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts +14 -0
  319. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  320. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +38 -0
  321. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  322. package/dist/cjs/shared/lib/UserSession.d.ts +17 -0
  323. package/dist/cjs/shared/lib/UserSession.d.ts.map +1 -0
  324. package/dist/cjs/shared/lib/UserSession.js +27 -0
  325. package/dist/cjs/shared/lib/UserSession.js.map +1 -0
  326. package/dist/cjs/shared/lib/iframeUtils.d.ts +6 -0
  327. package/dist/cjs/shared/lib/iframeUtils.d.ts.map +1 -0
  328. package/dist/cjs/shared/lib/iframeUtils.js +11 -0
  329. package/dist/cjs/shared/lib/iframeUtils.js.map +1 -0
  330. package/dist/cjs/shared/lib/session.d.ts +4 -0
  331. package/dist/cjs/shared/lib/session.d.ts.map +1 -0
  332. package/dist/cjs/shared/lib/session.js +48 -0
  333. package/dist/cjs/shared/lib/session.js.map +1 -0
  334. package/dist/cjs/shared/lib/storage.d.ts +35 -0
  335. package/dist/cjs/shared/lib/storage.d.ts.map +1 -0
  336. package/dist/cjs/shared/lib/storage.js +21 -0
  337. package/dist/cjs/shared/lib/storage.js.map +1 -0
  338. package/dist/cjs/shared/lib/types.d.ts +39 -0
  339. package/dist/cjs/shared/lib/types.d.ts.map +1 -0
  340. package/dist/cjs/shared/lib/types.js +22 -0
  341. package/dist/cjs/shared/lib/types.js.map +1 -0
  342. package/dist/cjs/shared/lib/util.d.ts +40 -0
  343. package/dist/cjs/shared/lib/util.d.ts.map +1 -0
  344. package/dist/cjs/shared/lib/util.js +252 -0
  345. package/dist/cjs/shared/lib/util.js.map +1 -0
  346. package/dist/cjs/shared/providers/AuthContext.d.ts +12 -0
  347. package/dist/cjs/shared/providers/AuthContext.d.ts.map +1 -0
  348. package/dist/cjs/shared/providers/AuthContext.js +7 -0
  349. package/dist/cjs/shared/providers/AuthContext.js.map +1 -0
  350. package/dist/cjs/shared/providers/AuthProvider.d.ts +22 -0
  351. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +1 -0
  352. package/dist/cjs/shared/providers/AuthProvider.js +108 -0
  353. package/dist/cjs/shared/providers/AuthProvider.js.map +1 -0
  354. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +19 -0
  355. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  356. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +59 -0
  357. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +1 -0
  358. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts +6 -0
  359. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  360. package/dist/cjs/shared/providers/CivicAuthProvider.js +38 -0
  361. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +1 -0
  362. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  363. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  364. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +168 -0
  365. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  366. package/dist/cjs/shared/providers/IframeProvider.d.ts +25 -0
  367. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +1 -0
  368. package/dist/cjs/shared/providers/IframeProvider.js +63 -0
  369. package/dist/cjs/shared/providers/IframeProvider.js.map +1 -0
  370. package/dist/cjs/shared/providers/SessionProvider.d.ts +19 -0
  371. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +1 -0
  372. package/dist/cjs/shared/providers/SessionProvider.js +28 -0
  373. package/dist/cjs/shared/providers/SessionProvider.js.map +1 -0
  374. package/dist/cjs/shared/providers/TokenProvider.d.ts +17 -0
  375. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -0
  376. package/dist/cjs/shared/providers/TokenProvider.js +39 -0
  377. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -0
  378. package/dist/cjs/shared/providers/UserProvider.d.ts +26 -0
  379. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -0
  380. package/dist/cjs/shared/providers/UserProvider.js +69 -0
  381. package/dist/cjs/shared/providers/UserProvider.js.map +1 -0
  382. package/dist/cjs/shared/providers/types.d.ts +15 -0
  383. package/dist/cjs/shared/providers/types.d.ts.map +1 -0
  384. package/dist/cjs/shared/providers/types.js +3 -0
  385. package/dist/cjs/shared/providers/types.js.map +1 -0
  386. package/dist/cjs/shared/version.d.ts +2 -0
  387. package/dist/cjs/shared/version.d.ts.map +1 -0
  388. package/dist/cjs/shared/version.js +6 -0
  389. package/dist/cjs/shared/version.js.map +1 -0
  390. package/dist/cjs/types.d.ts +163 -0
  391. package/dist/cjs/types.d.ts.map +1 -0
  392. package/dist/cjs/types.js +20 -0
  393. package/dist/cjs/types.js.map +1 -0
  394. package/dist/cjs/utils.d.ts +15 -0
  395. package/dist/cjs/utils.d.ts.map +1 -0
  396. package/dist/cjs/utils.js +47 -0
  397. package/dist/cjs/utils.js.map +1 -0
  398. package/dist/cjs/version.d.ts +2 -0
  399. package/dist/cjs/version.d.ts.map +1 -0
  400. package/dist/cjs/version.js +6 -0
  401. package/dist/cjs/version.js.map +1 -0
  402. package/dist/esm/browser/storage.d.ts +10 -0
  403. package/dist/esm/browser/storage.d.ts.map +1 -0
  404. package/dist/esm/browser/storage.js +20 -0
  405. package/dist/esm/browser/storage.js.map +1 -0
  406. package/dist/esm/config.d.ts +3 -0
  407. package/dist/esm/config.d.ts.map +1 -0
  408. package/dist/esm/config.js +5 -0
  409. package/dist/esm/config.js.map +1 -0
  410. package/dist/esm/constants.d.ts +15 -0
  411. package/dist/esm/constants.d.ts.map +1 -0
  412. package/dist/esm/constants.js +29 -0
  413. package/dist/esm/constants.js.map +1 -0
  414. package/dist/esm/index.d.ts +8 -0
  415. package/dist/esm/index.d.ts.map +1 -0
  416. package/dist/esm/index.js +6 -0
  417. package/dist/esm/index.js.map +1 -0
  418. package/dist/esm/lib/cookies.d.ts +7 -0
  419. package/dist/esm/lib/cookies.d.ts.map +1 -0
  420. package/dist/esm/lib/cookies.js +26 -0
  421. package/dist/esm/lib/cookies.js.map +1 -0
  422. package/dist/esm/lib/jwt.d.ts +3 -0
  423. package/dist/esm/lib/jwt.d.ts.map +1 -0
  424. package/dist/esm/lib/jwt.js +9 -0
  425. package/dist/esm/lib/jwt.js.map +1 -0
  426. package/dist/esm/lib/logger.d.ts +26 -0
  427. package/dist/esm/lib/logger.d.ts.map +1 -0
  428. package/dist/esm/lib/logger.js +55 -0
  429. package/dist/esm/lib/logger.js.map +1 -0
  430. package/dist/esm/lib/oauth.d.ts +19 -0
  431. package/dist/esm/lib/oauth.d.ts.map +1 -0
  432. package/dist/esm/lib/oauth.js +67 -0
  433. package/dist/esm/lib/oauth.js.map +1 -0
  434. package/dist/esm/lib/obj.d.ts +3 -0
  435. package/dist/esm/lib/obj.d.ts.map +1 -0
  436. package/dist/esm/lib/obj.js +18 -0
  437. package/dist/esm/lib/obj.js.map +1 -0
  438. package/dist/esm/lib/postMessage.d.ts +4 -0
  439. package/dist/esm/lib/postMessage.d.ts.map +1 -0
  440. package/dist/esm/lib/postMessage.js +13 -0
  441. package/dist/esm/lib/postMessage.js.map +1 -0
  442. package/dist/esm/lib/windowUtil.d.ts +4 -0
  443. package/dist/esm/lib/windowUtil.d.ts.map +1 -0
  444. package/dist/esm/lib/windowUtil.js +31 -0
  445. package/dist/esm/lib/windowUtil.js.map +1 -0
  446. package/dist/esm/nextjs/GetUser.d.ts +6 -0
  447. package/dist/esm/nextjs/GetUser.d.ts.map +1 -0
  448. package/dist/esm/nextjs/GetUser.js +7 -0
  449. package/dist/esm/nextjs/GetUser.js.map +1 -0
  450. package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts +8 -0
  451. package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts.map +1 -0
  452. package/dist/esm/nextjs/NextClientAuthenticationRefresher.js +24 -0
  453. package/dist/esm/nextjs/NextClientAuthenticationRefresher.js.map +1 -0
  454. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.d.ts +12 -0
  455. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +1 -0
  456. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.js +25 -0
  457. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.js.map +1 -0
  458. package/dist/esm/nextjs/config.d.ts +209 -0
  459. package/dist/esm/nextjs/config.d.ts.map +1 -0
  460. package/dist/esm/nextjs/config.js +186 -0
  461. package/dist/esm/nextjs/config.js.map +1 -0
  462. package/dist/esm/nextjs/cookies.d.ts +16 -0
  463. package/dist/esm/nextjs/cookies.d.ts.map +1 -0
  464. package/dist/esm/nextjs/cookies.js +41 -0
  465. package/dist/esm/nextjs/cookies.js.map +1 -0
  466. package/dist/esm/nextjs/hooks/index.d.ts +2 -0
  467. package/dist/esm/nextjs/hooks/index.d.ts.map +1 -0
  468. package/dist/esm/nextjs/hooks/index.js +2 -0
  469. package/dist/esm/nextjs/hooks/index.js.map +1 -0
  470. package/dist/esm/nextjs/hooks/usePrevious.d.ts +2 -0
  471. package/dist/esm/nextjs/hooks/usePrevious.d.ts.map +1 -0
  472. package/dist/esm/nextjs/hooks/usePrevious.js +9 -0
  473. package/dist/esm/nextjs/hooks/usePrevious.js.map +1 -0
  474. package/dist/esm/nextjs/hooks/useRefresh.d.ts +6 -0
  475. package/dist/esm/nextjs/hooks/useRefresh.d.ts.map +1 -0
  476. package/dist/esm/nextjs/hooks/useRefresh.js +48 -0
  477. package/dist/esm/nextjs/hooks/useRefresh.js.map +1 -0
  478. package/dist/esm/nextjs/hooks/useUserCookie.d.ts +8 -0
  479. package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  480. package/dist/esm/nextjs/hooks/useUserCookie.js +89 -0
  481. package/dist/esm/nextjs/hooks/useUserCookie.js.map +1 -0
  482. package/dist/esm/nextjs/index.d.ts +9 -0
  483. package/dist/esm/nextjs/index.d.ts.map +1 -0
  484. package/dist/esm/nextjs/index.js +17 -0
  485. package/dist/esm/nextjs/index.js.map +1 -0
  486. package/dist/esm/nextjs/middleware/index.d.ts +2 -0
  487. package/dist/esm/nextjs/middleware/index.d.ts.map +1 -0
  488. package/dist/esm/nextjs/middleware/index.js +4 -0
  489. package/dist/esm/nextjs/middleware/index.js.map +1 -0
  490. package/dist/esm/nextjs/middleware.d.ts +57 -0
  491. package/dist/esm/nextjs/middleware.d.ts.map +1 -0
  492. package/dist/esm/nextjs/middleware.js +101 -0
  493. package/dist/esm/nextjs/middleware.js.map +1 -0
  494. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +9 -0
  495. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  496. package/dist/esm/nextjs/providers/NextAuthProvider.js +105 -0
  497. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -0
  498. package/dist/esm/nextjs/routeHandler.d.ts +19 -0
  499. package/dist/esm/nextjs/routeHandler.d.ts.map +1 -0
  500. package/dist/esm/nextjs/routeHandler.js +319 -0
  501. package/dist/esm/nextjs/routeHandler.js.map +1 -0
  502. package/dist/esm/nextjs/utils.d.ts +3 -0
  503. package/dist/esm/nextjs/utils.d.ts.map +1 -0
  504. package/dist/esm/nextjs/utils.js +5 -0
  505. package/dist/esm/nextjs/utils.js.map +1 -0
  506. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts +17 -0
  507. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -0
  508. package/dist/esm/reactjs/components/ButtonContentOrLoader.js +37 -0
  509. package/dist/esm/reactjs/components/ButtonContentOrLoader.js.map +1 -0
  510. package/dist/esm/reactjs/components/SignInButton.d.ts +9 -0
  511. package/dist/esm/reactjs/components/SignInButton.d.ts.map +1 -0
  512. package/dist/esm/reactjs/components/SignInButton.js +28 -0
  513. package/dist/esm/reactjs/components/SignInButton.js.map +1 -0
  514. package/dist/esm/reactjs/components/SignOutButton.d.ts +7 -0
  515. package/dist/esm/reactjs/components/SignOutButton.d.ts.map +1 -0
  516. package/dist/esm/reactjs/components/SignOutButton.js +24 -0
  517. package/dist/esm/reactjs/components/SignOutButton.js.map +1 -0
  518. package/dist/esm/reactjs/components/UserButton.d.ts +9 -0
  519. package/dist/esm/reactjs/components/UserButton.d.ts.map +1 -0
  520. package/dist/esm/reactjs/components/UserButton.js +142 -0
  521. package/dist/esm/reactjs/components/UserButton.js.map +1 -0
  522. package/dist/esm/reactjs/components/index.d.ts +6 -0
  523. package/dist/esm/reactjs/components/index.d.ts.map +1 -0
  524. package/dist/esm/reactjs/components/index.js +6 -0
  525. package/dist/esm/reactjs/components/index.js.map +1 -0
  526. package/dist/esm/reactjs/components/utils.d.ts +13 -0
  527. package/dist/esm/reactjs/components/utils.d.ts.map +1 -0
  528. package/dist/esm/reactjs/components/utils.js +27 -0
  529. package/dist/esm/reactjs/components/utils.js.map +1 -0
  530. package/dist/esm/reactjs/hooks/index.d.ts +3 -0
  531. package/dist/esm/reactjs/hooks/index.d.ts.map +1 -0
  532. package/dist/esm/reactjs/hooks/index.js +3 -0
  533. package/dist/esm/reactjs/hooks/index.js.map +1 -0
  534. package/dist/esm/reactjs/hooks/useAuth.d.ts +3 -0
  535. package/dist/esm/reactjs/hooks/useAuth.d.ts.map +1 -0
  536. package/dist/esm/reactjs/hooks/useAuth.js +12 -0
  537. package/dist/esm/reactjs/hooks/useAuth.js.map +1 -0
  538. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  539. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  540. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js +13 -0
  541. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  542. package/dist/esm/reactjs/hooks/useSignIn.d.ts +6 -0
  543. package/dist/esm/reactjs/hooks/useSignIn.d.ts.map +1 -0
  544. package/dist/esm/reactjs/hooks/useSignIn.js +34 -0
  545. package/dist/esm/reactjs/hooks/useSignIn.js.map +1 -0
  546. package/dist/esm/reactjs/hooks/useUser.d.ts +4 -0
  547. package/dist/esm/reactjs/hooks/useUser.d.ts.map +1 -0
  548. package/dist/esm/reactjs/hooks/useUser.js +12 -0
  549. package/dist/esm/reactjs/hooks/useUser.js.map +1 -0
  550. package/dist/esm/reactjs/index.d.ts +6 -0
  551. package/dist/esm/reactjs/index.d.ts.map +1 -0
  552. package/dist/esm/reactjs/index.js +10 -0
  553. package/dist/esm/reactjs/index.js.map +1 -0
  554. package/dist/esm/reactjs/providers/AuthProvider.d.ts +10 -0
  555. package/dist/esm/reactjs/providers/AuthProvider.d.ts.map +1 -0
  556. package/dist/esm/reactjs/providers/AuthProvider.js +97 -0
  557. package/dist/esm/reactjs/providers/AuthProvider.js.map +1 -0
  558. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts +5 -0
  559. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  560. package/dist/esm/reactjs/providers/CivicAuthProvider.js +27 -0
  561. package/dist/esm/reactjs/providers/CivicAuthProvider.js.map +1 -0
  562. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  563. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  564. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js +142 -0
  565. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  566. package/dist/esm/reactjs/providers/index.d.ts +8 -0
  567. package/dist/esm/reactjs/providers/index.d.ts.map +1 -0
  568. package/dist/esm/reactjs/providers/index.js +7 -0
  569. package/dist/esm/reactjs/providers/index.js.map +1 -0
  570. package/dist/esm/server/ServerAuthenticationResolver.d.ts +20 -0
  571. package/dist/esm/server/ServerAuthenticationResolver.d.ts.map +1 -0
  572. package/dist/esm/server/ServerAuthenticationResolver.js +67 -0
  573. package/dist/esm/server/ServerAuthenticationResolver.js.map +1 -0
  574. package/dist/esm/server/config.d.ts +11 -0
  575. package/dist/esm/server/config.d.ts.map +1 -0
  576. package/dist/esm/server/config.js +2 -0
  577. package/dist/esm/server/config.js.map +1 -0
  578. package/dist/esm/server/index.d.ts +9 -0
  579. package/dist/esm/server/index.d.ts.map +1 -0
  580. package/dist/esm/server/index.js +9 -0
  581. package/dist/esm/server/index.js.map +1 -0
  582. package/dist/esm/server/login.d.ts +17 -0
  583. package/dist/esm/server/login.d.ts.map +1 -0
  584. package/dist/esm/server/login.js +37 -0
  585. package/dist/esm/server/login.js.map +1 -0
  586. package/dist/esm/server/logout.d.ts +7 -0
  587. package/dist/esm/server/logout.d.ts.map +1 -0
  588. package/dist/esm/server/logout.js +23 -0
  589. package/dist/esm/server/logout.js.map +1 -0
  590. package/dist/esm/server/refresh.d.ts +7 -0
  591. package/dist/esm/server/refresh.d.ts.map +1 -0
  592. package/dist/esm/server/refresh.js +16 -0
  593. package/dist/esm/server/refresh.js.map +1 -0
  594. package/dist/esm/services/AuthenticationService.d.ts +93 -0
  595. package/dist/esm/services/AuthenticationService.d.ts.map +1 -0
  596. package/dist/esm/services/AuthenticationService.js +361 -0
  597. package/dist/esm/services/AuthenticationService.js.map +1 -0
  598. package/dist/esm/services/PKCE.d.ts +20 -0
  599. package/dist/esm/services/PKCE.d.ts.map +1 -0
  600. package/dist/esm/services/PKCE.js +44 -0
  601. package/dist/esm/services/PKCE.js.map +1 -0
  602. package/dist/esm/services/types.d.ts +24 -0
  603. package/dist/esm/services/types.d.ts.map +1 -0
  604. package/dist/esm/services/types.js +7 -0
  605. package/dist/esm/services/types.js.map +1 -0
  606. package/dist/esm/shared/components/BlockDisplay.d.ts +6 -0
  607. package/dist/esm/shared/components/BlockDisplay.d.ts.map +1 -0
  608. package/dist/esm/shared/components/BlockDisplay.js +29 -0
  609. package/dist/esm/shared/components/BlockDisplay.js.map +1 -0
  610. package/dist/esm/shared/components/CivicAuthIframe.d.ts +9 -0
  611. package/dist/esm/shared/components/CivicAuthIframe.d.ts.map +1 -0
  612. package/dist/esm/shared/components/CivicAuthIframe.js +33 -0
  613. package/dist/esm/shared/components/CivicAuthIframe.js.map +1 -0
  614. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts +14 -0
  615. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  616. package/dist/esm/shared/components/CivicAuthIframeContainer.js +154 -0
  617. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +1 -0
  618. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts +6 -0
  619. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  620. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js +19 -0
  621. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  622. package/dist/esm/shared/components/CloseIcon.d.ts +3 -0
  623. package/dist/esm/shared/components/CloseIcon.d.ts.map +1 -0
  624. package/dist/esm/shared/components/CloseIcon.js +5 -0
  625. package/dist/esm/shared/components/CloseIcon.js.map +1 -0
  626. package/dist/esm/shared/components/IFrameAndLoading.d.ts +7 -0
  627. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -0
  628. package/dist/esm/shared/components/IFrameAndLoading.js +36 -0
  629. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -0
  630. package/dist/esm/shared/components/LoadingIcon.d.ts +6 -0
  631. package/dist/esm/shared/components/LoadingIcon.d.ts.map +1 -0
  632. package/dist/esm/shared/components/LoadingIcon.js +26 -0
  633. package/dist/esm/shared/components/LoadingIcon.js.map +1 -0
  634. package/dist/esm/shared/components/SVGLoading.d.ts +4 -0
  635. package/dist/esm/shared/components/SVGLoading.d.ts.map +1 -0
  636. package/dist/esm/shared/components/SVGLoading.js +28 -0
  637. package/dist/esm/shared/components/SVGLoading.js.map +1 -0
  638. package/dist/esm/shared/hooks/index.d.ts +11 -0
  639. package/dist/esm/shared/hooks/index.d.ts.map +1 -0
  640. package/dist/esm/shared/hooks/index.js +11 -0
  641. package/dist/esm/shared/hooks/index.js.map +1 -0
  642. package/dist/esm/shared/hooks/useAuth.d.ts +3 -0
  643. package/dist/esm/shared/hooks/useAuth.d.ts.map +1 -0
  644. package/dist/esm/shared/hooks/useAuth.js +12 -0
  645. package/dist/esm/shared/hooks/useAuth.js.map +1 -0
  646. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  647. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  648. package/dist/esm/shared/hooks/useCivicAuthConfig.js +10 -0
  649. package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +1 -0
  650. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  651. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  652. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +13 -0
  653. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  654. package/dist/esm/shared/hooks/useCurrentUrl.d.ts +3 -0
  655. package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  656. package/dist/esm/shared/hooks/useCurrentUrl.js +24 -0
  657. package/dist/esm/shared/hooks/useCurrentUrl.js.map +1 -0
  658. package/dist/esm/shared/hooks/useIframe.d.ts +3 -0
  659. package/dist/esm/shared/hooks/useIframe.d.ts.map +1 -0
  660. package/dist/esm/shared/hooks/useIframe.js +13 -0
  661. package/dist/esm/shared/hooks/useIframe.js.map +1 -0
  662. package/dist/esm/shared/hooks/useIsInIframe.d.ts +3 -0
  663. package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +1 -0
  664. package/dist/esm/shared/hooks/useIsInIframe.js +14 -0
  665. package/dist/esm/shared/hooks/useIsInIframe.js.map +1 -0
  666. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  667. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  668. package/dist/esm/shared/hooks/useOAuthEndpoints.js +14 -0
  669. package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +1 -0
  670. package/dist/esm/shared/hooks/useRefresh.d.ts +6 -0
  671. package/dist/esm/shared/hooks/useRefresh.d.ts.map +1 -0
  672. package/dist/esm/shared/hooks/useRefresh.js +46 -0
  673. package/dist/esm/shared/hooks/useRefresh.js.map +1 -0
  674. package/dist/esm/shared/hooks/useSession.d.ts +3 -0
  675. package/dist/esm/shared/hooks/useSession.d.ts.map +1 -0
  676. package/dist/esm/shared/hooks/useSession.js +13 -0
  677. package/dist/esm/shared/hooks/useSession.js.map +1 -0
  678. package/dist/esm/shared/hooks/useSignIn.d.ts +17 -0
  679. package/dist/esm/shared/hooks/useSignIn.d.ts.map +1 -0
  680. package/dist/esm/shared/hooks/useSignIn.js +168 -0
  681. package/dist/esm/shared/hooks/useSignIn.js.map +1 -0
  682. package/dist/esm/shared/hooks/useToken.d.ts +3 -0
  683. package/dist/esm/shared/hooks/useToken.d.ts.map +1 -0
  684. package/dist/esm/shared/hooks/useToken.js +12 -0
  685. package/dist/esm/shared/hooks/useToken.js.map +1 -0
  686. package/dist/esm/shared/hooks/useWindowFocused.d.ts +5 -0
  687. package/dist/esm/shared/hooks/useWindowFocused.d.ts.map +1 -0
  688. package/dist/esm/shared/hooks/useWindowFocused.js +21 -0
  689. package/dist/esm/shared/hooks/useWindowFocused.js.map +1 -0
  690. package/dist/esm/shared/index.d.ts +7 -0
  691. package/dist/esm/shared/index.d.ts.map +1 -0
  692. package/dist/esm/shared/index.js +18 -0
  693. package/dist/esm/shared/index.js.map +1 -0
  694. package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts +14 -0
  695. package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -0
  696. package/dist/esm/shared/lib/AuthenticationRefresherImpl.js +51 -0
  697. package/dist/esm/shared/lib/AuthenticationRefresherImpl.js.map +1 -0
  698. package/dist/esm/shared/lib/BrowserAuthenticationRefresher.d.ts +11 -0
  699. package/dist/esm/shared/lib/BrowserAuthenticationRefresher.d.ts.map +1 -0
  700. package/dist/esm/shared/lib/BrowserAuthenticationRefresher.js +59 -0
  701. package/dist/esm/shared/lib/BrowserAuthenticationRefresher.js.map +1 -0
  702. package/dist/esm/shared/lib/BrowserCookieStorage.d.ts +9 -0
  703. package/dist/esm/shared/lib/BrowserCookieStorage.d.ts.map +1 -0
  704. package/dist/esm/shared/lib/BrowserCookieStorage.js +56 -0
  705. package/dist/esm/shared/lib/BrowserCookieStorage.js.map +1 -0
  706. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +14 -0
  707. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  708. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js +34 -0
  709. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  710. package/dist/esm/shared/lib/UserSession.d.ts +17 -0
  711. package/dist/esm/shared/lib/UserSession.d.ts.map +1 -0
  712. package/dist/esm/shared/lib/UserSession.js +23 -0
  713. package/dist/esm/shared/lib/UserSession.js.map +1 -0
  714. package/dist/esm/shared/lib/iframeUtils.d.ts +6 -0
  715. package/dist/esm/shared/lib/iframeUtils.d.ts.map +1 -0
  716. package/dist/esm/shared/lib/iframeUtils.js +7 -0
  717. package/dist/esm/shared/lib/iframeUtils.js.map +1 -0
  718. package/dist/esm/shared/lib/session.d.ts +4 -0
  719. package/dist/esm/shared/lib/session.d.ts.map +1 -0
  720. package/dist/esm/shared/lib/session.js +44 -0
  721. package/dist/esm/shared/lib/session.js.map +1 -0
  722. package/dist/esm/shared/lib/storage.d.ts +35 -0
  723. package/dist/esm/shared/lib/storage.d.ts.map +1 -0
  724. package/dist/esm/shared/lib/storage.js +17 -0
  725. package/dist/esm/shared/lib/storage.js.map +1 -0
  726. package/dist/esm/shared/lib/types.d.ts +39 -0
  727. package/dist/esm/shared/lib/types.d.ts.map +1 -0
  728. package/dist/esm/shared/lib/types.js +19 -0
  729. package/dist/esm/shared/lib/types.js.map +1 -0
  730. package/dist/esm/shared/lib/util.d.ts +40 -0
  731. package/dist/esm/shared/lib/util.d.ts.map +1 -0
  732. package/dist/esm/shared/lib/util.js +200 -0
  733. package/dist/esm/shared/lib/util.js.map +1 -0
  734. package/dist/esm/shared/providers/AuthContext.d.ts +12 -0
  735. package/dist/esm/shared/providers/AuthContext.d.ts.map +1 -0
  736. package/dist/esm/shared/providers/AuthContext.js +4 -0
  737. package/dist/esm/shared/providers/AuthContext.js.map +1 -0
  738. package/dist/esm/shared/providers/AuthProvider.d.ts +22 -0
  739. package/dist/esm/shared/providers/AuthProvider.d.ts.map +1 -0
  740. package/dist/esm/shared/providers/AuthProvider.js +72 -0
  741. package/dist/esm/shared/providers/AuthProvider.js.map +1 -0
  742. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +19 -0
  743. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  744. package/dist/esm/shared/providers/CivicAuthConfigContext.js +55 -0
  745. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +1 -0
  746. package/dist/esm/shared/providers/CivicAuthProvider.d.ts +6 -0
  747. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  748. package/dist/esm/shared/providers/CivicAuthProvider.js +32 -0
  749. package/dist/esm/shared/providers/CivicAuthProvider.js.map +1 -0
  750. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  751. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  752. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +131 -0
  753. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  754. package/dist/esm/shared/providers/IframeProvider.d.ts +25 -0
  755. package/dist/esm/shared/providers/IframeProvider.d.ts.map +1 -0
  756. package/dist/esm/shared/providers/IframeProvider.js +59 -0
  757. package/dist/esm/shared/providers/IframeProvider.js.map +1 -0
  758. package/dist/esm/shared/providers/SessionProvider.d.ts +19 -0
  759. package/dist/esm/shared/providers/SessionProvider.d.ts.map +1 -0
  760. package/dist/esm/shared/providers/SessionProvider.js +24 -0
  761. package/dist/esm/shared/providers/SessionProvider.js.map +1 -0
  762. package/dist/esm/shared/providers/TokenProvider.d.ts +17 -0
  763. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -0
  764. package/dist/esm/shared/providers/TokenProvider.js +35 -0
  765. package/dist/esm/shared/providers/TokenProvider.js.map +1 -0
  766. package/dist/esm/shared/providers/UserProvider.d.ts +26 -0
  767. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -0
  768. package/dist/esm/shared/providers/UserProvider.js +65 -0
  769. package/dist/esm/shared/providers/UserProvider.js.map +1 -0
  770. package/dist/esm/shared/providers/types.d.ts +15 -0
  771. package/dist/esm/shared/providers/types.d.ts.map +1 -0
  772. package/dist/esm/shared/providers/types.js +2 -0
  773. package/dist/esm/shared/providers/types.js.map +1 -0
  774. package/dist/esm/shared/version.d.ts +2 -0
  775. package/dist/esm/shared/version.d.ts.map +1 -0
  776. package/dist/esm/shared/version.js +3 -0
  777. package/dist/esm/shared/version.js.map +1 -0
  778. package/dist/esm/types.d.ts +163 -0
  779. package/dist/esm/types.d.ts.map +1 -0
  780. package/dist/esm/types.js +17 -0
  781. package/dist/esm/types.js.map +1 -0
  782. package/dist/esm/utils.d.ts +15 -0
  783. package/dist/esm/utils.d.ts.map +1 -0
  784. package/dist/esm/utils.js +42 -0
  785. package/dist/esm/utils.js.map +1 -0
  786. package/dist/esm/version.d.ts +2 -0
  787. package/dist/esm/version.d.ts.map +1 -0
  788. package/dist/esm/version.js +3 -0
  789. package/dist/esm/version.js.map +1 -0
  790. package/dist/nextjs/NextClientAuthenticationRefresher.d.ts +3 -4
  791. package/dist/nextjs/NextClientAuthenticationRefresher.d.ts.map +1 -1
  792. package/dist/nextjs/NextClientAuthenticationRefresher.js +14 -12
  793. package/dist/nextjs/NextClientAuthenticationRefresher.js.map +1 -1
  794. package/dist/nextjs/NextServerAuthenticationRefresherImpl.d.ts +2 -1
  795. package/dist/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +1 -1
  796. package/dist/nextjs/NextServerAuthenticationRefresherImpl.js +7 -5
  797. package/dist/nextjs/NextServerAuthenticationRefresherImpl.js.map +1 -1
  798. package/dist/nextjs/hooks/useRefresh.d.ts +3 -1
  799. package/dist/nextjs/hooks/useRefresh.d.ts.map +1 -1
  800. package/dist/nextjs/hooks/useRefresh.js +11 -2
  801. package/dist/nextjs/hooks/useRefresh.js.map +1 -1
  802. package/dist/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  803. package/dist/nextjs/providers/NextAuthProvider.js +16 -5
  804. package/dist/nextjs/providers/NextAuthProvider.js.map +1 -1
  805. package/dist/nextjs/routeHandler.d.ts.map +1 -1
  806. package/dist/nextjs/routeHandler.js +18 -11
  807. package/dist/nextjs/routeHandler.js.map +1 -1
  808. package/dist/reactjs/providers/AuthProvider.d.ts.map +1 -1
  809. package/dist/reactjs/providers/AuthProvider.js +11 -1
  810. package/dist/reactjs/providers/AuthProvider.js.map +1 -1
  811. package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -1
  812. package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.js +1 -2
  813. package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -1
  814. package/dist/server/refresh.d.ts.map +1 -1
  815. package/dist/server/refresh.js +4 -1
  816. package/dist/server/refresh.js.map +1 -1
  817. package/dist/services/AuthenticationService.d.ts.map +1 -1
  818. package/dist/services/AuthenticationService.js +1 -6
  819. package/dist/services/AuthenticationService.js.map +1 -1
  820. package/dist/shared/components/CivicAuthIframe.d.ts.map +1 -1
  821. package/dist/shared/components/CivicAuthIframe.js +8 -2
  822. package/dist/shared/components/CivicAuthIframe.js.map +1 -1
  823. package/dist/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  824. package/dist/shared/components/CivicAuthIframeContainer.js +4 -1
  825. package/dist/shared/components/CivicAuthIframeContainer.js.map +1 -1
  826. package/dist/shared/hooks/useRefresh.d.ts +3 -1
  827. package/dist/shared/hooks/useRefresh.d.ts.map +1 -1
  828. package/dist/shared/hooks/useRefresh.js +11 -2
  829. package/dist/shared/hooks/useRefresh.js.map +1 -1
  830. package/dist/shared/hooks/useSignIn.js +3 -3
  831. package/dist/shared/hooks/useSignIn.js.map +1 -1
  832. package/dist/shared/lib/AuthenticationRefresherImpl.d.ts +2 -2
  833. package/dist/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -1
  834. package/dist/shared/lib/AuthenticationRefresherImpl.js +7 -9
  835. package/dist/shared/lib/AuthenticationRefresherImpl.js.map +1 -1
  836. package/dist/shared/lib/GenericAuthenticationRefresher.d.ts +2 -4
  837. package/dist/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  838. package/dist/shared/lib/GenericAuthenticationRefresher.js +10 -44
  839. package/dist/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  840. package/dist/shared/lib/iframeUtils.d.ts +1 -1
  841. package/dist/shared/lib/iframeUtils.d.ts.map +1 -1
  842. package/dist/shared/lib/iframeUtils.js +2 -2
  843. package/dist/shared/lib/iframeUtils.js.map +1 -1
  844. package/dist/shared/lib/util.d.ts.map +1 -1
  845. package/dist/shared/lib/util.js +3 -7
  846. package/dist/shared/lib/util.js.map +1 -1
  847. package/dist/shared/providers/IframeProvider.d.ts +3 -0
  848. package/dist/shared/providers/IframeProvider.d.ts.map +1 -1
  849. package/dist/shared/providers/IframeProvider.js +5 -0
  850. package/dist/shared/providers/IframeProvider.js.map +1 -1
  851. package/dist/shared/version.d.ts +1 -1
  852. package/dist/shared/version.d.ts.map +1 -1
  853. package/dist/shared/version.js +1 -1
  854. package/dist/shared/version.js.map +1 -1
  855. package/dist/tsconfig.cjs.tsbuildinfo +1 -0
  856. package/dist/tsconfig.esm.tsbuildinfo +1 -0
  857. package/package.json +1 -1
@@ -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;CAWjB"}
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,18 +3,20 @@ 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
  }
11
11
  async storeTokens(tokenResponseBody) {
12
12
  if (!this.storage)
13
13
  throw new Error("No storage available");
14
- console.log("NextServerAuthenticationRefresherImpl storeTokens calling storeServerTokens", {
15
- tokenResponseBody,
16
- });
17
14
  await storeServerTokens(this.storage, tokenResponseBody);
18
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
+ }
19
21
  }
20
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;QAE3D,OAAO,CAAC,GAAG,CACT,6EAA6E,EAC7E;YACE,iBAAiB;SAClB,CACF,CAAC;QACF,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\n console.log(\n \"NextServerAuthenticationRefresherImpl storeTokens calling storeServerTokens\",\n {\n tokenResponseBody,\n },\n );\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
@@ -1 +1 @@
1
- {"version":3,"file":"useRefresh.js","sourceRoot":"","sources":["../../../src/nextjs/hooks/useRefresh.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAE1E,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,iCAAiC,EAAE,MAAM,+CAA+C,CAAC;AAClG,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAEjD,MAAM,UAAU,GAAG,CAAC,OAA2B,EAAE,EAAE;IACjD,MAAM,UAAU,GAAG,kBAAkB,EAAE,CAAC;IAExC,0BAA0B;IAC1B,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAExC,SAAS,CAAC,CAAC;IAEb,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,UAAU;YAAE,OAAO;QACxB,MAAM,eAAe,GAAG,IAAI,eAAe,EAAE,CAAC;QAC9C,MAAM,gBAAgB,GAAG,SAAS,CAAC;QACnC,MAAM,MAAM,GAAG,iBAAiB,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;QACnD,MAAM,OAAO,GAAG,IAAI,oBAAoB,CACtC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CACnC,CAAC;QAEF,iCAAiC,CAAC,KAAK,CAAC,EAAE,GAAG,UAAU,EAAE,EAAE,OAAO,CAAC,CAAC,IAAI,CACtE,CAAC,YAAY,EAAE,EAAE;YACf,IAAI,eAAe,CAAC,MAAM,CAAC,OAAO;gBAAE,OAAO;YAE3C,gBAAgB,EAAE,gBAAgB,EAAE,CAAC;YACrC,YAAY,CAAC,YAAY,CAAC,CAAC;QAC7B,CAAC,CACF,CAAC;QAEF,OAAO,GAAG,EAAE;YACV,eAAe,CAAC,KAAK,EAAE,CAAC;YACxB,gBAAgB,EAAE,gBAAgB,EAAE,CAAC;QACvC,CAAC,CAAC;QACF,uDAAuD;IACzD,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,uCAAuC;IAEzD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,EAAE,aAAa,EAAE,CAAC;YAC3B,SAAS,EAAE,gBAAgB,EAAE,CAAC;QAChC,CAAC;aAAM,CAAC;YACN,SAAS,EAAE,gBAAgB,EAAE,CAAC;QAChC,CAAC;QAED,OAAO,GAAG,EAAE,CAAC,SAAS,EAAE,gBAAgB,EAAE,CAAC;IAC7C,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;AAC1C,CAAC,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC","sourcesContent":["import { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nimport type { SessionData } from \"@/types.js\";\nimport { useEffect, useState } from \"react\";\nimport { NextClientAuthenticationRefresher } from \"@/nextjs/NextClientAuthenticationRefresher.js\";\nimport { BrowserCookieStorage } from \"@/shared/index.js\";\nimport { resolveAuthConfig } from \"../config.js\";\n\nconst useRefresh = (session: SessionData | null) => {\n const authConfig = useCivicAuthConfig();\n\n // setup token autorefresh\n const [refresher, setRefresher] = useState<\n NextClientAuthenticationRefresher | undefined\n >(undefined);\n\n useEffect(() => {\n if (!authConfig) return;\n const abortController = new AbortController();\n const currentRefresher = refresher;\n const config = resolveAuthConfig(authConfig ?? {});\n const storage = new BrowserCookieStorage(\n config.cookies.tokens.access_token,\n );\n\n NextClientAuthenticationRefresher.build({ ...authConfig }, storage).then(\n (newRefresher) => {\n if (abortController.signal.aborted) return;\n\n currentRefresher?.clearAutorefresh();\n setRefresher(newRefresher);\n },\n );\n\n return () => {\n abortController.abort();\n currentRefresher?.clearAutorefresh();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [authConfig]); // Only depend on what actually changes\n\n useEffect(() => {\n if (session?.authenticated) {\n refresher?.setupAutorefresh();\n } else {\n refresher?.clearAutorefresh();\n }\n\n return () => refresher?.clearAutorefresh();\n }, [refresher, session?.authenticated]);\n};\n\nexport { useRefresh };\n"]}
1
+ {"version":3,"file":"useRefresh.js","sourceRoot":"","sources":["../../../src/nextjs/hooks/useRefresh.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAE1E,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,iCAAiC,EAAE,MAAM,yCAAyC,CAAC;AAE5F,MAAM,UAAU,GAAG,CAAC,OAA2B,EAAE,EAAE;IACjD,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,EAAS,CAAC;IAC5C,MAAM,UAAU,GAAG,kBAAkB,EAAE,CAAC;IAExC,0BAA0B;IAC1B,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAExC,SAAS,CAAC,CAAC;IAEb,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,UAAU;YAAE,OAAO;QACxB,MAAM,eAAe,GAAG,IAAI,eAAe,EAAE,CAAC;QAC9C,MAAM,gBAAgB,GAAG,SAAS,CAAC;QACnC,MAAM,MAAM,GAAG,iBAAiB,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;QACnD,MAAM,OAAO,GAAG,IAAI,oBAAoB,CACtC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CACnC,CAAC;QACF,MAAM,OAAO,GAAG,KAAK,EAAE,KAAY,EAAE,EAAE;YACrC,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,KAAK,CAAC,CAAC;YAC/C,SAAS,EAAE,gBAAgB,EAAE,CAAC;YAC9B,QAAQ,CAAC,KAAK,CAAC,CAAC;QAClB,CAAC,CAAC;QACF,iCAAiC,CAAC,KAAK,CACrC,EAAE,GAAG,UAAU,EAAE,EACjB,OAAO,EACP,OAAO,CACR,CAAC,IAAI,CAAC,CAAC,YAAY,EAAE,EAAE;YACtB,IAAI,eAAe,CAAC,MAAM,CAAC,OAAO;gBAAE,OAAO;YAE3C,gBAAgB,EAAE,gBAAgB,EAAE,CAAC;YACrC,YAAY,CAAC,YAAY,CAAC,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEH,OAAO,GAAG,EAAE;YACV,eAAe,CAAC,KAAK,EAAE,CAAC;YACxB,gBAAgB,EAAE,gBAAgB,EAAE,CAAC;QACvC,CAAC,CAAC;QACF,uDAAuD;IACzD,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,uCAAuC;IAEzD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,EAAE,aAAa,EAAE,CAAC;YAC3B,SAAS,EAAE,gBAAgB,EAAE,CAAC;QAChC,CAAC;aAAM,CAAC;YACN,SAAS,EAAE,gBAAgB,EAAE,CAAC;QAChC,CAAC;QAED,OAAO,GAAG,EAAE,CAAC,SAAS,EAAE,gBAAgB,EAAE,CAAC;IAC7C,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;IAExC,OAAO;QACL,KAAK;KACN,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC","sourcesContent":["import { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nimport type { SessionData } from \"@/types.js\";\nimport { useEffect, useState } from \"react\";\nimport { BrowserCookieStorage } from \"@/shared/index.js\";\nimport { resolveAuthConfig } from \"../config.js\";\nimport { NextClientAuthenticationRefresher } from \"../NextClientAuthenticationRefresher.js\";\n\nconst useRefresh = (session: SessionData | null) => {\n const [error, setError] = useState<Error>();\n const authConfig = useCivicAuthConfig();\n\n // setup token autorefresh\n const [refresher, setRefresher] = useState<\n NextClientAuthenticationRefresher | undefined\n >(undefined);\n\n useEffect(() => {\n if (!authConfig) return;\n const abortController = new AbortController();\n const currentRefresher = refresher;\n const config = resolveAuthConfig(authConfig ?? {});\n const storage = new BrowserCookieStorage(\n config.cookies.tokens.access_token,\n );\n const onError = async (error: Error) => {\n console.error(\"Error refreshing token\", error);\n refresher?.clearAutorefresh();\n setError(error);\n };\n NextClientAuthenticationRefresher.build(\n { ...authConfig },\n storage,\n onError,\n ).then((newRefresher) => {\n if (abortController.signal.aborted) return;\n\n currentRefresher?.clearAutorefresh();\n setRefresher(newRefresher);\n });\n\n return () => {\n abortController.abort();\n currentRefresher?.clearAutorefresh();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [authConfig]); // Only depend on what actually changes\n\n useEffect(() => {\n if (session?.authenticated) {\n refresher?.setupAutorefresh();\n } else {\n refresher?.clearAutorefresh();\n }\n\n return () => refresher?.clearAutorefresh();\n }, [refresher, session?.authenticated]);\n\n return {\n error,\n };\n};\n\nexport { useRefresh };\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"NextAuthProvider.d.ts","sourceRoot":"","sources":["../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"AAKA,OAAO,EAEL,KAAK,sBAAsB,EAC5B,MAAM,oBAAoB,CAAC;AAe5B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAcrE,KAAK,kCAAkC,GAAG,IAAI,CAC5C,iBAAiB,EACjB,UAAU,CACX,GAAG;IACF,cAAc,EAAE,sBAAsB,CAAC;CACxC,CAAC;AACF,KAAK,0BAA0B,GAAG,IAAI,CACpC,kCAAkC,EAClC,UAAU,GAAG,gBAAgB,GAAG,aAAa,CAC9C,CAAC;AAoHF,QAAA,MAAM,qBAAqB,2BAGxB,0BAA0B,qDA0C5B,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,KAAK,0BAA0B,EAAE,CAAC"}
1
+ {"version":3,"file":"NextAuthProvider.d.ts","sourceRoot":"","sources":["../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"AAKA,OAAO,EAEL,KAAK,sBAAsB,EAC5B,MAAM,oBAAoB,CAAC;AAe5B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAerE,KAAK,kCAAkC,GAAG,IAAI,CAC5C,iBAAiB,EACjB,UAAU,CACX,GAAG;IACF,cAAc,EAAE,sBAAsB,CAAC;CACxC,CAAC;AACF,KAAK,0BAA0B,GAAG,IAAI,CACpC,kCAAkC,EAClC,UAAU,GAAG,gBAAgB,GAAG,aAAa,CAC9C,CAAC;AAgIF,QAAA,MAAM,qBAAqB,2BAGxB,0BAA0B,qDA0C5B,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,KAAK,0BAA0B,EAAE,CAAC"}
@@ -24,9 +24,10 @@ import { AuthStatus } from "../../types.js";
24
24
  import { useRefresh } from "../../nextjs/hooks/useRefresh.js";
25
25
  import { useCurrentUrl, useSession } from "../../shared/hooks/index.js";
26
26
  import { BrowserCookieStorage } from "../../shared/index.js";
27
+ import { getIframeRef } from "../../shared/lib/iframeUtils.js";
27
28
  const CivicNextAuthTokenProviderInternal = ({ children, isLoading, displayMode = "iframe", user, fetchUser, ...props }) => {
28
29
  const { iframeMode, resolvedConfig } = props;
29
- const { iframeRef, setIframeIsVisible } = useIframe();
30
+ const { iframeRef, setIframeIsVisible, isIframeMounted, setIframeMounted } = useIframe();
30
31
  const civicAuthConfig = useCivicAuthConfig();
31
32
  const { challengeUrl } = resolvedConfig;
32
33
  const pkceConsumer = new ConfidentialClientPKCEConsumer(challengeUrl);
@@ -34,11 +35,12 @@ const CivicNextAuthTokenProviderInternal = ({ children, isLoading, displayMode =
34
35
  const currentUrl = useCurrentUrl();
35
36
  useEffect(() => {
36
37
  if (session?.authenticated) {
38
+ setIframeMounted(false);
37
39
  // the session is authenticated, so don't show the login iframe
38
40
  setIframeIsVisible(false);
39
41
  return;
40
42
  }
41
- }, [session?.authenticated, setIframeIsVisible]);
43
+ }, [session?.authenticated, setIframeIsVisible, setIframeMounted]);
42
44
  const postSignOut = useCallback(async () => {
43
45
  // user is signed out, manually update the user from cookies to not wait for polling
44
46
  await fetchUser();
@@ -50,9 +52,11 @@ const CivicNextAuthTokenProviderInternal = ({ children, isLoading, displayMode =
50
52
  displayMode,
51
53
  });
52
54
  useEffect(() => {
53
- if (civicAuthConfig &&
55
+ const ref = getIframeRef(iframeRef?.current, true);
56
+ if (isIframeMounted &&
57
+ civicAuthConfig &&
54
58
  !session?.authenticated &&
55
- iframeRef?.current &&
59
+ ref &&
56
60
  authStatus === AuthStatus.UNAUTHENTICATED &&
57
61
  displayMode === "iframe" &&
58
62
  !currentUrl?.includes("code=")) {
@@ -60,6 +64,7 @@ const CivicNextAuthTokenProviderInternal = ({ children, isLoading, displayMode =
60
64
  }
61
65
  // eslint-disable-next-line react-hooks/exhaustive-deps
62
66
  }, [
67
+ isIframeMounted,
63
68
  currentUrl,
64
69
  iframeMode,
65
70
  iframeRef,
@@ -69,6 +74,13 @@ const CivicNextAuthTokenProviderInternal = ({ children, isLoading, displayMode =
69
74
  startSignIn,
70
75
  displayMode,
71
76
  ]);
77
+ const { error: refreshError } = useRefresh(session);
78
+ useEffect(() => {
79
+ if (refreshError) {
80
+ console.error("Error refreshing token, signing out...", refreshError);
81
+ signOut();
82
+ }
83
+ }, [refreshError, signOut]);
72
84
  return (_jsx(TokenProvider, { children: _jsxs(UserProvider, { storage: new BrowserCookieStorage(), user: user, signOut: signOut, signIn: signIn, displayMode: displayMode, authStatus: authStatus, children: [_jsx(IFrameAndLoading, { error: null, isLoading: isLoading }), isLoading && (_jsx(BlockDisplay, { children: _jsx(LoadingIcon, {}) })), children] }) }));
73
85
  };
74
86
  const CivicNextAuthProviderInternal = ({ children, ...props }) => {
@@ -80,7 +92,6 @@ const CivicNextAuthProviderInternal = ({ children, ...props }) => {
80
92
  authenticated: !!user,
81
93
  idToken,
82
94
  };
83
- useRefresh(session);
84
95
  return (_jsx(SessionProvider, { data: session, isLoading: isLoading, children: _jsx(CivicNextAuthTokenProviderInternal, { ...props, user: user, idToken: idToken, fetchUser: fetchUser, isLoading: isLoading, children: children }) }));
85
96
  };
86
97
  const CivicNextAuthProvider = ({ children, ...props }) => {