@civic/auth 0.0.1--.tsc.alpha.1

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 (744) hide show
  1. package/.eslintignore +3 -0
  2. package/.eslintrc.json +10 -0
  3. package/.prettierignore +3 -0
  4. package/.prettierrc +4 -0
  5. package/.turbo/turbo-build.log +13 -0
  6. package/.turbo/turbo-lint.log +6 -0
  7. package/.turbo/turbo-test.log +2415 -0
  8. package/README.md +202 -0
  9. package/civic-auth-0.0.1-beta.21.tgz +0 -0
  10. package/dist/cjs/src/browser/storage.d.ts +6 -0
  11. package/dist/cjs/src/browser/storage.d.ts.map +1 -0
  12. package/dist/cjs/src/browser/storage.js +13 -0
  13. package/dist/cjs/src/browser/storage.js.map +1 -0
  14. package/dist/cjs/src/config.d.ts +3 -0
  15. package/dist/cjs/src/config.d.ts.map +1 -0
  16. package/dist/cjs/src/config.js +8 -0
  17. package/dist/cjs/src/config.js.map +1 -0
  18. package/dist/cjs/src/constants.d.ts +9 -0
  19. package/dist/cjs/src/constants.d.ts.map +1 -0
  20. package/dist/cjs/src/constants.js +26 -0
  21. package/dist/cjs/src/constants.js.map +1 -0
  22. package/dist/cjs/src/index.d.ts +5 -0
  23. package/dist/cjs/src/index.d.ts.map +1 -0
  24. package/dist/cjs/src/index.js +5 -0
  25. package/dist/cjs/src/index.js.map +1 -0
  26. package/dist/cjs/src/lib/cookies.d.ts +7 -0
  27. package/dist/cjs/src/lib/cookies.d.ts.map +1 -0
  28. package/dist/cjs/src/lib/cookies.js +26 -0
  29. package/dist/cjs/src/lib/cookies.js.map +1 -0
  30. package/dist/cjs/src/lib/jwt.d.ts +3 -0
  31. package/dist/cjs/src/lib/jwt.d.ts.map +1 -0
  32. package/dist/cjs/src/lib/jwt.js +13 -0
  33. package/dist/cjs/src/lib/jwt.js.map +1 -0
  34. package/dist/cjs/src/lib/logger.d.ts +26 -0
  35. package/dist/cjs/src/lib/logger.d.ts.map +1 -0
  36. package/dist/cjs/src/lib/logger.js +62 -0
  37. package/dist/cjs/src/lib/logger.js.map +1 -0
  38. package/dist/cjs/src/lib/oauth.d.ts +19 -0
  39. package/dist/cjs/src/lib/oauth.d.ts.map +1 -0
  40. package/dist/cjs/src/lib/oauth.js +67 -0
  41. package/dist/cjs/src/lib/oauth.js.map +1 -0
  42. package/dist/cjs/src/lib/postMessage.d.ts +4 -0
  43. package/dist/cjs/src/lib/postMessage.d.ts.map +1 -0
  44. package/dist/cjs/src/lib/postMessage.js +18 -0
  45. package/dist/cjs/src/lib/postMessage.js.map +1 -0
  46. package/dist/cjs/src/lib/windowUtil.d.ts +4 -0
  47. package/dist/cjs/src/lib/windowUtil.d.ts.map +1 -0
  48. package/dist/cjs/src/lib/windowUtil.js +34 -0
  49. package/dist/cjs/src/lib/windowUtil.js.map +1 -0
  50. package/dist/cjs/src/nextjs/GetUser.d.ts +6 -0
  51. package/dist/cjs/src/nextjs/GetUser.d.ts.map +1 -0
  52. package/dist/cjs/src/nextjs/GetUser.js +22 -0
  53. package/dist/cjs/src/nextjs/GetUser.js.map +1 -0
  54. package/dist/cjs/src/nextjs/client/index.d.ts +2 -0
  55. package/dist/cjs/src/nextjs/client/index.d.ts.map +1 -0
  56. package/dist/cjs/src/nextjs/client/index.js +6 -0
  57. package/dist/cjs/src/nextjs/client/index.js.map +1 -0
  58. package/dist/cjs/src/nextjs/config.d.ts +180 -0
  59. package/dist/cjs/src/nextjs/config.d.ts.map +1 -0
  60. package/dist/cjs/src/nextjs/config.js +163 -0
  61. package/dist/cjs/src/nextjs/config.js.map +1 -0
  62. package/dist/cjs/src/nextjs/cookies.d.ts +30 -0
  63. package/dist/cjs/src/nextjs/cookies.d.ts.map +1 -0
  64. package/dist/cjs/src/nextjs/cookies.js +116 -0
  65. package/dist/cjs/src/nextjs/cookies.js.map +1 -0
  66. package/dist/cjs/src/nextjs/hooks/index.d.ts +2 -0
  67. package/dist/cjs/src/nextjs/hooks/index.d.ts.map +1 -0
  68. package/dist/cjs/src/nextjs/hooks/index.js +6 -0
  69. package/dist/cjs/src/nextjs/hooks/index.js.map +1 -0
  70. package/dist/cjs/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
  71. package/dist/cjs/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
  72. package/dist/cjs/src/nextjs/hooks/useTokenCookie.js +41 -0
  73. package/dist/cjs/src/nextjs/hooks/useTokenCookie.js.map +1 -0
  74. package/dist/cjs/src/nextjs/hooks/useUserCookie.d.ts +3 -0
  75. package/dist/cjs/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  76. package/dist/cjs/src/nextjs/hooks/useUserCookie.js +40 -0
  77. package/dist/cjs/src/nextjs/hooks/useUserCookie.js.map +1 -0
  78. package/dist/cjs/src/nextjs/index.d.ts +7 -0
  79. package/dist/cjs/src/nextjs/index.d.ts.map +1 -0
  80. package/dist/cjs/src/nextjs/index.js +20 -0
  81. package/dist/cjs/src/nextjs/index.js.map +1 -0
  82. package/dist/cjs/src/nextjs/middleware/index.d.ts +2 -0
  83. package/dist/cjs/src/nextjs/middleware/index.d.ts.map +1 -0
  84. package/dist/cjs/src/nextjs/middleware/index.js +8 -0
  85. package/dist/cjs/src/nextjs/middleware/index.js.map +1 -0
  86. package/dist/cjs/src/nextjs/middleware.d.ts +59 -0
  87. package/dist/cjs/src/nextjs/middleware.d.ts.map +1 -0
  88. package/dist/cjs/src/nextjs/middleware.js +116 -0
  89. package/dist/cjs/src/nextjs/middleware.js.map +1 -0
  90. package/dist/cjs/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
  91. package/dist/cjs/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  92. package/dist/cjs/src/nextjs/providers/NextAuthProvider.js +77 -0
  93. package/dist/cjs/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  94. package/dist/cjs/src/nextjs/routeHandler.d.ts +18 -0
  95. package/dist/cjs/src/nextjs/routeHandler.d.ts.map +1 -0
  96. package/dist/cjs/src/nextjs/routeHandler.js +208 -0
  97. package/dist/cjs/src/nextjs/routeHandler.js.map +1 -0
  98. package/dist/cjs/src/nextjs/utils.d.ts +3 -0
  99. package/dist/cjs/src/nextjs/utils.d.ts.map +1 -0
  100. package/dist/cjs/src/nextjs/utils.js +10 -0
  101. package/dist/cjs/src/nextjs/utils.js.map +1 -0
  102. package/dist/cjs/src/nextjs/worker/index.d.ts +2 -0
  103. package/dist/cjs/src/nextjs/worker/index.d.ts.map +1 -0
  104. package/dist/cjs/src/nextjs/worker/index.js +8 -0
  105. package/dist/cjs/src/nextjs/worker/index.js.map +1 -0
  106. package/dist/cjs/src/reactjs/components/NextLogOut.d.ts +7 -0
  107. package/dist/cjs/src/reactjs/components/NextLogOut.d.ts.map +1 -0
  108. package/dist/cjs/src/reactjs/components/NextLogOut.js +18 -0
  109. package/dist/cjs/src/reactjs/components/NextLogOut.js.map +1 -0
  110. package/dist/cjs/src/reactjs/components/SignInButton.d.ts +8 -0
  111. package/dist/cjs/src/reactjs/components/SignInButton.d.ts.map +1 -0
  112. package/dist/cjs/src/reactjs/components/SignInButton.js +16 -0
  113. package/dist/cjs/src/reactjs/components/SignInButton.js.map +1 -0
  114. package/dist/cjs/src/reactjs/components/SignOutButton.d.ts +6 -0
  115. package/dist/cjs/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  116. package/dist/cjs/src/reactjs/components/SignOutButton.js +16 -0
  117. package/dist/cjs/src/reactjs/components/SignOutButton.js.map +1 -0
  118. package/dist/cjs/src/reactjs/components/UserButton.d.ts +8 -0
  119. package/dist/cjs/src/reactjs/components/UserButton.d.ts.map +1 -0
  120. package/dist/cjs/src/reactjs/components/UserButton.js +84 -0
  121. package/dist/cjs/src/reactjs/components/UserButton.js.map +1 -0
  122. package/dist/cjs/src/reactjs/components/index.d.ts +6 -0
  123. package/dist/cjs/src/reactjs/components/index.d.ts.map +1 -0
  124. package/dist/cjs/src/reactjs/components/index.js +14 -0
  125. package/dist/cjs/src/reactjs/components/index.js.map +1 -0
  126. package/dist/cjs/src/reactjs/hooks/index.d.ts +9 -0
  127. package/dist/cjs/src/reactjs/hooks/index.d.ts.map +1 -0
  128. package/dist/cjs/src/reactjs/hooks/index.js +20 -0
  129. package/dist/cjs/src/reactjs/hooks/index.js.map +1 -0
  130. package/dist/cjs/src/reactjs/hooks/useAuth.d.ts +3 -0
  131. package/dist/cjs/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  132. package/dist/cjs/src/reactjs/hooks/useAuth.js +15 -0
  133. package/dist/cjs/src/reactjs/hooks/useAuth.js.map +1 -0
  134. package/dist/cjs/src/reactjs/hooks/useUser.d.ts +4 -0
  135. package/dist/cjs/src/reactjs/hooks/useUser.d.ts.map +1 -0
  136. package/dist/cjs/src/reactjs/hooks/useUser.js +15 -0
  137. package/dist/cjs/src/reactjs/hooks/useUser.js.map +1 -0
  138. package/dist/cjs/src/reactjs/index.d.ts +6 -0
  139. package/dist/cjs/src/reactjs/index.d.ts.map +1 -0
  140. package/dist/cjs/src/reactjs/index.js +30 -0
  141. package/dist/cjs/src/reactjs/index.js.map +1 -0
  142. package/dist/cjs/src/reactjs/providers/index.d.ts +8 -0
  143. package/dist/cjs/src/reactjs/providers/index.d.ts.map +1 -0
  144. package/dist/cjs/src/reactjs/providers/index.js +19 -0
  145. package/dist/cjs/src/reactjs/providers/index.js.map +1 -0
  146. package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts +18 -0
  147. package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  148. package/dist/cjs/src/server/ServerAuthenticationResolver.js +66 -0
  149. package/dist/cjs/src/server/ServerAuthenticationResolver.js.map +1 -0
  150. package/dist/cjs/src/server/config.d.ts +16 -0
  151. package/dist/cjs/src/server/config.d.ts.map +1 -0
  152. package/dist/cjs/src/server/config.js +3 -0
  153. package/dist/cjs/src/server/config.js.map +1 -0
  154. package/dist/cjs/src/server/index.d.ts +6 -0
  155. package/dist/cjs/src/server/index.d.ts.map +1 -0
  156. package/dist/cjs/src/server/index.js +14 -0
  157. package/dist/cjs/src/server/index.js.map +1 -0
  158. package/dist/cjs/src/server/login.d.ts +17 -0
  159. package/dist/cjs/src/server/login.d.ts.map +1 -0
  160. package/dist/cjs/src/server/login.js +42 -0
  161. package/dist/cjs/src/server/login.js.map +1 -0
  162. package/dist/cjs/src/server/refresh.d.ts +7 -0
  163. package/dist/cjs/src/server/refresh.d.ts.map +1 -0
  164. package/dist/cjs/src/server/refresh.js +16 -0
  165. package/dist/cjs/src/server/refresh.js.map +1 -0
  166. package/dist/cjs/src/services/AuthenticationService.d.ts +87 -0
  167. package/dist/cjs/src/services/AuthenticationService.d.ts.map +1 -0
  168. package/dist/cjs/src/services/AuthenticationService.js +228 -0
  169. package/dist/cjs/src/services/AuthenticationService.js.map +1 -0
  170. package/dist/cjs/src/services/PKCE.d.ts +20 -0
  171. package/dist/cjs/src/services/PKCE.d.ts.map +1 -0
  172. package/dist/cjs/src/services/PKCE.js +50 -0
  173. package/dist/cjs/src/services/PKCE.js.map +1 -0
  174. package/dist/cjs/src/services/types.d.ts +23 -0
  175. package/dist/cjs/src/services/types.d.ts.map +1 -0
  176. package/dist/cjs/src/services/types.js +11 -0
  177. package/dist/cjs/src/services/types.js.map +1 -0
  178. package/dist/cjs/src/shared/AuthContext.d.ts +10 -0
  179. package/dist/cjs/src/shared/AuthContext.d.ts.map +1 -0
  180. package/dist/cjs/src/shared/AuthContext.js +6 -0
  181. package/dist/cjs/src/shared/AuthContext.js.map +1 -0
  182. package/dist/cjs/src/shared/AuthProvider.d.ts +18 -0
  183. package/dist/cjs/src/shared/AuthProvider.d.ts.map +1 -0
  184. package/dist/cjs/src/shared/AuthProvider.js +276 -0
  185. package/dist/cjs/src/shared/AuthProvider.js.map +1 -0
  186. package/dist/cjs/src/shared/CivicAuthProvider.d.ts +7 -0
  187. package/dist/cjs/src/shared/CivicAuthProvider.d.ts.map +1 -0
  188. package/dist/cjs/src/shared/CivicAuthProvider.js +23 -0
  189. package/dist/cjs/src/shared/CivicAuthProvider.js.map +1 -0
  190. package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts +15 -0
  191. package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts.map +1 -0
  192. package/dist/cjs/src/shared/GenericAuthenticationRefresher.js +47 -0
  193. package/dist/cjs/src/shared/GenericAuthenticationRefresher.js.map +1 -0
  194. package/dist/cjs/src/shared/UserProvider.d.ts +18 -0
  195. package/dist/cjs/src/shared/UserProvider.d.ts.map +1 -0
  196. package/dist/cjs/src/shared/UserProvider.js +65 -0
  197. package/dist/cjs/src/shared/UserProvider.js.map +1 -0
  198. package/dist/cjs/src/shared/UserSession.d.ts +12 -0
  199. package/dist/cjs/src/shared/UserSession.d.ts.map +1 -0
  200. package/dist/cjs/src/shared/UserSession.js +24 -0
  201. package/dist/cjs/src/shared/UserSession.js.map +1 -0
  202. package/dist/cjs/src/shared/components/CivicAuthIframe.d.ts +8 -0
  203. package/dist/cjs/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  204. package/dist/cjs/src/shared/components/CivicAuthIframe.js +35 -0
  205. package/dist/cjs/src/shared/components/CivicAuthIframe.js.map +1 -0
  206. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.d.ts +9 -0
  207. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  208. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.js +117 -0
  209. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  210. package/dist/cjs/src/shared/components/CloseIcon.d.ts +4 -0
  211. package/dist/cjs/src/shared/components/CloseIcon.d.ts.map +1 -0
  212. package/dist/cjs/src/shared/components/CloseIcon.js +12 -0
  213. package/dist/cjs/src/shared/components/CloseIcon.js.map +1 -0
  214. package/dist/cjs/src/shared/components/LoadingIcon.d.ts +4 -0
  215. package/dist/cjs/src/shared/components/LoadingIcon.d.ts.map +1 -0
  216. package/dist/cjs/src/shared/components/LoadingIcon.js +14 -0
  217. package/dist/cjs/src/shared/components/LoadingIcon.js.map +1 -0
  218. package/dist/cjs/src/shared/hooks/index.d.ts +5 -0
  219. package/dist/cjs/src/shared/hooks/index.d.ts.map +1 -0
  220. package/dist/cjs/src/shared/hooks/index.js +12 -0
  221. package/dist/cjs/src/shared/hooks/index.js.map +1 -0
  222. package/dist/cjs/src/shared/hooks/useAuth.d.ts +3 -0
  223. package/dist/cjs/src/shared/hooks/useAuth.d.ts.map +1 -0
  224. package/dist/cjs/src/shared/hooks/useAuth.js +15 -0
  225. package/dist/cjs/src/shared/hooks/useAuth.js.map +1 -0
  226. package/dist/cjs/src/shared/hooks/useConfig.d.ts +3 -0
  227. package/dist/cjs/src/shared/hooks/useConfig.d.ts.map +1 -0
  228. package/dist/cjs/src/shared/hooks/useConfig.js +16 -0
  229. package/dist/cjs/src/shared/hooks/useConfig.js.map +1 -0
  230. package/dist/cjs/src/shared/hooks/useIframe.d.ts +3 -0
  231. package/dist/cjs/src/shared/hooks/useIframe.d.ts.map +1 -0
  232. package/dist/cjs/src/shared/hooks/useIframe.js +16 -0
  233. package/dist/cjs/src/shared/hooks/useIframe.js.map +1 -0
  234. package/dist/cjs/src/shared/hooks/useSession.d.ts +3 -0
  235. package/dist/cjs/src/shared/hooks/useSession.d.ts.map +1 -0
  236. package/dist/cjs/src/shared/hooks/useSession.js +16 -0
  237. package/dist/cjs/src/shared/hooks/useSession.js.map +1 -0
  238. package/dist/cjs/src/shared/hooks/useToken.d.ts +3 -0
  239. package/dist/cjs/src/shared/hooks/useToken.d.ts.map +1 -0
  240. package/dist/cjs/src/shared/hooks/useToken.js +15 -0
  241. package/dist/cjs/src/shared/hooks/useToken.js.map +1 -0
  242. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts +15 -0
  243. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  244. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js +47 -0
  245. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  246. package/dist/cjs/src/shared/lib/UserSession.d.ts +12 -0
  247. package/dist/cjs/src/shared/lib/UserSession.d.ts.map +1 -0
  248. package/dist/cjs/src/shared/lib/UserSession.js +24 -0
  249. package/dist/cjs/src/shared/lib/UserSession.js.map +1 -0
  250. package/dist/cjs/src/shared/lib/session.d.ts +3 -0
  251. package/dist/cjs/src/shared/lib/session.d.ts.map +1 -0
  252. package/dist/cjs/src/shared/lib/session.js +13 -0
  253. package/dist/cjs/src/shared/lib/session.js.map +1 -0
  254. package/dist/cjs/src/shared/lib/storage.d.ts +25 -0
  255. package/dist/cjs/src/shared/lib/storage.d.ts.map +1 -0
  256. package/dist/cjs/src/shared/lib/storage.js +21 -0
  257. package/dist/cjs/src/shared/lib/storage.js.map +1 -0
  258. package/dist/cjs/src/shared/lib/types.d.ts +21 -0
  259. package/dist/cjs/src/shared/lib/types.d.ts.map +1 -0
  260. package/dist/cjs/src/shared/lib/types.js +18 -0
  261. package/dist/cjs/src/shared/lib/types.js.map +1 -0
  262. package/dist/cjs/src/shared/lib/util.d.ts +33 -0
  263. package/dist/cjs/src/shared/lib/util.d.ts.map +1 -0
  264. package/dist/cjs/src/shared/lib/util.js +164 -0
  265. package/dist/cjs/src/shared/lib/util.js.map +1 -0
  266. package/dist/cjs/src/shared/providers/AuthContext.d.ts +10 -0
  267. package/dist/cjs/src/shared/providers/AuthContext.d.ts.map +1 -0
  268. package/dist/cjs/src/shared/providers/AuthContext.js +6 -0
  269. package/dist/cjs/src/shared/providers/AuthContext.js.map +1 -0
  270. package/dist/cjs/src/shared/providers/AuthProvider.d.ts +18 -0
  271. package/dist/cjs/src/shared/providers/AuthProvider.d.ts.map +1 -0
  272. package/dist/cjs/src/shared/providers/AuthProvider.js +271 -0
  273. package/dist/cjs/src/shared/providers/AuthProvider.js.map +1 -0
  274. package/dist/cjs/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  275. package/dist/cjs/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  276. package/dist/cjs/src/shared/providers/CivicAuthProvider.js +23 -0
  277. package/dist/cjs/src/shared/providers/CivicAuthProvider.js.map +1 -0
  278. package/dist/cjs/src/shared/providers/ConfigProvider.d.ts +21 -0
  279. package/dist/cjs/src/shared/providers/ConfigProvider.d.ts.map +1 -0
  280. package/dist/cjs/src/shared/providers/ConfigProvider.js +46 -0
  281. package/dist/cjs/src/shared/providers/ConfigProvider.js.map +1 -0
  282. package/dist/cjs/src/shared/providers/IframeProvider.d.ts +16 -0
  283. package/dist/cjs/src/shared/providers/IframeProvider.d.ts.map +1 -0
  284. package/dist/cjs/src/shared/providers/IframeProvider.js +38 -0
  285. package/dist/cjs/src/shared/providers/IframeProvider.js.map +1 -0
  286. package/dist/cjs/src/shared/providers/SessionProvider.d.ts +13 -0
  287. package/dist/cjs/src/shared/providers/SessionProvider.d.ts.map +1 -0
  288. package/dist/cjs/src/shared/providers/SessionProvider.js +40 -0
  289. package/dist/cjs/src/shared/providers/SessionProvider.js.map +1 -0
  290. package/dist/cjs/src/shared/providers/TokenProvider.d.ts +18 -0
  291. package/dist/cjs/src/shared/providers/TokenProvider.d.ts.map +1 -0
  292. package/dist/cjs/src/shared/providers/TokenProvider.js +80 -0
  293. package/dist/cjs/src/shared/providers/TokenProvider.js.map +1 -0
  294. package/dist/cjs/src/shared/providers/UserProvider.d.ts +18 -0
  295. package/dist/cjs/src/shared/providers/UserProvider.d.ts.map +1 -0
  296. package/dist/cjs/src/shared/providers/UserProvider.js +65 -0
  297. package/dist/cjs/src/shared/providers/UserProvider.js.map +1 -0
  298. package/dist/cjs/src/shared/session.d.ts +3 -0
  299. package/dist/cjs/src/shared/session.d.ts.map +1 -0
  300. package/dist/cjs/src/shared/session.js +13 -0
  301. package/dist/cjs/src/shared/session.js.map +1 -0
  302. package/dist/cjs/src/shared/storage.d.ts +25 -0
  303. package/dist/cjs/src/shared/storage.d.ts.map +1 -0
  304. package/dist/cjs/src/shared/storage.js +21 -0
  305. package/dist/cjs/src/shared/storage.js.map +1 -0
  306. package/dist/cjs/src/shared/types.d.ts +21 -0
  307. package/dist/cjs/src/shared/types.d.ts.map +1 -0
  308. package/dist/cjs/src/shared/types.js +18 -0
  309. package/dist/cjs/src/shared/types.js.map +1 -0
  310. package/dist/cjs/src/shared/util.d.ts +33 -0
  311. package/dist/cjs/src/shared/util.d.ts.map +1 -0
  312. package/dist/cjs/src/shared/util.js +164 -0
  313. package/dist/cjs/src/shared/util.js.map +1 -0
  314. package/dist/cjs/src/types.d.ts +146 -0
  315. package/dist/cjs/src/types.d.ts.map +1 -0
  316. package/dist/cjs/src/types.js +3 -0
  317. package/dist/cjs/src/types.js.map +1 -0
  318. package/dist/cjs/src/utils.d.ts +17 -0
  319. package/dist/cjs/src/utils.d.ts.map +1 -0
  320. package/dist/cjs/src/utils.js +53 -0
  321. package/dist/cjs/src/utils.js.map +1 -0
  322. package/dist/cjs/src/worker/index.d.ts +2 -0
  323. package/dist/cjs/src/worker/index.d.ts.map +1 -0
  324. package/dist/cjs/src/worker/index.js +8 -0
  325. package/dist/cjs/src/worker/index.js.map +1 -0
  326. package/dist/cjs/tsconfig.build.tsbuildinfo +1 -0
  327. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -0
  328. package/dist/esm/src/browser/storage.d.ts +6 -0
  329. package/dist/esm/src/browser/storage.d.ts.map +1 -0
  330. package/dist/esm/src/browser/storage.js +9 -0
  331. package/dist/esm/src/browser/storage.js.map +1 -0
  332. package/dist/esm/src/config.d.ts +3 -0
  333. package/dist/esm/src/config.d.ts.map +1 -0
  334. package/dist/esm/src/config.js +5 -0
  335. package/dist/esm/src/config.js.map +1 -0
  336. package/dist/esm/src/constants.d.ts +9 -0
  337. package/dist/esm/src/constants.d.ts.map +1 -0
  338. package/dist/esm/src/constants.js +17 -0
  339. package/dist/esm/src/constants.js.map +1 -0
  340. package/dist/esm/src/index.d.ts +5 -0
  341. package/dist/esm/src/index.d.ts.map +1 -0
  342. package/dist/esm/src/index.js +3 -0
  343. package/dist/esm/src/index.js.map +1 -0
  344. package/dist/esm/src/lib/cookies.d.ts +7 -0
  345. package/dist/esm/src/lib/cookies.d.ts.map +1 -0
  346. package/dist/esm/src/lib/cookies.js +23 -0
  347. package/dist/esm/src/lib/cookies.js.map +1 -0
  348. package/dist/esm/src/lib/jwt.d.ts +3 -0
  349. package/dist/esm/src/lib/jwt.d.ts.map +1 -0
  350. package/dist/esm/src/lib/jwt.js +9 -0
  351. package/dist/esm/src/lib/jwt.js.map +1 -0
  352. package/dist/esm/src/lib/logger.d.ts +26 -0
  353. package/dist/esm/src/lib/logger.d.ts.map +1 -0
  354. package/dist/esm/src/lib/logger.js +55 -0
  355. package/dist/esm/src/lib/logger.js.map +1 -0
  356. package/dist/esm/src/lib/oauth.d.ts +19 -0
  357. package/dist/esm/src/lib/oauth.d.ts.map +1 -0
  358. package/dist/esm/src/lib/oauth.js +60 -0
  359. package/dist/esm/src/lib/oauth.js.map +1 -0
  360. package/dist/esm/src/lib/postMessage.d.ts +4 -0
  361. package/dist/esm/src/lib/postMessage.d.ts.map +1 -0
  362. package/dist/esm/src/lib/postMessage.js +15 -0
  363. package/dist/esm/src/lib/postMessage.js.map +1 -0
  364. package/dist/esm/src/lib/windowUtil.d.ts +4 -0
  365. package/dist/esm/src/lib/windowUtil.d.ts.map +1 -0
  366. package/dist/esm/src/lib/windowUtil.js +30 -0
  367. package/dist/esm/src/lib/windowUtil.js.map +1 -0
  368. package/dist/esm/src/nextjs/GetUser.d.ts +6 -0
  369. package/dist/esm/src/nextjs/GetUser.d.ts.map +1 -0
  370. package/dist/esm/src/nextjs/GetUser.js +18 -0
  371. package/dist/esm/src/nextjs/GetUser.js.map +1 -0
  372. package/dist/esm/src/nextjs/client/index.d.ts +2 -0
  373. package/dist/esm/src/nextjs/client/index.d.ts.map +1 -0
  374. package/dist/esm/src/nextjs/client/index.js +2 -0
  375. package/dist/esm/src/nextjs/client/index.js.map +1 -0
  376. package/dist/esm/src/nextjs/config.d.ts +180 -0
  377. package/dist/esm/src/nextjs/config.d.ts.map +1 -0
  378. package/dist/esm/src/nextjs/config.js +158 -0
  379. package/dist/esm/src/nextjs/config.js.map +1 -0
  380. package/dist/esm/src/nextjs/cookies.d.ts +30 -0
  381. package/dist/esm/src/nextjs/cookies.d.ts.map +1 -0
  382. package/dist/esm/src/nextjs/cookies.js +109 -0
  383. package/dist/esm/src/nextjs/cookies.js.map +1 -0
  384. package/dist/esm/src/nextjs/hooks/index.d.ts +2 -0
  385. package/dist/esm/src/nextjs/hooks/index.d.ts.map +1 -0
  386. package/dist/esm/src/nextjs/hooks/index.js +2 -0
  387. package/dist/esm/src/nextjs/hooks/index.js.map +1 -0
  388. package/dist/esm/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
  389. package/dist/esm/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
  390. package/dist/esm/src/nextjs/hooks/useTokenCookie.js +37 -0
  391. package/dist/esm/src/nextjs/hooks/useTokenCookie.js.map +1 -0
  392. package/dist/esm/src/nextjs/hooks/useUserCookie.d.ts +3 -0
  393. package/dist/esm/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  394. package/dist/esm/src/nextjs/hooks/useUserCookie.js +36 -0
  395. package/dist/esm/src/nextjs/hooks/useUserCookie.js.map +1 -0
  396. package/dist/esm/src/nextjs/index.d.ts +7 -0
  397. package/dist/esm/src/nextjs/index.d.ts.map +1 -0
  398. package/dist/esm/src/nextjs/index.js +6 -0
  399. package/dist/esm/src/nextjs/index.js.map +1 -0
  400. package/dist/esm/src/nextjs/middleware/index.d.ts +2 -0
  401. package/dist/esm/src/nextjs/middleware/index.d.ts.map +1 -0
  402. package/dist/esm/src/nextjs/middleware/index.js +2 -0
  403. package/dist/esm/src/nextjs/middleware/index.js.map +1 -0
  404. package/dist/esm/src/nextjs/middleware.d.ts +59 -0
  405. package/dist/esm/src/nextjs/middleware.d.ts.map +1 -0
  406. package/dist/esm/src/nextjs/middleware.js +107 -0
  407. package/dist/esm/src/nextjs/middleware.js.map +1 -0
  408. package/dist/esm/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
  409. package/dist/esm/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  410. package/dist/esm/src/nextjs/providers/NextAuthProvider.js +51 -0
  411. package/dist/esm/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  412. package/dist/esm/src/nextjs/routeHandler.d.ts +18 -0
  413. package/dist/esm/src/nextjs/routeHandler.d.ts.map +1 -0
  414. package/dist/esm/src/nextjs/routeHandler.js +203 -0
  415. package/dist/esm/src/nextjs/routeHandler.js.map +1 -0
  416. package/dist/esm/src/nextjs/utils.d.ts +3 -0
  417. package/dist/esm/src/nextjs/utils.d.ts.map +1 -0
  418. package/dist/esm/src/nextjs/utils.js +6 -0
  419. package/dist/esm/src/nextjs/utils.js.map +1 -0
  420. package/dist/esm/src/nextjs/worker/index.d.ts +2 -0
  421. package/dist/esm/src/nextjs/worker/index.d.ts.map +1 -0
  422. package/dist/esm/src/nextjs/worker/index.js +2 -0
  423. package/dist/esm/src/nextjs/worker/index.js.map +1 -0
  424. package/dist/esm/src/reactjs/components/NextLogOut.d.ts +7 -0
  425. package/dist/esm/src/reactjs/components/NextLogOut.d.ts.map +1 -0
  426. package/dist/esm/src/reactjs/components/NextLogOut.js +12 -0
  427. package/dist/esm/src/reactjs/components/NextLogOut.js.map +1 -0
  428. package/dist/esm/src/reactjs/components/SignInButton.d.ts +8 -0
  429. package/dist/esm/src/reactjs/components/SignInButton.d.ts.map +1 -0
  430. package/dist/esm/src/reactjs/components/SignInButton.js +10 -0
  431. package/dist/esm/src/reactjs/components/SignInButton.js.map +1 -0
  432. package/dist/esm/src/reactjs/components/SignOutButton.d.ts +6 -0
  433. package/dist/esm/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  434. package/dist/esm/src/reactjs/components/SignOutButton.js +10 -0
  435. package/dist/esm/src/reactjs/components/SignOutButton.js.map +1 -0
  436. package/dist/esm/src/reactjs/components/UserButton.d.ts +8 -0
  437. package/dist/esm/src/reactjs/components/UserButton.d.ts.map +1 -0
  438. package/dist/esm/src/reactjs/components/UserButton.js +58 -0
  439. package/dist/esm/src/reactjs/components/UserButton.js.map +1 -0
  440. package/dist/esm/src/reactjs/components/index.d.ts +6 -0
  441. package/dist/esm/src/reactjs/components/index.d.ts.map +1 -0
  442. package/dist/esm/src/reactjs/components/index.js +6 -0
  443. package/dist/esm/src/reactjs/components/index.js.map +1 -0
  444. package/dist/esm/src/reactjs/hooks/index.d.ts +9 -0
  445. package/dist/esm/src/reactjs/hooks/index.d.ts.map +1 -0
  446. package/dist/esm/src/reactjs/hooks/index.js +9 -0
  447. package/dist/esm/src/reactjs/hooks/index.js.map +1 -0
  448. package/dist/esm/src/reactjs/hooks/useAuth.d.ts +3 -0
  449. package/dist/esm/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  450. package/dist/esm/src/reactjs/hooks/useAuth.js +12 -0
  451. package/dist/esm/src/reactjs/hooks/useAuth.js.map +1 -0
  452. package/dist/esm/src/reactjs/hooks/useUser.d.ts +4 -0
  453. package/dist/esm/src/reactjs/hooks/useUser.d.ts.map +1 -0
  454. package/dist/esm/src/reactjs/hooks/useUser.js +12 -0
  455. package/dist/esm/src/reactjs/hooks/useUser.js.map +1 -0
  456. package/dist/esm/src/reactjs/index.d.ts +6 -0
  457. package/dist/esm/src/reactjs/index.d.ts.map +1 -0
  458. package/dist/esm/src/reactjs/index.js +8 -0
  459. package/dist/esm/src/reactjs/index.js.map +1 -0
  460. package/dist/esm/src/reactjs/providers/index.d.ts +8 -0
  461. package/dist/esm/src/reactjs/providers/index.d.ts.map +1 -0
  462. package/dist/esm/src/reactjs/providers/index.js +7 -0
  463. package/dist/esm/src/reactjs/providers/index.js.map +1 -0
  464. package/dist/esm/src/server/ServerAuthenticationResolver.d.ts +18 -0
  465. package/dist/esm/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  466. package/dist/esm/src/server/ServerAuthenticationResolver.js +62 -0
  467. package/dist/esm/src/server/ServerAuthenticationResolver.js.map +1 -0
  468. package/dist/esm/src/server/config.d.ts +16 -0
  469. package/dist/esm/src/server/config.d.ts.map +1 -0
  470. package/dist/esm/src/server/config.js +2 -0
  471. package/dist/esm/src/server/config.js.map +1 -0
  472. package/dist/esm/src/server/index.d.ts +6 -0
  473. package/dist/esm/src/server/index.d.ts.map +1 -0
  474. package/dist/esm/src/server/index.js +5 -0
  475. package/dist/esm/src/server/index.js.map +1 -0
  476. package/dist/esm/src/server/login.d.ts +17 -0
  477. package/dist/esm/src/server/login.d.ts.map +1 -0
  478. package/dist/esm/src/server/login.js +37 -0
  479. package/dist/esm/src/server/login.js.map +1 -0
  480. package/dist/esm/src/server/refresh.d.ts +7 -0
  481. package/dist/esm/src/server/refresh.d.ts.map +1 -0
  482. package/dist/esm/src/server/refresh.js +13 -0
  483. package/dist/esm/src/server/refresh.js.map +1 -0
  484. package/dist/esm/src/services/AuthenticationService.d.ts +87 -0
  485. package/dist/esm/src/services/AuthenticationService.d.ts.map +1 -0
  486. package/dist/esm/src/services/AuthenticationService.js +222 -0
  487. package/dist/esm/src/services/AuthenticationService.js.map +1 -0
  488. package/dist/esm/src/services/PKCE.d.ts +20 -0
  489. package/dist/esm/src/services/PKCE.d.ts.map +1 -0
  490. package/dist/esm/src/services/PKCE.js +44 -0
  491. package/dist/esm/src/services/PKCE.js.map +1 -0
  492. package/dist/esm/src/services/types.d.ts +23 -0
  493. package/dist/esm/src/services/types.d.ts.map +1 -0
  494. package/dist/esm/src/services/types.js +7 -0
  495. package/dist/esm/src/services/types.js.map +1 -0
  496. package/dist/esm/src/shared/AuthContext.d.ts +10 -0
  497. package/dist/esm/src/shared/AuthContext.d.ts.map +1 -0
  498. package/dist/esm/src/shared/AuthContext.js +3 -0
  499. package/dist/esm/src/shared/AuthContext.js.map +1 -0
  500. package/dist/esm/src/shared/AuthProvider.d.ts +18 -0
  501. package/dist/esm/src/shared/AuthProvider.d.ts.map +1 -0
  502. package/dist/esm/src/shared/AuthProvider.js +250 -0
  503. package/dist/esm/src/shared/AuthProvider.js.map +1 -0
  504. package/dist/esm/src/shared/CivicAuthProvider.d.ts +7 -0
  505. package/dist/esm/src/shared/CivicAuthProvider.d.ts.map +1 -0
  506. package/dist/esm/src/shared/CivicAuthProvider.js +17 -0
  507. package/dist/esm/src/shared/CivicAuthProvider.js.map +1 -0
  508. package/dist/esm/src/shared/GenericAuthenticationRefresher.d.ts +15 -0
  509. package/dist/esm/src/shared/GenericAuthenticationRefresher.d.ts.map +1 -0
  510. package/dist/esm/src/shared/GenericAuthenticationRefresher.js +43 -0
  511. package/dist/esm/src/shared/GenericAuthenticationRefresher.js.map +1 -0
  512. package/dist/esm/src/shared/UserProvider.d.ts +18 -0
  513. package/dist/esm/src/shared/UserProvider.d.ts.map +1 -0
  514. package/dist/esm/src/shared/UserProvider.js +38 -0
  515. package/dist/esm/src/shared/UserProvider.js.map +1 -0
  516. package/dist/esm/src/shared/UserSession.d.ts +12 -0
  517. package/dist/esm/src/shared/UserSession.d.ts.map +1 -0
  518. package/dist/esm/src/shared/UserSession.js +20 -0
  519. package/dist/esm/src/shared/UserSession.js.map +1 -0
  520. package/dist/esm/src/shared/components/CivicAuthIframe.d.ts +8 -0
  521. package/dist/esm/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  522. package/dist/esm/src/shared/components/CivicAuthIframe.js +9 -0
  523. package/dist/esm/src/shared/components/CivicAuthIframe.js.map +1 -0
  524. package/dist/esm/src/shared/components/CivicAuthIframeContainer.d.ts +9 -0
  525. package/dist/esm/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  526. package/dist/esm/src/shared/components/CivicAuthIframeContainer.js +91 -0
  527. package/dist/esm/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  528. package/dist/esm/src/shared/components/CloseIcon.d.ts +4 -0
  529. package/dist/esm/src/shared/components/CloseIcon.d.ts.map +1 -0
  530. package/dist/esm/src/shared/components/CloseIcon.js +6 -0
  531. package/dist/esm/src/shared/components/CloseIcon.js.map +1 -0
  532. package/dist/esm/src/shared/components/LoadingIcon.d.ts +4 -0
  533. package/dist/esm/src/shared/components/LoadingIcon.d.ts.map +1 -0
  534. package/dist/esm/src/shared/components/LoadingIcon.js +8 -0
  535. package/dist/esm/src/shared/components/LoadingIcon.js.map +1 -0
  536. package/dist/esm/src/shared/hooks/index.d.ts +5 -0
  537. package/dist/esm/src/shared/hooks/index.d.ts.map +1 -0
  538. package/dist/esm/src/shared/hooks/index.js +5 -0
  539. package/dist/esm/src/shared/hooks/index.js.map +1 -0
  540. package/dist/esm/src/shared/hooks/useAuth.d.ts +3 -0
  541. package/dist/esm/src/shared/hooks/useAuth.d.ts.map +1 -0
  542. package/dist/esm/src/shared/hooks/useAuth.js +12 -0
  543. package/dist/esm/src/shared/hooks/useAuth.js.map +1 -0
  544. package/dist/esm/src/shared/hooks/useConfig.d.ts +3 -0
  545. package/dist/esm/src/shared/hooks/useConfig.d.ts.map +1 -0
  546. package/dist/esm/src/shared/hooks/useConfig.js +13 -0
  547. package/dist/esm/src/shared/hooks/useConfig.js.map +1 -0
  548. package/dist/esm/src/shared/hooks/useIframe.d.ts +3 -0
  549. package/dist/esm/src/shared/hooks/useIframe.d.ts.map +1 -0
  550. package/dist/esm/src/shared/hooks/useIframe.js +13 -0
  551. package/dist/esm/src/shared/hooks/useIframe.js.map +1 -0
  552. package/dist/esm/src/shared/hooks/useSession.d.ts +3 -0
  553. package/dist/esm/src/shared/hooks/useSession.d.ts.map +1 -0
  554. package/dist/esm/src/shared/hooks/useSession.js +13 -0
  555. package/dist/esm/src/shared/hooks/useSession.js.map +1 -0
  556. package/dist/esm/src/shared/hooks/useToken.d.ts +3 -0
  557. package/dist/esm/src/shared/hooks/useToken.d.ts.map +1 -0
  558. package/dist/esm/src/shared/hooks/useToken.js +12 -0
  559. package/dist/esm/src/shared/hooks/useToken.js.map +1 -0
  560. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts +15 -0
  561. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  562. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js +43 -0
  563. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  564. package/dist/esm/src/shared/lib/UserSession.d.ts +12 -0
  565. package/dist/esm/src/shared/lib/UserSession.d.ts.map +1 -0
  566. package/dist/esm/src/shared/lib/UserSession.js +20 -0
  567. package/dist/esm/src/shared/lib/UserSession.js.map +1 -0
  568. package/dist/esm/src/shared/lib/session.d.ts +3 -0
  569. package/dist/esm/src/shared/lib/session.d.ts.map +1 -0
  570. package/dist/esm/src/shared/lib/session.js +10 -0
  571. package/dist/esm/src/shared/lib/session.js.map +1 -0
  572. package/dist/esm/src/shared/lib/storage.d.ts +25 -0
  573. package/dist/esm/src/shared/lib/storage.d.ts.map +1 -0
  574. package/dist/esm/src/shared/lib/storage.js +17 -0
  575. package/dist/esm/src/shared/lib/storage.js.map +1 -0
  576. package/dist/esm/src/shared/lib/types.d.ts +21 -0
  577. package/dist/esm/src/shared/lib/types.d.ts.map +1 -0
  578. package/dist/esm/src/shared/lib/types.js +15 -0
  579. package/dist/esm/src/shared/lib/types.js.map +1 -0
  580. package/dist/esm/src/shared/lib/util.d.ts +33 -0
  581. package/dist/esm/src/shared/lib/util.d.ts.map +1 -0
  582. package/dist/esm/src/shared/lib/util.js +128 -0
  583. package/dist/esm/src/shared/lib/util.js.map +1 -0
  584. package/dist/esm/src/shared/providers/AuthContext.d.ts +10 -0
  585. package/dist/esm/src/shared/providers/AuthContext.d.ts.map +1 -0
  586. package/dist/esm/src/shared/providers/AuthContext.js +3 -0
  587. package/dist/esm/src/shared/providers/AuthContext.js.map +1 -0
  588. package/dist/esm/src/shared/providers/AuthProvider.d.ts +18 -0
  589. package/dist/esm/src/shared/providers/AuthProvider.d.ts.map +1 -0
  590. package/dist/esm/src/shared/providers/AuthProvider.js +245 -0
  591. package/dist/esm/src/shared/providers/AuthProvider.js.map +1 -0
  592. package/dist/esm/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  593. package/dist/esm/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  594. package/dist/esm/src/shared/providers/CivicAuthProvider.js +17 -0
  595. package/dist/esm/src/shared/providers/CivicAuthProvider.js.map +1 -0
  596. package/dist/esm/src/shared/providers/ConfigProvider.d.ts +21 -0
  597. package/dist/esm/src/shared/providers/ConfigProvider.d.ts.map +1 -0
  598. package/dist/esm/src/shared/providers/ConfigProvider.js +19 -0
  599. package/dist/esm/src/shared/providers/ConfigProvider.js.map +1 -0
  600. package/dist/esm/src/shared/providers/IframeProvider.d.ts +16 -0
  601. package/dist/esm/src/shared/providers/IframeProvider.d.ts.map +1 -0
  602. package/dist/esm/src/shared/providers/IframeProvider.js +11 -0
  603. package/dist/esm/src/shared/providers/IframeProvider.js.map +1 -0
  604. package/dist/esm/src/shared/providers/SessionProvider.d.ts +13 -0
  605. package/dist/esm/src/shared/providers/SessionProvider.d.ts.map +1 -0
  606. package/dist/esm/src/shared/providers/SessionProvider.js +13 -0
  607. package/dist/esm/src/shared/providers/SessionProvider.js.map +1 -0
  608. package/dist/esm/src/shared/providers/TokenProvider.d.ts +18 -0
  609. package/dist/esm/src/shared/providers/TokenProvider.d.ts.map +1 -0
  610. package/dist/esm/src/shared/providers/TokenProvider.js +53 -0
  611. package/dist/esm/src/shared/providers/TokenProvider.js.map +1 -0
  612. package/dist/esm/src/shared/providers/UserProvider.d.ts +18 -0
  613. package/dist/esm/src/shared/providers/UserProvider.d.ts.map +1 -0
  614. package/dist/esm/src/shared/providers/UserProvider.js +38 -0
  615. package/dist/esm/src/shared/providers/UserProvider.js.map +1 -0
  616. package/dist/esm/src/shared/session.d.ts +3 -0
  617. package/dist/esm/src/shared/session.d.ts.map +1 -0
  618. package/dist/esm/src/shared/session.js +10 -0
  619. package/dist/esm/src/shared/session.js.map +1 -0
  620. package/dist/esm/src/shared/storage.d.ts +25 -0
  621. package/dist/esm/src/shared/storage.d.ts.map +1 -0
  622. package/dist/esm/src/shared/storage.js +17 -0
  623. package/dist/esm/src/shared/storage.js.map +1 -0
  624. package/dist/esm/src/shared/types.d.ts +21 -0
  625. package/dist/esm/src/shared/types.d.ts.map +1 -0
  626. package/dist/esm/src/shared/types.js +15 -0
  627. package/dist/esm/src/shared/types.js.map +1 -0
  628. package/dist/esm/src/shared/util.d.ts +33 -0
  629. package/dist/esm/src/shared/util.d.ts.map +1 -0
  630. package/dist/esm/src/shared/util.js +128 -0
  631. package/dist/esm/src/shared/util.js.map +1 -0
  632. package/dist/esm/src/types.d.ts +146 -0
  633. package/dist/esm/src/types.d.ts.map +1 -0
  634. package/dist/esm/src/types.js +2 -0
  635. package/dist/esm/src/types.js.map +1 -0
  636. package/dist/esm/src/utils.d.ts +17 -0
  637. package/dist/esm/src/utils.d.ts.map +1 -0
  638. package/dist/esm/src/utils.js +48 -0
  639. package/dist/esm/src/utils.js.map +1 -0
  640. package/dist/esm/src/worker/index.d.ts +2 -0
  641. package/dist/esm/src/worker/index.d.ts.map +1 -0
  642. package/dist/esm/src/worker/index.js +2 -0
  643. package/dist/esm/src/worker/index.js.map +1 -0
  644. package/dist/esm/tsconfig.build.tsbuildinfo +1 -0
  645. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -0
  646. package/package.json +115 -0
  647. package/postcss.config.cjs +6 -0
  648. package/src/browser/storage.ts +11 -0
  649. package/src/config.ts +6 -0
  650. package/src/constants.ts +29 -0
  651. package/src/index.ts +18 -0
  652. package/src/lib/cookies.ts +28 -0
  653. package/src/lib/jwt.ts +15 -0
  654. package/src/lib/logger.ts +72 -0
  655. package/src/lib/oauth.ts +83 -0
  656. package/src/lib/postMessage.ts +22 -0
  657. package/src/lib/windowUtil.ts +29 -0
  658. package/src/nextjs/GetUser.ts +22 -0
  659. package/src/nextjs/client/index.ts +4 -0
  660. package/src/nextjs/config.ts +203 -0
  661. package/src/nextjs/cookies.ts +166 -0
  662. package/src/nextjs/hooks/index.ts +1 -0
  663. package/src/nextjs/hooks/useTokenCookie.ts +41 -0
  664. package/src/nextjs/hooks/useUserCookie.ts +41 -0
  665. package/src/nextjs/index.ts +24 -0
  666. package/src/nextjs/middleware/index.ts +1 -0
  667. package/src/nextjs/middleware.ts +155 -0
  668. package/src/nextjs/providers/NextAuthProvider.tsx +89 -0
  669. package/src/nextjs/routeHandler.ts +276 -0
  670. package/src/nextjs/utils.ts +10 -0
  671. package/src/reactjs/components/SignInButton.tsx +30 -0
  672. package/src/reactjs/components/SignOutButton.tsx +22 -0
  673. package/src/reactjs/components/UserButton.tsx +153 -0
  674. package/src/reactjs/components/index.ts +5 -0
  675. package/src/reactjs/hooks/index.ts +8 -0
  676. package/src/reactjs/hooks/useAuth.ts +15 -0
  677. package/src/reactjs/hooks/useUser.ts +20 -0
  678. package/src/reactjs/index.ts +19 -0
  679. package/src/reactjs/providers/index.ts +27 -0
  680. package/src/server/ServerAuthenticationResolver.ts +107 -0
  681. package/src/server/config.ts +17 -0
  682. package/src/server/index.ts +12 -0
  683. package/src/server/login.ts +58 -0
  684. package/src/server/refresh.ts +23 -0
  685. package/src/services/AuthenticationService.ts +334 -0
  686. package/src/services/PKCE.ts +43 -0
  687. package/src/services/types.ts +54 -0
  688. package/src/shared/components/CivicAuthIframe.tsx +26 -0
  689. package/src/shared/components/CivicAuthIframeContainer.tsx +150 -0
  690. package/src/shared/components/CloseIcon.tsx +21 -0
  691. package/src/shared/components/LoadingIcon.tsx +25 -0
  692. package/src/shared/hooks/index.ts +4 -0
  693. package/src/shared/hooks/useAuth.ts +15 -0
  694. package/src/shared/hooks/useConfig.ts +14 -0
  695. package/src/shared/hooks/useIframe.ts +14 -0
  696. package/src/shared/hooks/useSession.ts +14 -0
  697. package/src/shared/hooks/useToken.ts +15 -0
  698. package/src/shared/lib/GenericAuthenticationRefresher.ts +75 -0
  699. package/src/shared/lib/UserSession.ts +25 -0
  700. package/src/shared/lib/session.ts +11 -0
  701. package/src/shared/lib/storage.ts +40 -0
  702. package/src/shared/lib/types.ts +25 -0
  703. package/src/shared/lib/util.ts +217 -0
  704. package/src/shared/providers/AuthContext.tsx +11 -0
  705. package/src/shared/providers/AuthProvider.tsx +364 -0
  706. package/src/shared/providers/CivicAuthProvider.tsx +34 -0
  707. package/src/shared/providers/ConfigProvider.tsx +50 -0
  708. package/src/shared/providers/IframeProvider.tsx +34 -0
  709. package/src/shared/providers/SessionProvider.tsx +29 -0
  710. package/src/shared/providers/TokenProvider.tsx +78 -0
  711. package/src/shared/providers/UserProvider.tsx +80 -0
  712. package/src/styles.css +3 -0
  713. package/src/types.ts +227 -0
  714. package/src/utils.ts +65 -0
  715. package/tailwind.config.js +8 -0
  716. package/test/integration/sdk.test.tsx +266 -0
  717. package/test/support/fixtures.ts +56 -0
  718. package/test/support/tokens.json +26 -0
  719. package/test/unit/lib/oauth.test.ts +72 -0
  720. package/test/unit/logger.test.ts +175 -0
  721. package/test/unit/nextjs/NextAuthProvider.test.tsx +38 -0
  722. package/test/unit/nextjs/config.test.ts +201 -0
  723. package/test/unit/nextjs/getUser.test.ts +41 -0
  724. package/test/unit/nextjs/middleware.test.ts +138 -0
  725. package/test/unit/nextjs/routeHandler.test.ts +369 -0
  726. package/test/unit/nextjs/utils.test.ts +26 -0
  727. package/test/unit/publicApi/__snapshots__/apiSnapshot.test.ts.snap +19 -0
  728. package/test/unit/publicApi/apiSnapshot.test.ts +11 -0
  729. package/test/unit/react/components/SignInButton.test.tsx +50 -0
  730. package/test/unit/react/components/SignOutButton.test.tsx +49 -0
  731. package/test/unit/server/login.test.ts +179 -0
  732. package/test/unit/server/session.test.ts +51 -0
  733. package/test/unit/services/AuthenticationService.test.ts +152 -0
  734. package/test/unit/services/ServerAuthenticationResolver.test.ts +110 -0
  735. package/test/unit/shared/GenericAuthenticationRefresher.test.ts +89 -0
  736. package/test/unit/shared/UserSession.test.ts +42 -0
  737. package/test/unit/shared/components/CivicAuthIframeContainer.test.tsx +154 -0
  738. package/test/unit/shared/storage.test.ts +67 -0
  739. package/test/unit/utils.test.ts +48 -0
  740. package/tsconfig.build.json +5 -0
  741. package/tsconfig.cjs.json +8 -0
  742. package/tsconfig.esm.json +7 -0
  743. package/tsconfig.json +42 -0
  744. package/vitest.config.ts +41 -0
@@ -0,0 +1,203 @@
1
+ import { NextResponse } from "next/server.js";
2
+ import { revalidatePath } from "next/cache.js";
3
+ import { resolveAuthConfig } from "../nextjs/config.js";
4
+ import { loggers } from "../lib/logger.js";
5
+ import { clearAuthCookies, NextjsClientStorage, NextjsCookieStorage, } from "../nextjs/cookies.js";
6
+ import { GenericPublicClientPKCEProducer } from "../services/PKCE.js";
7
+ import { resolveOAuthAccessCode } from "../server/login.js";
8
+ import { getUser } from "../shared/lib/session.js";
9
+ import { resolveCallbackUrl } from "../nextjs/utils.js";
10
+ import { GenericUserSession } from "../shared/lib/UserSession.js";
11
+ import { TOKEN_EXCHANGE_SUCCESS_TEXT, TOKEN_EXCHANGE_TRIGGER_TEXT, } from "../constants.js";
12
+ import { serverTokenExchangeFromState } from "../lib/oauth.js";
13
+ import { cookies } from "next/headers.js";
14
+ import { CodeVerifier } from "../shared/lib/types.js";
15
+ const logger = loggers.nextjs.handlers.auth;
16
+ class AuthError extends Error {
17
+ status;
18
+ constructor(message, status = 401) {
19
+ super(message);
20
+ this.status = status;
21
+ this.name = "AuthError";
22
+ }
23
+ }
24
+ /**
25
+ * create a code verifier and challenge for PKCE
26
+ * saving the verifier in a cookie for later use
27
+ * @returns {Promise<NextResponse>}
28
+ */
29
+ async function handleChallenge(config) {
30
+ const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});
31
+ const pkceProducer = new GenericPublicClientPKCEProducer(cookieStorage);
32
+ const challenge = await pkceProducer.getCodeChallenge();
33
+ return NextResponse.json({ status: "success", challenge });
34
+ }
35
+ async function performTokenExchangeAndSetCookies(request, config, code, state) {
36
+ const resolvedConfigs = resolveAuthConfig(config);
37
+ const cookieStorage = new NextjsCookieStorage(resolvedConfigs.cookies.tokens);
38
+ const callbackUrl = resolveCallbackUrl(resolvedConfigs, request.url);
39
+ try {
40
+ await resolveOAuthAccessCode(code, state, cookieStorage, {
41
+ ...resolvedConfigs,
42
+ redirectUrl: callbackUrl,
43
+ });
44
+ }
45
+ catch (error) {
46
+ logger.error("Token exchange failed:", error);
47
+ throw new AuthError("Failed to authenticate user", 401);
48
+ }
49
+ const user = await getUser(cookieStorage);
50
+ if (!user) {
51
+ throw new AuthError("Failed to get user info", 401);
52
+ }
53
+ const clientStorage = new NextjsClientStorage();
54
+ const userSession = new GenericUserSession(clientStorage);
55
+ userSession.set(user);
56
+ }
57
+ async function handleCallback(request, config) {
58
+ const resolvedConfigs = resolveAuthConfig(config);
59
+ console.log("handleCallback", { request, resolvedConfigs });
60
+ const code = request.nextUrl.searchParams.get("code");
61
+ const state = request.nextUrl.searchParams.get("state") || "";
62
+ if (!code || !state)
63
+ throw new AuthError("Bad parameters", 400);
64
+ // If we have a code_verifier cookie, we can do a token exchange.
65
+ // Otherwise, just render an empty page.
66
+ // The initial redirect back from the auth server does not send cookies, because the redirect is from a 3rd-party domain.
67
+ // The client will make an additional call to this route with cookies included, at which point we do the token exchange.
68
+ console.log("handleCallback", { code, state, cookies: cookies() });
69
+ if (!request.cookies.get(CodeVerifier.COOKIE_NAME)) {
70
+ console.log("handleCallback no code_verifier found", {
71
+ state,
72
+ serverTokenExchange: serverTokenExchangeFromState(`${state}`),
73
+ });
74
+ let response = new NextResponse(`<html><body><span style="display:none">${TOKEN_EXCHANGE_TRIGGER_TEXT}</span></body></html>`);
75
+ // in server-side token exchange mode we need to launch a page that will trigger the token exchange
76
+ // from the same domain, allowing it access to the code_verifier cookie
77
+ // we only need to do this in redirect mode, as the iframe already triggers a client-side token exchange
78
+ // if no code-verifier cookie is found
79
+ if (state && serverTokenExchangeFromState(state)) {
80
+ console.log("handleCallback serverTokenExchangeFromState, launching redirect page...", {
81
+ requestUrl: request.url,
82
+ configCallbackUrl: resolvedConfigs.callbackUrl,
83
+ });
84
+ // we need to replace the URL with resolved config in case the server is hosted
85
+ // behind a reverse proxy or load balancer
86
+ const requestUrl = new URL(request.url);
87
+ const fetchUrl = `${resolvedConfigs.callbackUrl}?${requestUrl.searchParams.toString()}&sameDomainServerTokenExchange=true`;
88
+ response = new NextResponse(`<html>
89
+ <body>
90
+ <span style="display:none">
91
+ <script>
92
+ window.onload = function () {
93
+ fetch('${fetchUrl}').then((response) => {
94
+ response.json().then((jsonResponse) => {
95
+ console.log('fetch jsonResponse', jsonResponse);
96
+ if (jsonResponse.redirectUrl) {
97
+ console.log('handleCallback serverTokenExchangeFromState, redirecting');
98
+ window.location.href = jsonResponse.redirectUrl;
99
+ }
100
+ });
101
+ });
102
+ };
103
+ </script>
104
+ </span>
105
+ </body>
106
+ </html>
107
+ `);
108
+ }
109
+ response.headers.set("Content-Type", "text/html; charset=utf-8");
110
+ console.log(`handleCallback no code_verifier found, returning ${TOKEN_EXCHANGE_TRIGGER_TEXT}`);
111
+ return response;
112
+ }
113
+ await performTokenExchangeAndSetCookies(request, resolvedConfigs, code, state);
114
+ if (request.url.includes("sameDomainServerTokenExchange=true")) {
115
+ console.log("handleCallback sameDomainServerTokenExchange = true, returnining redirectUrl", resolvedConfigs.appUrl);
116
+ return NextResponse.json({
117
+ status: "success",
118
+ redirectUrl: resolvedConfigs.appUrl,
119
+ });
120
+ }
121
+ // this is the case where a 'normal' redirect is happening
122
+ if (serverTokenExchangeFromState(state)) {
123
+ console.log("handleCallback serverTokenExchangeFromState, redirect to config.appUrl", resolvedConfigs.appUrl);
124
+ if (!resolvedConfigs.appUrl) {
125
+ throw new Error("appUrl not defined in config. Cannot redirect.");
126
+ }
127
+ return NextResponse.redirect(`${resolvedConfigs.appUrl}`);
128
+ }
129
+ // return an empty HTML response so the iframe doesn't show any response
130
+ // in the short moment between the redirect and the parent window
131
+ // acknowledging the redirect and closing the iframe
132
+ const response = new NextResponse(`<html><span style="display:none">${TOKEN_EXCHANGE_SUCCESS_TEXT}</span></html>`);
133
+ response.headers.set("Content-Type", "text/html; charset=utf-8");
134
+ return response;
135
+ }
136
+ /**
137
+ * If redirectPath is an absolute path, return it as-is.
138
+ * Otherwise for relative paths, append it to the current domain.
139
+ * @param redirectPath
140
+ * @returns
141
+ */
142
+ const getAbsoluteRedirectPath = (redirectPath, currentBasePath) => {
143
+ // Check if the redirectPath is an absolute URL
144
+ if (/^(https?:\/\/|www\.).+/i.test(redirectPath)) {
145
+ return redirectPath; // Return as-is if it's an absolute URL
146
+ }
147
+ return new URL(redirectPath, currentBasePath).href;
148
+ };
149
+ export async function handleLogout(request, config) {
150
+ const resolvedConfigs = resolveAuthConfig(config);
151
+ const defaultRedirectPath = resolvedConfigs.loginUrl ?? "/";
152
+ const redirectTarget = new URL(request.url).searchParams.get("redirect") || defaultRedirectPath;
153
+ const isAbsoluteRedirect = /^(https?:\/\/|www\.).+/i.test(redirectTarget);
154
+ const finalRedirectUrl = getAbsoluteRedirectPath(redirectTarget, new URL(resolvedConfigs.appUrl ?? request.url).origin);
155
+ const response = NextResponse.redirect(finalRedirectUrl);
156
+ clearAuthCookies(config);
157
+ try {
158
+ revalidatePath(isAbsoluteRedirect ? finalRedirectUrl : redirectTarget);
159
+ }
160
+ catch (error) {
161
+ logger.warn("Failed to revalidate path after logout:", error);
162
+ }
163
+ return response;
164
+ }
165
+ /**
166
+ * Creates an authentication handler for Next.js API routes
167
+ *
168
+ * Usage:
169
+ * ```ts
170
+ * // app/api/auth/[...civicauth]/route.ts
171
+ * import { handler } from '@civic/auth/nextjs'
172
+ * export const GET = handler({
173
+ * // optional config overrides
174
+ * })
175
+ * ```
176
+ */
177
+ export const handler = (authConfig = {}) => async (request) => {
178
+ const config = resolveAuthConfig(authConfig);
179
+ try {
180
+ const pathname = request.nextUrl.pathname;
181
+ const pathSegments = pathname.split("/");
182
+ const lastSegment = pathSegments[pathSegments.length - 1];
183
+ switch (lastSegment) {
184
+ case "challenge":
185
+ return await handleChallenge(config);
186
+ case "callback":
187
+ return await handleCallback(request, config);
188
+ case "logout":
189
+ return await handleLogout(request, config);
190
+ default:
191
+ throw new AuthError(`Invalid auth route: ${pathname}`, 404);
192
+ }
193
+ }
194
+ catch (error) {
195
+ logger.error("Auth handler error:", error);
196
+ const status = error instanceof AuthError ? error.status : 500;
197
+ const message = error instanceof Error ? error.message : "Authentication failed";
198
+ const response = NextResponse.json({ error: message }, { status });
199
+ clearAuthCookies(config);
200
+ return response;
201
+ }
202
+ };
203
+ //# sourceMappingURL=routeHandler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"routeHandler.js","sourceRoot":"","sources":["../../../../src/nextjs/routeHandler.ts"],"names":[],"mappings":"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","sourcesContent":["import type { NextRequest } from \"next/server.js\";\nimport { NextResponse } from \"next/server.js\";\nimport { revalidatePath } from \"next/cache.js\";\nimport type { AuthConfig } from \"@/nextjs/config.js\";\nimport { resolveAuthConfig } from \"@/nextjs/config.js\";\nimport { loggers } from \"@/lib/logger.js\";\nimport {\n clearAuthCookies,\n NextjsClientStorage,\n NextjsCookieStorage,\n} from \"@/nextjs/cookies.js\";\nimport { GenericPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport { resolveOAuthAccessCode } from \"@/server/login.js\";\nimport { getUser } from \"@/shared/lib/session.js\";\nimport { resolveCallbackUrl } from \"@/nextjs/utils.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport {\n TOKEN_EXCHANGE_SUCCESS_TEXT,\n TOKEN_EXCHANGE_TRIGGER_TEXT,\n} from \"@/constants.js\";\nimport { serverTokenExchangeFromState } from \"@/lib/oauth.js\";\nimport { cookies } from \"next/headers.js\";\nimport { CodeVerifier } from \"@/shared/lib/types.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\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(config: AuthConfig): Promise<NextResponse> {\n const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});\n const pkceProducer = new GenericPublicClientPKCEProducer(cookieStorage);\n\n const challenge = await pkceProducer.getCodeChallenge();\n\n return NextResponse.json({ status: \"success\", challenge });\n}\n\nasync function performTokenExchangeAndSetCookies(\n request: NextRequest,\n config: AuthConfig,\n code: string,\n state: string,\n) {\n const resolvedConfigs = resolveAuthConfig(config);\n const cookieStorage = new NextjsCookieStorage(resolvedConfigs.cookies.tokens);\n\n const callbackUrl = resolveCallbackUrl(resolvedConfigs, request.url);\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(cookieStorage);\n if (!user) {\n throw new AuthError(\"Failed to get user info\", 401);\n }\n\n const clientStorage = new NextjsClientStorage();\n const userSession = new GenericUserSession(clientStorage);\n userSession.set(user);\n}\nasync function handleCallback(\n request: NextRequest,\n config: AuthConfig,\n): Promise<NextResponse> {\n const resolvedConfigs = resolveAuthConfig(config);\n console.log(\"handleCallback\", { request, resolvedConfigs });\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 // If we have a code_verifier cookie, 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 console.log(\"handleCallback\", { code, state, cookies: cookies() });\n if (!request.cookies.get(CodeVerifier.COOKIE_NAME)) {\n console.log(\"handleCallback no code_verifier found\", {\n state,\n serverTokenExchange: serverTokenExchangeFromState(`${state}`),\n });\n let response = new NextResponse(\n `<html><body><span style=\"display:none\">${TOKEN_EXCHANGE_TRIGGER_TEXT}</span></body></html>`,\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 console.log(\n \"handleCallback serverTokenExchangeFromState, launching redirect page...\",\n {\n requestUrl: request.url,\n configCallbackUrl: resolvedConfigs.callbackUrl,\n },\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 = `${resolvedConfigs.callbackUrl}?${requestUrl.searchParams.toString()}&sameDomainServerTokenExchange=true`;\n response = new NextResponse(\n `<html>\n <body>\n <span style=\"display:none\">\n <script>\n window.onload = function () {\n fetch('${fetchUrl}').then((response) => {\n response.json().then((jsonResponse) => {\n console.log('fetch jsonResponse', jsonResponse);\n if (jsonResponse.redirectUrl) {\n console.log('handleCallback serverTokenExchangeFromState, redirecting');\n window.location.href = jsonResponse.redirectUrl;\n }\n });\n });\n };\n </script>\n </span>\n </body>\n </html>\n `,\n );\n }\n response.headers.set(\"Content-Type\", \"text/html; charset=utf-8\");\n console.log(\n `handleCallback no code_verifier found, returning ${TOKEN_EXCHANGE_TRIGGER_TEXT}`,\n );\n return response;\n }\n\n await performTokenExchangeAndSetCookies(\n request,\n resolvedConfigs,\n code,\n state,\n );\n\n if (request.url.includes(\"sameDomainServerTokenExchange=true\")) {\n console.log(\n \"handleCallback sameDomainServerTokenExchange = true, returnining redirectUrl\",\n resolvedConfigs.appUrl,\n );\n return NextResponse.json({\n status: \"success\",\n redirectUrl: resolvedConfigs.appUrl,\n });\n }\n\n // this is the case where a 'normal' redirect is happening\n if (serverTokenExchangeFromState(state)) {\n console.log(\n \"handleCallback serverTokenExchangeFromState, redirect to config.appUrl\",\n resolvedConfigs.appUrl,\n );\n if (!resolvedConfigs.appUrl) {\n throw new Error(\"appUrl not defined in config. Cannot redirect.\");\n }\n return NextResponse.redirect(`${resolvedConfigs.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><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 * @returns\n */\nconst getAbsoluteRedirectPath = (\n redirectPath: string,\n currentBasePath: string,\n) => {\n // Check if the redirectPath is an absolute URL\n if (/^(https?:\\/\\/|www\\.).+/i.test(redirectPath)) {\n return redirectPath; // Return as-is if it's an absolute URL\n }\n return new URL(redirectPath, currentBasePath).href;\n};\n\nexport async function handleLogout(\n request: NextRequest,\n config: AuthConfig,\n): Promise<NextResponse> {\n const resolvedConfigs = resolveAuthConfig(config);\n const defaultRedirectPath = resolvedConfigs.loginUrl ?? \"/\";\n const redirectTarget =\n new URL(request.url).searchParams.get(\"redirect\") || defaultRedirectPath;\n const isAbsoluteRedirect = /^(https?:\\/\\/|www\\.).+/i.test(redirectTarget);\n const finalRedirectUrl = getAbsoluteRedirectPath(\n redirectTarget,\n new URL(resolvedConfigs.appUrl ?? request.url).origin,\n );\n\n const response = NextResponse.redirect(finalRedirectUrl);\n\n clearAuthCookies(config);\n\n try {\n revalidatePath(isAbsoluteRedirect ? finalRedirectUrl : redirectTarget);\n } catch (error) {\n logger.warn(\"Failed to revalidate path after logout:\", error);\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(config);\n case \"callback\":\n return await handleCallback(request, config);\n case \"logout\":\n return await handleLogout(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 clearAuthCookies(config);\n return response;\n }\n };\n"]}
@@ -0,0 +1,3 @@
1
+ import type { AuthConfigWithDefaults } from "../nextjs/config.js";
2
+ export declare const resolveCallbackUrl: (config: AuthConfigWithDefaults, alternativeUrl?: string) => string;
3
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
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,mBACb,MAAM,KACtB,MAIF,CAAC"}
@@ -0,0 +1,6 @@
1
+ export const resolveCallbackUrl = (config, alternativeUrl) => {
2
+ const baseUrl = config.appUrl ?? alternativeUrl;
3
+ const callbackUrl = new URL(config?.callbackUrl, baseUrl).toString();
4
+ return callbackUrl.toString();
5
+ };
6
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/nextjs/utils.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,MAA8B,EAC9B,cAAuB,EACf,EAAE;IACV,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,IAAI,cAAc,CAAC;IAChD,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 alternativeUrl?: string,\n): string => {\n const baseUrl = config.appUrl ?? alternativeUrl;\n const callbackUrl = new URL(config?.callbackUrl, baseUrl).toString();\n return callbackUrl.toString();\n};\n"]}
@@ -0,0 +1,2 @@
1
+ export { authMiddleware, auth, withAuth } from "../../nextjs/middleware.js";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/nextjs/worker/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { authMiddleware, auth, withAuth } from "../../nextjs/middleware.js";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/nextjs/worker/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC","sourcesContent":["export { authMiddleware, auth, withAuth } from \"@/nextjs/middleware.js\";"]}
@@ -0,0 +1,7 @@
1
+ import type { ReactNode } from "react";
2
+ import React from "react";
3
+ declare const NextLogOut: ({ children }: {
4
+ children: ReactNode;
5
+ }) => React.JSX.Element;
6
+ export { NextLogOut };
7
+ //# sourceMappingURL=NextLogOut.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NextLogOut.d.ts","sourceRoot":"","sources":["../../../../../src/reactjs/components/NextLogOut.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,QAAA,MAAM,UAAU,iBAAkB;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,sBAKxD,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Trigger a backend API that logs the user out and then redirects to the homepage (TODO parameterize the redirect)
3
+ */
4
+ import { resolveAuthConfig } from "../../nextjs/config.js";
5
+ import React from "react";
6
+ const NextLogOut = ({ children }) => {
7
+ const config = resolveAuthConfig();
8
+ const logoutUrl = `${config.logoutUrl}`;
9
+ return React.createElement("a", { href: logoutUrl }, children);
10
+ };
11
+ export { NextLogOut };
12
+ //# sourceMappingURL=NextLogOut.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NextLogOut.js","sourceRoot":"","sources":["../../../../../src/reactjs/components/NextLogOut.tsx"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAEvD,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,UAAU,GAAG,CAAC,EAAE,QAAQ,EAA2B,EAAE,EAAE;IAC3D,MAAM,MAAM,GAAG,iBAAiB,EAAE,CAAC;IACnC,MAAM,SAAS,GAAG,GAAG,MAAM,CAAC,SAAS,EAAE,CAAC;IAExC,OAAO,2BAAG,IAAI,EAAE,SAAS,IAAG,QAAQ,CAAK,CAAC;AAC5C,CAAC,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC","sourcesContent":["/**\n * Trigger a backend API that logs the user out and then redirects to the homepage (TODO parameterize the redirect)\n */\nimport { resolveAuthConfig } from \"@/nextjs/config.js\";\nimport type { ReactNode } from \"react\";\nimport React from \"react\";\n\nconst NextLogOut = ({ children }: { children: ReactNode }) => {\n const config = resolveAuthConfig();\n const logoutUrl = `${config.logoutUrl}`;\n\n return <a href={logoutUrl}>{children}</a>;\n};\n\nexport { NextLogOut };\n"]}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import type { DisplayMode } from "../../types.js";
3
+ declare const SignInButton: ({ displayMode, className, }: {
4
+ displayMode?: DisplayMode;
5
+ className?: string;
6
+ }) => React.JSX.Element;
7
+ export { SignInButton };
8
+ //# sourceMappingURL=SignInButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SignInButton.d.ts","sourceRoot":"","sources":["../../../../../src/reactjs/components/SignInButton.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAG9C,QAAA,MAAM,YAAY,gCAGf;IACD,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,sBAeA,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,10 @@
1
+ "use client";
2
+ import React from "react";
3
+ import { cn } from "../../utils.js";
4
+ import { useUser } from "../../reactjs/hooks/useUser.js";
5
+ const SignInButton = ({ displayMode, className, }) => {
6
+ const { signIn } = useUser();
7
+ return (React.createElement("button", { "data-testid": "sign-in-button", className: cn("cac-rounded-full cac-border cac-border-neutral-500 cac-px-3 cac-py-2 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50", className), onClick: () => signIn(displayMode) }, "Sign In"));
8
+ };
9
+ export { SignInButton };
10
+ //# sourceMappingURL=SignInButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SignInButton.js","sourceRoot":"","sources":["../../../../../src/reactjs/components/SignInButton.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,EAAE,EAAE,MAAM,YAAY,CAAC;AAEhC,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AAErD,MAAM,YAAY,GAAG,CAAC,EACpB,WAAW,EACX,SAAS,GAIV,EAAE,EAAE;IACH,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,EAAE,CAAC;IAE7B,OAAO,CACL,+CACc,gBAAgB,EAC5B,SAAS,EAAE,EAAE,CACX,6IAA6I,EAC7I,SAAS,CACV,EACD,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,cAG3B,CACV,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport { cn } from \"@/utils.js\";\nimport type { DisplayMode } from \"@/types.js\";\nimport { useUser } from \"@/reactjs/hooks/useUser.js\";\n\nconst SignInButton = ({\n displayMode,\n className,\n}: {\n displayMode?: DisplayMode;\n className?: string;\n}) => {\n const { signIn } = useUser();\n\n return (\n <button\n data-testid=\"sign-in-button\"\n className={cn(\n \"cac-rounded-full cac-border cac-border-neutral-500 cac-px-3 cac-py-2 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50\",\n className,\n )}\n onClick={() => signIn(displayMode)}\n >\n Sign In\n </button>\n );\n};\n\nexport { SignInButton };\n"]}
@@ -0,0 +1,6 @@
1
+ import React from "react";
2
+ declare const SignOutButton: ({ className }: {
3
+ className?: string;
4
+ }) => React.JSX.Element;
5
+ export { SignOutButton };
6
+ //# sourceMappingURL=SignOutButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SignOutButton.d.ts","sourceRoot":"","sources":["../../../../../src/reactjs/components/SignOutButton.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,QAAA,MAAM,aAAa,kBAAmB;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,sBAc3D,CAAC;AAEF,OAAO,EAAE,aAAa,EAAE,CAAC"}
@@ -0,0 +1,10 @@
1
+ "use client";
2
+ import React from "react";
3
+ import { cn } from "../../utils.js";
4
+ import { useUser } from "../../reactjs/hooks/useUser.js";
5
+ const SignOutButton = ({ className }) => {
6
+ const { signOut } = useUser();
7
+ return (React.createElement("button", { className: cn("cac-rounded-full cac-border cac-border-neutral-500 cac-px-3 cac-py-2 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50", className), onClick: () => signOut() }, "Sign Out"));
8
+ };
9
+ export { SignOutButton };
10
+ //# sourceMappingURL=SignOutButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SignOutButton.js","sourceRoot":"","sources":["../../../../../src/reactjs/components/SignOutButton.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,EAAE,EAAE,MAAM,YAAY,CAAC;AAChC,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AAErD,MAAM,aAAa,GAAG,CAAC,EAAE,SAAS,EAA0B,EAAE,EAAE;IAC9D,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,CAAC;IAE9B,OAAO,CACL,gCACE,SAAS,EAAE,EAAE,CACX,6IAA6I,EAC7I,SAAS,CACV,EACD,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,eAGjB,CACV,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,aAAa,EAAE,CAAC","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport { cn } from \"@/utils.js\";\nimport { useUser } from \"@/reactjs/hooks/useUser.js\";\n\nconst SignOutButton = ({ className }: { className?: string }) => {\n const { signOut } = useUser();\n\n return (\n <button\n className={cn(\n \"cac-rounded-full cac-border cac-border-neutral-500 cac-px-3 cac-py-2 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50\",\n className,\n )}\n onClick={() => signOut()}\n >\n Sign Out\n </button>\n );\n};\n\nexport { SignOutButton };\n"]}
@@ -0,0 +1,8 @@
1
+ import type { DisplayMode } from "../../types.js";
2
+ import React from "react";
3
+ declare const UserButton: ({ displayMode, className, }: {
4
+ displayMode?: DisplayMode;
5
+ className?: string;
6
+ }) => React.JSX.Element;
7
+ export { UserButton };
8
+ //# sourceMappingURL=UserButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserButton.d.ts","sourceRoot":"","sources":["../../../../../src/reactjs/components/UserButton.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,OAAO,KAA2C,MAAM,OAAO,CAAC;AAoChE,QAAA,MAAM,UAAU,gCAGb;IACD,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,sBAwGA,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -0,0 +1,58 @@
1
+ "use client";
2
+ import { useUser } from "../../reactjs/hooks/index.js";
3
+ import { cn } from "../../utils.js";
4
+ import React, { useCallback, useEffect, useState } from "react";
5
+ const ChevronDown = () => (React.createElement("svg", { xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", className: "lucide lucide-chevron-down" },
6
+ React.createElement("path", { d: "m6 9 6 6 6-6" })));
7
+ const ChevronUp = () => (React.createElement("svg", { xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", className: "lucide lucide-chevron-up" },
8
+ React.createElement("path", { d: "m18 15-6-6-6 6" })));
9
+ const UserButton = ({ displayMode, className, }) => {
10
+ const [isOpen, setIsOpen] = useState(false);
11
+ const { user, signIn, signOut } = useUser();
12
+ const handleClickOutside = useCallback((event) => {
13
+ const target = event.target;
14
+ if (!target.closest("#civic-dropdown-container")) {
15
+ setIsOpen(false);
16
+ }
17
+ }, []);
18
+ const handleSignOut = useCallback(async () => {
19
+ signOut();
20
+ setIsOpen(false);
21
+ }, [signOut]);
22
+ const handleSignIn = useCallback(async () => {
23
+ await signIn(displayMode);
24
+ setIsOpen(false);
25
+ }, [signIn, displayMode]);
26
+ const handleEscape = useCallback((event) => {
27
+ if (event.key === "Escape") {
28
+ setIsOpen(false);
29
+ }
30
+ }, []);
31
+ useEffect(() => {
32
+ if (isOpen) {
33
+ window.addEventListener("click", handleClickOutside);
34
+ window.addEventListener("keydown", handleEscape);
35
+ }
36
+ return () => {
37
+ window.removeEventListener("click", handleClickOutside);
38
+ window.removeEventListener("keydown", handleEscape);
39
+ };
40
+ }, [handleClickOutside, handleEscape, isOpen]);
41
+ if (user) {
42
+ return (React.createElement("div", { className: "cac-relative", id: "civic-dropdown-container" },
43
+ React.createElement("button", { className: cn("cac-flex cac-w-full cac-items-center cac-justify-between cac-gap-2 cac-rounded-full cac-border cac-border-neutral-500 cac-px-3 cac-py-2 cac-text-neutral-500 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50", className), onClick: () => setIsOpen((isOpen) => !isOpen) },
44
+ user?.picture ? (React.createElement("span", { className: "cac-relative cac-flex cac-h-10 cac-w-10 cac-shrink-0 cac-gap-2 cac-overflow-hidden cac-rounded-full" },
45
+ React.createElement("img", { className: "cac-h-full cac-w-full cac-object-cover", src: user.picture, alt: user?.name || user?.email }))) : (React.createElement("div", null)),
46
+ React.createElement("span", null, user?.name || user?.email),
47
+ isOpen ? React.createElement(ChevronUp, null) : React.createElement(ChevronDown, null)),
48
+ React.createElement("div", { className: isOpen
49
+ ? "cac-absolute cac-right-0 cac-mt-2 cac-w-full cac-rounded-lg cac-bg-white cac-py-2 cac-text-neutral-500 cac-shadow-xl"
50
+ : "cac-hidden" },
51
+ React.createElement("ul", null,
52
+ React.createElement("li", null,
53
+ React.createElement("button", { className: "cac-block cac-w-full cac-px-4 cac-py-2 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50", onClick: handleSignOut }, "Logout"))))));
54
+ }
55
+ return (React.createElement("button", { "data-testid": "sign-in-button", className: cn("cac-rounded-full cac-border cac-border-neutral-500 cac-px-3 cac-py-2 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50", className), onClick: handleSignIn }, "Sign in"));
56
+ };
57
+ export { UserButton };
58
+ //# sourceMappingURL=UserButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserButton.js","sourceRoot":"","sources":["../../../../../src/reactjs/components/UserButton.tsx"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\nimport { useUser } from \"@/reactjs/hooks/index.js\";\nimport type { DisplayMode } from \"@/types.js\";\nimport { cn } from \"@/utils.js\";\nimport React, { useCallback, useEffect, useState } from \"react\";\n\nconst ChevronDown = () => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className=\"lucide lucide-chevron-down\"\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n);\n\nconst ChevronUp = () => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className=\"lucide lucide-chevron-up\"\n >\n <path d=\"m18 15-6-6-6 6\" />\n </svg>\n);\n\nconst UserButton = ({\n displayMode,\n className,\n}: {\n displayMode?: DisplayMode;\n className?: string;\n}) => {\n const [isOpen, setIsOpen] = useState(false);\n const { user, signIn, signOut } = useUser();\n\n const handleClickOutside = useCallback((event: MouseEvent) => {\n const target = event.target as HTMLElement;\n\n if (!target.closest(\"#civic-dropdown-container\")) {\n setIsOpen(false);\n }\n }, []);\n\n const handleSignOut = useCallback(async () => {\n signOut();\n\n setIsOpen(false);\n }, [signOut]);\n\n const handleSignIn = useCallback(async () => {\n await signIn(displayMode);\n\n setIsOpen(false);\n }, [signIn, displayMode]);\n\n const handleEscape = useCallback((event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n setIsOpen(false);\n }\n }, []);\n\n useEffect(() => {\n if (isOpen) {\n window.addEventListener(\"click\", handleClickOutside);\n\n window.addEventListener(\"keydown\", handleEscape);\n }\n\n return () => {\n window.removeEventListener(\"click\", handleClickOutside);\n\n window.removeEventListener(\"keydown\", handleEscape);\n };\n }, [handleClickOutside, handleEscape, isOpen]);\n\n if (user) {\n return (\n <div className=\"cac-relative\" id=\"civic-dropdown-container\">\n <button\n className={cn(\n \"cac-flex cac-w-full cac-items-center cac-justify-between cac-gap-2 cac-rounded-full cac-border cac-border-neutral-500 cac-px-3 cac-py-2 cac-text-neutral-500 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50\",\n className,\n )}\n onClick={() => setIsOpen((isOpen) => !isOpen)}\n >\n {user?.picture ? (\n <span className=\"cac-relative cac-flex cac-h-10 cac-w-10 cac-shrink-0 cac-gap-2 cac-overflow-hidden cac-rounded-full\">\n <img\n className=\"cac-h-full cac-w-full cac-object-cover\"\n src={user.picture}\n alt={user?.name || user?.email}\n />\n </span>\n ) : (\n <div />\n )}\n\n <span>{user?.name || user?.email}</span>\n\n {isOpen ? <ChevronUp /> : <ChevronDown />}\n </button>\n <div\n className={\n isOpen\n ? \"cac-absolute cac-right-0 cac-mt-2 cac-w-full cac-rounded-lg cac-bg-white cac-py-2 cac-text-neutral-500 cac-shadow-xl\"\n : \"cac-hidden\"\n }\n >\n <ul>\n <li>\n <button\n className=\"cac-block cac-w-full cac-px-4 cac-py-2 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50\"\n onClick={handleSignOut}\n >\n Logout\n </button>\n </li>\n </ul>\n </div>\n </div>\n );\n }\n\n return (\n <button\n data-testid=\"sign-in-button\"\n className={cn(\n \"cac-rounded-full cac-border cac-border-neutral-500 cac-px-3 cac-py-2 cac-transition-colors hover:cac-bg-neutral-200 hover:cac-bg-opacity-50\",\n className,\n )}\n onClick={handleSignIn}\n >\n Sign in\n </button>\n );\n};\n\nexport { UserButton };\n"]}
@@ -0,0 +1,6 @@
1
+ export { CivicAuthIframe } from "../../shared/components/CivicAuthIframe.js";
2
+ export { CivicAuthIframeContainer } from "../../shared/components/CivicAuthIframeContainer.js";
3
+ export { UserButton } from "../../reactjs/components/UserButton.js";
4
+ export { SignInButton } from "../../reactjs/components/SignInButton.js";
5
+ export { SignOutButton } from "../../reactjs/components/SignOutButton.js";
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/reactjs/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAC;AACzE,OAAO,EAAE,wBAAwB,EAAE,MAAM,iDAAiD,CAAC;AAC3F,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,uCAAuC,CAAC"}
@@ -0,0 +1,6 @@
1
+ export { CivicAuthIframe } from "../../shared/components/CivicAuthIframe.js";
2
+ export { CivicAuthIframeContainer } from "../../shared/components/CivicAuthIframeContainer.js";
3
+ export { UserButton } from "../../reactjs/components/UserButton.js";
4
+ export { SignInButton } from "../../reactjs/components/SignInButton.js";
5
+ export { SignOutButton } from "../../reactjs/components/SignOutButton.js";
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/reactjs/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAC;AACzE,OAAO,EAAE,wBAAwB,EAAE,MAAM,iDAAiD,CAAC;AAC3F,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,uCAAuC,CAAC","sourcesContent":["export { CivicAuthIframe } from \"@/shared/components/CivicAuthIframe.js\";\nexport { CivicAuthIframeContainer } from \"@/shared/components/CivicAuthIframeContainer.js\";\nexport { UserButton } from \"@/reactjs/components/UserButton.js\";\nexport { SignInButton } from \"@/reactjs/components/SignInButton.js\";\nexport { SignOutButton } from \"@/reactjs/components/SignOutButton.js\";\n"]}
@@ -0,0 +1,9 @@
1
+ export { useUser } from "../../reactjs/hooks/useUser.js";
2
+ export { useUserCookie } from "../../nextjs/hooks/useUserCookie.js";
3
+ export { useToken } from "../../shared/hooks/useToken.js";
4
+ export { useAuth } from "../../shared/hooks/useAuth.js";
5
+ export { useSession } from "../../shared/hooks/useSession.js";
6
+ export { useConfig } from "../../shared/hooks/useConfig.js";
7
+ export { useTokenCookie } from "../../nextjs/hooks/useTokenCookie.js";
8
+ export { useIframe } from "../../shared/hooks/useIframe.js";
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/reactjs/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC"}
@@ -0,0 +1,9 @@
1
+ export { useUser } from "../../reactjs/hooks/useUser.js";
2
+ export { useUserCookie } from "../../nextjs/hooks/useUserCookie.js";
3
+ export { useToken } from "../../shared/hooks/useToken.js";
4
+ export { useAuth } from "../../shared/hooks/useAuth.js";
5
+ export { useSession } from "../../shared/hooks/useSession.js";
6
+ export { useConfig } from "../../shared/hooks/useConfig.js";
7
+ export { useTokenCookie } from "../../nextjs/hooks/useTokenCookie.js";
8
+ export { useIframe } from "../../shared/hooks/useIframe.js";
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/reactjs/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC","sourcesContent":["export { useUser } from \"@/reactjs/hooks/useUser.js\";\nexport { useUserCookie } from \"@/nextjs/hooks/useUserCookie.js\";\nexport { useToken } from \"@/shared/hooks/useToken.js\";\nexport { useAuth } from \"@/shared/hooks/useAuth.js\";\nexport { useSession } from \"@/shared/hooks/useSession.js\";\nexport { useConfig } from \"@/shared/hooks/useConfig.js\";\nexport { useTokenCookie } from \"@/nextjs/hooks/useTokenCookie.js\";\nexport { useIframe } from \"@/shared/hooks/useIframe.js\";\n"]}
@@ -0,0 +1,3 @@
1
+ declare const useAuth: () => import("../../shared/providers/AuthContext.js").AuthContextType;
2
+ export { useAuth };
3
+ //# sourceMappingURL=useAuth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAuth.d.ts","sourceRoot":"","sources":["../../../../../src/reactjs/hooks/useAuth.ts"],"names":[],"mappings":"AAIA,QAAA,MAAM,OAAO,mEAQZ,CAAC;AAEF,OAAO,EAAE,OAAO,EAAE,CAAC"}
@@ -0,0 +1,12 @@
1
+ "use client";
2
+ import { useContext } from "react";
3
+ import { AuthContext } from "../../shared/providers/AuthContext.js";
4
+ const useAuth = () => {
5
+ const context = useContext(AuthContext);
6
+ if (!context) {
7
+ throw new Error("useAuth must be used within an AuthProvider");
8
+ }
9
+ return context;
10
+ };
11
+ export { useAuth };
12
+ //# sourceMappingURL=useAuth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAuth.js","sourceRoot":"","sources":["../../../../../src/reactjs/hooks/useAuth.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACnC,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAEhE,MAAM,OAAO,GAAG,GAAG,EAAE;IACnB,MAAM,OAAO,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;IAExC,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;IACjE,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,OAAO,EAAE,OAAO,EAAE,CAAC","sourcesContent":["\"use client\";\nimport { useContext } from \"react\";\nimport { AuthContext } from \"@/shared/providers/AuthContext.js\";\n\nconst useAuth = () => {\n const context = useContext(AuthContext);\n\n if (!context) {\n throw new Error(\"useAuth must be used within an AuthProvider\");\n }\n\n return context;\n};\n\nexport { useAuth };\n"]}
@@ -0,0 +1,4 @@
1
+ import { type UserContextType } from "../../shared/providers/UserProvider.js";
2
+ declare const useUser: <T extends Record<string, unknown> = Record<string, never>>() => UserContextType<T>;
3
+ export { useUser };
4
+ //# sourceMappingURL=useUser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useUser.d.ts","sourceRoot":"","sources":["../../../../../src/reactjs/hooks/useUser.ts"],"names":[],"mappings":"AAEA,OAAO,EAEL,KAAK,eAAe,EACrB,MAAM,oCAAoC,CAAC;AAE5C,QAAA,MAAM,OAAO,GACX,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,+BAC9B,eAAe,CAAC,CAAC,CAQrB,CAAC;AAEF,OAAO,EAAE,OAAO,EAAE,CAAC"}
@@ -0,0 +1,12 @@
1
+ "use client";
2
+ import { useContext } from "react";
3
+ import { UserContext, } from "../../shared/providers/UserProvider.js";
4
+ const useUser = () => {
5
+ const context = useContext(UserContext);
6
+ if (!context) {
7
+ throw new Error("useUser must be used within a UserProvider");
8
+ }
9
+ return context;
10
+ };
11
+ export { useUser };
12
+ //# sourceMappingURL=useUser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useUser.js","sourceRoot":"","sources":["../../../../../src/reactjs/hooks/useUser.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACnC,OAAO,EACL,WAAW,GAEZ,MAAM,oCAAoC,CAAC;AAE5C,MAAM,OAAO,GAAG,GAEQ,EAAE;IACxB,MAAM,OAAO,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;IAExC,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;IAChE,CAAC;IAED,OAAO,OAA6B,CAAC;AACvC,CAAC,CAAC;AAEF,OAAO,EAAE,OAAO,EAAE,CAAC","sourcesContent":["\"use client\";\nimport { useContext } from \"react\";\nimport {\n UserContext,\n type UserContextType,\n} from \"@/shared/providers/UserProvider.js\";\n\nconst useUser = <\n T extends Record<string, unknown> = Record<string, never>,\n>(): UserContextType<T> => {\n const context = useContext(UserContext);\n\n if (!context) {\n throw new Error(\"useUser must be used within a UserProvider\");\n }\n\n return context as UserContextType<T>;\n};\n\nexport { useUser };\n"]}
@@ -0,0 +1,6 @@
1
+ export * from "../reactjs/hooks/index.js";
2
+ export { CivicAuthProvider, type CivicAuthProviderProps, } from "../reactjs/providers/index.js";
3
+ export type { AuthContextType, TokenContextType, UserContextType, } from "../reactjs/providers/index.js";
4
+ export { CivicAuthIframeContainer } from "../shared/components/CivicAuthIframeContainer.js";
5
+ export { UserButton, SignInButton, SignOutButton, } from "../reactjs/components/index.js";
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/index.ts"],"names":[],"mappings":"AAGA,cAAc,0BAA0B,CAAC;AACzC,OAAO,EACL,iBAAiB,EACjB,KAAK,sBAAsB,GAC5B,MAAM,8BAA8B,CAAC;AACtC,YAAY,EACV,eAAe,EACf,gBAAgB,EAChB,eAAe,GAChB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,wBAAwB,EAAE,MAAM,iDAAiD,CAAC;AAC3F,OAAO,EACL,UAAU,EACV,YAAY,EACZ,aAAa,GACd,MAAM,+BAA+B,CAAC"}
@@ -0,0 +1,8 @@
1
+ // These are the default exports of the project.
2
+ // They are limited by design to ensure that the public API does not expose any internal implementation details.
3
+ // Do not change this without thinking carefully about the impact on the client-facing public API.
4
+ export * from "../reactjs/hooks/index.js";
5
+ export { CivicAuthProvider, } from "../reactjs/providers/index.js";
6
+ export { CivicAuthIframeContainer } from "../shared/components/CivicAuthIframeContainer.js";
7
+ export { UserButton, SignInButton, SignOutButton, } from "../reactjs/components/index.js";
8
+ //# sourceMappingURL=index.js.map