@civic/auth 0.3.5-temp-debug-logs.2 → 0.3.6-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 (975) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/browser/storage.d.ts.map +1 -0
  3. package/dist/browser/storage.js.map +1 -0
  4. package/dist/config.d.ts.map +1 -0
  5. package/dist/config.js.map +1 -0
  6. package/dist/constants.d.ts +15 -0
  7. package/dist/constants.d.ts.map +1 -0
  8. package/dist/constants.js +29 -0
  9. package/dist/constants.js.map +1 -0
  10. package/dist/index.d.ts.map +1 -0
  11. package/dist/index.js.map +1 -0
  12. package/dist/lib/cookies.d.ts.map +1 -0
  13. package/dist/lib/cookies.js.map +1 -0
  14. package/dist/lib/jwt.d.ts.map +1 -0
  15. package/dist/lib/jwt.js.map +1 -0
  16. package/dist/lib/logger.d.ts.map +1 -0
  17. package/dist/lib/logger.js.map +1 -0
  18. package/dist/lib/oauth.d.ts.map +1 -0
  19. package/dist/lib/oauth.js.map +1 -0
  20. package/dist/lib/obj.d.ts.map +1 -0
  21. package/dist/lib/obj.js.map +1 -0
  22. package/dist/lib/postMessage.d.ts.map +1 -0
  23. package/dist/lib/postMessage.js +13 -0
  24. package/dist/lib/postMessage.js.map +1 -0
  25. package/dist/lib/windowUtil.d.ts.map +1 -0
  26. package/dist/lib/windowUtil.js.map +1 -0
  27. package/dist/nextjs/NextClientAuthenticationRefresher.d.ts.map +1 -0
  28. package/dist/nextjs/NextClientAuthenticationRefresher.js.map +1 -0
  29. package/dist/nextjs/NextServerAuthenticationRefresherImpl.d.ts +11 -0
  30. package/dist/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +1 -0
  31. package/dist/nextjs/NextServerAuthenticationRefresherImpl.js +17 -0
  32. package/dist/nextjs/NextServerAuthenticationRefresherImpl.js.map +1 -0
  33. package/dist/nextjs/config.d.ts.map +1 -0
  34. package/dist/nextjs/config.js.map +1 -0
  35. package/dist/nextjs/cookies.d.ts +16 -0
  36. package/dist/nextjs/cookies.d.ts.map +1 -0
  37. package/dist/nextjs/cookies.js +41 -0
  38. package/dist/nextjs/cookies.js.map +1 -0
  39. package/dist/nextjs/hooks/index.d.ts.map +1 -0
  40. package/dist/nextjs/hooks/index.js.map +1 -0
  41. package/dist/nextjs/hooks/usePrevious.d.ts.map +1 -0
  42. package/dist/nextjs/hooks/usePrevious.js.map +1 -0
  43. package/dist/nextjs/hooks/useRefresh.d.ts.map +1 -0
  44. package/dist/nextjs/hooks/useRefresh.js.map +1 -0
  45. package/dist/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  46. package/dist/nextjs/hooks/useUserCookie.js.map +1 -0
  47. package/dist/nextjs/index.d.ts.map +1 -0
  48. package/dist/nextjs/index.js.map +1 -0
  49. package/dist/nextjs/middleware/index.d.ts.map +1 -0
  50. package/dist/nextjs/middleware/index.js.map +1 -0
  51. package/dist/nextjs/middleware.d.ts.map +1 -0
  52. package/dist/nextjs/middleware.js +101 -0
  53. package/dist/nextjs/middleware.js.map +1 -0
  54. package/dist/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  55. package/dist/nextjs/providers/NextAuthProvider.js.map +1 -0
  56. package/dist/nextjs/routeHandler.d.ts.map +1 -0
  57. package/dist/nextjs/routeHandler.js +312 -0
  58. package/dist/nextjs/routeHandler.js.map +1 -0
  59. package/dist/nextjs/utils.d.ts.map +1 -0
  60. package/dist/nextjs/utils.js.map +1 -0
  61. package/dist/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -0
  62. package/dist/reactjs/components/ButtonContentOrLoader.js.map +1 -0
  63. package/dist/reactjs/components/SignInButton.d.ts.map +1 -0
  64. package/dist/reactjs/components/SignInButton.js.map +1 -0
  65. package/dist/reactjs/components/SignOutButton.d.ts.map +1 -0
  66. package/dist/reactjs/components/SignOutButton.js.map +1 -0
  67. package/dist/reactjs/components/UserButton.d.ts.map +1 -0
  68. package/dist/reactjs/components/UserButton.js +142 -0
  69. package/dist/reactjs/components/UserButton.js.map +1 -0
  70. package/dist/reactjs/components/index.d.ts.map +1 -0
  71. package/dist/reactjs/components/index.js.map +1 -0
  72. package/dist/reactjs/components/utils.d.ts.map +1 -0
  73. package/dist/reactjs/components/utils.js.map +1 -0
  74. package/dist/reactjs/hooks/index.d.ts.map +1 -0
  75. package/dist/reactjs/hooks/index.js.map +1 -0
  76. package/dist/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  77. package/dist/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  78. package/dist/reactjs/hooks/useUser.d.ts.map +1 -0
  79. package/dist/reactjs/hooks/useUser.js.map +1 -0
  80. package/dist/reactjs/index.d.ts.map +1 -0
  81. package/dist/reactjs/index.js.map +1 -0
  82. package/dist/reactjs/providers/AuthProvider.d.ts.map +1 -0
  83. package/dist/reactjs/providers/AuthProvider.js.map +1 -0
  84. package/dist/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  85. package/dist/reactjs/providers/CivicAuthProvider.js.map +1 -0
  86. package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  87. package/dist/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  88. package/dist/reactjs/providers/index.d.ts.map +1 -0
  89. package/dist/reactjs/providers/index.js.map +1 -0
  90. package/dist/server/ServerAuthenticationResolver.d.ts.map +1 -0
  91. package/dist/server/ServerAuthenticationResolver.js +67 -0
  92. package/dist/server/ServerAuthenticationResolver.js.map +1 -0
  93. package/dist/server/config.d.ts.map +1 -0
  94. package/dist/server/config.js.map +1 -0
  95. package/dist/server/index.d.ts.map +1 -0
  96. package/dist/server/index.js.map +1 -0
  97. package/dist/server/login.d.ts.map +1 -0
  98. package/dist/server/login.js.map +1 -0
  99. package/dist/server/logout.d.ts.map +1 -0
  100. package/dist/server/logout.js.map +1 -0
  101. package/dist/server/refresh.d.ts.map +1 -0
  102. package/dist/server/refresh.js.map +1 -0
  103. package/dist/services/AuthenticationService.d.ts +93 -0
  104. package/dist/services/AuthenticationService.d.ts.map +1 -0
  105. package/dist/services/AuthenticationService.js +366 -0
  106. package/dist/services/AuthenticationService.js.map +1 -0
  107. package/dist/services/PKCE.d.ts.map +1 -0
  108. package/dist/services/PKCE.js.map +1 -0
  109. package/dist/services/types.d.ts.map +1 -0
  110. package/dist/services/types.js.map +1 -0
  111. package/dist/shared/components/BlockDisplay.d.ts.map +1 -0
  112. package/dist/shared/components/BlockDisplay.js +29 -0
  113. package/dist/shared/components/BlockDisplay.js.map +1 -0
  114. package/dist/shared/components/CivicAuthIframe.d.ts.map +1 -0
  115. package/dist/shared/components/CivicAuthIframe.js +27 -0
  116. package/dist/shared/components/CivicAuthIframe.js.map +1 -0
  117. package/dist/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  118. package/dist/shared/components/CivicAuthIframeContainer.js +154 -0
  119. package/dist/shared/components/CivicAuthIframeContainer.js.map +1 -0
  120. package/dist/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  121. package/dist/shared/components/CivicAuthLogoutIframeContainer.js +19 -0
  122. package/dist/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  123. package/dist/shared/components/CloseIcon.d.ts.map +1 -0
  124. package/dist/shared/components/CloseIcon.js.map +1 -0
  125. package/dist/shared/components/IFrameAndLoading.d.ts.map +1 -0
  126. package/dist/shared/components/IFrameAndLoading.js.map +1 -0
  127. package/dist/shared/components/LoadingIcon.d.ts.map +1 -0
  128. package/dist/shared/components/LoadingIcon.js.map +1 -0
  129. package/dist/shared/components/SVGLoading.d.ts +4 -0
  130. package/dist/shared/components/SVGLoading.d.ts.map +1 -0
  131. package/dist/shared/components/SVGLoading.js +28 -0
  132. package/dist/shared/components/SVGLoading.js.map +1 -0
  133. package/dist/shared/hooks/index.d.ts.map +1 -0
  134. package/dist/shared/hooks/index.js.map +1 -0
  135. package/dist/shared/hooks/useAuth.d.ts.map +1 -0
  136. package/dist/shared/hooks/useAuth.js.map +1 -0
  137. package/dist/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  138. package/dist/shared/hooks/useCivicAuthConfig.js.map +1 -0
  139. package/dist/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  140. package/dist/shared/hooks/useCurrentUrl.js.map +1 -0
  141. package/dist/shared/hooks/useIframe.d.ts.map +1 -0
  142. package/dist/shared/hooks/useIframe.js.map +1 -0
  143. package/dist/shared/hooks/useIsInIframe.d.ts.map +1 -0
  144. package/dist/shared/hooks/useIsInIframe.js.map +1 -0
  145. package/dist/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  146. package/dist/shared/hooks/useOAuthEndpoints.js.map +1 -0
  147. package/dist/shared/hooks/useRefresh.d.ts.map +1 -0
  148. package/dist/shared/hooks/useRefresh.js.map +1 -0
  149. package/dist/shared/hooks/useSession.d.ts.map +1 -0
  150. package/dist/shared/hooks/useSession.js.map +1 -0
  151. package/dist/shared/hooks/useSignIn.d.ts.map +1 -0
  152. package/dist/shared/hooks/useSignIn.js +168 -0
  153. package/dist/shared/hooks/useSignIn.js.map +1 -0
  154. package/dist/shared/hooks/useToken.d.ts.map +1 -0
  155. package/dist/shared/hooks/useToken.js.map +1 -0
  156. package/dist/shared/hooks/useWindowFocused.d.ts.map +1 -0
  157. package/dist/shared/hooks/useWindowFocused.js.map +1 -0
  158. package/dist/shared/index.d.ts.map +1 -0
  159. package/dist/shared/index.js.map +1 -0
  160. package/dist/shared/lib/AuthenticationRefresherImpl.d.ts +14 -0
  161. package/dist/shared/lib/AuthenticationRefresherImpl.d.ts.map +1 -0
  162. package/dist/shared/lib/AuthenticationRefresherImpl.js +48 -0
  163. package/dist/shared/lib/AuthenticationRefresherImpl.js.map +1 -0
  164. package/dist/shared/lib/BrowserCookieStorage.d.ts +9 -0
  165. package/dist/shared/lib/BrowserCookieStorage.d.ts.map +1 -0
  166. package/dist/shared/lib/BrowserCookieStorage.js +56 -0
  167. package/dist/shared/lib/BrowserCookieStorage.js.map +1 -0
  168. package/dist/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  169. package/dist/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  170. package/dist/shared/lib/UserSession.d.ts.map +1 -0
  171. package/dist/shared/lib/UserSession.js.map +1 -0
  172. package/dist/shared/lib/iframeUtils.d.ts.map +1 -0
  173. package/dist/shared/lib/iframeUtils.js.map +1 -0
  174. package/dist/shared/lib/session.d.ts.map +1 -0
  175. package/dist/shared/lib/session.js.map +1 -0
  176. package/dist/shared/lib/storage.d.ts +35 -0
  177. package/dist/shared/lib/storage.d.ts.map +1 -0
  178. package/dist/shared/lib/storage.js.map +1 -0
  179. package/dist/shared/lib/types.d.ts +39 -0
  180. package/dist/shared/lib/types.d.ts.map +1 -0
  181. package/dist/shared/lib/types.js.map +1 -0
  182. package/dist/shared/lib/util.d.ts +40 -0
  183. package/dist/shared/lib/util.d.ts.map +1 -0
  184. package/dist/shared/lib/util.js +187 -0
  185. package/dist/shared/lib/util.js.map +1 -0
  186. package/dist/shared/providers/AuthContext.d.ts.map +1 -0
  187. package/dist/shared/providers/AuthContext.js.map +1 -0
  188. package/dist/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  189. package/dist/shared/providers/CivicAuthConfigContext.js.map +1 -0
  190. package/dist/shared/providers/IframeProvider.d.ts +25 -0
  191. package/dist/shared/providers/IframeProvider.d.ts.map +1 -0
  192. package/dist/shared/providers/IframeProvider.js +59 -0
  193. package/dist/shared/providers/IframeProvider.js.map +1 -0
  194. package/dist/shared/providers/SessionProvider.d.ts.map +1 -0
  195. package/dist/shared/providers/SessionProvider.js.map +1 -0
  196. package/dist/shared/providers/TokenProvider.d.ts.map +1 -0
  197. package/dist/shared/providers/TokenProvider.js.map +1 -0
  198. package/dist/shared/providers/UserProvider.d.ts.map +1 -0
  199. package/dist/shared/providers/UserProvider.js.map +1 -0
  200. package/dist/shared/providers/types.d.ts.map +1 -0
  201. package/dist/shared/providers/types.js.map +1 -0
  202. package/dist/shared/version.d.ts +2 -0
  203. package/dist/shared/version.d.ts.map +1 -0
  204. package/dist/shared/version.js +3 -0
  205. package/dist/shared/version.js.map +1 -0
  206. package/dist/types.d.ts +163 -0
  207. package/dist/types.d.ts.map +1 -0
  208. package/dist/types.js.map +1 -0
  209. package/dist/utils.d.ts.map +1 -0
  210. package/dist/utils.js.map +1 -0
  211. package/dist/version.d.ts.map +1 -0
  212. package/dist/version.js.map +1 -0
  213. package/package.json +21 -37
  214. package/dist/cjs/browser/storage.d.ts.map +0 -1
  215. package/dist/cjs/browser/storage.js +0 -24
  216. package/dist/cjs/browser/storage.js.map +0 -1
  217. package/dist/cjs/config.d.ts.map +0 -1
  218. package/dist/cjs/config.js +0 -8
  219. package/dist/cjs/config.js.map +0 -1
  220. package/dist/cjs/constants.d.ts +0 -12
  221. package/dist/cjs/constants.d.ts.map +0 -1
  222. package/dist/cjs/constants.js +0 -38
  223. package/dist/cjs/constants.js.map +0 -1
  224. package/dist/cjs/index.d.ts.map +0 -1
  225. package/dist/cjs/index.js +0 -11
  226. package/dist/cjs/index.js.map +0 -1
  227. package/dist/cjs/lib/cookies.d.ts.map +0 -1
  228. package/dist/cjs/lib/cookies.js +0 -29
  229. package/dist/cjs/lib/cookies.js.map +0 -1
  230. package/dist/cjs/lib/jwt.d.ts.map +0 -1
  231. package/dist/cjs/lib/jwt.js +0 -13
  232. package/dist/cjs/lib/jwt.js.map +0 -1
  233. package/dist/cjs/lib/logger.d.ts.map +0 -1
  234. package/dist/cjs/lib/logger.js +0 -62
  235. package/dist/cjs/lib/logger.js.map +0 -1
  236. package/dist/cjs/lib/oauth.d.ts.map +0 -1
  237. package/dist/cjs/lib/oauth.js +0 -74
  238. package/dist/cjs/lib/oauth.js.map +0 -1
  239. package/dist/cjs/lib/obj.d.ts.map +0 -1
  240. package/dist/cjs/lib/obj.js +0 -21
  241. package/dist/cjs/lib/obj.js.map +0 -1
  242. package/dist/cjs/lib/postMessage.d.ts.map +0 -1
  243. package/dist/cjs/lib/postMessage.js +0 -17
  244. package/dist/cjs/lib/postMessage.js.map +0 -1
  245. package/dist/cjs/lib/windowUtil.d.ts.map +0 -1
  246. package/dist/cjs/lib/windowUtil.js +0 -35
  247. package/dist/cjs/lib/windowUtil.js.map +0 -1
  248. package/dist/cjs/nextjs/GetUser.d.ts +0 -6
  249. package/dist/cjs/nextjs/GetUser.d.ts.map +0 -1
  250. package/dist/cjs/nextjs/GetUser.js +0 -11
  251. package/dist/cjs/nextjs/GetUser.js.map +0 -1
  252. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.d.ts.map +0 -1
  253. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js +0 -26
  254. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js.map +0 -1
  255. package/dist/cjs/nextjs/config.d.ts +0 -209
  256. package/dist/cjs/nextjs/config.d.ts.map +0 -1
  257. package/dist/cjs/nextjs/config.js +0 -191
  258. package/dist/cjs/nextjs/config.js.map +0 -1
  259. package/dist/cjs/nextjs/cookies.d.ts +0 -27
  260. package/dist/cjs/nextjs/cookies.d.ts.map +0 -1
  261. package/dist/cjs/nextjs/cookies.js +0 -141
  262. package/dist/cjs/nextjs/cookies.js.map +0 -1
  263. package/dist/cjs/nextjs/hooks/index.d.ts.map +0 -1
  264. package/dist/cjs/nextjs/hooks/index.js +0 -6
  265. package/dist/cjs/nextjs/hooks/index.js.map +0 -1
  266. package/dist/cjs/nextjs/hooks/usePrevious.d.ts.map +0 -1
  267. package/dist/cjs/nextjs/hooks/usePrevious.js +0 -12
  268. package/dist/cjs/nextjs/hooks/usePrevious.js.map +0 -1
  269. package/dist/cjs/nextjs/hooks/useRefresh.d.ts.map +0 -1
  270. package/dist/cjs/nextjs/hooks/useRefresh.js +0 -43
  271. package/dist/cjs/nextjs/hooks/useRefresh.js.map +0 -1
  272. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +0 -1
  273. package/dist/cjs/nextjs/hooks/useUserCookie.js +0 -93
  274. package/dist/cjs/nextjs/hooks/useUserCookie.js.map +0 -1
  275. package/dist/cjs/nextjs/index.d.ts.map +0 -1
  276. package/dist/cjs/nextjs/index.js +0 -27
  277. package/dist/cjs/nextjs/index.js.map +0 -1
  278. package/dist/cjs/nextjs/middleware/index.d.ts.map +0 -1
  279. package/dist/cjs/nextjs/middleware/index.js +0 -10
  280. package/dist/cjs/nextjs/middleware/index.js.map +0 -1
  281. package/dist/cjs/nextjs/middleware.d.ts.map +0 -1
  282. package/dist/cjs/nextjs/middleware.js +0 -111
  283. package/dist/cjs/nextjs/middleware.js.map +0 -1
  284. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
  285. package/dist/cjs/nextjs/providers/NextAuthProvider.js +0 -102
  286. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +0 -1
  287. package/dist/cjs/nextjs/routeHandler.d.ts.map +0 -1
  288. package/dist/cjs/nextjs/routeHandler.js +0 -318
  289. package/dist/cjs/nextjs/routeHandler.js.map +0 -1
  290. package/dist/cjs/nextjs/utils.d.ts.map +0 -1
  291. package/dist/cjs/nextjs/utils.js +0 -9
  292. package/dist/cjs/nextjs/utils.js.map +0 -1
  293. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts.map +0 -1
  294. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js +0 -40
  295. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js.map +0 -1
  296. package/dist/cjs/reactjs/components/SignInButton.d.ts.map +0 -1
  297. package/dist/cjs/reactjs/components/SignInButton.js +0 -31
  298. package/dist/cjs/reactjs/components/SignInButton.js.map +0 -1
  299. package/dist/cjs/reactjs/components/SignOutButton.d.ts.map +0 -1
  300. package/dist/cjs/reactjs/components/SignOutButton.js +0 -27
  301. package/dist/cjs/reactjs/components/SignOutButton.js.map +0 -1
  302. package/dist/cjs/reactjs/components/UserButton.d.ts.map +0 -1
  303. package/dist/cjs/reactjs/components/UserButton.js +0 -146
  304. package/dist/cjs/reactjs/components/UserButton.js.map +0 -1
  305. package/dist/cjs/reactjs/components/index.d.ts.map +0 -1
  306. package/dist/cjs/reactjs/components/index.js +0 -14
  307. package/dist/cjs/reactjs/components/index.js.map +0 -1
  308. package/dist/cjs/reactjs/components/utils.d.ts.map +0 -1
  309. package/dist/cjs/reactjs/components/utils.js +0 -31
  310. package/dist/cjs/reactjs/components/utils.js.map +0 -1
  311. package/dist/cjs/reactjs/hooks/index.d.ts.map +0 -1
  312. package/dist/cjs/reactjs/hooks/index.js +0 -8
  313. package/dist/cjs/reactjs/hooks/index.js.map +0 -1
  314. package/dist/cjs/reactjs/hooks/useAuth.d.ts.map +0 -1
  315. package/dist/cjs/reactjs/hooks/useAuth.js +0 -15
  316. package/dist/cjs/reactjs/hooks/useAuth.js.map +0 -1
  317. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  318. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js +0 -16
  319. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js.map +0 -1
  320. package/dist/cjs/reactjs/hooks/useSignIn.d.ts +0 -6
  321. package/dist/cjs/reactjs/hooks/useSignIn.d.ts.map +0 -1
  322. package/dist/cjs/reactjs/hooks/useSignIn.js +0 -38
  323. package/dist/cjs/reactjs/hooks/useSignIn.js.map +0 -1
  324. package/dist/cjs/reactjs/hooks/useUser.d.ts.map +0 -1
  325. package/dist/cjs/reactjs/hooks/useUser.js +0 -15
  326. package/dist/cjs/reactjs/hooks/useUser.js.map +0 -1
  327. package/dist/cjs/reactjs/index.d.ts.map +0 -1
  328. package/dist/cjs/reactjs/index.js +0 -32
  329. package/dist/cjs/reactjs/index.js.map +0 -1
  330. package/dist/cjs/reactjs/providers/AuthProvider.d.ts.map +0 -1
  331. package/dist/cjs/reactjs/providers/AuthProvider.js +0 -91
  332. package/dist/cjs/reactjs/providers/AuthProvider.js.map +0 -1
  333. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts.map +0 -1
  334. package/dist/cjs/reactjs/providers/CivicAuthProvider.js +0 -29
  335. package/dist/cjs/reactjs/providers/CivicAuthProvider.js.map +0 -1
  336. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  337. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js +0 -147
  338. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  339. package/dist/cjs/reactjs/providers/index.d.ts.map +0 -1
  340. package/dist/cjs/reactjs/providers/index.js +0 -19
  341. package/dist/cjs/reactjs/providers/index.js.map +0 -1
  342. package/dist/cjs/server/ServerAuthenticationResolver.d.ts.map +0 -1
  343. package/dist/cjs/server/ServerAuthenticationResolver.js +0 -71
  344. package/dist/cjs/server/ServerAuthenticationResolver.js.map +0 -1
  345. package/dist/cjs/server/config.d.ts.map +0 -1
  346. package/dist/cjs/server/config.js +0 -3
  347. package/dist/cjs/server/config.js.map +0 -1
  348. package/dist/cjs/server/index.d.ts.map +0 -1
  349. package/dist/cjs/server/index.js +0 -21
  350. package/dist/cjs/server/index.js.map +0 -1
  351. package/dist/cjs/server/login.d.ts.map +0 -1
  352. package/dist/cjs/server/login.js +0 -42
  353. package/dist/cjs/server/login.js.map +0 -1
  354. package/dist/cjs/server/logout.d.ts.map +0 -1
  355. package/dist/cjs/server/logout.js +0 -26
  356. package/dist/cjs/server/logout.js.map +0 -1
  357. package/dist/cjs/server/refresh.d.ts.map +0 -1
  358. package/dist/cjs/server/refresh.js +0 -16
  359. package/dist/cjs/server/refresh.js.map +0 -1
  360. package/dist/cjs/services/AuthenticationService.d.ts +0 -91
  361. package/dist/cjs/services/AuthenticationService.d.ts.map +0 -1
  362. package/dist/cjs/services/AuthenticationService.js +0 -358
  363. package/dist/cjs/services/AuthenticationService.js.map +0 -1
  364. package/dist/cjs/services/PKCE.d.ts.map +0 -1
  365. package/dist/cjs/services/PKCE.js +0 -50
  366. package/dist/cjs/services/PKCE.js.map +0 -1
  367. package/dist/cjs/services/types.d.ts.map +0 -1
  368. package/dist/cjs/services/types.js +0 -11
  369. package/dist/cjs/services/types.js.map +0 -1
  370. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +0 -1
  371. package/dist/cjs/shared/components/BlockDisplay.js +0 -27
  372. package/dist/cjs/shared/components/BlockDisplay.js.map +0 -1
  373. package/dist/cjs/shared/components/CivicAuthIframe.d.ts.map +0 -1
  374. package/dist/cjs/shared/components/CivicAuthIframe.js +0 -69
  375. package/dist/cjs/shared/components/CivicAuthIframe.js.map +0 -1
  376. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
  377. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +0 -159
  378. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +0 -1
  379. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +0 -1
  380. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js +0 -22
  381. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js.map +0 -1
  382. package/dist/cjs/shared/components/CloseIcon.d.ts.map +0 -1
  383. package/dist/cjs/shared/components/CloseIcon.js +0 -7
  384. package/dist/cjs/shared/components/CloseIcon.js.map +0 -1
  385. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +0 -1
  386. package/dist/cjs/shared/components/IFrameAndLoading.js +0 -39
  387. package/dist/cjs/shared/components/IFrameAndLoading.js.map +0 -1
  388. package/dist/cjs/shared/components/LoadingIcon.d.ts.map +0 -1
  389. package/dist/cjs/shared/components/LoadingIcon.js +0 -28
  390. package/dist/cjs/shared/components/LoadingIcon.js.map +0 -1
  391. package/dist/cjs/shared/components/SVGLoading.d.ts +0 -2
  392. package/dist/cjs/shared/components/SVGLoading.d.ts.map +0 -1
  393. package/dist/cjs/shared/components/SVGLoading.js +0 -30
  394. package/dist/cjs/shared/components/SVGLoading.js.map +0 -1
  395. package/dist/cjs/shared/hooks/index.d.ts.map +0 -1
  396. package/dist/cjs/shared/hooks/index.js +0 -24
  397. package/dist/cjs/shared/hooks/index.js.map +0 -1
  398. package/dist/cjs/shared/hooks/useAuth.d.ts +0 -3
  399. package/dist/cjs/shared/hooks/useAuth.d.ts.map +0 -1
  400. package/dist/cjs/shared/hooks/useAuth.js +0 -15
  401. package/dist/cjs/shared/hooks/useAuth.js.map +0 -1
  402. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +0 -3
  403. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +0 -1
  404. package/dist/cjs/shared/hooks/useCivicAuthConfig.js +0 -13
  405. package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +0 -1
  406. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +0 -3
  407. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  408. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +0 -16
  409. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +0 -1
  410. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +0 -1
  411. package/dist/cjs/shared/hooks/useCurrentUrl.js +0 -27
  412. package/dist/cjs/shared/hooks/useCurrentUrl.js.map +0 -1
  413. package/dist/cjs/shared/hooks/useIframe.d.ts.map +0 -1
  414. package/dist/cjs/shared/hooks/useIframe.js +0 -16
  415. package/dist/cjs/shared/hooks/useIframe.js.map +0 -1
  416. package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +0 -1
  417. package/dist/cjs/shared/hooks/useIsInIframe.js +0 -17
  418. package/dist/cjs/shared/hooks/useIsInIframe.js.map +0 -1
  419. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +0 -1
  420. package/dist/cjs/shared/hooks/useOAuthEndpoints.js +0 -17
  421. package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +0 -1
  422. package/dist/cjs/shared/hooks/useRefresh.d.ts.map +0 -1
  423. package/dist/cjs/shared/hooks/useRefresh.js +0 -41
  424. package/dist/cjs/shared/hooks/useRefresh.js.map +0 -1
  425. package/dist/cjs/shared/hooks/useSession.d.ts.map +0 -1
  426. package/dist/cjs/shared/hooks/useSession.js +0 -16
  427. package/dist/cjs/shared/hooks/useSession.js.map +0 -1
  428. package/dist/cjs/shared/hooks/useSignIn.d.ts.map +0 -1
  429. package/dist/cjs/shared/hooks/useSignIn.js +0 -168
  430. package/dist/cjs/shared/hooks/useSignIn.js.map +0 -1
  431. package/dist/cjs/shared/hooks/useToken.d.ts.map +0 -1
  432. package/dist/cjs/shared/hooks/useToken.js +0 -15
  433. package/dist/cjs/shared/hooks/useToken.js.map +0 -1
  434. package/dist/cjs/shared/hooks/useWindowFocused.d.ts.map +0 -1
  435. package/dist/cjs/shared/hooks/useWindowFocused.js +0 -24
  436. package/dist/cjs/shared/hooks/useWindowFocused.js.map +0 -1
  437. package/dist/cjs/shared/index.d.ts.map +0 -1
  438. package/dist/cjs/shared/index.js +0 -25
  439. package/dist/cjs/shared/index.js.map +0 -1
  440. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts +0 -13
  441. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts.map +0 -1
  442. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js +0 -47
  443. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js.map +0 -1
  444. package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts +0 -8
  445. package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts.map +0 -1
  446. package/dist/cjs/shared/lib/BrowserCookieStorage.js +0 -56
  447. package/dist/cjs/shared/lib/BrowserCookieStorage.js.map +0 -1
  448. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
  449. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +0 -65
  450. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
  451. package/dist/cjs/shared/lib/UserSession.d.ts.map +0 -1
  452. package/dist/cjs/shared/lib/UserSession.js +0 -27
  453. package/dist/cjs/shared/lib/UserSession.js.map +0 -1
  454. package/dist/cjs/shared/lib/iframeUtils.d.ts.map +0 -1
  455. package/dist/cjs/shared/lib/iframeUtils.js +0 -11
  456. package/dist/cjs/shared/lib/iframeUtils.js.map +0 -1
  457. package/dist/cjs/shared/lib/session.d.ts.map +0 -1
  458. package/dist/cjs/shared/lib/session.js +0 -48
  459. package/dist/cjs/shared/lib/session.js.map +0 -1
  460. package/dist/cjs/shared/lib/storage.d.ts +0 -34
  461. package/dist/cjs/shared/lib/storage.d.ts.map +0 -1
  462. package/dist/cjs/shared/lib/storage.js +0 -21
  463. package/dist/cjs/shared/lib/storage.js.map +0 -1
  464. package/dist/cjs/shared/lib/types.d.ts +0 -38
  465. package/dist/cjs/shared/lib/types.d.ts.map +0 -1
  466. package/dist/cjs/shared/lib/types.js +0 -22
  467. package/dist/cjs/shared/lib/types.js.map +0 -1
  468. package/dist/cjs/shared/lib/util.d.ts +0 -37
  469. package/dist/cjs/shared/lib/util.d.ts.map +0 -1
  470. package/dist/cjs/shared/lib/util.js +0 -204
  471. package/dist/cjs/shared/lib/util.js.map +0 -1
  472. package/dist/cjs/shared/providers/AuthContext.d.ts.map +0 -1
  473. package/dist/cjs/shared/providers/AuthContext.js +0 -7
  474. package/dist/cjs/shared/providers/AuthContext.js.map +0 -1
  475. package/dist/cjs/shared/providers/AuthProvider.d.ts +0 -22
  476. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +0 -1
  477. package/dist/cjs/shared/providers/AuthProvider.js +0 -108
  478. package/dist/cjs/shared/providers/AuthProvider.js.map +0 -1
  479. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +0 -1
  480. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +0 -59
  481. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +0 -1
  482. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts +0 -6
  483. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +0 -1
  484. package/dist/cjs/shared/providers/CivicAuthProvider.js +0 -38
  485. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +0 -1
  486. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
  487. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  488. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +0 -168
  489. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  490. package/dist/cjs/shared/providers/IframeProvider.d.ts +0 -24
  491. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +0 -1
  492. package/dist/cjs/shared/providers/IframeProvider.js +0 -45
  493. package/dist/cjs/shared/providers/IframeProvider.js.map +0 -1
  494. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +0 -1
  495. package/dist/cjs/shared/providers/SessionProvider.js +0 -28
  496. package/dist/cjs/shared/providers/SessionProvider.js.map +0 -1
  497. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +0 -1
  498. package/dist/cjs/shared/providers/TokenProvider.js +0 -39
  499. package/dist/cjs/shared/providers/TokenProvider.js.map +0 -1
  500. package/dist/cjs/shared/providers/UserProvider.d.ts.map +0 -1
  501. package/dist/cjs/shared/providers/UserProvider.js +0 -69
  502. package/dist/cjs/shared/providers/UserProvider.js.map +0 -1
  503. package/dist/cjs/shared/providers/types.d.ts.map +0 -1
  504. package/dist/cjs/shared/providers/types.js +0 -3
  505. package/dist/cjs/shared/providers/types.js.map +0 -1
  506. package/dist/cjs/shared/version.d.ts +0 -2
  507. package/dist/cjs/shared/version.d.ts.map +0 -1
  508. package/dist/cjs/shared/version.js +0 -6
  509. package/dist/cjs/shared/version.js.map +0 -1
  510. package/dist/cjs/types.d.ts +0 -159
  511. package/dist/cjs/types.d.ts.map +0 -1
  512. package/dist/cjs/types.js +0 -20
  513. package/dist/cjs/types.js.map +0 -1
  514. package/dist/cjs/utils.d.ts.map +0 -1
  515. package/dist/cjs/utils.js +0 -47
  516. package/dist/cjs/utils.js.map +0 -1
  517. package/dist/cjs/version.d.ts.map +0 -1
  518. package/dist/cjs/version.js +0 -6
  519. package/dist/cjs/version.js.map +0 -1
  520. package/dist/esm/browser/storage.d.ts +0 -10
  521. package/dist/esm/browser/storage.d.ts.map +0 -1
  522. package/dist/esm/browser/storage.js.map +0 -1
  523. package/dist/esm/config.d.ts +0 -3
  524. package/dist/esm/config.d.ts.map +0 -1
  525. package/dist/esm/config.js.map +0 -1
  526. package/dist/esm/constants.d.ts +0 -12
  527. package/dist/esm/constants.d.ts.map +0 -1
  528. package/dist/esm/constants.js +0 -26
  529. package/dist/esm/constants.js.map +0 -1
  530. package/dist/esm/index.d.ts +0 -8
  531. package/dist/esm/index.d.ts.map +0 -1
  532. package/dist/esm/index.js.map +0 -1
  533. package/dist/esm/lib/cookies.d.ts +0 -7
  534. package/dist/esm/lib/cookies.d.ts.map +0 -1
  535. package/dist/esm/lib/cookies.js.map +0 -1
  536. package/dist/esm/lib/jwt.d.ts +0 -3
  537. package/dist/esm/lib/jwt.d.ts.map +0 -1
  538. package/dist/esm/lib/jwt.js.map +0 -1
  539. package/dist/esm/lib/logger.d.ts +0 -26
  540. package/dist/esm/lib/logger.d.ts.map +0 -1
  541. package/dist/esm/lib/logger.js.map +0 -1
  542. package/dist/esm/lib/oauth.d.ts +0 -19
  543. package/dist/esm/lib/oauth.d.ts.map +0 -1
  544. package/dist/esm/lib/oauth.js.map +0 -1
  545. package/dist/esm/lib/obj.d.ts +0 -3
  546. package/dist/esm/lib/obj.d.ts.map +0 -1
  547. package/dist/esm/lib/obj.js.map +0 -1
  548. package/dist/esm/lib/postMessage.d.ts +0 -4
  549. package/dist/esm/lib/postMessage.d.ts.map +0 -1
  550. package/dist/esm/lib/postMessage.js +0 -14
  551. package/dist/esm/lib/postMessage.js.map +0 -1
  552. package/dist/esm/lib/windowUtil.d.ts +0 -4
  553. package/dist/esm/lib/windowUtil.d.ts.map +0 -1
  554. package/dist/esm/lib/windowUtil.js.map +0 -1
  555. package/dist/esm/nextjs/GetUser.d.ts +0 -6
  556. package/dist/esm/nextjs/GetUser.d.ts.map +0 -1
  557. package/dist/esm/nextjs/GetUser.js +0 -7
  558. package/dist/esm/nextjs/GetUser.js.map +0 -1
  559. package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts +0 -9
  560. package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts.map +0 -1
  561. package/dist/esm/nextjs/NextClientAuthenticationRefresher.js.map +0 -1
  562. package/dist/esm/nextjs/config.d.ts.map +0 -1
  563. package/dist/esm/nextjs/config.js.map +0 -1
  564. package/dist/esm/nextjs/cookies.d.ts +0 -27
  565. package/dist/esm/nextjs/cookies.d.ts.map +0 -1
  566. package/dist/esm/nextjs/cookies.js +0 -103
  567. package/dist/esm/nextjs/cookies.js.map +0 -1
  568. package/dist/esm/nextjs/hooks/index.d.ts +0 -2
  569. package/dist/esm/nextjs/hooks/index.d.ts.map +0 -1
  570. package/dist/esm/nextjs/hooks/index.js.map +0 -1
  571. package/dist/esm/nextjs/hooks/usePrevious.d.ts +0 -2
  572. package/dist/esm/nextjs/hooks/usePrevious.d.ts.map +0 -1
  573. package/dist/esm/nextjs/hooks/usePrevious.js.map +0 -1
  574. package/dist/esm/nextjs/hooks/useRefresh.d.ts +0 -4
  575. package/dist/esm/nextjs/hooks/useRefresh.d.ts.map +0 -1
  576. package/dist/esm/nextjs/hooks/useRefresh.js.map +0 -1
  577. package/dist/esm/nextjs/hooks/useUserCookie.d.ts +0 -8
  578. package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +0 -1
  579. package/dist/esm/nextjs/hooks/useUserCookie.js.map +0 -1
  580. package/dist/esm/nextjs/index.d.ts +0 -9
  581. package/dist/esm/nextjs/index.d.ts.map +0 -1
  582. package/dist/esm/nextjs/index.js.map +0 -1
  583. package/dist/esm/nextjs/middleware/index.d.ts +0 -2
  584. package/dist/esm/nextjs/middleware/index.d.ts.map +0 -1
  585. package/dist/esm/nextjs/middleware/index.js.map +0 -1
  586. package/dist/esm/nextjs/middleware.d.ts +0 -57
  587. package/dist/esm/nextjs/middleware.d.ts.map +0 -1
  588. package/dist/esm/nextjs/middleware.js +0 -102
  589. package/dist/esm/nextjs/middleware.js.map +0 -1
  590. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +0 -9
  591. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
  592. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +0 -1
  593. package/dist/esm/nextjs/routeHandler.d.ts +0 -19
  594. package/dist/esm/nextjs/routeHandler.d.ts.map +0 -1
  595. package/dist/esm/nextjs/routeHandler.js +0 -312
  596. package/dist/esm/nextjs/routeHandler.js.map +0 -1
  597. package/dist/esm/nextjs/utils.d.ts +0 -3
  598. package/dist/esm/nextjs/utils.d.ts.map +0 -1
  599. package/dist/esm/nextjs/utils.js.map +0 -1
  600. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts +0 -17
  601. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts.map +0 -1
  602. package/dist/esm/reactjs/components/ButtonContentOrLoader.js.map +0 -1
  603. package/dist/esm/reactjs/components/SignInButton.d.ts +0 -9
  604. package/dist/esm/reactjs/components/SignInButton.d.ts.map +0 -1
  605. package/dist/esm/reactjs/components/SignInButton.js.map +0 -1
  606. package/dist/esm/reactjs/components/SignOutButton.d.ts +0 -7
  607. package/dist/esm/reactjs/components/SignOutButton.d.ts.map +0 -1
  608. package/dist/esm/reactjs/components/SignOutButton.js.map +0 -1
  609. package/dist/esm/reactjs/components/UserButton.d.ts +0 -9
  610. package/dist/esm/reactjs/components/UserButton.d.ts.map +0 -1
  611. package/dist/esm/reactjs/components/UserButton.js +0 -143
  612. package/dist/esm/reactjs/components/UserButton.js.map +0 -1
  613. package/dist/esm/reactjs/components/index.d.ts +0 -6
  614. package/dist/esm/reactjs/components/index.d.ts.map +0 -1
  615. package/dist/esm/reactjs/components/index.js.map +0 -1
  616. package/dist/esm/reactjs/components/utils.d.ts +0 -13
  617. package/dist/esm/reactjs/components/utils.d.ts.map +0 -1
  618. package/dist/esm/reactjs/components/utils.js.map +0 -1
  619. package/dist/esm/reactjs/hooks/index.d.ts +0 -3
  620. package/dist/esm/reactjs/hooks/index.d.ts.map +0 -1
  621. package/dist/esm/reactjs/hooks/index.js.map +0 -1
  622. package/dist/esm/reactjs/hooks/useAuth.d.ts +0 -3
  623. package/dist/esm/reactjs/hooks/useAuth.d.ts.map +0 -1
  624. package/dist/esm/reactjs/hooks/useAuth.js.map +0 -1
  625. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts +0 -3
  626. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  627. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js.map +0 -1
  628. package/dist/esm/reactjs/hooks/useSignIn.d.ts +0 -6
  629. package/dist/esm/reactjs/hooks/useSignIn.d.ts.map +0 -1
  630. package/dist/esm/reactjs/hooks/useSignIn.js +0 -34
  631. package/dist/esm/reactjs/hooks/useSignIn.js.map +0 -1
  632. package/dist/esm/reactjs/hooks/useUser.d.ts +0 -4
  633. package/dist/esm/reactjs/hooks/useUser.d.ts.map +0 -1
  634. package/dist/esm/reactjs/hooks/useUser.js.map +0 -1
  635. package/dist/esm/reactjs/index.d.ts +0 -6
  636. package/dist/esm/reactjs/index.d.ts.map +0 -1
  637. package/dist/esm/reactjs/index.js.map +0 -1
  638. package/dist/esm/reactjs/providers/AuthProvider.d.ts +0 -10
  639. package/dist/esm/reactjs/providers/AuthProvider.d.ts.map +0 -1
  640. package/dist/esm/reactjs/providers/AuthProvider.js.map +0 -1
  641. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts +0 -5
  642. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts.map +0 -1
  643. package/dist/esm/reactjs/providers/CivicAuthProvider.js.map +0 -1
  644. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
  645. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  646. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  647. package/dist/esm/reactjs/providers/index.d.ts +0 -8
  648. package/dist/esm/reactjs/providers/index.d.ts.map +0 -1
  649. package/dist/esm/reactjs/providers/index.js.map +0 -1
  650. package/dist/esm/server/ServerAuthenticationResolver.d.ts +0 -20
  651. package/dist/esm/server/ServerAuthenticationResolver.d.ts.map +0 -1
  652. package/dist/esm/server/ServerAuthenticationResolver.js +0 -67
  653. package/dist/esm/server/ServerAuthenticationResolver.js.map +0 -1
  654. package/dist/esm/server/config.d.ts +0 -11
  655. package/dist/esm/server/config.d.ts.map +0 -1
  656. package/dist/esm/server/config.js.map +0 -1
  657. package/dist/esm/server/index.d.ts +0 -9
  658. package/dist/esm/server/index.d.ts.map +0 -1
  659. package/dist/esm/server/index.js.map +0 -1
  660. package/dist/esm/server/login.d.ts +0 -17
  661. package/dist/esm/server/login.d.ts.map +0 -1
  662. package/dist/esm/server/login.js.map +0 -1
  663. package/dist/esm/server/logout.d.ts +0 -7
  664. package/dist/esm/server/logout.d.ts.map +0 -1
  665. package/dist/esm/server/logout.js.map +0 -1
  666. package/dist/esm/server/refresh.d.ts +0 -7
  667. package/dist/esm/server/refresh.d.ts.map +0 -1
  668. package/dist/esm/server/refresh.js.map +0 -1
  669. package/dist/esm/services/AuthenticationService.d.ts +0 -91
  670. package/dist/esm/services/AuthenticationService.d.ts.map +0 -1
  671. package/dist/esm/services/AuthenticationService.js +0 -352
  672. package/dist/esm/services/AuthenticationService.js.map +0 -1
  673. package/dist/esm/services/PKCE.d.ts +0 -20
  674. package/dist/esm/services/PKCE.d.ts.map +0 -1
  675. package/dist/esm/services/PKCE.js.map +0 -1
  676. package/dist/esm/services/types.d.ts +0 -24
  677. package/dist/esm/services/types.d.ts.map +0 -1
  678. package/dist/esm/services/types.js.map +0 -1
  679. package/dist/esm/shared/components/BlockDisplay.d.ts +0 -6
  680. package/dist/esm/shared/components/BlockDisplay.d.ts.map +0 -1
  681. package/dist/esm/shared/components/BlockDisplay.js +0 -25
  682. package/dist/esm/shared/components/BlockDisplay.js.map +0 -1
  683. package/dist/esm/shared/components/CivicAuthIframe.d.ts +0 -9
  684. package/dist/esm/shared/components/CivicAuthIframe.d.ts.map +0 -1
  685. package/dist/esm/shared/components/CivicAuthIframe.js +0 -30
  686. package/dist/esm/shared/components/CivicAuthIframe.js.map +0 -1
  687. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts +0 -14
  688. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
  689. package/dist/esm/shared/components/CivicAuthIframeContainer.js +0 -155
  690. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +0 -1
  691. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts +0 -6
  692. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +0 -1
  693. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js +0 -20
  694. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js.map +0 -1
  695. package/dist/esm/shared/components/CloseIcon.d.ts +0 -3
  696. package/dist/esm/shared/components/CloseIcon.d.ts.map +0 -1
  697. package/dist/esm/shared/components/CloseIcon.js.map +0 -1
  698. package/dist/esm/shared/components/IFrameAndLoading.d.ts +0 -7
  699. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +0 -1
  700. package/dist/esm/shared/components/IFrameAndLoading.js.map +0 -1
  701. package/dist/esm/shared/components/LoadingIcon.d.ts +0 -6
  702. package/dist/esm/shared/components/LoadingIcon.d.ts.map +0 -1
  703. package/dist/esm/shared/components/LoadingIcon.js.map +0 -1
  704. package/dist/esm/shared/components/SVGLoading.d.ts +0 -2
  705. package/dist/esm/shared/components/SVGLoading.d.ts.map +0 -1
  706. package/dist/esm/shared/components/SVGLoading.js +0 -28
  707. package/dist/esm/shared/components/SVGLoading.js.map +0 -1
  708. package/dist/esm/shared/hooks/index.d.ts +0 -11
  709. package/dist/esm/shared/hooks/index.d.ts.map +0 -1
  710. package/dist/esm/shared/hooks/index.js.map +0 -1
  711. package/dist/esm/shared/hooks/useAuth.d.ts +0 -3
  712. package/dist/esm/shared/hooks/useAuth.d.ts.map +0 -1
  713. package/dist/esm/shared/hooks/useAuth.js +0 -12
  714. package/dist/esm/shared/hooks/useAuth.js.map +0 -1
  715. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +0 -1
  716. package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +0 -1
  717. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +0 -3
  718. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  719. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +0 -13
  720. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +0 -1
  721. package/dist/esm/shared/hooks/useCurrentUrl.d.ts +0 -3
  722. package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +0 -1
  723. package/dist/esm/shared/hooks/useCurrentUrl.js.map +0 -1
  724. package/dist/esm/shared/hooks/useIframe.d.ts +0 -3
  725. package/dist/esm/shared/hooks/useIframe.d.ts.map +0 -1
  726. package/dist/esm/shared/hooks/useIframe.js.map +0 -1
  727. package/dist/esm/shared/hooks/useIsInIframe.d.ts +0 -3
  728. package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +0 -1
  729. package/dist/esm/shared/hooks/useIsInIframe.js.map +0 -1
  730. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +0 -4
  731. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +0 -1
  732. package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +0 -1
  733. package/dist/esm/shared/hooks/useRefresh.d.ts +0 -4
  734. package/dist/esm/shared/hooks/useRefresh.d.ts.map +0 -1
  735. package/dist/esm/shared/hooks/useRefresh.js.map +0 -1
  736. package/dist/esm/shared/hooks/useSession.d.ts +0 -3
  737. package/dist/esm/shared/hooks/useSession.d.ts.map +0 -1
  738. package/dist/esm/shared/hooks/useSession.js.map +0 -1
  739. package/dist/esm/shared/hooks/useSignIn.d.ts +0 -17
  740. package/dist/esm/shared/hooks/useSignIn.d.ts.map +0 -1
  741. package/dist/esm/shared/hooks/useSignIn.js +0 -165
  742. package/dist/esm/shared/hooks/useSignIn.js.map +0 -1
  743. package/dist/esm/shared/hooks/useToken.d.ts +0 -3
  744. package/dist/esm/shared/hooks/useToken.d.ts.map +0 -1
  745. package/dist/esm/shared/hooks/useToken.js.map +0 -1
  746. package/dist/esm/shared/hooks/useWindowFocused.d.ts +0 -5
  747. package/dist/esm/shared/hooks/useWindowFocused.d.ts.map +0 -1
  748. package/dist/esm/shared/hooks/useWindowFocused.js.map +0 -1
  749. package/dist/esm/shared/index.d.ts +0 -7
  750. package/dist/esm/shared/index.d.ts.map +0 -1
  751. package/dist/esm/shared/index.js.map +0 -1
  752. package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts +0 -13
  753. package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts.map +0 -1
  754. package/dist/esm/shared/lib/AuthenticationRefresherImpl.js +0 -43
  755. package/dist/esm/shared/lib/AuthenticationRefresherImpl.js.map +0 -1
  756. package/dist/esm/shared/lib/BrowserCookieStorage.d.ts +0 -8
  757. package/dist/esm/shared/lib/BrowserCookieStorage.d.ts.map +0 -1
  758. package/dist/esm/shared/lib/BrowserCookieStorage.js +0 -52
  759. package/dist/esm/shared/lib/BrowserCookieStorage.js.map +0 -1
  760. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +0 -16
  761. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
  762. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
  763. package/dist/esm/shared/lib/UserSession.d.ts +0 -17
  764. package/dist/esm/shared/lib/UserSession.d.ts.map +0 -1
  765. package/dist/esm/shared/lib/UserSession.js.map +0 -1
  766. package/dist/esm/shared/lib/iframeUtils.d.ts +0 -6
  767. package/dist/esm/shared/lib/iframeUtils.d.ts.map +0 -1
  768. package/dist/esm/shared/lib/iframeUtils.js.map +0 -1
  769. package/dist/esm/shared/lib/session.d.ts +0 -4
  770. package/dist/esm/shared/lib/session.d.ts.map +0 -1
  771. package/dist/esm/shared/lib/session.js.map +0 -1
  772. package/dist/esm/shared/lib/storage.d.ts +0 -34
  773. package/dist/esm/shared/lib/storage.d.ts.map +0 -1
  774. package/dist/esm/shared/lib/storage.js.map +0 -1
  775. package/dist/esm/shared/lib/types.d.ts +0 -38
  776. package/dist/esm/shared/lib/types.d.ts.map +0 -1
  777. package/dist/esm/shared/lib/types.js.map +0 -1
  778. package/dist/esm/shared/lib/util.d.ts +0 -37
  779. package/dist/esm/shared/lib/util.d.ts.map +0 -1
  780. package/dist/esm/shared/lib/util.js +0 -155
  781. package/dist/esm/shared/lib/util.js.map +0 -1
  782. package/dist/esm/shared/providers/AuthContext.d.ts +0 -12
  783. package/dist/esm/shared/providers/AuthContext.d.ts.map +0 -1
  784. package/dist/esm/shared/providers/AuthContext.js.map +0 -1
  785. package/dist/esm/shared/providers/AuthProvider.d.ts +0 -22
  786. package/dist/esm/shared/providers/AuthProvider.d.ts.map +0 -1
  787. package/dist/esm/shared/providers/AuthProvider.js +0 -72
  788. package/dist/esm/shared/providers/AuthProvider.js.map +0 -1
  789. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +0 -19
  790. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +0 -1
  791. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +0 -1
  792. package/dist/esm/shared/providers/CivicAuthProvider.d.ts +0 -6
  793. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +0 -1
  794. package/dist/esm/shared/providers/CivicAuthProvider.js +0 -32
  795. package/dist/esm/shared/providers/CivicAuthProvider.js.map +0 -1
  796. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
  797. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  798. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +0 -131
  799. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  800. package/dist/esm/shared/providers/IframeProvider.d.ts +0 -24
  801. package/dist/esm/shared/providers/IframeProvider.d.ts.map +0 -1
  802. package/dist/esm/shared/providers/IframeProvider.js +0 -41
  803. package/dist/esm/shared/providers/IframeProvider.js.map +0 -1
  804. package/dist/esm/shared/providers/SessionProvider.d.ts +0 -19
  805. package/dist/esm/shared/providers/SessionProvider.d.ts.map +0 -1
  806. package/dist/esm/shared/providers/SessionProvider.js.map +0 -1
  807. package/dist/esm/shared/providers/TokenProvider.d.ts +0 -17
  808. package/dist/esm/shared/providers/TokenProvider.d.ts.map +0 -1
  809. package/dist/esm/shared/providers/TokenProvider.js.map +0 -1
  810. package/dist/esm/shared/providers/UserProvider.d.ts +0 -26
  811. package/dist/esm/shared/providers/UserProvider.d.ts.map +0 -1
  812. package/dist/esm/shared/providers/UserProvider.js.map +0 -1
  813. package/dist/esm/shared/providers/types.d.ts +0 -15
  814. package/dist/esm/shared/providers/types.d.ts.map +0 -1
  815. package/dist/esm/shared/providers/types.js.map +0 -1
  816. package/dist/esm/shared/version.d.ts +0 -2
  817. package/dist/esm/shared/version.d.ts.map +0 -1
  818. package/dist/esm/shared/version.js +0 -3
  819. package/dist/esm/shared/version.js.map +0 -1
  820. package/dist/esm/types.d.ts +0 -159
  821. package/dist/esm/types.d.ts.map +0 -1
  822. package/dist/esm/types.js.map +0 -1
  823. package/dist/esm/utils.d.ts +0 -15
  824. package/dist/esm/utils.d.ts.map +0 -1
  825. package/dist/esm/utils.js.map +0 -1
  826. package/dist/esm/version.d.ts +0 -2
  827. package/dist/esm/version.d.ts.map +0 -1
  828. package/dist/esm/version.js.map +0 -1
  829. package/dist/tsconfig.cjs.tsbuildinfo +0 -1
  830. package/dist/tsconfig.esm.tsbuildinfo +0 -1
  831. /package/dist/{cjs/browser → browser}/storage.d.ts +0 -0
  832. /package/dist/{esm/browser → browser}/storage.js +0 -0
  833. /package/dist/{cjs/config.d.ts → config.d.ts} +0 -0
  834. /package/dist/{esm/config.js → config.js} +0 -0
  835. /package/dist/{cjs/index.d.ts → index.d.ts} +0 -0
  836. /package/dist/{esm/index.js → index.js} +0 -0
  837. /package/dist/{cjs/lib → lib}/cookies.d.ts +0 -0
  838. /package/dist/{esm/lib → lib}/cookies.js +0 -0
  839. /package/dist/{cjs/lib → lib}/jwt.d.ts +0 -0
  840. /package/dist/{esm/lib → lib}/jwt.js +0 -0
  841. /package/dist/{cjs/lib → lib}/logger.d.ts +0 -0
  842. /package/dist/{esm/lib → lib}/logger.js +0 -0
  843. /package/dist/{cjs/lib → lib}/oauth.d.ts +0 -0
  844. /package/dist/{esm/lib → lib}/oauth.js +0 -0
  845. /package/dist/{cjs/lib → lib}/obj.d.ts +0 -0
  846. /package/dist/{esm/lib → lib}/obj.js +0 -0
  847. /package/dist/{cjs/lib → lib}/postMessage.d.ts +0 -0
  848. /package/dist/{cjs/lib → lib}/windowUtil.d.ts +0 -0
  849. /package/dist/{esm/lib → lib}/windowUtil.js +0 -0
  850. /package/dist/{cjs/nextjs → nextjs}/NextClientAuthenticationRefresher.d.ts +0 -0
  851. /package/dist/{esm/nextjs → nextjs}/NextClientAuthenticationRefresher.js +0 -0
  852. /package/dist/{esm/nextjs → nextjs}/config.d.ts +0 -0
  853. /package/dist/{esm/nextjs → nextjs}/config.js +0 -0
  854. /package/dist/{cjs/nextjs → nextjs}/hooks/index.d.ts +0 -0
  855. /package/dist/{esm/nextjs → nextjs}/hooks/index.js +0 -0
  856. /package/dist/{cjs/nextjs → nextjs}/hooks/usePrevious.d.ts +0 -0
  857. /package/dist/{esm/nextjs → nextjs}/hooks/usePrevious.js +0 -0
  858. /package/dist/{cjs/nextjs → nextjs}/hooks/useRefresh.d.ts +0 -0
  859. /package/dist/{esm/nextjs → nextjs}/hooks/useRefresh.js +0 -0
  860. /package/dist/{cjs/nextjs → nextjs}/hooks/useUserCookie.d.ts +0 -0
  861. /package/dist/{esm/nextjs → nextjs}/hooks/useUserCookie.js +0 -0
  862. /package/dist/{cjs/nextjs → nextjs}/index.d.ts +0 -0
  863. /package/dist/{esm/nextjs → nextjs}/index.js +0 -0
  864. /package/dist/{cjs/nextjs → nextjs}/middleware/index.d.ts +0 -0
  865. /package/dist/{esm/nextjs → nextjs}/middleware/index.js +0 -0
  866. /package/dist/{cjs/nextjs → nextjs}/middleware.d.ts +0 -0
  867. /package/dist/{cjs/nextjs → nextjs}/providers/NextAuthProvider.d.ts +0 -0
  868. /package/dist/{esm/nextjs → nextjs}/providers/NextAuthProvider.js +0 -0
  869. /package/dist/{cjs/nextjs → nextjs}/routeHandler.d.ts +0 -0
  870. /package/dist/{cjs/nextjs → nextjs}/utils.d.ts +0 -0
  871. /package/dist/{esm/nextjs → nextjs}/utils.js +0 -0
  872. /package/dist/{cjs/reactjs → reactjs}/components/ButtonContentOrLoader.d.ts +0 -0
  873. /package/dist/{esm/reactjs → reactjs}/components/ButtonContentOrLoader.js +0 -0
  874. /package/dist/{cjs/reactjs → reactjs}/components/SignInButton.d.ts +0 -0
  875. /package/dist/{esm/reactjs → reactjs}/components/SignInButton.js +0 -0
  876. /package/dist/{cjs/reactjs → reactjs}/components/SignOutButton.d.ts +0 -0
  877. /package/dist/{esm/reactjs → reactjs}/components/SignOutButton.js +0 -0
  878. /package/dist/{cjs/reactjs → reactjs}/components/UserButton.d.ts +0 -0
  879. /package/dist/{cjs/reactjs → reactjs}/components/index.d.ts +0 -0
  880. /package/dist/{esm/reactjs → reactjs}/components/index.js +0 -0
  881. /package/dist/{cjs/reactjs → reactjs}/components/utils.d.ts +0 -0
  882. /package/dist/{esm/reactjs → reactjs}/components/utils.js +0 -0
  883. /package/dist/{cjs/reactjs → reactjs}/hooks/index.d.ts +0 -0
  884. /package/dist/{esm/reactjs → reactjs}/hooks/index.js +0 -0
  885. /package/dist/{cjs/reactjs → reactjs}/hooks/useClientTokenExchangeSession.d.ts +0 -0
  886. /package/dist/{esm/reactjs → reactjs}/hooks/useClientTokenExchangeSession.js +0 -0
  887. /package/dist/{cjs/reactjs → reactjs}/hooks/useUser.d.ts +0 -0
  888. /package/dist/{esm/reactjs → reactjs}/hooks/useUser.js +0 -0
  889. /package/dist/{cjs/reactjs → reactjs}/index.d.ts +0 -0
  890. /package/dist/{esm/reactjs → reactjs}/index.js +0 -0
  891. /package/dist/{cjs/reactjs → reactjs}/providers/AuthProvider.d.ts +0 -0
  892. /package/dist/{esm/reactjs → reactjs}/providers/AuthProvider.js +0 -0
  893. /package/dist/{cjs/reactjs → reactjs}/providers/CivicAuthProvider.d.ts +0 -0
  894. /package/dist/{esm/reactjs → reactjs}/providers/CivicAuthProvider.js +0 -0
  895. /package/dist/{cjs/reactjs → reactjs}/providers/ClientTokenExchangeSessionProvider.d.ts +0 -0
  896. /package/dist/{esm/reactjs → reactjs}/providers/ClientTokenExchangeSessionProvider.js +0 -0
  897. /package/dist/{cjs/reactjs → reactjs}/providers/index.d.ts +0 -0
  898. /package/dist/{esm/reactjs → reactjs}/providers/index.js +0 -0
  899. /package/dist/{cjs/server → server}/ServerAuthenticationResolver.d.ts +0 -0
  900. /package/dist/{cjs/server → server}/config.d.ts +0 -0
  901. /package/dist/{esm/server → server}/config.js +0 -0
  902. /package/dist/{cjs/server → server}/index.d.ts +0 -0
  903. /package/dist/{esm/server → server}/index.js +0 -0
  904. /package/dist/{cjs/server → server}/login.d.ts +0 -0
  905. /package/dist/{esm/server → server}/login.js +0 -0
  906. /package/dist/{cjs/server → server}/logout.d.ts +0 -0
  907. /package/dist/{esm/server → server}/logout.js +0 -0
  908. /package/dist/{cjs/server → server}/refresh.d.ts +0 -0
  909. /package/dist/{esm/server → server}/refresh.js +0 -0
  910. /package/dist/{cjs/services → services}/PKCE.d.ts +0 -0
  911. /package/dist/{esm/services → services}/PKCE.js +0 -0
  912. /package/dist/{cjs/services → services}/types.d.ts +0 -0
  913. /package/dist/{esm/services → services}/types.js +0 -0
  914. /package/dist/{cjs/shared → shared}/components/BlockDisplay.d.ts +0 -0
  915. /package/dist/{cjs/shared → shared}/components/CivicAuthIframe.d.ts +0 -0
  916. /package/dist/{cjs/shared → shared}/components/CivicAuthIframeContainer.d.ts +0 -0
  917. /package/dist/{cjs/shared → shared}/components/CivicAuthLogoutIframeContainer.d.ts +0 -0
  918. /package/dist/{cjs/shared → shared}/components/CloseIcon.d.ts +0 -0
  919. /package/dist/{esm/shared → shared}/components/CloseIcon.js +0 -0
  920. /package/dist/{cjs/shared → shared}/components/IFrameAndLoading.d.ts +0 -0
  921. /package/dist/{esm/shared → shared}/components/IFrameAndLoading.js +0 -0
  922. /package/dist/{cjs/shared → shared}/components/LoadingIcon.d.ts +0 -0
  923. /package/dist/{esm/shared → shared}/components/LoadingIcon.js +0 -0
  924. /package/dist/{cjs/shared → shared}/hooks/index.d.ts +0 -0
  925. /package/dist/{esm/shared → shared}/hooks/index.js +0 -0
  926. /package/dist/{cjs/reactjs → shared}/hooks/useAuth.d.ts +0 -0
  927. /package/dist/{esm/reactjs → shared}/hooks/useAuth.js +0 -0
  928. /package/dist/{esm/shared → shared}/hooks/useCivicAuthConfig.d.ts +0 -0
  929. /package/dist/{esm/shared → shared}/hooks/useCivicAuthConfig.js +0 -0
  930. /package/dist/{cjs/shared → shared}/hooks/useCurrentUrl.d.ts +0 -0
  931. /package/dist/{esm/shared → shared}/hooks/useCurrentUrl.js +0 -0
  932. /package/dist/{cjs/shared → shared}/hooks/useIframe.d.ts +0 -0
  933. /package/dist/{esm/shared → shared}/hooks/useIframe.js +0 -0
  934. /package/dist/{cjs/shared → shared}/hooks/useIsInIframe.d.ts +0 -0
  935. /package/dist/{esm/shared → shared}/hooks/useIsInIframe.js +0 -0
  936. /package/dist/{cjs/shared → shared}/hooks/useOAuthEndpoints.d.ts +0 -0
  937. /package/dist/{esm/shared → shared}/hooks/useOAuthEndpoints.js +0 -0
  938. /package/dist/{cjs/shared → shared}/hooks/useRefresh.d.ts +0 -0
  939. /package/dist/{esm/shared → shared}/hooks/useRefresh.js +0 -0
  940. /package/dist/{cjs/shared → shared}/hooks/useSession.d.ts +0 -0
  941. /package/dist/{esm/shared → shared}/hooks/useSession.js +0 -0
  942. /package/dist/{cjs/shared → shared}/hooks/useSignIn.d.ts +0 -0
  943. /package/dist/{cjs/shared → shared}/hooks/useToken.d.ts +0 -0
  944. /package/dist/{esm/shared → shared}/hooks/useToken.js +0 -0
  945. /package/dist/{cjs/shared → shared}/hooks/useWindowFocused.d.ts +0 -0
  946. /package/dist/{esm/shared → shared}/hooks/useWindowFocused.js +0 -0
  947. /package/dist/{cjs/shared → shared}/index.d.ts +0 -0
  948. /package/dist/{esm/shared → shared}/index.js +0 -0
  949. /package/dist/{cjs/shared → shared}/lib/GenericAuthenticationRefresher.d.ts +0 -0
  950. /package/dist/{esm/shared → shared}/lib/GenericAuthenticationRefresher.js +0 -0
  951. /package/dist/{cjs/shared → shared}/lib/UserSession.d.ts +0 -0
  952. /package/dist/{esm/shared → shared}/lib/UserSession.js +0 -0
  953. /package/dist/{cjs/shared → shared}/lib/iframeUtils.d.ts +0 -0
  954. /package/dist/{esm/shared → shared}/lib/iframeUtils.js +0 -0
  955. /package/dist/{cjs/shared → shared}/lib/session.d.ts +0 -0
  956. /package/dist/{esm/shared → shared}/lib/session.js +0 -0
  957. /package/dist/{esm/shared → shared}/lib/storage.js +0 -0
  958. /package/dist/{esm/shared → shared}/lib/types.js +0 -0
  959. /package/dist/{cjs/shared → shared}/providers/AuthContext.d.ts +0 -0
  960. /package/dist/{esm/shared → shared}/providers/AuthContext.js +0 -0
  961. /package/dist/{cjs/shared → shared}/providers/CivicAuthConfigContext.d.ts +0 -0
  962. /package/dist/{esm/shared → shared}/providers/CivicAuthConfigContext.js +0 -0
  963. /package/dist/{cjs/shared → shared}/providers/SessionProvider.d.ts +0 -0
  964. /package/dist/{esm/shared → shared}/providers/SessionProvider.js +0 -0
  965. /package/dist/{cjs/shared → shared}/providers/TokenProvider.d.ts +0 -0
  966. /package/dist/{esm/shared → shared}/providers/TokenProvider.js +0 -0
  967. /package/dist/{cjs/shared → shared}/providers/UserProvider.d.ts +0 -0
  968. /package/dist/{esm/shared → shared}/providers/UserProvider.js +0 -0
  969. /package/dist/{cjs/shared → shared}/providers/types.d.ts +0 -0
  970. /package/dist/{esm/shared → shared}/providers/types.js +0 -0
  971. /package/dist/{esm/types.js → types.js} +0 -0
  972. /package/dist/{cjs/utils.d.ts → utils.d.ts} +0 -0
  973. /package/dist/{esm/utils.js → utils.js} +0 -0
  974. /package/dist/{cjs/version.d.ts → version.d.ts} +0 -0
  975. /package/dist/{esm/version.js → version.js} +0 -0
@@ -1,102 +0,0 @@
1
- import { NextResponse } from "next/server.js";
2
- import picomatch from "picomatch";
3
- import { resolveAuthConfig } from "../nextjs/config.js";
4
- // Matches globs:
5
- // Examples:
6
- // /user
7
- // /user/*
8
- // /user/**/info
9
- const matchGlob = (pathname, globPattern) => {
10
- const matches = picomatch(globPattern);
11
- return matches(pathname);
12
- };
13
- // Matches globs:
14
- // Examples:
15
- // /user
16
- // /user/*
17
- // /user/**/info
18
- const matchesGlobs = (pathname, patterns) => patterns.some((pattern) => {
19
- if (!pattern)
20
- return false;
21
- return matchGlob(pathname, pattern);
22
- });
23
- // internal - used by all exported functions
24
- const applyAuth = async (authConfig, request) => {
25
- const authConfigWithDefaults = resolveAuthConfig(authConfig);
26
- // Check for any valid auth token
27
- const isAuthenticated = !!request.cookies.get("id_token");
28
- console.log("Applying auth middleware", { requestMethod: request.method, pathname: request.nextUrl.pathname, requestUrl: request.url, configLoginUrl: authConfigWithDefaults.loginUrl });
29
- // skip auth check for redirect to login url
30
- if (request.nextUrl.pathname === authConfigWithDefaults.loginUrl &&
31
- request.method === "GET") {
32
- console.log("→ Skipping auth check - this is the login URL");
33
- return undefined;
34
- }
35
- if (!matchesGlobs(request.nextUrl.pathname, authConfigWithDefaults.include)) {
36
- console.log("→ Skipping auth check - path not in include patterns");
37
- return undefined;
38
- }
39
- if (matchesGlobs(request.nextUrl.pathname, authConfigWithDefaults.exclude)) {
40
- console.log("→ Skipping auth check - path in exclude patterns");
41
- return undefined;
42
- }
43
- // Check for either token type
44
- if (!isAuthenticated) {
45
- const loginUrl = new URL(authConfigWithDefaults.loginUrl, request.url);
46
- console.log("Redirecting to login url", { loginUrl: loginUrl?.toString(), requestUrl: request.url?.toString() });
47
- console.log("→ No valid token found - redirecting to login", loginUrl);
48
- return NextResponse.redirect(loginUrl);
49
- }
50
- console.log("→ Auth check passed");
51
- return undefined;
52
- };
53
- /**
54
- *
55
- * Use this when auth is the only middleware you need.
56
- * Usage:
57
- *
58
- * export default authMiddleware({ loginUrl = '/login' }); // or just authMiddleware();
59
- *
60
- */
61
- export const authMiddleware = (authConfig = {}) => async (request) => {
62
- const response = await applyAuth(authConfig, request);
63
- if (response)
64
- return response;
65
- // NextJS doesn't do middleware chaining yet, so this does not mean
66
- // "call the next middleware" - it means "continue to the route handler"
67
- return NextResponse.next();
68
- };
69
- /**
70
- * Usage:
71
- *
72
- * export default withAuth(async (request) => {
73
- * console.log('my middleware');
74
- * return NextResponse.next();
75
- * })
76
- */
77
- // use this when you have your own middleware to chain
78
- export function withAuth(middleware) {
79
- return auth()(middleware);
80
- }
81
- /**
82
- * Use this when you want to configure the middleware here (an alternative is to do it in the next.config file)
83
- *
84
- * Usage:
85
- *
86
- * export default auth(authConfig: AuthConfig ) => {
87
- * console.log('my middleware');
88
- * return NextResponse.next();
89
- * })
90
- *
91
- */
92
- export function auth(authConfig = {}) {
93
- return (middleware) => {
94
- return async (request) => {
95
- const response = await applyAuth(authConfig, request);
96
- if (response)
97
- return response;
98
- return middleware(request);
99
- };
100
- };
101
- }
102
- //# sourceMappingURL=middleware.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/nextjs/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Authenticates the user on all requests by checking the token cookie\n *\n * Usage:\n * Option 1: use if no other middleware (e.g. no next-intl etc)\n * export default authMiddleware();\n *\n * Option 2: use if other middleware is needed - default auth config\n * export default withAuth((request) => {\n * console.log('in custom middleware', request.nextUrl.pathname);\n * return NextResponse.next();\n * })\n *\n * Option 3: use if other middleware is needed - specifying auth config\n * const withCivicAuth = auth({ loginUrl: '/login', include: ['/[.*]/user'] })\n * export default withCivicAuth((request) => {\n * console.log('in custom middleware', request.url);\n * return NextResponse.next();\n * })\n *\n */\nimport type { NextRequest } from \"next/server.js\";\nimport { NextResponse } from \"next/server.js\";\nimport picomatch from \"picomatch\";\nimport type { OptionalAuthConfig } from \"@/nextjs/config.js\";\nimport { resolveAuthConfig } from \"@/nextjs/config.js\";\n\ntype Middleware = (\n request: NextRequest,\n) => Promise<NextResponse> | NextResponse;\n\n// Matches globs:\n// Examples:\n// /user\n// /user/*\n// /user/**/info\nconst matchGlob = (pathname: string, globPattern: string) => {\n const matches = picomatch(globPattern);\n return matches(pathname);\n};\n\n// Matches globs:\n// Examples:\n// /user\n// /user/*\n// /user/**/info\nconst matchesGlobs = (pathname: string, patterns: string[]) =>\n patterns.some((pattern) => {\n if (!pattern) return false;\n return matchGlob(pathname, pattern);\n });\n\n// internal - used by all exported functions\nconst applyAuth = async (\n authConfig: OptionalAuthConfig,\n request: NextRequest,\n): Promise<NextResponse | undefined> => {\n const authConfigWithDefaults = resolveAuthConfig(authConfig);\n // Check for any valid auth token\n const isAuthenticated = !!request.cookies.get(\"id_token\");\n\n console.log(\"Applying auth middleware\", {requestMethod: request.method, pathname: request.nextUrl.pathname, requestUrl: request.url, configLoginUrl: authConfigWithDefaults.loginUrl});\n\n // skip auth check for redirect to login url\n if (\n request.nextUrl.pathname === authConfigWithDefaults.loginUrl &&\n request.method === \"GET\"\n ) {\n console.log(\"→ Skipping auth check - this is the login URL\");\n return undefined;\n }\n\n if (!matchesGlobs(request.nextUrl.pathname, authConfigWithDefaults.include)) {\n console.log(\"→ Skipping auth check - path not in include patterns\");\n return undefined;\n }\n\n if (matchesGlobs(request.nextUrl.pathname, authConfigWithDefaults.exclude)) {\n console.log(\"→ Skipping auth check - path in exclude patterns\");\n return undefined;\n }\n\n // Check for either token type\n if (!isAuthenticated) {\n const loginUrl = new URL(authConfigWithDefaults.loginUrl, request.url);\n console.log(\"Redirecting to login url\", {loginUrl: loginUrl?.toString(), requestUrl: request.url?.toString()});\n console.log(\"→ No valid token found - redirecting to login\", loginUrl);\n return NextResponse.redirect(loginUrl);\n }\n\n console.log(\"→ Auth check passed\");\n return undefined;\n};\n\n/**\n *\n * Use this when auth is the only middleware you need.\n * Usage:\n *\n * export default authMiddleware({ loginUrl = '/login' }); // or just authMiddleware();\n *\n */\nexport const authMiddleware =\n (authConfig: OptionalAuthConfig = {}) =>\n async (request: NextRequest): Promise<NextResponse> => {\n const response = await applyAuth(authConfig, request);\n if (response) return response;\n\n // NextJS doesn't do middleware chaining yet, so this does not mean\n // \"call the next middleware\" - it means \"continue to the route handler\"\n return NextResponse.next();\n };\n\n/**\n * Usage:\n *\n * export default withAuth(async (request) => {\n * console.log('my middleware');\n * return NextResponse.next();\n * })\n */\n// use this when you have your own middleware to chain\nexport function withAuth(\n middleware: Middleware,\n): (request: NextRequest) => Promise<NextResponse> {\n return auth()(middleware);\n}\n\n/**\n * Use this when you want to configure the middleware here (an alternative is to do it in the next.config file)\n *\n * Usage:\n *\n * export default auth(authConfig: AuthConfig ) => {\n * console.log('my middleware');\n * return NextResponse.next();\n * })\n *\n */\nexport function auth(authConfig: OptionalAuthConfig = {}) {\n return (\n middleware: Middleware,\n ): ((request: NextRequest) => Promise<NextResponse>) => {\n return async (request: NextRequest): Promise<NextResponse> => {\n const response = await applyAuth(authConfig, request);\n if (response) return response;\n\n return middleware(request);\n };\n };\n}\n"]}
@@ -1,9 +0,0 @@
1
- import { type AuthConfigWithDefaults } from "../../nextjs/config.js";
2
- import type { AuthProviderProps } from "../../shared/providers/types.js";
3
- type NextCivicAuthProviderInternalProps = Omit<AuthProviderProps, "clientId"> & {
4
- resolvedConfig: AuthConfigWithDefaults;
5
- };
6
- type NextCivicAuthProviderProps = Omit<NextCivicAuthProviderInternalProps, "clientId" | "resolvedConfig" | "redirectUrl">;
7
- declare const CivicNextAuthProvider: ({ children, ...props }: NextCivicAuthProviderProps) => import("@emotion/react/jsx-runtime").JSX.Element;
8
- export { CivicNextAuthProvider, type NextCivicAuthProviderProps };
9
- //# sourceMappingURL=NextAuthProvider.d.ts.map
@@ -1 +0,0 @@
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 +0,0 @@
1
- {"version":3,"file":"NextAuthProvider.js","sourceRoot":"","sources":["../../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AACb;;GAEG;AACH,OAAO,KAAK,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAChE,OAAO,EACL,iBAAiB,GAElB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,8BAA8B,EAAE,MAAM,oBAAoB,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAE,MAAM,8CAA8C,CAAC;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AACxE,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AACtE,OAAO,EAAE,aAAa,EAAE,MAAM,qCAAqC,CAAC;AACpE,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAC3E,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAC;AACjE,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAExD,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,UAAU,EAAiC,MAAM,YAAY,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAoBzD,MAAM,kCAAkC,GAAG,CAEzC,EACA,QAAQ,EACR,SAAS,EACT,WAAW,GAAG,QAAQ,EACtB,IAAI,EACJ,SAAS,EACT,GAAG,KAAK,EACuC,EAAE,EAAE;IACnD,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,GAAG,KAAK,CAAC;IAC7C,MAAM,EAAE,SAAS,EAAE,kBAAkB,EAAE,GAAG,SAAS,EAAE,CAAC;IACtD,MAAM,eAAe,GAAG,kBAAkB,EAAE,CAAC;IAC7C,MAAM,EAAE,YAAY,EAAE,GAAG,cAAc,CAAC;IACxC,MAAM,YAAY,GAAG,IAAI,8BAA8B,CAAC,YAAY,CAAC,CAAC;IACtE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,CAAC;IACvC,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IAEnC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,EAAE,aAAa,EAAE,CAAC;YAC3B,+DAA+D;YAC/D,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAC1B,OAAO;QACT,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,EAAE,aAAa,EAAE,kBAAkB,CAAC,CAAC,CAAC;IAEjD,MAAM,WAAW,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACzC,oFAAoF;QACpF,MAAM,SAAS,EAAE,CAAC;QAClB,MAAM,KAAK,EAAE,SAAS,EAAE,EAAE,CAAC;IAC7B,CAAC,EAAE,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC;IAEvB,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,SAAS,CAAC;QAC7D,WAAW;QACX,YAAY;QACZ,WAAW;KACZ,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,IACE,eAAe;YACf,CAAC,OAAO,EAAE,aAAa;YACvB,SAAS,EAAE,OAAO;YAClB,UAAU,KAAK,UAAU,CAAC,eAAe;YACzC,WAAW,KAAK,QAAQ;YACxB,CAAC,UAAU,EAAE,QAAQ,CAAC,OAAO,CAAC,EAC9B,CAAC;YACD,WAAW,EAAE,CAAC;QAChB,CAAC;QACD,uDAAuD;IACzD,CAAC,EAAE;QACD,UAAU;QACV,UAAU;QACV,SAAS;QACT,eAAe;QACf,OAAO,EAAE,aAAa;QACtB,UAAU;QACV,WAAW;QACX,WAAW;KACZ,CAAC,CAAC;IAEH,OAAO,CACL,KAAC,aAAa,cACZ,MAAC,YAAY,IACX,OAAO,EAAE,IAAI,oBAAoB,EAAE,EACnC,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,UAAU,aAEtB,KAAC,gBAAgB,IAAC,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,GAAI,EACtD,SAAS,IAAI,CACZ,KAAC,YAAY,cACX,KAAC,WAAW,KAAG,GACF,CAChB,EACA,QAAQ,IACI,GACD,CACjB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,6BAA6B,GAAG,CAAC,EACrC,QAAQ,EACR,GAAG,KAAK,EAC2B,EAAE,EAAE;IACvC,2EAA2E;IAC3E,kCAAkC;IAClC,MAAM,SAAS,GAAG,aAAa,EAAE,CAAC;IAClC,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,aAAa,EAAE,CAAC;IAErD,MAAM,OAAO,GAAG;QACd,aAAa,EAAE,CAAC,CAAC,IAAI;QACrB,OAAO;KACR,CAAC;IAEF,UAAU,CAAC,OAAO,CAAC,CAAC;IAEpB,OAAO,CACL,KAAC,eAAe,IAAC,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,YAClD,KAAC,kCAAkC,OAC7B,KAAK,EACT,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,SAAS,YAEnB,QAAQ,GAC0B,GACrB,CACnB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,qBAAqB,GAAG,CAAC,EAC7B,QAAQ,EACR,GAAG,KAAK,EACmB,EAAE,EAAE;IAC/B,MAAM,cAAc,GAAG,iBAAiB,EAAE,CAAC;IAC3C,MAAM,EACJ,QAAQ,EACR,WAAW,EACX,WAAW,EACX,YAAY,EACZ,SAAS,EACT,UAAU,EACV,iBAAiB,GAClB,GAAG,cAAc,CAAC;IACnB,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAS,EAAE,CAAC,CAAC;IAE3D,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,UAAU,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;YAC7C,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;YACjD,cAAc,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC,EAAE,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC,CAAC;IAElC,OAAO,CACL,KAAC,uBAAuB,IACtB,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,QAAQ,EAClB,WAAW,EAAE,WAAW,EACxB,iBAAiB,EAAE,iBAAiB,EACpC,KAAK,EAAE,KAAK,EAAE,KAAK,EACnB,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,UAAU,EACtB,SAAS,EAAE,SAAS,EACpB,iBAAiB,EAAE,iBAAiB,YAEpC,KAAC,cAAc,IAAC,UAAU,EAAE,KAAK,CAAC,UAAU,YAC1C,KAAC,6BAA6B,OACxB,KAAK,EACT,cAAc,EAAE,cAAc,YAE7B,QAAQ,GACqB,GACjB,GACO,CAC3B,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAmC,CAAC","sourcesContent":["\"use client\";\n/**\n * A very small context provider for the user object - it takes the user object from the cookie and provides it to the app.\n */\nimport React, { useCallback, useEffect, useState } from \"react\";\nimport {\n resolveAuthConfig,\n type AuthConfigWithDefaults,\n} from \"@/nextjs/config.js\";\nimport { resolveCallbackUrl } from \"@/nextjs/utils.js\";\nimport { ConfidentialClientPKCEConsumer } from \"@/services/PKCE.js\";\nimport { UserProvider } from \"@/shared/providers/UserProvider.js\";\nimport { useUserCookie } from \"@/nextjs/hooks/useUserCookie.js\";\nimport { CivicAuthConfigProvider } from \"@/shared/providers/CivicAuthConfigContext.js\";\nimport { SessionProvider } from \"@/shared/providers/SessionProvider.js\";\nimport { IframeProvider } from \"@/shared/providers/IframeProvider.js\";\nimport { TokenProvider } from \"@/shared/providers/TokenProvider.js\";\nimport { useSignIn } from \"@/shared/hooks/useSignIn.js\";\nimport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nimport { IFrameAndLoading } from \"@/shared/components/IFrameAndLoading.js\";\nimport { BlockDisplay } from \"@/shared/components/BlockDisplay.js\";\nimport { LoadingIcon } from \"@/shared/components/LoadingIcon.js\";\nimport { useIframe } from \"@/shared/hooks/useIframe.js\";\nimport type { AuthProviderProps } from \"@/shared/providers/types.js\";\nimport { useIsInIframe } from \"@/shared/hooks/useIsInIframe.js\";\nimport { AuthStatus, type UnknownObject, type User } from \"@/types.js\";\nimport { useRefresh } from \"@/nextjs/hooks/useRefresh.js\";\nimport { useCurrentUrl, useSession } from \"@/shared/hooks/index.js\";\nimport { BrowserCookieStorage } from \"@/shared/index.js\";\n\ntype CivicNextAuthTokenProviderInternalProps<TUser extends UnknownObject> =\n NextCivicAuthProviderInternalProps & {\n isLoading: boolean;\n idToken?: string;\n user: User<TUser> | null;\n fetchUser: () => Promise<void>;\n };\ntype NextCivicAuthProviderInternalProps = Omit<\n AuthProviderProps,\n \"clientId\"\n> & {\n resolvedConfig: AuthConfigWithDefaults;\n};\ntype NextCivicAuthProviderProps = Omit<\n NextCivicAuthProviderInternalProps,\n \"clientId\" | \"resolvedConfig\" | \"redirectUrl\"\n>;\n\nconst CivicNextAuthTokenProviderInternal = <\n TUser extends UnknownObject = UnknownObject,\n>({\n children,\n isLoading,\n displayMode = \"iframe\",\n user,\n fetchUser,\n ...props\n}: CivicNextAuthTokenProviderInternalProps<TUser>) => {\n const { iframeMode, resolvedConfig } = props;\n const { iframeRef, setIframeIsVisible } = useIframe();\n const civicAuthConfig = useCivicAuthConfig();\n const { challengeUrl } = resolvedConfig;\n const pkceConsumer = new ConfidentialClientPKCEConsumer(challengeUrl);\n const { data: session } = useSession();\n const currentUrl = useCurrentUrl();\n\n useEffect(() => {\n if (session?.authenticated) {\n // the session is authenticated, so don't show the login iframe\n setIframeIsVisible(false);\n return;\n }\n }, [session?.authenticated, setIframeIsVisible]);\n\n const postSignOut = useCallback(async () => {\n // user is signed out, manually update the user from cookies to not wait for polling\n await fetchUser();\n await props?.onSignOut?.();\n }, [fetchUser, props]);\n\n const { signIn, startSignIn, signOut, authStatus } = useSignIn({\n postSignOut,\n pkceConsumer,\n displayMode,\n });\n\n useEffect(() => {\n if (\n civicAuthConfig &&\n !session?.authenticated &&\n iframeRef?.current &&\n authStatus === AuthStatus.UNAUTHENTICATED &&\n displayMode === \"iframe\" &&\n !currentUrl?.includes(\"code=\")\n ) {\n startSignIn();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n currentUrl,\n iframeMode,\n iframeRef,\n civicAuthConfig,\n session?.authenticated,\n authStatus,\n startSignIn,\n displayMode,\n ]);\n\n return (\n <TokenProvider>\n <UserProvider\n storage={new BrowserCookieStorage()}\n user={user}\n signOut={signOut}\n signIn={signIn}\n displayMode={displayMode}\n authStatus={authStatus}\n >\n <IFrameAndLoading error={null} isLoading={isLoading} />\n {isLoading && (\n <BlockDisplay>\n <LoadingIcon />\n </BlockDisplay>\n )}\n {children}\n </UserProvider>\n </TokenProvider>\n );\n};\n\nconst CivicNextAuthProviderInternal = ({\n children,\n ...props\n}: NextCivicAuthProviderInternalProps) => {\n // if the SDK loads in an iframe, we show the loading spinner as the iframe\n // will be waiting to be minimized\n const isLoading = useIsInIframe();\n const { user, idToken, fetchUser } = useUserCookie();\n\n const session = {\n authenticated: !!user,\n idToken,\n };\n\n useRefresh(session);\n\n return (\n <SessionProvider data={session} isLoading={isLoading}>\n <CivicNextAuthTokenProviderInternal\n {...props}\n user={user}\n idToken={idToken}\n fetchUser={fetchUser}\n isLoading={isLoading}\n >\n {children}\n </CivicNextAuthTokenProviderInternal>\n </SessionProvider>\n );\n};\n\nconst CivicNextAuthProvider = ({\n children,\n ...props\n}: NextCivicAuthProviderProps) => {\n const resolvedConfig = resolveAuthConfig();\n const {\n clientId,\n oauthServer,\n callbackUrl,\n challengeUrl,\n logoutUrl,\n refreshUrl,\n logoutCallbackUrl,\n } = resolvedConfig;\n const [redirectUrl, setRedirectUrl] = useState<string>(\"\");\n\n useEffect(() => {\n if (typeof globalThis.window !== \"undefined\") {\n const appUrl = globalThis.window.location.origin;\n setRedirectUrl(resolveCallbackUrl(resolvedConfig, appUrl));\n }\n }, [callbackUrl, resolvedConfig]);\n\n return (\n <CivicAuthConfigProvider\n oauthServer={oauthServer}\n clientId={clientId}\n redirectUrl={redirectUrl}\n logoutRedirectUrl={logoutCallbackUrl}\n nonce={props?.nonce}\n challengeUrl={challengeUrl}\n refreshUrl={refreshUrl}\n logoutUrl={logoutUrl}\n logoutCallbackUrl={logoutCallbackUrl}\n >\n <IframeProvider iframeMode={props.iframeMode}>\n <CivicNextAuthProviderInternal\n {...props}\n resolvedConfig={resolvedConfig}\n >\n {children}\n </CivicNextAuthProviderInternal>\n </IframeProvider>\n </CivicAuthConfigProvider>\n );\n};\n\nexport { CivicNextAuthProvider, type NextCivicAuthProviderProps };\n"]}
@@ -1,19 +0,0 @@
1
- import type { AuthConfig } from "../nextjs/config.js";
2
- import type { NextRequest } from "next/server.js";
3
- import { NextResponse } from "next/server.js";
4
- export declare function handleLogout(request: NextRequest, config: AuthConfig): Promise<NextResponse>;
5
- export declare function handleLogoutCallback(request: NextRequest, config: AuthConfig): Promise<NextResponse>;
6
- /**
7
- * Creates an authentication handler for Next.js API routes
8
- *
9
- * Usage:
10
- * ```ts
11
- * // app/api/auth/[...civicauth]/route.ts
12
- * import { handler } from '@civic/auth/nextjs'
13
- * export const GET = handler({
14
- * // optional config overrides
15
- * })
16
- * ```
17
- */
18
- export declare const handler: (authConfig?: {}) => (request: NextRequest) => Promise<NextResponse>;
19
- //# sourceMappingURL=routeHandler.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"routeHandler.d.ts","sourceRoot":"","sources":["../../../src/nextjs/routeHandler.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAYrD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AA0Q9C,wBAAsB,YAAY,CAChC,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,YAAY,CAAC,CAiCvB;AAED,wBAAsB,oBAAoB,CACxC,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,YAAY,CAAC,CAmDvB;AAED;;;;;;;;;;;GAWG;AACH,eAAO,MAAM,OAAO,iCAEF,WAAW,KAAG,OAAO,CAAC,YAAY,CAkCjD,CAAC"}
@@ -1,312 +0,0 @@
1
- import { TOKEN_EXCHANGE_SUCCESS_TEXT, TOKEN_EXCHANGE_TRIGGER_TEXT, } from "../constants.js";
2
- import { loggers } from "../lib/logger.js";
3
- import { displayModeFromState, serverTokenExchangeFromState, } from "../lib/oauth.js";
4
- import { resolveAuthConfig } from "../nextjs/config.js";
5
- import { clearAuthCookies, NextjsCookieStorage } from "../nextjs/cookies.js";
6
- import { getUser } from "../nextjs/index.js";
7
- import { resolveCallbackUrl } from "../nextjs/utils.js";
8
- import { resolveOAuthAccessCode } from "../server/login.js";
9
- import { GenericPublicClientPKCEProducer } from "../services/PKCE.js";
10
- import { AuthenticationRefresherImpl } from "../shared/lib/AuthenticationRefresherImpl.js";
11
- import { CodeVerifier, OAuthTokens } from "../shared/lib/types.js";
12
- import { GenericUserSession } from "../shared/lib/UserSession.js";
13
- import { generateOauthLogoutUrl } from "../shared/lib/util.js";
14
- import { revalidatePath } from "next/cache.js";
15
- import { NextResponse } from "next/server.js";
16
- const logger = loggers.nextjs.handlers.auth;
17
- class AuthError extends Error {
18
- status;
19
- constructor(message, status = 401) {
20
- super(message);
21
- this.status = status;
22
- this.name = "AuthError";
23
- }
24
- }
25
- const getAppUrl = (request) => request.cookies.get(CodeVerifier.APP_URL)?.value ||
26
- request.nextUrl.searchParams.get("appUrl");
27
- const getIdToken = async (config) => {
28
- const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});
29
- return cookieStorage.get(OAuthTokens.ID_TOKEN);
30
- };
31
- /**
32
- * create a code verifier and challenge for PKCE
33
- * saving the verifier in a cookie for later use
34
- * @returns {Promise<NextResponse>}
35
- */
36
- async function handleChallenge(request, config) {
37
- const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});
38
- const pkceProducer = new GenericPublicClientPKCEProducer(cookieStorage);
39
- const challenge = await pkceProducer.getCodeChallenge();
40
- const appUrl = request.nextUrl.searchParams.get("appUrl");
41
- if (appUrl) {
42
- cookieStorage.set(CodeVerifier.APP_URL, appUrl);
43
- }
44
- return NextResponse.json({ status: "success", challenge });
45
- }
46
- async function performTokenExchangeAndSetCookies(config, code, state, appUrl) {
47
- const resolvedConfigs = resolveAuthConfig(config);
48
- // TODO This is messy, better would be to fix the config.cookies type to always be <name: settings>
49
- // rather than nesting the tokens-related ones *and* code-verifier inside "tokens"
50
- // (despite code-verifier not relating directly to tokens)
51
- const cookieStorage = new NextjsCookieStorage({
52
- ...resolvedConfigs.cookies.tokens,
53
- user: resolvedConfigs.cookies.user,
54
- });
55
- const callbackUrl = resolveCallbackUrl(resolvedConfigs, appUrl);
56
- try {
57
- await resolveOAuthAccessCode(code, state, cookieStorage, {
58
- ...resolvedConfigs,
59
- redirectUrl: callbackUrl,
60
- });
61
- }
62
- catch (error) {
63
- logger.error("Token exchange failed:", error);
64
- throw new AuthError("Failed to authenticate user", 401);
65
- }
66
- const user = await getUser();
67
- if (!user) {
68
- throw new AuthError("Failed to get user info", 401);
69
- }
70
- const userSession = new GenericUserSession(cookieStorage);
71
- await userSession.set(user);
72
- }
73
- async function handleRefresh(request, config) {
74
- const resolvedConfigs = resolveAuthConfig(config);
75
- const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});
76
- const refresher = await AuthenticationRefresherImpl.build({
77
- clientId: resolvedConfigs.clientId,
78
- oauthServer: resolvedConfigs.oauthServer,
79
- redirectUrl: resolvedConfigs.callbackUrl,
80
- refreshUrl: resolvedConfigs.refreshUrl,
81
- }, cookieStorage);
82
- const tokens = await refresher.refreshAccessToken();
83
- // this will use the refresh token to get new tokens and, if successful
84
- // the idToken, accessToken and user cookies will be updated
85
- // await newRefresher.refreshTokens();
86
- return NextResponse.json({ status: "success", tokens });
87
- }
88
- const generateHtmlResponseWithCallback = (request, callbackUrl) => {
89
- // we need to replace the URL with resolved config in case the server is hosted
90
- // behind a reverse proxy or load balancer
91
- const requestUrl = new URL(request.url);
92
- const fetchUrl = `${callbackUrl}?${requestUrl.searchParams.toString()}&sameDomainCallback=true`;
93
- return new NextResponse(`<html lang="en">
94
- <body>
95
- <span style="display:none">
96
- <script>
97
- window.onload = function () {
98
- const appUrl = globalThis.window?.location?.origin;
99
- fetch('${fetchUrl}&appUrl=' + appUrl).then((response) => {
100
- response.json().then((jsonResponse) => {
101
- if (jsonResponse.redirectUrl) {
102
- window.location.href = jsonResponse.redirectUrl;
103
- }
104
- });
105
- });
106
- };
107
- </script>
108
- </span>
109
- </body>
110
- </html>
111
- `);
112
- };
113
- async function handleCallback(request, config) {
114
- const resolvedConfigs = resolveAuthConfig(config);
115
- const code = request.nextUrl.searchParams.get("code");
116
- const state = request.nextUrl.searchParams.get("state");
117
- if (!code || !state)
118
- throw new AuthError("Bad parameters", 400);
119
- // appUrl is passed from the client to the server in the query string
120
- // this is necessary because the server does not have access to the client's window.location.origin
121
- // and can not accurately determine the appUrl (specially if the app is behind a reverse proxy)
122
- const appUrl = getAppUrl(request);
123
- // If we have a code_verifier cookie and the appUrl, we can do a token exchange.
124
- // Otherwise, just render an empty page.
125
- // The initial redirect back from the auth server does not send cookies, because the redirect is from a 3rd-party domain.
126
- // The client will make an additional call to this route with cookies included, at which point we do the token exchange.
127
- const codeVerifier = request.cookies.get(CodeVerifier.COOKIE_NAME);
128
- if (!codeVerifier || !appUrl) {
129
- logger.debug("handleCallback no code_verifier found", {
130
- state,
131
- serverTokenExchange: serverTokenExchangeFromState(`${state}`),
132
- });
133
- let response = new NextResponse(`<html lang="en"><body><span style="display:none">${TOKEN_EXCHANGE_TRIGGER_TEXT}</span></body></html>`);
134
- // in server-side token exchange mode we need to launch a page that will trigger the token exchange
135
- // from the same domain, allowing it access to the code_verifier cookie
136
- // we only need to do this in redirect mode, as the iframe already triggers a client-side token exchange
137
- // if no code-verifier cookie is found
138
- if (state && serverTokenExchangeFromState(state)) {
139
- logger.debug("handleCallback serverTokenExchangeFromState, launching redirect page...", {
140
- requestUrl: request.url,
141
- configCallbackUrl: resolvedConfigs.callbackUrl,
142
- });
143
- // generate a page that will callback to the same domain, allowing access
144
- // to the code_verifier cookie and passing the appUrl.
145
- response = generateHtmlResponseWithCallback(request, resolvedConfigs.callbackUrl);
146
- }
147
- response.headers.set("Content-Type", "text/html; charset=utf-8");
148
- logger.debug(`handleCallback no code_verifier found, returning ${TOKEN_EXCHANGE_TRIGGER_TEXT}`);
149
- return response;
150
- }
151
- await performTokenExchangeAndSetCookies(resolvedConfigs, code, state, appUrl);
152
- if (request.url.includes("sameDomainCallback=true")) {
153
- logger.debug("handleCallback sameDomainCallback = true, returning redirectUrl", appUrl);
154
- return NextResponse.json({
155
- status: "success",
156
- redirectUrl: appUrl,
157
- });
158
- }
159
- // this is the case where a 'normal' redirect is happening
160
- if (serverTokenExchangeFromState(state)) {
161
- logger.debug("handleCallback serverTokenExchangeFromState, redirect to appUrl", appUrl);
162
- if (!appUrl) {
163
- throw new Error("appUrl undefined. Cannot redirect.");
164
- }
165
- return NextResponse.redirect(`${appUrl}`);
166
- }
167
- // return an empty HTML response so the iframe doesn't show any response
168
- // in the short moment between the redirect and the parent window
169
- // acknowledging the redirect and closing the iframe
170
- const response = new NextResponse(`<html lang="en"><span style="display:none">${TOKEN_EXCHANGE_SUCCESS_TEXT}</span></html>`);
171
- response.headers.set("Content-Type", "text/html; charset=utf-8");
172
- return response;
173
- }
174
- /**
175
- * If redirectPath is an absolute path, return it as-is.
176
- * Otherwise for relative paths, append it to the current domain.
177
- * @param redirectPath
178
- * @param currentBasePath
179
- * @returns
180
- */
181
- const getAbsoluteRedirectPath = (redirectPath, currentBasePath) => new URL(redirectPath, currentBasePath).href;
182
- const getPostLogoutRedirectUrl = (request, config) => {
183
- const { loginUrl } = resolveAuthConfig(config);
184
- const redirectTarget = loginUrl ?? "/";
185
- // if the optional loginUrl is provided and it is an absolute URL,
186
- // use it as the redirect target
187
- const isAbsoluteRedirect = /^(https?:\/\/|www\.).+/i.test(redirectTarget);
188
- if (isAbsoluteRedirect) {
189
- return redirectTarget;
190
- }
191
- // if loginUrl is not defined, the appUrl is passed from the client to the server
192
- // in the query string or cookies. This is necessary because the server does not
193
- // have access to the client's window.location and can not accurately determine
194
- // the appUrl (specially if the app is behind a reverse proxy).
195
- const appUrl = getAppUrl(request);
196
- if (appUrl)
197
- return getAbsoluteRedirectPath(redirectTarget, appUrl);
198
- return null;
199
- };
200
- const revalidateUrlPath = async (url) => {
201
- try {
202
- const path = new URL(url).pathname;
203
- revalidatePath(path);
204
- }
205
- catch (error) {
206
- logger.warn("Failed to revalidate path after logout:", error);
207
- }
208
- };
209
- export async function handleLogout(request, config) {
210
- const resolvedConfigs = resolveAuthConfig(config);
211
- const postLogoutUrl = new URL(resolvedConfigs.logoutCallbackUrl, getAppUrl(request) || request.url);
212
- // read the id_token from the cookies
213
- const idToken = await getIdToken(resolvedConfigs);
214
- // read the state from the query parameters
215
- const state = request.nextUrl.searchParams.get("state");
216
- if (!state || !idToken) {
217
- logger.error("handleLogout: missing state or idToken", { state, idToken });
218
- // if token or state is missing, the logout call to the server will fail,
219
- // (token has potentially expired already) so go straight to the postLogoutUrl
220
- // so the user can be signed out.
221
- return NextResponse.redirect(`${postLogoutUrl}${state ? "?state=" + state : ""}`);
222
- }
223
- const logoutUrl = await generateOauthLogoutUrl({
224
- clientId: resolvedConfigs.clientId,
225
- idToken,
226
- state,
227
- redirectUrl: postLogoutUrl.href,
228
- oauthServer: resolvedConfigs.oauthServer,
229
- });
230
- return NextResponse.redirect(`${logoutUrl.href}`);
231
- }
232
- export async function handleLogoutCallback(request, config) {
233
- const resolvedConfigs = resolveAuthConfig(config);
234
- const state = request.nextUrl.searchParams.get("state") || "";
235
- const displayMode = displayModeFromState(state, "iframe");
236
- const canAccessCookies = !!(await getIdToken(resolvedConfigs));
237
- const isSameDomainCallback = request.url.includes("sameDomainCallback=true");
238
- if (canAccessCookies || isSameDomainCallback) {
239
- await clearAuthCookies();
240
- }
241
- let response;
242
- // handle logout for iframe display mode
243
- if (displayMode === "iframe") {
244
- // try to read the token from cookies. If cookies cant be read/written
245
- // because the request cames from a cross-origin redirect,
246
- // we need to show a page that will trigger the logout from the same domain
247
- if (canAccessCookies || isSameDomainCallback) {
248
- // just return success
249
- return NextResponse.json({ status: "success" });
250
- }
251
- // return a page that will trigger the logout from the same domain
252
- response = generateHtmlResponseWithCallback(request, resolvedConfigs.logoutCallbackUrl);
253
- response.headers.set("Content-Type", "text/html; charset=utf-8");
254
- return response;
255
- }
256
- // handle logout for non-iframe display mode
257
- const redirectUrl = getPostLogoutRedirectUrl(request, resolvedConfigs);
258
- if (redirectUrl && (canAccessCookies || isSameDomainCallback)) {
259
- // just redirect to the app url
260
- response = NextResponse.redirect(`${redirectUrl}`);
261
- revalidateUrlPath(redirectUrl);
262
- }
263
- else {
264
- logger.debug("handleLogout no redirectUrl found", { state });
265
- response = generateHtmlResponseWithCallback(request, resolvedConfigs.logoutCallbackUrl);
266
- response.headers.set("Content-Type", "text/html; charset=utf-8");
267
- }
268
- return response;
269
- }
270
- /**
271
- * Creates an authentication handler for Next.js API routes
272
- *
273
- * Usage:
274
- * ```ts
275
- * // app/api/auth/[...civicauth]/route.ts
276
- * import { handler } from '@civic/auth/nextjs'
277
- * export const GET = handler({
278
- * // optional config overrides
279
- * })
280
- * ```
281
- */
282
- export const handler = (authConfig = {}) => async (request) => {
283
- const config = resolveAuthConfig(authConfig);
284
- try {
285
- const pathname = request.nextUrl.pathname;
286
- const pathSegments = pathname.split("/");
287
- const lastSegment = pathSegments[pathSegments.length - 1];
288
- switch (lastSegment) {
289
- case "challenge":
290
- return await handleChallenge(request, config);
291
- case "callback":
292
- return await handleCallback(request, config);
293
- case "refresh":
294
- return await handleRefresh(request, config);
295
- case "logout":
296
- return await handleLogout(request, config);
297
- case "logoutcallback":
298
- return await handleLogoutCallback(request, config);
299
- default:
300
- throw new AuthError(`Invalid auth route: ${pathname}`, 404);
301
- }
302
- }
303
- catch (error) {
304
- logger.error("Auth handler error:", error);
305
- const status = error instanceof AuthError ? error.status : 500;
306
- const message = error instanceof Error ? error.message : "Authentication failed";
307
- const response = NextResponse.json({ error: message }, { status });
308
- await clearAuthCookies();
309
- return response;
310
- }
311
- };
312
- //# sourceMappingURL=routeHandler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"routeHandler.js","sourceRoot":"","sources":["../../../src/nextjs/routeHandler.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n TOKEN_EXCHANGE_SUCCESS_TEXT,\n TOKEN_EXCHANGE_TRIGGER_TEXT,\n} from \"@/constants.js\";\nimport { loggers } from \"@/lib/logger.js\";\nimport {\n displayModeFromState,\n serverTokenExchangeFromState,\n} from \"@/lib/oauth.js\";\nimport type { AuthConfig } from \"@/nextjs/config.js\";\nimport { resolveAuthConfig } from \"@/nextjs/config.js\";\nimport { clearAuthCookies, NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nimport { getUser } from \"@/nextjs/index.js\";\nimport { resolveCallbackUrl } from \"@/nextjs/utils.js\";\nimport { resolveOAuthAccessCode } from \"@/server/login.js\";\nimport { GenericPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport { AuthenticationRefresherImpl } from \"@/shared/lib/AuthenticationRefresherImpl.js\";\nimport { CodeVerifier, OAuthTokens } from \"@/shared/lib/types.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport { generateOauthLogoutUrl } from \"@/shared/lib/util.js\";\nimport { revalidatePath } from \"next/cache.js\";\nimport type { NextRequest } from \"next/server.js\";\nimport { NextResponse } from \"next/server.js\";\n\nconst logger = loggers.nextjs.handlers.auth;\n\nclass AuthError extends Error {\n constructor(\n message: string,\n public readonly status: number = 401,\n ) {\n super(message);\n this.name = \"AuthError\";\n }\n}\n\nconst getAppUrl = (request: NextRequest): string | null =>\n request.cookies.get(CodeVerifier.APP_URL)?.value ||\n request.nextUrl.searchParams.get(\"appUrl\");\n\nconst getIdToken = async (config: AuthConfig): Promise<string | null> => {\n const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});\n return cookieStorage.get(OAuthTokens.ID_TOKEN);\n};\n\n/**\n * create a code verifier and challenge for PKCE\n * saving the verifier in a cookie for later use\n * @returns {Promise<NextResponse>}\n */\nasync function handleChallenge(\n request: NextRequest,\n config: AuthConfig,\n): Promise<NextResponse> {\n const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});\n const pkceProducer = new GenericPublicClientPKCEProducer(cookieStorage);\n\n const challenge = await pkceProducer.getCodeChallenge();\n const appUrl = request.nextUrl.searchParams.get(\"appUrl\");\n if (appUrl) {\n cookieStorage.set(CodeVerifier.APP_URL, appUrl);\n }\n return NextResponse.json({ status: \"success\", challenge });\n}\n\nasync function performTokenExchangeAndSetCookies(\n config: AuthConfig,\n code: string,\n state: string,\n appUrl: string,\n) {\n const resolvedConfigs = resolveAuthConfig(config);\n // TODO This is messy, better would be to fix the config.cookies type to always be <name: settings>\n // rather than nesting the tokens-related ones *and* code-verifier inside \"tokens\"\n // (despite code-verifier not relating directly to tokens)\n const cookieStorage = new NextjsCookieStorage({\n ...resolvedConfigs.cookies.tokens,\n user: resolvedConfigs.cookies.user,\n });\n\n const callbackUrl = resolveCallbackUrl(resolvedConfigs, appUrl);\n try {\n await resolveOAuthAccessCode(code, state, cookieStorage, {\n ...resolvedConfigs,\n redirectUrl: callbackUrl,\n });\n } catch (error) {\n logger.error(\"Token exchange failed:\", error);\n throw new AuthError(\"Failed to authenticate user\", 401);\n }\n\n const user = await getUser();\n if (!user) {\n throw new AuthError(\"Failed to get user info\", 401);\n }\n const userSession = new GenericUserSession(cookieStorage);\n await userSession.set(user);\n}\nasync function handleRefresh(\n request: NextRequest,\n config: AuthConfig,\n): Promise<NextResponse> {\n const resolvedConfigs = resolveAuthConfig(config);\n const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});\n\n const refresher = await AuthenticationRefresherImpl.build(\n {\n clientId: resolvedConfigs.clientId,\n oauthServer: resolvedConfigs.oauthServer,\n redirectUrl: resolvedConfigs.callbackUrl,\n refreshUrl: resolvedConfigs.refreshUrl,\n },\n cookieStorage,\n );\n const tokens = await refresher.refreshAccessToken();\n\n // this will use the refresh token to get new tokens and, if successful\n // the idToken, accessToken and user cookies will be updated\n // await newRefresher.refreshTokens();\n return NextResponse.json({ status: \"success\", tokens });\n}\n\nconst generateHtmlResponseWithCallback = (\n request: NextRequest,\n callbackUrl: string,\n) => {\n // we need to replace the URL with resolved config in case the server is hosted\n // behind a reverse proxy or load balancer\n const requestUrl = new URL(request.url);\n const fetchUrl = `${callbackUrl}?${requestUrl.searchParams.toString()}&sameDomainCallback=true`;\n return new NextResponse(\n `<html lang=\"en\">\n <body>\n <span style=\"display:none\">\n <script>\n window.onload = function () {\n const appUrl = globalThis.window?.location?.origin;\n fetch('${fetchUrl}&appUrl=' + appUrl).then((response) => {\n response.json().then((jsonResponse) => {\n if (jsonResponse.redirectUrl) {\n window.location.href = jsonResponse.redirectUrl;\n }\n });\n });\n };\n </script>\n </span>\n </body>\n </html>\n `,\n );\n};\n\nasync function handleCallback(\n request: NextRequest,\n config: AuthConfig,\n): Promise<NextResponse> {\n const resolvedConfigs = resolveAuthConfig(config);\n const code = request.nextUrl.searchParams.get(\"code\");\n const state = request.nextUrl.searchParams.get(\"state\");\n if (!code || !state) throw new AuthError(\"Bad parameters\", 400);\n\n // appUrl is passed from the client to the server in the query string\n // this is necessary because the server does not have access to the client's window.location.origin\n // and can not accurately determine the appUrl (specially if the app is behind a reverse proxy)\n const appUrl = getAppUrl(request);\n\n // If we have a code_verifier cookie and the appUrl, we can do a token exchange.\n // Otherwise, just render an empty page.\n // The initial redirect back from the auth server does not send cookies, because the redirect is from a 3rd-party domain.\n // The client will make an additional call to this route with cookies included, at which point we do the token exchange.\n const codeVerifier = request.cookies.get(CodeVerifier.COOKIE_NAME);\n\n if (!codeVerifier || !appUrl) {\n logger.debug(\"handleCallback no code_verifier found\", {\n state,\n serverTokenExchange: serverTokenExchangeFromState(`${state}`),\n });\n let response = new NextResponse(\n `<html lang=\"en\"><body><span style=\"display:none\">${TOKEN_EXCHANGE_TRIGGER_TEXT}</span></body></html>`,\n );\n\n // in server-side token exchange mode we need to launch a page that will trigger the token exchange\n // from the same domain, allowing it access to the code_verifier cookie\n // we only need to do this in redirect mode, as the iframe already triggers a client-side token exchange\n // if no code-verifier cookie is found\n if (state && serverTokenExchangeFromState(state)) {\n logger.debug(\n \"handleCallback serverTokenExchangeFromState, launching redirect page...\",\n {\n requestUrl: request.url,\n configCallbackUrl: resolvedConfigs.callbackUrl,\n },\n );\n // generate a page that will callback to the same domain, allowing access\n // to the code_verifier cookie and passing the appUrl.\n response = generateHtmlResponseWithCallback(\n request,\n resolvedConfigs.callbackUrl,\n );\n }\n\n response.headers.set(\"Content-Type\", \"text/html; charset=utf-8\");\n logger.debug(\n `handleCallback no code_verifier found, returning ${TOKEN_EXCHANGE_TRIGGER_TEXT}`,\n );\n return response;\n }\n\n await performTokenExchangeAndSetCookies(resolvedConfigs, code, state, appUrl);\n\n if (request.url.includes(\"sameDomainCallback=true\")) {\n logger.debug(\n \"handleCallback sameDomainCallback = true, returning redirectUrl\",\n appUrl,\n );\n return NextResponse.json({\n status: \"success\",\n redirectUrl: appUrl,\n });\n }\n\n // this is the case where a 'normal' redirect is happening\n if (serverTokenExchangeFromState(state)) {\n logger.debug(\n \"handleCallback serverTokenExchangeFromState, redirect to appUrl\",\n appUrl,\n );\n if (!appUrl) {\n throw new Error(\"appUrl undefined. Cannot redirect.\");\n }\n return NextResponse.redirect(`${appUrl}`);\n }\n // return an empty HTML response so the iframe doesn't show any response\n // in the short moment between the redirect and the parent window\n // acknowledging the redirect and closing the iframe\n const response = new NextResponse(\n `<html lang=\"en\"><span style=\"display:none\">${TOKEN_EXCHANGE_SUCCESS_TEXT}</span></html>`,\n );\n response.headers.set(\"Content-Type\", \"text/html; charset=utf-8\");\n return response;\n}\n\n/**\n * If redirectPath is an absolute path, return it as-is.\n * Otherwise for relative paths, append it to the current domain.\n * @param redirectPath\n * @param currentBasePath\n * @returns\n */\nconst getAbsoluteRedirectPath = (\n redirectPath: string,\n currentBasePath: string,\n) => new URL(redirectPath, currentBasePath).href;\n\nconst getPostLogoutRedirectUrl = (\n request: NextRequest,\n config: AuthConfig,\n): string | null => {\n const { loginUrl } = resolveAuthConfig(config);\n const redirectTarget = loginUrl ?? \"/\";\n\n // if the optional loginUrl is provided and it is an absolute URL,\n // use it as the redirect target\n const isAbsoluteRedirect = /^(https?:\\/\\/|www\\.).+/i.test(redirectTarget);\n if (isAbsoluteRedirect) {\n return redirectTarget;\n }\n\n // if loginUrl is not defined, the appUrl is passed from the client to the server\n // in the query string or cookies. This is necessary because the server does not\n // have access to the client's window.location and can not accurately determine\n // the appUrl (specially if the app is behind a reverse proxy).\n const appUrl = getAppUrl(request);\n if (appUrl) return getAbsoluteRedirectPath(redirectTarget, appUrl);\n\n return null;\n};\n\nconst revalidateUrlPath = async (url: string) => {\n try {\n const path = new URL(url).pathname;\n revalidatePath(path);\n } catch (error) {\n logger.warn(\"Failed to revalidate path after logout:\", error);\n }\n};\n\nexport async function handleLogout(\n request: NextRequest,\n config: AuthConfig,\n): Promise<NextResponse> {\n const resolvedConfigs = resolveAuthConfig(config);\n\n const postLogoutUrl = new URL(\n resolvedConfigs.logoutCallbackUrl,\n getAppUrl(request) || request.url,\n );\n\n // read the id_token from the cookies\n const idToken = await getIdToken(resolvedConfigs);\n\n // read the state from the query parameters\n const state = request.nextUrl.searchParams.get(\"state\");\n\n if (!state || !idToken) {\n logger.error(\"handleLogout: missing state or idToken\", { state, idToken });\n // if token or state is missing, the logout call to the server will fail,\n // (token has potentially expired already) so go straight to the postLogoutUrl\n // so the user can be signed out.\n return NextResponse.redirect(\n `${postLogoutUrl}${state ? \"?state=\" + state : \"\"}`,\n );\n }\n\n const logoutUrl = await generateOauthLogoutUrl({\n clientId: resolvedConfigs.clientId,\n idToken,\n state,\n redirectUrl: postLogoutUrl.href,\n oauthServer: resolvedConfigs.oauthServer,\n });\n\n return NextResponse.redirect(`${logoutUrl.href}`);\n}\n\nexport async function handleLogoutCallback(\n request: NextRequest,\n config: AuthConfig,\n): Promise<NextResponse> {\n const resolvedConfigs = resolveAuthConfig(config);\n\n const state = request.nextUrl.searchParams.get(\"state\") || \"\";\n const displayMode = displayModeFromState(state, \"iframe\");\n\n const canAccessCookies = !!(await getIdToken(resolvedConfigs));\n const isSameDomainCallback = request.url.includes(\"sameDomainCallback=true\");\n\n if (canAccessCookies || isSameDomainCallback) {\n await clearAuthCookies();\n }\n\n let response;\n\n // handle logout for iframe display mode\n if (displayMode === \"iframe\") {\n // try to read the token from cookies. If cookies cant be read/written\n // because the request cames from a cross-origin redirect,\n // we need to show a page that will trigger the logout from the same domain\n if (canAccessCookies || isSameDomainCallback) {\n // just return success\n return NextResponse.json({ status: \"success\" });\n }\n\n // return a page that will trigger the logout from the same domain\n response = generateHtmlResponseWithCallback(\n request,\n resolvedConfigs.logoutCallbackUrl,\n );\n response.headers.set(\"Content-Type\", \"text/html; charset=utf-8\");\n return response;\n }\n\n // handle logout for non-iframe display mode\n const redirectUrl = getPostLogoutRedirectUrl(request, resolvedConfigs);\n\n if (redirectUrl && (canAccessCookies || isSameDomainCallback)) {\n // just redirect to the app url\n response = NextResponse.redirect(`${redirectUrl}`);\n revalidateUrlPath(redirectUrl);\n } else {\n logger.debug(\"handleLogout no redirectUrl found\", { state });\n response = generateHtmlResponseWithCallback(\n request,\n resolvedConfigs.logoutCallbackUrl,\n );\n response.headers.set(\"Content-Type\", \"text/html; charset=utf-8\");\n }\n\n return response;\n}\n\n/**\n * Creates an authentication handler for Next.js API routes\n *\n * Usage:\n * ```ts\n * // app/api/auth/[...civicauth]/route.ts\n * import { handler } from '@civic/auth/nextjs'\n * export const GET = handler({\n * // optional config overrides\n * })\n * ```\n */\nexport const handler =\n (authConfig = {}) =>\n async (request: NextRequest): Promise<NextResponse> => {\n const config = resolveAuthConfig(authConfig);\n\n try {\n const pathname = request.nextUrl.pathname;\n const pathSegments = pathname.split(\"/\");\n const lastSegment = pathSegments[pathSegments.length - 1];\n\n switch (lastSegment) {\n case \"challenge\":\n return await handleChallenge(request, config);\n case \"callback\":\n return await handleCallback(request, config);\n case \"refresh\":\n return await handleRefresh(request, config);\n case \"logout\":\n return await handleLogout(request, config);\n case \"logoutcallback\":\n return await handleLogoutCallback(request, config);\n default:\n throw new AuthError(`Invalid auth route: ${pathname}`, 404);\n }\n } catch (error) {\n logger.error(\"Auth handler error:\", error);\n\n const status = error instanceof AuthError ? error.status : 500;\n const message =\n error instanceof Error ? error.message : \"Authentication failed\";\n\n const response = NextResponse.json({ error: message }, { status });\n\n await clearAuthCookies();\n return response;\n }\n };\n"]}
@@ -1,3 +0,0 @@
1
- import type { AuthConfigWithDefaults } from "../nextjs/config.js";
2
- export declare const resolveCallbackUrl: (config: AuthConfigWithDefaults, baseUrl?: string) => string;
3
- //# sourceMappingURL=utils.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/nextjs/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAEjE,eAAO,MAAM,kBAAkB,WACrB,sBAAsB,YACpB,MAAM,KACf,MAGF,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/nextjs/utils.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,MAA8B,EAC9B,OAAgB,EACR,EAAE;IACV,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,MAAM,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC;IACrE,OAAO,WAAW,CAAC,QAAQ,EAAE,CAAC;AAChC,CAAC,CAAC","sourcesContent":["import type { AuthConfigWithDefaults } from \"@/nextjs/config.js\";\n\nexport const resolveCallbackUrl = (\n config: AuthConfigWithDefaults,\n baseUrl?: string,\n): string => {\n const callbackUrl = new URL(config?.callbackUrl, baseUrl).toString();\n return callbackUrl.toString();\n};\n"]}
@@ -1,17 +0,0 @@
1
- import React from "react";
2
- import type { AuthStatus, DisplayMode } from "../../types.js";
3
- /**
4
- * show the loader if the user action has started and the iframe has not been aborted
5
- * @param {AuthStatus} options.authStatus
6
- * @param {DisplayMode} options.displayMode
7
- * @param {boolean} options.userActionStarted
8
- * @param options.children
9
- * @returns
10
- */
11
- export declare const ButtonContentOrLoader: ({ authStatus, displayMode, userActionStarted, children, }: {
12
- authStatus: AuthStatus;
13
- displayMode: DisplayMode;
14
- userActionStarted?: boolean;
15
- children: React.ReactNode;
16
- }) => import("@emotion/react/jsx-runtime").JSX.Element;
17
- //# sourceMappingURL=ButtonContentOrLoader.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ButtonContentOrLoader.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/ButtonContentOrLoader.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAI1D;;;;;;;GAOG;AACH,eAAO,MAAM,qBAAqB,8DAK/B;IACD,UAAU,EAAE,UAAU,CAAC;IACvB,WAAW,EAAE,WAAW,CAAC;IACzB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,qDA0CA,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ButtonContentOrLoader.js","sourceRoot":"","sources":["../../../../src/reactjs/components/ButtonContentOrLoader.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AACb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAC;AAEjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAExD;;;;;;;GAOG;AACH,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,EACpC,UAAU,EACV,WAAW,EACX,iBAAiB,EACjB,QAAQ,GAMT,EAAE,EAAE;IACH,MAAM,EAAE,aAAa,EAAE,GAAG,SAAS,EAAE,CAAC;IACtC,MAAM,UAAU,GAAG,gBAAgB,CACjC,UAAU,EACV,WAAW,EACX,iBAAiB,IAAI,CAAC,aAAa,CACpC,CAAC;IACF,OAAO,CACL,eACE,GAAG,EAAE;YACH,QAAQ,EAAE,UAAU;YACpB,OAAO,EAAE,MAAM;YACf,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;SACzB,aAED,eACE,GAAG,EAAE;oBACH,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;oBAC7C,UAAU,EAAE,QAAQ;iBACrB,YAEA,QAAQ,GACJ,EACN,UAAU,CAAC,CAAC,CAAC,CACZ,eACE,GAAG,EAAE;oBACH,QAAQ,EAAE,UAAU;oBACpB,OAAO,EAAE,MAAM;oBACf,cAAc,EAAE,QAAQ;oBACxB,UAAU,EAAE,QAAQ;oBACpB,GAAG,EAAE,CAAC;oBACN,IAAI,EAAE,CAAC;oBACP,KAAK,EAAE,CAAC;oBACR,MAAM,EAAE,CAAC;iBACV,YAED,KAAC,WAAW,IAAC,KAAK,EAAC,OAAO,EAAC,MAAM,EAAC,OAAO,GAAG,GACvC,CACR,CAAC,CAAC,CAAC,IAAI,IACJ,CACP,CAAC;AACJ,CAAC,CAAC","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport { LoadingIcon } from \"@/shared/components/LoadingIcon.js\";\nimport type { AuthStatus, DisplayMode } from \"@/types.js\";\nimport { shouldShowLoader } from \"./utils.js\";\nimport { useIframe } from \"@/shared/hooks/useIframe.js\";\n\n/**\n * show the loader if the user action has started and the iframe has not been aborted\n * @param {AuthStatus} options.authStatus\n * @param {DisplayMode} options.displayMode\n * @param {boolean} options.userActionStarted\n * @param options.children\n * @returns\n */\nexport const ButtonContentOrLoader = ({\n authStatus,\n displayMode,\n userActionStarted,\n children,\n}: {\n authStatus: AuthStatus;\n displayMode: DisplayMode;\n userActionStarted?: boolean;\n children: React.ReactNode;\n}) => {\n const { iframeAborted } = useIframe();\n const showLoader = shouldShowLoader(\n authStatus,\n displayMode,\n userActionStarted && !iframeAborted,\n );\n return (\n <div\n css={{\n position: \"relative\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n }}\n >\n <span\n css={{\n visibility: showLoader ? \"hidden\" : \"visible\",\n whiteSpace: \"nowrap\",\n }}\n >\n {children}\n </span>\n {showLoader ? (\n <span\n css={{\n position: \"absolute\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n }}\n >\n <LoadingIcon width=\"1.5em\" height=\"1.5em\" />\n </span>\n ) : null}\n </div>\n );\n};\n"]}
@@ -1,9 +0,0 @@
1
- import { type CSSProperties } from "react";
2
- import { type DisplayMode } from "../../types.js";
3
- declare const SignInButton: ({ displayMode, className, style, }: {
4
- displayMode?: DisplayMode;
5
- className?: string;
6
- style?: CSSProperties;
7
- }) => import("@emotion/react/jsx-runtime").JSX.Element;
8
- export { SignInButton };
9
- //# sourceMappingURL=SignInButton.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SignInButton.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/SignInButton.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAuB,KAAK,aAAa,EAAE,MAAM,OAAO,CAAC;AAChE,OAAO,EAAc,KAAK,WAAW,EAAE,MAAM,YAAY,CAAC;AAI1D,QAAA,MAAM,YAAY,uCAIf;IACD,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB,qDAwCA,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"SignInButton.js","sourceRoot":"","sources":["../../../../src/reactjs/components/SignInButton.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAsB,MAAM,OAAO,CAAC;AAChE,OAAO,EAAE,UAAU,EAAoB,MAAM,YAAY,CAAC;AAC1D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,MAAM,YAAY,GAAG,CAAC,EACpB,WAAW,EACX,SAAS,EACT,KAAK,GAKN,EAAE,EAAE;IACH,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,OAAO,EAAE,CAAC;IACvE,MAAM,CAAC,iBAAiB,EAAE,oBAAoB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAElE,mEAAmE;IACnE,SAAS,CAAC,GAAG,EAAE;QACb,IACE,CAAC,UAAU,CAAC,aAAa,EAAE,UAAU,CAAC,eAAe,CAAC,CAAC,QAAQ,CAC7D,UAAU,CACX,EACD,CAAC;YACD,oBAAoB,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IACjB,OAAO,CACL,gCACc,gBAAgB,EAC5B,GAAG,EAAE;YACH,YAAY,EAAE,QAAQ;YACtB,MAAM,EAAE,mBAAmB;YAC3B,OAAO,EAAE,cAAc;YACvB,UAAU,EAAE,uBAAuB;YACnC,QAAQ,EAAE,KAAK,EAAE,kEAAkE;SACpF,EACD,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,GAAG,EAAE;YACZ,oBAAoB,CAAC,IAAI,CAAC,CAAC;YAC3B,MAAM,CAAC,WAAW,CAAC,CAAC;QACtB,CAAC,YAED,KAAC,qBAAqB,IACpB,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,IAAI,eAAe,EAC3C,iBAAiB,EAAE,iBAAiB,wBAGd,GACjB,CACV,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC","sourcesContent":["\"use client\";\n\nimport { useEffect, useState, type CSSProperties } from \"react\";\nimport { AuthStatus, type DisplayMode } from \"@/types.js\";\nimport { useUser } from \"@/reactjs/hooks/useUser.js\";\nimport { ButtonContentOrLoader } from \"./ButtonContentOrLoader.js\";\n\nconst SignInButton = ({\n displayMode,\n className,\n style,\n}: {\n displayMode?: DisplayMode;\n className?: string;\n style?: CSSProperties;\n}) => {\n const { signIn, authStatus, displayMode: userDisplayMode } = useUser();\n const [userActionStarted, setUserActionStarted] = useState(false);\n\n // reset the userActionStarted state if the user logs out or aborts\n useEffect(() => {\n if (\n [AuthStatus.AUTHENTICATED, AuthStatus.UNAUTHENTICATED].includes(\n authStatus,\n )\n ) {\n setUserActionStarted(false);\n }\n }, [authStatus]);\n return (\n <button\n data-testid=\"sign-in-button\"\n css={{\n borderRadius: \"9999px\",\n border: \"1px solid #6b7280\",\n padding: \"0.75rem 1rem\",\n transition: \"background-color 0.2s\",\n minWidth: \"9em\", // this stops the button from going too small when in loading mode\n }}\n className={className}\n style={style}\n onClick={() => {\n setUserActionStarted(true);\n signIn(displayMode);\n }}\n >\n <ButtonContentOrLoader\n authStatus={authStatus}\n displayMode={displayMode || userDisplayMode}\n userActionStarted={userActionStarted}\n >\n Sign In\n </ButtonContentOrLoader>\n </button>\n );\n};\n\nexport { SignInButton };\n"]}