@civic/auth 0.1.3 → 0.1.4-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 (737) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/README.md +2 -2
  3. package/dist/cjs/browser/storage.d.ts +3 -0
  4. package/dist/cjs/browser/storage.d.ts.map +1 -1
  5. package/dist/cjs/browser/storage.js +8 -0
  6. package/dist/cjs/browser/storage.js.map +1 -1
  7. package/dist/cjs/lib/cookies.d.ts +2 -2
  8. package/dist/cjs/lib/cookies.d.ts.map +1 -1
  9. package/dist/cjs/lib/cookies.js +7 -5
  10. package/dist/cjs/lib/cookies.js.map +1 -1
  11. package/dist/cjs/lib/postMessage.js +1 -1
  12. package/dist/cjs/lib/postMessage.js.map +1 -1
  13. package/dist/cjs/lib/windowUtil.d.ts.map +1 -1
  14. package/dist/cjs/lib/windowUtil.js +1 -0
  15. package/dist/cjs/lib/windowUtil.js.map +1 -1
  16. package/dist/cjs/nextjs/config.d.ts.map +1 -1
  17. package/dist/cjs/nextjs/config.js +12 -0
  18. package/dist/cjs/nextjs/config.js.map +1 -1
  19. package/dist/cjs/nextjs/hooks/index.d.ts +1 -1
  20. package/dist/cjs/nextjs/hooks/index.d.ts.map +1 -1
  21. package/dist/cjs/nextjs/hooks/index.js +3 -3
  22. package/dist/cjs/nextjs/hooks/index.js.map +1 -1
  23. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  24. package/dist/cjs/nextjs/hooks/useUserCookie.js +43 -14
  25. package/dist/cjs/nextjs/hooks/useUserCookie.js.map +1 -1
  26. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +5 -1
  27. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  28. package/dist/cjs/nextjs/providers/NextAuthProvider.js +74 -35
  29. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -1
  30. package/dist/cjs/reactjs/components/UserButton.js +20 -10
  31. package/dist/cjs/reactjs/components/UserButton.js.map +1 -1
  32. package/dist/cjs/reactjs/hooks/index.d.ts +0 -1
  33. package/dist/cjs/reactjs/hooks/index.d.ts.map +1 -1
  34. package/dist/cjs/reactjs/hooks/index.js +1 -3
  35. package/dist/cjs/reactjs/hooks/index.js.map +1 -1
  36. package/dist/cjs/services/AuthenticationService.d.ts +4 -1
  37. package/dist/cjs/services/AuthenticationService.d.ts.map +1 -1
  38. package/dist/cjs/services/AuthenticationService.js +38 -7
  39. package/dist/cjs/services/AuthenticationService.js.map +1 -1
  40. package/dist/cjs/shared/components/BlockDisplay.d.ts +7 -0
  41. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +1 -0
  42. package/dist/cjs/shared/components/BlockDisplay.js +31 -0
  43. package/dist/cjs/shared/components/BlockDisplay.js.map +1 -0
  44. package/dist/cjs/shared/components/CivicAuthIframe.js +17 -7
  45. package/dist/cjs/shared/components/CivicAuthIframe.js.map +1 -1
  46. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  47. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +39 -20
  48. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +1 -1
  49. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +7 -0
  50. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -0
  51. package/dist/cjs/shared/components/IFrameAndLoading.js +28 -0
  52. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -0
  53. package/dist/cjs/shared/hooks/index.d.ts +5 -1
  54. package/dist/cjs/shared/hooks/index.d.ts.map +1 -1
  55. package/dist/cjs/shared/hooks/index.js +11 -3
  56. package/dist/cjs/shared/hooks/index.js.map +1 -1
  57. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  58. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  59. package/dist/cjs/shared/hooks/useCivicAuthConfig.js +13 -0
  60. package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +1 -0
  61. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  62. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  63. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +16 -0
  64. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  65. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts +3 -0
  66. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  67. package/dist/cjs/shared/hooks/useCurrentUrl.js +27 -0
  68. package/dist/cjs/shared/hooks/useCurrentUrl.js.map +1 -0
  69. package/dist/cjs/shared/hooks/useIsInIframe.d.ts +3 -0
  70. package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +1 -0
  71. package/dist/cjs/shared/hooks/useIsInIframe.js +17 -0
  72. package/dist/cjs/shared/hooks/useIsInIframe.js.map +1 -0
  73. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  74. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  75. package/dist/cjs/shared/hooks/useOAuthEndpoints.js +17 -0
  76. package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +1 -0
  77. package/dist/cjs/shared/hooks/useRefresh.d.ts +4 -0
  78. package/dist/cjs/shared/hooks/useRefresh.d.ts.map +1 -0
  79. package/dist/cjs/shared/hooks/useRefresh.js +41 -0
  80. package/dist/cjs/shared/hooks/useRefresh.js.map +1 -0
  81. package/dist/cjs/shared/hooks/useSession.d.ts +1 -1
  82. package/dist/cjs/shared/hooks/useSession.d.ts.map +1 -1
  83. package/dist/cjs/shared/hooks/useSignIn.d.ts +14 -0
  84. package/dist/cjs/shared/hooks/useSignIn.d.ts.map +1 -0
  85. package/dist/cjs/shared/hooks/useSignIn.js +74 -0
  86. package/dist/cjs/shared/hooks/useSignIn.js.map +1 -0
  87. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  88. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  89. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +30 -0
  90. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  91. package/dist/cjs/shared/lib/types.d.ts +14 -1
  92. package/dist/cjs/shared/lib/types.d.ts.map +1 -1
  93. package/dist/cjs/shared/lib/types.js +2 -0
  94. package/dist/cjs/shared/lib/types.js.map +1 -1
  95. package/dist/cjs/shared/lib/util.d.ts.map +1 -1
  96. package/dist/cjs/shared/lib/util.js +27 -9
  97. package/dist/cjs/shared/lib/util.js.map +1 -1
  98. package/dist/cjs/shared/providers/AuthProvider.d.ts +3 -2
  99. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +1 -1
  100. package/dist/cjs/shared/providers/AuthProvider.js +53 -244
  101. package/dist/cjs/shared/providers/AuthProvider.js.map +1 -1
  102. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  103. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  104. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +80 -0
  105. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +1 -0
  106. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  107. package/dist/cjs/shared/providers/CivicAuthProvider.js +23 -6
  108. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +1 -1
  109. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  110. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  111. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +183 -0
  112. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  113. package/dist/cjs/shared/providers/IframeProvider.d.ts +7 -4
  114. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +1 -1
  115. package/dist/cjs/shared/providers/IframeProvider.js +37 -9
  116. package/dist/cjs/shared/providers/IframeProvider.js.map +1 -1
  117. package/dist/cjs/shared/providers/SessionProvider.d.ts +10 -4
  118. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +1 -1
  119. package/dist/cjs/shared/providers/SessionProvider.js +32 -12
  120. package/dist/cjs/shared/providers/SessionProvider.js.map +1 -1
  121. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -1
  122. package/dist/cjs/shared/providers/TokenProvider.js +29 -30
  123. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -1
  124. package/dist/cjs/shared/providers/UserProvider.d.ts +4 -3
  125. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -1
  126. package/dist/cjs/shared/providers/UserProvider.js +46 -25
  127. package/dist/cjs/shared/providers/UserProvider.js.map +1 -1
  128. package/dist/cjs/types.d.ts +1 -0
  129. package/dist/cjs/types.d.ts.map +1 -1
  130. package/dist/cjs/types.js.map +1 -1
  131. package/dist/cjs/utils.d.ts.map +1 -1
  132. package/dist/esm/browser/storage.d.ts +3 -0
  133. package/dist/esm/browser/storage.d.ts.map +1 -1
  134. package/dist/esm/browser/storage.js +8 -0
  135. package/dist/esm/browser/storage.js.map +1 -1
  136. package/dist/esm/lib/cookies.d.ts +2 -2
  137. package/dist/esm/lib/cookies.d.ts.map +1 -1
  138. package/dist/esm/lib/cookies.js +7 -5
  139. package/dist/esm/lib/cookies.js.map +1 -1
  140. package/dist/esm/lib/postMessage.js +1 -1
  141. package/dist/esm/lib/postMessage.js.map +1 -1
  142. package/dist/esm/lib/windowUtil.d.ts.map +1 -1
  143. package/dist/esm/lib/windowUtil.js +1 -0
  144. package/dist/esm/lib/windowUtil.js.map +1 -1
  145. package/dist/esm/nextjs/config.d.ts.map +1 -1
  146. package/dist/esm/nextjs/config.js +12 -0
  147. package/dist/esm/nextjs/config.js.map +1 -1
  148. package/dist/esm/nextjs/hooks/index.d.ts +1 -1
  149. package/dist/esm/nextjs/hooks/index.d.ts.map +1 -1
  150. package/dist/esm/nextjs/hooks/index.js +1 -1
  151. package/dist/esm/nextjs/hooks/index.js.map +1 -1
  152. package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  153. package/dist/esm/nextjs/hooks/useUserCookie.js +45 -16
  154. package/dist/esm/nextjs/hooks/useUserCookie.js.map +1 -1
  155. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +5 -1
  156. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  157. package/dist/esm/nextjs/providers/NextAuthProvider.js +59 -30
  158. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -1
  159. package/dist/esm/reactjs/components/UserButton.js +3 -3
  160. package/dist/esm/reactjs/components/UserButton.js.map +1 -1
  161. package/dist/esm/reactjs/hooks/index.d.ts +0 -1
  162. package/dist/esm/reactjs/hooks/index.d.ts.map +1 -1
  163. package/dist/esm/reactjs/hooks/index.js +0 -1
  164. package/dist/esm/reactjs/hooks/index.js.map +1 -1
  165. package/dist/esm/services/AuthenticationService.d.ts +4 -1
  166. package/dist/esm/services/AuthenticationService.d.ts.map +1 -1
  167. package/dist/esm/services/AuthenticationService.js +39 -8
  168. package/dist/esm/services/AuthenticationService.js.map +1 -1
  169. package/dist/esm/shared/components/BlockDisplay.d.ts +7 -0
  170. package/dist/esm/shared/components/BlockDisplay.d.ts.map +1 -0
  171. package/dist/esm/shared/components/BlockDisplay.js +25 -0
  172. package/dist/esm/shared/components/BlockDisplay.js.map +1 -0
  173. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  174. package/dist/esm/shared/components/CivicAuthIframeContainer.js +23 -14
  175. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +1 -1
  176. package/dist/esm/shared/components/IFrameAndLoading.d.ts +7 -0
  177. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -0
  178. package/dist/esm/shared/components/IFrameAndLoading.js +22 -0
  179. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -0
  180. package/dist/esm/shared/hooks/index.d.ts +5 -1
  181. package/dist/esm/shared/hooks/index.d.ts.map +1 -1
  182. package/dist/esm/shared/hooks/index.js +5 -1
  183. package/dist/esm/shared/hooks/index.js.map +1 -1
  184. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  185. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  186. package/dist/esm/shared/hooks/useCivicAuthConfig.js +10 -0
  187. package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +1 -0
  188. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  189. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  190. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +13 -0
  191. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  192. package/dist/esm/shared/hooks/useCurrentUrl.d.ts +3 -0
  193. package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  194. package/dist/esm/shared/hooks/useCurrentUrl.js +24 -0
  195. package/dist/esm/shared/hooks/useCurrentUrl.js.map +1 -0
  196. package/dist/esm/shared/hooks/useIsInIframe.d.ts +3 -0
  197. package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +1 -0
  198. package/dist/esm/shared/hooks/useIsInIframe.js +14 -0
  199. package/dist/esm/shared/hooks/useIsInIframe.js.map +1 -0
  200. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  201. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  202. package/dist/esm/shared/hooks/useOAuthEndpoints.js +14 -0
  203. package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +1 -0
  204. package/dist/esm/shared/hooks/useRefresh.d.ts +4 -0
  205. package/dist/esm/shared/hooks/useRefresh.d.ts.map +1 -0
  206. package/dist/esm/shared/hooks/useRefresh.js +38 -0
  207. package/dist/esm/shared/hooks/useRefresh.js.map +1 -0
  208. package/dist/esm/shared/hooks/useSession.d.ts +1 -1
  209. package/dist/esm/shared/hooks/useSession.d.ts.map +1 -1
  210. package/dist/esm/shared/hooks/useSignIn.d.ts +14 -0
  211. package/dist/esm/shared/hooks/useSignIn.d.ts.map +1 -0
  212. package/dist/esm/shared/hooks/useSignIn.js +71 -0
  213. package/dist/esm/shared/hooks/useSignIn.js.map +1 -0
  214. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  215. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  216. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js +30 -0
  217. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  218. package/dist/esm/shared/lib/types.d.ts +14 -1
  219. package/dist/esm/shared/lib/types.d.ts.map +1 -1
  220. package/dist/esm/shared/lib/types.js +2 -0
  221. package/dist/esm/shared/lib/types.js.map +1 -1
  222. package/dist/esm/shared/lib/util.d.ts.map +1 -1
  223. package/dist/esm/shared/lib/util.js +10 -2
  224. package/dist/esm/shared/lib/util.js.map +1 -1
  225. package/dist/esm/shared/providers/AuthProvider.d.ts +3 -2
  226. package/dist/esm/shared/providers/AuthProvider.d.ts.map +1 -1
  227. package/dist/esm/shared/providers/AuthProvider.js +37 -238
  228. package/dist/esm/shared/providers/AuthProvider.js.map +1 -1
  229. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  230. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  231. package/dist/esm/shared/providers/CivicAuthConfigContext.js +43 -0
  232. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +1 -0
  233. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  234. package/dist/esm/shared/providers/CivicAuthProvider.js +23 -6
  235. package/dist/esm/shared/providers/CivicAuthProvider.js.map +1 -1
  236. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  237. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  238. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +146 -0
  239. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  240. package/dist/esm/shared/providers/IframeProvider.d.ts +7 -4
  241. package/dist/esm/shared/providers/IframeProvider.d.ts.map +1 -1
  242. package/dist/esm/shared/providers/IframeProvider.js +21 -3
  243. package/dist/esm/shared/providers/IframeProvider.js.map +1 -1
  244. package/dist/esm/shared/providers/SessionProvider.d.ts +10 -4
  245. package/dist/esm/shared/providers/SessionProvider.d.ts.map +1 -1
  246. package/dist/esm/shared/providers/SessionProvider.js +15 -5
  247. package/dist/esm/shared/providers/SessionProvider.js.map +1 -1
  248. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -1
  249. package/dist/esm/shared/providers/TokenProvider.js +13 -24
  250. package/dist/esm/shared/providers/TokenProvider.js.map +1 -1
  251. package/dist/esm/shared/providers/UserProvider.d.ts +4 -3
  252. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -1
  253. package/dist/esm/shared/providers/UserProvider.js +30 -19
  254. package/dist/esm/shared/providers/UserProvider.js.map +1 -1
  255. package/dist/esm/types.d.ts +1 -0
  256. package/dist/esm/types.d.ts.map +1 -1
  257. package/dist/esm/types.js.map +1 -1
  258. package/dist/esm/utils.d.ts.map +1 -1
  259. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  260. package/dist/src/nextjs/hooks/useUserCookie.js +45 -16
  261. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -1
  262. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  263. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  264. package/dist/tsconfig.tsbuildinfo +1 -1
  265. package/package.json +7 -1
  266. package/.eslintignore +0 -3
  267. package/.eslintrc.json +0 -10
  268. package/.prettierignore +0 -3
  269. package/.prettierrc +0 -1
  270. package/.turbo/turbo-build.log +0 -13
  271. package/.turbo/turbo-lint$colon$fix.log +0 -10
  272. package/.turbo/turbo-test.log +0 -1153
  273. package/dist/cjs/nextjs/hooks/useTokenCookie.d.ts +0 -3
  274. package/dist/cjs/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  275. package/dist/cjs/nextjs/hooks/useTokenCookie.js +0 -41
  276. package/dist/cjs/nextjs/hooks/useTokenCookie.js.map +0 -1
  277. package/dist/cjs/shared/hooks/useConfig.d.ts +0 -3
  278. package/dist/cjs/shared/hooks/useConfig.d.ts.map +0 -1
  279. package/dist/cjs/shared/hooks/useConfig.js +0 -16
  280. package/dist/cjs/shared/hooks/useConfig.js.map +0 -1
  281. package/dist/cjs/shared/providers/ConfigProvider.d.ts +0 -21
  282. package/dist/cjs/shared/providers/ConfigProvider.d.ts.map +0 -1
  283. package/dist/cjs/shared/providers/ConfigProvider.js +0 -46
  284. package/dist/cjs/shared/providers/ConfigProvider.js.map +0 -1
  285. package/dist/esm/nextjs/hooks/useTokenCookie.d.ts +0 -3
  286. package/dist/esm/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  287. package/dist/esm/nextjs/hooks/useTokenCookie.js +0 -37
  288. package/dist/esm/nextjs/hooks/useTokenCookie.js.map +0 -1
  289. package/dist/esm/shared/hooks/useConfig.d.ts +0 -3
  290. package/dist/esm/shared/hooks/useConfig.d.ts.map +0 -1
  291. package/dist/esm/shared/hooks/useConfig.js +0 -13
  292. package/dist/esm/shared/hooks/useConfig.js.map +0 -1
  293. package/dist/esm/shared/providers/ConfigProvider.d.ts +0 -21
  294. package/dist/esm/shared/providers/ConfigProvider.d.ts.map +0 -1
  295. package/dist/esm/shared/providers/ConfigProvider.js +0 -19
  296. package/dist/esm/shared/providers/ConfigProvider.js.map +0 -1
  297. package/dist/src/browser/storage.d.ts +0 -6
  298. package/dist/src/browser/storage.d.ts.map +0 -1
  299. package/dist/src/browser/storage.js +0 -9
  300. package/dist/src/browser/storage.js.map +0 -1
  301. package/dist/src/config.d.ts +0 -3
  302. package/dist/src/config.d.ts.map +0 -1
  303. package/dist/src/config.js +0 -5
  304. package/dist/src/config.js.map +0 -1
  305. package/dist/src/constants.d.ts +0 -9
  306. package/dist/src/constants.d.ts.map +0 -1
  307. package/dist/src/constants.js +0 -17
  308. package/dist/src/constants.js.map +0 -1
  309. package/dist/src/index.d.ts +0 -4
  310. package/dist/src/index.d.ts.map +0 -1
  311. package/dist/src/index.js +0 -2
  312. package/dist/src/index.js.map +0 -1
  313. package/dist/src/lib/cookies.d.ts +0 -7
  314. package/dist/src/lib/cookies.d.ts.map +0 -1
  315. package/dist/src/lib/cookies.js +0 -23
  316. package/dist/src/lib/cookies.js.map +0 -1
  317. package/dist/src/lib/jwt.d.ts +0 -3
  318. package/dist/src/lib/jwt.d.ts.map +0 -1
  319. package/dist/src/lib/jwt.js +0 -9
  320. package/dist/src/lib/jwt.js.map +0 -1
  321. package/dist/src/lib/logger.d.ts +0 -26
  322. package/dist/src/lib/logger.d.ts.map +0 -1
  323. package/dist/src/lib/logger.js +0 -55
  324. package/dist/src/lib/logger.js.map +0 -1
  325. package/dist/src/lib/oauth.d.ts +0 -19
  326. package/dist/src/lib/oauth.d.ts.map +0 -1
  327. package/dist/src/lib/oauth.js +0 -60
  328. package/dist/src/lib/oauth.js.map +0 -1
  329. package/dist/src/lib/postMessage.d.ts +0 -4
  330. package/dist/src/lib/postMessage.d.ts.map +0 -1
  331. package/dist/src/lib/postMessage.js +0 -15
  332. package/dist/src/lib/postMessage.js.map +0 -1
  333. package/dist/src/lib/windowUtil.d.ts +0 -4
  334. package/dist/src/lib/windowUtil.d.ts.map +0 -1
  335. package/dist/src/lib/windowUtil.js +0 -30
  336. package/dist/src/lib/windowUtil.js.map +0 -1
  337. package/dist/src/nextjs/GetUser.d.ts +0 -6
  338. package/dist/src/nextjs/GetUser.d.ts.map +0 -1
  339. package/dist/src/nextjs/GetUser.js +0 -18
  340. package/dist/src/nextjs/GetUser.js.map +0 -1
  341. package/dist/src/nextjs/config.d.ts +0 -178
  342. package/dist/src/nextjs/config.d.ts.map +0 -1
  343. package/dist/src/nextjs/config.js +0 -161
  344. package/dist/src/nextjs/config.js.map +0 -1
  345. package/dist/src/nextjs/cookies.d.ts +0 -30
  346. package/dist/src/nextjs/cookies.d.ts.map +0 -1
  347. package/dist/src/nextjs/cookies.js +0 -112
  348. package/dist/src/nextjs/cookies.js.map +0 -1
  349. package/dist/src/nextjs/hooks/index.d.ts +0 -2
  350. package/dist/src/nextjs/hooks/index.d.ts.map +0 -1
  351. package/dist/src/nextjs/hooks/index.js +0 -2
  352. package/dist/src/nextjs/hooks/index.js.map +0 -1
  353. package/dist/src/nextjs/hooks/useTokenCookie.d.ts +0 -3
  354. package/dist/src/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  355. package/dist/src/nextjs/hooks/useTokenCookie.js +0 -37
  356. package/dist/src/nextjs/hooks/useTokenCookie.js.map +0 -1
  357. package/dist/src/nextjs/hooks/useUserCookie.d.ts +0 -3
  358. package/dist/src/nextjs/index.d.ts +0 -7
  359. package/dist/src/nextjs/index.d.ts.map +0 -1
  360. package/dist/src/nextjs/index.js +0 -6
  361. package/dist/src/nextjs/index.js.map +0 -1
  362. package/dist/src/nextjs/middleware/index.d.ts +0 -2
  363. package/dist/src/nextjs/middleware/index.d.ts.map +0 -1
  364. package/dist/src/nextjs/middleware/index.js +0 -2
  365. package/dist/src/nextjs/middleware/index.js.map +0 -1
  366. package/dist/src/nextjs/middleware.d.ts +0 -59
  367. package/dist/src/nextjs/middleware.d.ts.map +0 -1
  368. package/dist/src/nextjs/middleware.js +0 -107
  369. package/dist/src/nextjs/middleware.js.map +0 -1
  370. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +0 -9
  371. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
  372. package/dist/src/nextjs/providers/NextAuthProvider.js +0 -50
  373. package/dist/src/nextjs/providers/NextAuthProvider.js.map +0 -1
  374. package/dist/src/nextjs/routeHandler.d.ts +0 -18
  375. package/dist/src/nextjs/routeHandler.d.ts.map +0 -1
  376. package/dist/src/nextjs/routeHandler.js +0 -212
  377. package/dist/src/nextjs/routeHandler.js.map +0 -1
  378. package/dist/src/nextjs/utils.d.ts +0 -3
  379. package/dist/src/nextjs/utils.d.ts.map +0 -1
  380. package/dist/src/nextjs/utils.js +0 -5
  381. package/dist/src/nextjs/utils.js.map +0 -1
  382. package/dist/src/reactjs/components/SignInButton.d.ts +0 -8
  383. package/dist/src/reactjs/components/SignInButton.d.ts.map +0 -1
  384. package/dist/src/reactjs/components/SignInButton.js +0 -14
  385. package/dist/src/reactjs/components/SignInButton.js.map +0 -1
  386. package/dist/src/reactjs/components/SignOutButton.d.ts +0 -6
  387. package/dist/src/reactjs/components/SignOutButton.d.ts.map +0 -1
  388. package/dist/src/reactjs/components/SignOutButton.js +0 -14
  389. package/dist/src/reactjs/components/SignOutButton.js.map +0 -1
  390. package/dist/src/reactjs/components/UserButton.d.ts +0 -8
  391. package/dist/src/reactjs/components/UserButton.d.ts.map +0 -1
  392. package/dist/src/reactjs/components/UserButton.js +0 -118
  393. package/dist/src/reactjs/components/UserButton.js.map +0 -1
  394. package/dist/src/reactjs/components/index.d.ts +0 -6
  395. package/dist/src/reactjs/components/index.d.ts.map +0 -1
  396. package/dist/src/reactjs/components/index.js +0 -6
  397. package/dist/src/reactjs/components/index.js.map +0 -1
  398. package/dist/src/reactjs/hooks/index.d.ts +0 -7
  399. package/dist/src/reactjs/hooks/index.d.ts.map +0 -1
  400. package/dist/src/reactjs/hooks/index.js +0 -7
  401. package/dist/src/reactjs/hooks/index.js.map +0 -1
  402. package/dist/src/reactjs/hooks/useAuth.d.ts +0 -3
  403. package/dist/src/reactjs/hooks/useAuth.d.ts.map +0 -1
  404. package/dist/src/reactjs/hooks/useAuth.js +0 -12
  405. package/dist/src/reactjs/hooks/useAuth.js.map +0 -1
  406. package/dist/src/reactjs/hooks/useUser.d.ts +0 -4
  407. package/dist/src/reactjs/hooks/useUser.d.ts.map +0 -1
  408. package/dist/src/reactjs/hooks/useUser.js +0 -12
  409. package/dist/src/reactjs/hooks/useUser.js.map +0 -1
  410. package/dist/src/reactjs/index.d.ts +0 -6
  411. package/dist/src/reactjs/index.d.ts.map +0 -1
  412. package/dist/src/reactjs/index.js +0 -8
  413. package/dist/src/reactjs/index.js.map +0 -1
  414. package/dist/src/reactjs/providers/index.d.ts +0 -8
  415. package/dist/src/reactjs/providers/index.d.ts.map +0 -1
  416. package/dist/src/reactjs/providers/index.js +0 -7
  417. package/dist/src/reactjs/providers/index.js.map +0 -1
  418. package/dist/src/server/ServerAuthenticationResolver.d.ts +0 -19
  419. package/dist/src/server/ServerAuthenticationResolver.d.ts.map +0 -1
  420. package/dist/src/server/ServerAuthenticationResolver.js +0 -61
  421. package/dist/src/server/ServerAuthenticationResolver.js.map +0 -1
  422. package/dist/src/server/config.d.ts +0 -9
  423. package/dist/src/server/config.d.ts.map +0 -1
  424. package/dist/src/server/config.js +0 -2
  425. package/dist/src/server/config.js.map +0 -1
  426. package/dist/src/server/index.d.ts +0 -7
  427. package/dist/src/server/index.d.ts.map +0 -1
  428. package/dist/src/server/index.js +0 -5
  429. package/dist/src/server/index.js.map +0 -1
  430. package/dist/src/server/login.d.ts +0 -17
  431. package/dist/src/server/login.d.ts.map +0 -1
  432. package/dist/src/server/login.js +0 -37
  433. package/dist/src/server/login.js.map +0 -1
  434. package/dist/src/server/refresh.d.ts +0 -7
  435. package/dist/src/server/refresh.d.ts.map +0 -1
  436. package/dist/src/server/refresh.js +0 -13
  437. package/dist/src/server/refresh.js.map +0 -1
  438. package/dist/src/services/AuthenticationService.d.ts +0 -87
  439. package/dist/src/services/AuthenticationService.d.ts.map +0 -1
  440. package/dist/src/services/AuthenticationService.js +0 -212
  441. package/dist/src/services/AuthenticationService.js.map +0 -1
  442. package/dist/src/services/PKCE.d.ts +0 -20
  443. package/dist/src/services/PKCE.d.ts.map +0 -1
  444. package/dist/src/services/PKCE.js +0 -44
  445. package/dist/src/services/PKCE.js.map +0 -1
  446. package/dist/src/services/types.d.ts +0 -23
  447. package/dist/src/services/types.d.ts.map +0 -1
  448. package/dist/src/services/types.js +0 -7
  449. package/dist/src/services/types.js.map +0 -1
  450. package/dist/src/shared/components/CivicAuthIframe.d.ts +0 -8
  451. package/dist/src/shared/components/CivicAuthIframe.d.ts.map +0 -1
  452. package/dist/src/shared/components/CivicAuthIframe.js +0 -9
  453. package/dist/src/shared/components/CivicAuthIframe.js.map +0 -1
  454. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts +0 -9
  455. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
  456. package/dist/src/shared/components/CivicAuthIframeContainer.js +0 -129
  457. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +0 -1
  458. package/dist/src/shared/components/CloseIcon.d.ts +0 -4
  459. package/dist/src/shared/components/CloseIcon.d.ts.map +0 -1
  460. package/dist/src/shared/components/CloseIcon.js +0 -6
  461. package/dist/src/shared/components/CloseIcon.js.map +0 -1
  462. package/dist/src/shared/components/LoadingIcon.d.ts +0 -4
  463. package/dist/src/shared/components/LoadingIcon.d.ts.map +0 -1
  464. package/dist/src/shared/components/LoadingIcon.js +0 -30
  465. package/dist/src/shared/components/LoadingIcon.js.map +0 -1
  466. package/dist/src/shared/hooks/index.d.ts +0 -5
  467. package/dist/src/shared/hooks/index.d.ts.map +0 -1
  468. package/dist/src/shared/hooks/index.js +0 -5
  469. package/dist/src/shared/hooks/index.js.map +0 -1
  470. package/dist/src/shared/hooks/useAuth.d.ts +0 -3
  471. package/dist/src/shared/hooks/useAuth.d.ts.map +0 -1
  472. package/dist/src/shared/hooks/useAuth.js +0 -12
  473. package/dist/src/shared/hooks/useAuth.js.map +0 -1
  474. package/dist/src/shared/hooks/useConfig.d.ts +0 -3
  475. package/dist/src/shared/hooks/useConfig.d.ts.map +0 -1
  476. package/dist/src/shared/hooks/useConfig.js +0 -13
  477. package/dist/src/shared/hooks/useConfig.js.map +0 -1
  478. package/dist/src/shared/hooks/useIframe.d.ts +0 -3
  479. package/dist/src/shared/hooks/useIframe.d.ts.map +0 -1
  480. package/dist/src/shared/hooks/useIframe.js +0 -13
  481. package/dist/src/shared/hooks/useIframe.js.map +0 -1
  482. package/dist/src/shared/hooks/useSession.d.ts +0 -3
  483. package/dist/src/shared/hooks/useSession.d.ts.map +0 -1
  484. package/dist/src/shared/hooks/useSession.js +0 -13
  485. package/dist/src/shared/hooks/useSession.js.map +0 -1
  486. package/dist/src/shared/hooks/useToken.d.ts +0 -3
  487. package/dist/src/shared/hooks/useToken.d.ts.map +0 -1
  488. package/dist/src/shared/hooks/useToken.js +0 -12
  489. package/dist/src/shared/hooks/useToken.js.map +0 -1
  490. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +0 -16
  491. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
  492. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +0 -43
  493. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
  494. package/dist/src/shared/lib/UserSession.d.ts +0 -12
  495. package/dist/src/shared/lib/UserSession.d.ts.map +0 -1
  496. package/dist/src/shared/lib/UserSession.js +0 -20
  497. package/dist/src/shared/lib/UserSession.js.map +0 -1
  498. package/dist/src/shared/lib/session.d.ts +0 -3
  499. package/dist/src/shared/lib/session.d.ts.map +0 -1
  500. package/dist/src/shared/lib/session.js +0 -10
  501. package/dist/src/shared/lib/session.js.map +0 -1
  502. package/dist/src/shared/lib/storage.d.ts +0 -25
  503. package/dist/src/shared/lib/storage.d.ts.map +0 -1
  504. package/dist/src/shared/lib/storage.js +0 -17
  505. package/dist/src/shared/lib/storage.js.map +0 -1
  506. package/dist/src/shared/lib/types.d.ts +0 -22
  507. package/dist/src/shared/lib/types.d.ts.map +0 -1
  508. package/dist/src/shared/lib/types.js +0 -16
  509. package/dist/src/shared/lib/types.js.map +0 -1
  510. package/dist/src/shared/lib/util.d.ts +0 -33
  511. package/dist/src/shared/lib/util.d.ts.map +0 -1
  512. package/dist/src/shared/lib/util.js +0 -124
  513. package/dist/src/shared/lib/util.js.map +0 -1
  514. package/dist/src/shared/providers/AuthContext.d.ts +0 -10
  515. package/dist/src/shared/providers/AuthContext.d.ts.map +0 -1
  516. package/dist/src/shared/providers/AuthContext.js +0 -3
  517. package/dist/src/shared/providers/AuthContext.js.map +0 -1
  518. package/dist/src/shared/providers/AuthProvider.d.ts +0 -20
  519. package/dist/src/shared/providers/AuthProvider.d.ts.map +0 -1
  520. package/dist/src/shared/providers/AuthProvider.js +0 -264
  521. package/dist/src/shared/providers/AuthProvider.js.map +0 -1
  522. package/dist/src/shared/providers/CivicAuthProvider.d.ts +0 -6
  523. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +0 -1
  524. package/dist/src/shared/providers/CivicAuthProvider.js +0 -15
  525. package/dist/src/shared/providers/CivicAuthProvider.js.map +0 -1
  526. package/dist/src/shared/providers/ConfigProvider.d.ts +0 -21
  527. package/dist/src/shared/providers/ConfigProvider.d.ts.map +0 -1
  528. package/dist/src/shared/providers/ConfigProvider.js +0 -19
  529. package/dist/src/shared/providers/ConfigProvider.js.map +0 -1
  530. package/dist/src/shared/providers/IframeProvider.d.ts +0 -16
  531. package/dist/src/shared/providers/IframeProvider.d.ts.map +0 -1
  532. package/dist/src/shared/providers/IframeProvider.js +0 -11
  533. package/dist/src/shared/providers/IframeProvider.js.map +0 -1
  534. package/dist/src/shared/providers/SessionProvider.d.ts +0 -13
  535. package/dist/src/shared/providers/SessionProvider.d.ts.map +0 -1
  536. package/dist/src/shared/providers/SessionProvider.js +0 -13
  537. package/dist/src/shared/providers/SessionProvider.js.map +0 -1
  538. package/dist/src/shared/providers/TokenProvider.d.ts +0 -18
  539. package/dist/src/shared/providers/TokenProvider.d.ts.map +0 -1
  540. package/dist/src/shared/providers/TokenProvider.js +0 -53
  541. package/dist/src/shared/providers/TokenProvider.js.map +0 -1
  542. package/dist/src/shared/providers/UserProvider.d.ts +0 -18
  543. package/dist/src/shared/providers/UserProvider.d.ts.map +0 -1
  544. package/dist/src/shared/providers/UserProvider.js +0 -38
  545. package/dist/src/shared/providers/UserProvider.js.map +0 -1
  546. package/dist/src/types.d.ts +0 -146
  547. package/dist/src/types.d.ts.map +0 -1
  548. package/dist/src/types.js +0 -2
  549. package/dist/src/types.js.map +0 -1
  550. package/dist/src/utils.d.ts +0 -15
  551. package/dist/src/utils.d.ts.map +0 -1
  552. package/dist/src/utils.js +0 -43
  553. package/dist/src/utils.js.map +0 -1
  554. package/dist/test/integration/sdk.test.d.ts +0 -2
  555. package/dist/test/integration/sdk.test.d.ts.map +0 -1
  556. package/dist/test/integration/sdk.test.js +0 -183
  557. package/dist/test/integration/sdk.test.js.map +0 -1
  558. package/dist/test/support/fixtures.d.ts +0 -26
  559. package/dist/test/support/fixtures.d.ts.map +0 -1
  560. package/dist/test/support/fixtures.js +0 -55
  561. package/dist/test/support/fixtures.js.map +0 -1
  562. package/dist/test/support/tokens.json +0 -26
  563. package/dist/test/unit/lib/oauth.test.d.ts +0 -2
  564. package/dist/test/unit/lib/oauth.test.d.ts.map +0 -1
  565. package/dist/test/unit/lib/oauth.test.js +0 -55
  566. package/dist/test/unit/lib/oauth.test.js.map +0 -1
  567. package/dist/test/unit/logger.test.d.ts +0 -2
  568. package/dist/test/unit/logger.test.d.ts.map +0 -1
  569. package/dist/test/unit/logger.test.js +0 -141
  570. package/dist/test/unit/logger.test.js.map +0 -1
  571. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +0 -2
  572. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts.map +0 -1
  573. package/dist/test/unit/nextjs/NextAuthProvider.test.js +0 -29
  574. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +0 -1
  575. package/dist/test/unit/nextjs/config.test.d.ts +0 -2
  576. package/dist/test/unit/nextjs/config.test.d.ts.map +0 -1
  577. package/dist/test/unit/nextjs/config.test.js +0 -189
  578. package/dist/test/unit/nextjs/config.test.js.map +0 -1
  579. package/dist/test/unit/nextjs/getUser.test.d.ts +0 -2
  580. package/dist/test/unit/nextjs/getUser.test.d.ts.map +0 -1
  581. package/dist/test/unit/nextjs/getUser.test.js +0 -36
  582. package/dist/test/unit/nextjs/getUser.test.js.map +0 -1
  583. package/dist/test/unit/nextjs/middleware.test.d.ts +0 -2
  584. package/dist/test/unit/nextjs/middleware.test.d.ts.map +0 -1
  585. package/dist/test/unit/nextjs/middleware.test.js +0 -113
  586. package/dist/test/unit/nextjs/middleware.test.js.map +0 -1
  587. package/dist/test/unit/nextjs/utils.test.d.ts +0 -2
  588. package/dist/test/unit/nextjs/utils.test.d.ts.map +0 -1
  589. package/dist/test/unit/nextjs/utils.test.js +0 -13
  590. package/dist/test/unit/nextjs/utils.test.js.map +0 -1
  591. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +0 -2
  592. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts.map +0 -1
  593. package/dist/test/unit/publicApi/apiSnapshot.test.js +0 -10
  594. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +0 -1
  595. package/dist/test/unit/react/components/SignInButton.test.d.ts +0 -2
  596. package/dist/test/unit/react/components/SignInButton.test.d.ts.map +0 -1
  597. package/dist/test/unit/react/components/SignInButton.test.js +0 -31
  598. package/dist/test/unit/react/components/SignInButton.test.js.map +0 -1
  599. package/dist/test/unit/react/components/SignOutButton.test.d.ts +0 -2
  600. package/dist/test/unit/react/components/SignOutButton.test.d.ts.map +0 -1
  601. package/dist/test/unit/react/components/SignOutButton.test.js +0 -30
  602. package/dist/test/unit/react/components/SignOutButton.test.js.map +0 -1
  603. package/dist/test/unit/server/login.test.d.ts +0 -2
  604. package/dist/test/unit/server/login.test.d.ts.map +0 -1
  605. package/dist/test/unit/server/login.test.js +0 -127
  606. package/dist/test/unit/server/login.test.js.map +0 -1
  607. package/dist/test/unit/server/session.test.d.ts +0 -2
  608. package/dist/test/unit/server/session.test.d.ts.map +0 -1
  609. package/dist/test/unit/server/session.test.js +0 -41
  610. package/dist/test/unit/server/session.test.js.map +0 -1
  611. package/dist/test/unit/services/AuthenticationService.test.d.ts +0 -2
  612. package/dist/test/unit/services/AuthenticationService.test.d.ts.map +0 -1
  613. package/dist/test/unit/services/AuthenticationService.test.js +0 -104
  614. package/dist/test/unit/services/AuthenticationService.test.js.map +0 -1
  615. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +0 -2
  616. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts.map +0 -1
  617. package/dist/test/unit/services/ServerAuthenticationResolver.test.js +0 -74
  618. package/dist/test/unit/services/ServerAuthenticationResolver.test.js.map +0 -1
  619. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +0 -2
  620. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts.map +0 -1
  621. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js +0 -61
  622. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js.map +0 -1
  623. package/dist/test/unit/shared/UserSession.test.d.ts +0 -2
  624. package/dist/test/unit/shared/UserSession.test.d.ts.map +0 -1
  625. package/dist/test/unit/shared/UserSession.test.js +0 -37
  626. package/dist/test/unit/shared/UserSession.test.js.map +0 -1
  627. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +0 -2
  628. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts.map +0 -1
  629. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +0 -120
  630. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +0 -1
  631. package/dist/test/unit/shared/storage.test.d.ts +0 -2
  632. package/dist/test/unit/shared/storage.test.d.ts.map +0 -1
  633. package/dist/test/unit/shared/storage.test.js +0 -53
  634. package/dist/test/unit/shared/storage.test.js.map +0 -1
  635. package/dist/test/unit/utils.test.d.ts +0 -2
  636. package/dist/test/unit/utils.test.d.ts.map +0 -1
  637. package/dist/test/unit/utils.test.js +0 -40
  638. package/dist/test/unit/utils.test.js.map +0 -1
  639. package/dist/vitest.config.d.ts +0 -3
  640. package/dist/vitest.config.d.ts.map +0 -1
  641. package/dist/vitest.config.js +0 -40
  642. package/dist/vitest.config.js.map +0 -1
  643. package/src/browser/storage.ts +0 -11
  644. package/src/config.ts +0 -6
  645. package/src/constants.ts +0 -29
  646. package/src/index.ts +0 -16
  647. package/src/lib/cookies.ts +0 -28
  648. package/src/lib/jwt.ts +0 -15
  649. package/src/lib/logger.ts +0 -72
  650. package/src/lib/oauth.ts +0 -83
  651. package/src/lib/postMessage.ts +0 -22
  652. package/src/lib/windowUtil.ts +0 -29
  653. package/src/nextjs/GetUser.ts +0 -22
  654. package/src/nextjs/config.ts +0 -203
  655. package/src/nextjs/cookies.ts +0 -162
  656. package/src/nextjs/hooks/index.ts +0 -1
  657. package/src/nextjs/hooks/useTokenCookie.ts +0 -41
  658. package/src/nextjs/hooks/useUserCookie.ts +0 -41
  659. package/src/nextjs/index.ts +0 -20
  660. package/src/nextjs/middleware/index.ts +0 -1
  661. package/src/nextjs/middleware.ts +0 -155
  662. package/src/nextjs/providers/NextAuthProvider.tsx +0 -87
  663. package/src/nextjs/routeHandler.ts +0 -297
  664. package/src/nextjs/utils.ts +0 -9
  665. package/src/reactjs/components/SignInButton.tsx +0 -32
  666. package/src/reactjs/components/SignOutButton.tsx +0 -24
  667. package/src/reactjs/components/UserButton.tsx +0 -239
  668. package/src/reactjs/components/index.ts +0 -5
  669. package/src/reactjs/hooks/index.ts +0 -6
  670. package/src/reactjs/hooks/useAuth.ts +0 -15
  671. package/src/reactjs/hooks/useUser.ts +0 -20
  672. package/src/reactjs/index.ts +0 -19
  673. package/src/reactjs/providers/index.ts +0 -27
  674. package/src/server/ServerAuthenticationResolver.ts +0 -107
  675. package/src/server/config.ts +0 -9
  676. package/src/server/index.ts +0 -13
  677. package/src/server/login.ts +0 -59
  678. package/src/server/refresh.ts +0 -23
  679. package/src/services/AuthenticationService.ts +0 -329
  680. package/src/services/PKCE.ts +0 -45
  681. package/src/services/types.ts +0 -54
  682. package/src/shared/components/CivicAuthIframe.tsx +0 -26
  683. package/src/shared/components/CivicAuthIframeContainer.tsx +0 -195
  684. package/src/shared/components/CloseIcon.tsx +0 -21
  685. package/src/shared/components/LoadingIcon.tsx +0 -53
  686. package/src/shared/hooks/index.ts +0 -4
  687. package/src/shared/hooks/useAuth.ts +0 -15
  688. package/src/shared/hooks/useConfig.ts +0 -14
  689. package/src/shared/hooks/useIframe.ts +0 -14
  690. package/src/shared/hooks/useSession.ts +0 -14
  691. package/src/shared/hooks/useToken.ts +0 -15
  692. package/src/shared/lib/GenericAuthenticationRefresher.ts +0 -75
  693. package/src/shared/lib/UserSession.ts +0 -25
  694. package/src/shared/lib/session.ts +0 -11
  695. package/src/shared/lib/storage.ts +0 -40
  696. package/src/shared/lib/types.ts +0 -26
  697. package/src/shared/lib/util.ts +0 -212
  698. package/src/shared/providers/AuthContext.tsx +0 -11
  699. package/src/shared/providers/AuthProvider.tsx +0 -397
  700. package/src/shared/providers/CivicAuthProvider.tsx +0 -31
  701. package/src/shared/providers/ConfigProvider.tsx +0 -50
  702. package/src/shared/providers/IframeProvider.tsx +0 -34
  703. package/src/shared/providers/SessionProvider.tsx +0 -29
  704. package/src/shared/providers/TokenProvider.tsx +0 -78
  705. package/src/shared/providers/UserProvider.tsx +0 -80
  706. package/src/types.ts +0 -227
  707. package/src/utils.ts +0 -58
  708. package/test/integration/sdk.test.tsx +0 -266
  709. package/test/support/fixtures.ts +0 -56
  710. package/test/support/tokens.json +0 -26
  711. package/test/unit/lib/oauth.test.ts +0 -72
  712. package/test/unit/logger.test.ts +0 -175
  713. package/test/unit/nextjs/NextAuthProvider.test.tsx +0 -38
  714. package/test/unit/nextjs/config.test.ts +0 -218
  715. package/test/unit/nextjs/getUser.test.ts +0 -41
  716. package/test/unit/nextjs/middleware.test.ts +0 -138
  717. package/test/unit/nextjs/routeHandler.test.ts.skipped +0 -369
  718. package/test/unit/nextjs/utils.test.ts +0 -17
  719. package/test/unit/publicApi/__snapshots__/apiSnapshot.test.ts.snap +0 -17
  720. package/test/unit/publicApi/apiSnapshot.test.ts +0 -11
  721. package/test/unit/react/components/SignInButton.test.tsx +0 -50
  722. package/test/unit/react/components/SignOutButton.test.tsx +0 -49
  723. package/test/unit/server/login.test.ts +0 -181
  724. package/test/unit/server/session.test.ts +0 -51
  725. package/test/unit/services/AuthenticationService.test.ts +0 -152
  726. package/test/unit/services/ServerAuthenticationResolver.test.ts +0 -115
  727. package/test/unit/shared/GenericAuthenticationRefresher.test.ts +0 -89
  728. package/test/unit/shared/UserSession.test.ts +0 -42
  729. package/test/unit/shared/components/CivicAuthIframeContainer.test.tsx +0 -154
  730. package/test/unit/shared/storage.test.ts +0 -67
  731. package/test/unit/utils.test.ts +0 -48
  732. package/tsconfig.build.json +0 -9
  733. package/tsconfig.cjs.json +0 -8
  734. package/tsconfig.esm.json +0 -7
  735. package/tsconfig.json +0 -42
  736. package/tsconfig.tsbuildinfo +0 -1
  737. package/vitest.config.ts +0 -41
@@ -1,41 +0,0 @@
1
- "use client";
2
- import { useEffect, useRef } from "react";
3
- import { useRouter } from "next/navigation.js";
4
- import { useQuery } from "@tanstack/react-query";
5
- import { getWindowCookieValue } from "@/lib/cookies.js";
6
- import type { OAuthTokens } from "@/shared/lib/types.js";
7
-
8
- const getTokenFromCookie = (tokenName: OAuthTokens): string => {
9
- return getWindowCookieValue({
10
- key: tokenName,
11
- window: globalThis.window,
12
- parseJson: false,
13
- });
14
- };
15
-
16
- export const useTokenCookie = (tokenName: OAuthTokens): string | null => {
17
- const hasRunRef = useRef(false);
18
- const router = useRouter();
19
-
20
- const { data: token } = useQuery({
21
- queryKey: ["token", tokenName],
22
- queryFn: () => getTokenFromCookie(tokenName) || null,
23
- refetchInterval: 2000,
24
- refetchIntervalInBackground: true,
25
- enabled: !hasRunRef.current,
26
- refetchOnWindowFocus: true,
27
- });
28
-
29
- useEffect(() => {
30
- if (token) {
31
- if (!hasRunRef.current) {
32
- hasRunRef.current = true;
33
- router.refresh();
34
- }
35
- } else {
36
- hasRunRef.current = false;
37
- }
38
- }, [token, router]);
39
-
40
- return token ?? null;
41
- };
@@ -1,41 +0,0 @@
1
- "use client";
2
- import { useEffect, useRef } from "react";
3
- import { useRouter } from "next/navigation.js";
4
- import { useQuery } from "@tanstack/react-query";
5
- import { getWindowCookieValue } from "@/lib/cookies.js";
6
- import type { EmptyObject, User } from "@/types.js";
7
- import { UserStorage } from "@/shared/lib/types.js";
8
-
9
- const getUserFromCookie = () =>
10
- getWindowCookieValue({
11
- key: UserStorage.USER,
12
- window: globalThis.window,
13
- parseJson: true,
14
- });
15
-
16
- export const useUserCookie = <T extends EmptyObject>() => {
17
- const hasRunRef = useRef(false);
18
- const router = useRouter();
19
-
20
- const { data: user } = useQuery({
21
- queryKey: ["user"],
22
- queryFn: () => getUserFromCookie() as User<T> | null,
23
- refetchInterval: 2000,
24
- refetchIntervalInBackground: true,
25
- enabled: !hasRunRef.current,
26
- refetchOnWindowFocus: true,
27
- });
28
-
29
- useEffect(() => {
30
- if (user) {
31
- if (!hasRunRef.current) {
32
- hasRunRef.current = true;
33
- router.refresh();
34
- }
35
- } else {
36
- hasRunRef.current = false;
37
- }
38
- }, [user, router]);
39
-
40
- return user ?? null;
41
- };
@@ -1,20 +0,0 @@
1
- export { createCivicAuthPlugin } from "@/nextjs/config.js";
2
- export { getUser } from "@/nextjs/GetUser.js";
3
- export { handler } from "@/nextjs/routeHandler.js";
4
- export {
5
- createTokenCookies,
6
- createUserInfoCookie,
7
- clearAuthCookies,
8
- NextjsCookieStorage,
9
- NextjsClientStorage,
10
- } from "@/nextjs/cookies.js";
11
- export type {
12
- AuthConfig,
13
- CookiesConfigObject,
14
- AuthConfigWithDefaults,
15
- DefinedAuthConfig,
16
- } from "@/nextjs/config.js";
17
- export {
18
- CivicNextAuthProvider as CivicAuthProvider,
19
- type NextCivicAuthProviderProps as AuthProviderProps,
20
- } from "@/nextjs/providers/NextAuthProvider.js";
@@ -1 +0,0 @@
1
- export { authMiddleware, auth, withAuth } from "@/nextjs/middleware.js";
@@ -1,155 +0,0 @@
1
- /**
2
- * Authenticates the user on all requests by checking the token cookie
3
- *
4
- * Usage:
5
- * Option 1: use if no other middleware (e.g. no next-intl etc)
6
- * export default authMiddleware();
7
- *
8
- * Option 2: use if other middleware is needed - default auth config
9
- * export default withAuth((request) => {
10
- * console.log('in custom middleware', request.nextUrl.pathname);
11
- * return NextResponse.next();
12
- * })
13
- *
14
- * Option 3: use if other middleware is needed - specifying auth config
15
- * const withCivicAuth = auth({ loginUrl: '/login', include: ['/[.*]/user'] })
16
- * export default withCivicAuth((request) => {
17
- * console.log('in custom middleware', request.url);
18
- * return NextResponse.next();
19
- * })
20
- *
21
- */
22
- import type { NextRequest } from "next/server.js";
23
- import { NextResponse } from "next/server.js";
24
- import picomatch from "picomatch";
25
- import type { AuthConfig } from "@/nextjs/config.js";
26
- import { resolveAuthConfig } from "@/nextjs/config.js";
27
-
28
- type Middleware = (
29
- request: NextRequest,
30
- ) => Promise<NextResponse> | NextResponse;
31
-
32
- // Matches globs:
33
- // Examples:
34
- // /user
35
- // /user/*
36
- // /user/**/info
37
- const matchGlob = (pathname: string, globPattern: string) => {
38
- const matches = picomatch(globPattern);
39
- return matches(pathname);
40
- };
41
-
42
- // Matches globs:
43
- // Examples:
44
- // /user
45
- // /user/*
46
- // /user/**/info
47
- const matchesGlobs = (pathname: string, patterns: string[]) =>
48
- patterns.some((pattern) => {
49
- if (!pattern) return false;
50
- console.log("matching", {
51
- pattern,
52
- pathname,
53
- match: matchGlob(pathname, pattern),
54
- });
55
- return matchGlob(pathname, pattern);
56
- });
57
-
58
- // internal - used by all exported functions
59
- const applyAuth = async (
60
- authConfig: AuthConfig,
61
- request: NextRequest,
62
- ): Promise<NextResponse | undefined> => {
63
- const authConfigWithDefaults = resolveAuthConfig(authConfig);
64
- // Check for any valid auth token
65
- const isAuthenticated = !!request.cookies.get("id_token");
66
-
67
- // skip auth check for redirect to login url
68
- if (
69
- request.nextUrl.pathname === authConfigWithDefaults.loginUrl &&
70
- request.method === "GET"
71
- ) {
72
- console.log("→ Skipping auth check - this is the login URL");
73
- return undefined;
74
- }
75
-
76
- if (!matchesGlobs(request.nextUrl.pathname, authConfigWithDefaults.include)) {
77
- console.log("→ Skipping auth check - path not in include patterns");
78
- return undefined;
79
- }
80
-
81
- if (matchesGlobs(request.nextUrl.pathname, authConfigWithDefaults.exclude)) {
82
- console.log("→ Skipping auth check - path in exclude patterns");
83
- return undefined;
84
- }
85
-
86
- // Check for either token type
87
- if (!isAuthenticated) {
88
- const loginUrl = new URL(authConfigWithDefaults.loginUrl, request.url);
89
- console.log("→ No valid token found - redirecting to login", loginUrl);
90
- return NextResponse.redirect(loginUrl);
91
- }
92
-
93
- console.log("→ Auth check passed");
94
- return undefined;
95
- };
96
-
97
- /**
98
- *
99
- * Use this when auth is the only middleware you need.
100
- * Usage:
101
- *
102
- * export default authMiddleware({ loginUrl = '/login' }); // or just authMiddleware();
103
- *
104
- */
105
- export const authMiddleware =
106
- (authConfig: Partial<AuthConfig> = {}) =>
107
- async (request: NextRequest): Promise<NextResponse> => {
108
- const response = await applyAuth(authConfig, request);
109
- if (response) return response;
110
-
111
- // NextJS doesn't do middleware chaining yet, so this does not mean
112
- // "call the next middleware" - it means "continue to the route handler"
113
- return NextResponse.next();
114
- };
115
-
116
- /**
117
- * Usage:
118
- *
119
- * export default withAuth(async (request) => {
120
- * console.log('my middleware');
121
- * return NextResponse.next();
122
- * })
123
- */
124
- // use this when you have your own middleware to chain
125
- export function withAuth(
126
- middleware: Middleware,
127
- ): (request: NextRequest) => Promise<NextResponse> {
128
- return auth()(middleware);
129
- }
130
-
131
- /**
132
- * Use this when you want to configure the middleware here (an alternative is to do it in the next.config file)
133
- *
134
- * Usage:
135
- *
136
- * const withAuth = auth({ loginUrl = '/login' }); // or just auth();
137
- *
138
- * export default withAuth(async (request) => {
139
- * console.log('my middleware');
140
- * return NextResponse.next();
141
- * })
142
- *
143
- */
144
- export function auth(authConfig: AuthConfig = {}) {
145
- return (
146
- middleware: Middleware,
147
- ): ((request: NextRequest) => Promise<NextResponse>) => {
148
- return async (request: NextRequest): Promise<NextResponse> => {
149
- const response = await applyAuth(authConfig, request);
150
- if (response) return response;
151
-
152
- return middleware(request);
153
- };
154
- };
155
- }
@@ -1,87 +0,0 @@
1
- "use client";
2
- /**
3
- * A very small context provider for the user object - it takes the user object from the cookie and provides it to the app.
4
- */
5
- import React, { useEffect, useState } from "react";
6
- import type { AuthProviderProps } from "@/shared/providers/AuthProvider.js";
7
- import { AuthProvider } from "@/shared/providers/AuthProvider.js";
8
- import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
9
- import type { User } from "@/types.js";
10
- import { resolveAuthConfig } from "@/nextjs/config.js";
11
- import { resolveCallbackUrl } from "@/nextjs/utils.js";
12
- import { ConfidentialClientPKCEConsumer } from "@/services/PKCE.js";
13
- import { NextjsClientStorage } from "@/nextjs/cookies.js";
14
- import { UserProvider } from "@/shared/providers/UserProvider.js";
15
- import { OAuthTokens } from "@/shared/lib/types.js";
16
- import { useUserCookie } from "@/nextjs/hooks/useUserCookie.js";
17
- import { useTokenCookie } from "@/nextjs/hooks/index.js";
18
-
19
- const queryClient = new QueryClient();
20
-
21
- type NextCivicAuthProviderProps = Omit<AuthProviderProps, "clientId">;
22
-
23
- const CivicNextAuthProviderInternal = ({
24
- children,
25
- ...props
26
- }: NextCivicAuthProviderProps) => {
27
- const [redirectUrl, setRedirectUrl] = useState<string>("");
28
- const resolvedConfig = resolveAuthConfig();
29
- const { clientId, oauthServer, callbackUrl, challengeUrl, logoutUrl } =
30
- resolvedConfig;
31
-
32
- useEffect(() => {
33
- if (typeof globalThis.window !== "undefined") {
34
- const appUrl = globalThis.window.location.origin;
35
- setRedirectUrl(resolveCallbackUrl(resolvedConfig, appUrl));
36
- }
37
- }, [callbackUrl, resolvedConfig]);
38
-
39
- const user = useUserCookie();
40
- const idToken = useTokenCookie(OAuthTokens.ID_TOKEN);
41
- const combinedUser = user ? ({ ...(user || {}), idToken } as User) : null;
42
- const sessionData = {
43
- authenticated: !!user,
44
- ...(idToken ? { idToken } : {}),
45
- };
46
- const signOut = async (): Promise<void> => {
47
- if (props.onSignOut) {
48
- await props.onSignOut();
49
- }
50
- const appUrl = globalThis.window.location.origin;
51
- window.location.href = `${logoutUrl}?appUrl=${appUrl}`;
52
- return;
53
- };
54
- return (
55
- <AuthProvider
56
- {...props}
57
- redirectUrl={redirectUrl}
58
- config={{ oauthServer }}
59
- clientId={clientId}
60
- pkceConsumer={new ConfidentialClientPKCEConsumer(challengeUrl)}
61
- sessionData={sessionData}
62
- >
63
- <UserProvider
64
- storage={new NextjsClientStorage()}
65
- user={combinedUser}
66
- signOut={signOut}
67
- >
68
- {children}
69
- </UserProvider>
70
- </AuthProvider>
71
- );
72
- };
73
-
74
- const CivicNextAuthProvider = ({
75
- children,
76
- ...props
77
- }: NextCivicAuthProviderProps) => {
78
- return (
79
- <QueryClientProvider client={queryClient}>
80
- <CivicNextAuthProviderInternal {...props}>
81
- {children}
82
- </CivicNextAuthProviderInternal>
83
- </QueryClientProvider>
84
- );
85
- };
86
-
87
- export { CivicNextAuthProvider, type NextCivicAuthProviderProps };
@@ -1,297 +0,0 @@
1
- import type { NextRequest } from "next/server.js";
2
- import { NextResponse } from "next/server.js";
3
- import { revalidatePath } from "next/cache.js";
4
- import type { AuthConfig } from "@/nextjs/config.js";
5
- import { resolveAuthConfig } from "@/nextjs/config.js";
6
- import { loggers } from "@/lib/logger.js";
7
- import {
8
- clearAuthCookies,
9
- NextjsClientStorage,
10
- NextjsCookieStorage,
11
- } from "@/nextjs/cookies.js";
12
- import { GenericPublicClientPKCEProducer } from "@/services/PKCE.js";
13
- import { resolveOAuthAccessCode } from "@/server/login.js";
14
- import { getUser } from "@/shared/lib/session.js";
15
- import { resolveCallbackUrl } from "@/nextjs/utils.js";
16
- import { GenericUserSession } from "@/shared/lib/UserSession.js";
17
- import {
18
- TOKEN_EXCHANGE_SUCCESS_TEXT,
19
- TOKEN_EXCHANGE_TRIGGER_TEXT,
20
- } from "@/constants.js";
21
- import { serverTokenExchangeFromState } from "@/lib/oauth.js";
22
- import { CodeVerifier } from "@/shared/lib/types.js";
23
-
24
- const logger = loggers.nextjs.handlers.auth;
25
-
26
- class AuthError extends Error {
27
- constructor(
28
- message: string,
29
- public readonly status: number = 401,
30
- ) {
31
- super(message);
32
- this.name = "AuthError";
33
- }
34
- }
35
-
36
- /**
37
- * create a code verifier and challenge for PKCE
38
- * saving the verifier in a cookie for later use
39
- * @returns {Promise<NextResponse>}
40
- */
41
- async function handleChallenge(
42
- request: NextRequest,
43
- config: AuthConfig,
44
- ): Promise<NextResponse> {
45
- const cookieStorage = new NextjsCookieStorage(config.cookies?.tokens ?? {});
46
- const pkceProducer = new GenericPublicClientPKCEProducer(cookieStorage);
47
-
48
- const challenge = await pkceProducer.getCodeChallenge();
49
- const appUrl = request.nextUrl.searchParams.get("appUrl");
50
- if (appUrl) {
51
- cookieStorage.set(CodeVerifier.APP_URL, appUrl);
52
- }
53
- return NextResponse.json({ status: "success", challenge });
54
- }
55
-
56
- async function performTokenExchangeAndSetCookies(
57
- request: NextRequest,
58
- config: AuthConfig,
59
- code: string,
60
- state: string,
61
- appUrl: string,
62
- ) {
63
- const resolvedConfigs = resolveAuthConfig(config);
64
- const cookieStorage = new NextjsCookieStorage(resolvedConfigs.cookies.tokens);
65
-
66
- const callbackUrl = resolveCallbackUrl(resolvedConfigs, appUrl);
67
- try {
68
- await resolveOAuthAccessCode(code, state, cookieStorage, {
69
- ...resolvedConfigs,
70
- redirectUrl: callbackUrl,
71
- });
72
- } catch (error) {
73
- logger.error("Token exchange failed:", error);
74
- throw new AuthError("Failed to authenticate user", 401);
75
- }
76
-
77
- const user = await getUser(cookieStorage);
78
- if (!user) {
79
- throw new AuthError("Failed to get user info", 401);
80
- }
81
-
82
- const clientStorage = new NextjsClientStorage();
83
- const userSession = new GenericUserSession(clientStorage);
84
- userSession.set(user);
85
- }
86
- async function handleCallback(
87
- request: NextRequest,
88
- config: AuthConfig,
89
- ): Promise<NextResponse> {
90
- const resolvedConfigs = resolveAuthConfig(config);
91
- console.log("handleCallback", { request, resolvedConfigs });
92
- const code = request.nextUrl.searchParams.get("code");
93
- const state = request.nextUrl.searchParams.get("state") || "";
94
- if (!code || !state) throw new AuthError("Bad parameters", 400);
95
-
96
- // appUrl is passed from the client to the server in the query string
97
- // this is necessary because the server does not have access to the client's window.location.origin
98
- // and can not accurately determine the appUrl (specially if the app is behind a reverse proxy)
99
- const appUrl =
100
- request.cookies.get(CodeVerifier.APP_URL)?.value ||
101
- request.nextUrl.searchParams.get("appUrl");
102
-
103
- // If we have a code_verifier cookie and the appUrl, we can do a token exchange.
104
- // Otherwise, just render an empty page.
105
- // The initial redirect back from the auth server does not send cookies, because the redirect is from a 3rd-party domain.
106
- // The client will make an additional call to this route with cookies included, at which point we do the token exchange.
107
- console.log("handleCallback", {
108
- code,
109
- state,
110
- appUrl,
111
- });
112
-
113
- const codeVerifier = request.cookies.get(CodeVerifier.COOKIE_NAME);
114
-
115
- if (!codeVerifier || !appUrl) {
116
- console.log("handleCallback no code_verifier found", {
117
- state,
118
- serverTokenExchange: serverTokenExchangeFromState(`${state}`),
119
- });
120
- let response = new NextResponse(
121
- `<html><body><span style="display:none">${TOKEN_EXCHANGE_TRIGGER_TEXT}</span></body></html>`,
122
- );
123
-
124
- // in server-side token exchange mode we need to launch a page that will trigger the token exchange
125
- // from the same domain, allowing it access to the code_verifier cookie
126
- // we only need to do this in redirect mode, as the iframe already triggers a client-side token exchange
127
- // if no code-verifier cookie is found
128
- if (state && serverTokenExchangeFromState(state)) {
129
- console.log(
130
- "handleCallback serverTokenExchangeFromState, launching redirect page...",
131
- {
132
- requestUrl: request.url,
133
- configCallbackUrl: resolvedConfigs.callbackUrl,
134
- },
135
- );
136
- // we need to replace the URL with resolved config in case the server is hosted
137
- // behind a reverse proxy or load balancer
138
- const requestUrl = new URL(request.url);
139
- const fetchUrl = `${resolvedConfigs.callbackUrl}?${requestUrl.searchParams.toString()}&sameDomainServerTokenExchange=true`;
140
- response = new NextResponse(
141
- `<html>
142
- <body>
143
- <span style="display:none">
144
- <script>
145
- window.onload = function () {
146
- const appUrl = globalThis.window?.location?.origin;
147
- fetch('${fetchUrl}&appUrl=' + appUrl).then((response) => {
148
- response.json().then((jsonResponse) => {
149
- if (jsonResponse.redirectUrl) {
150
- window.location.href = jsonResponse.redirectUrl;
151
- }
152
- });
153
- });
154
- };
155
- </script>
156
- </span>
157
- </body>
158
- </html>
159
- `,
160
- );
161
- }
162
- response.headers.set("Content-Type", "text/html; charset=utf-8");
163
- console.log(
164
- `handleCallback no code_verifier found, returning ${TOKEN_EXCHANGE_TRIGGER_TEXT}`,
165
- );
166
- return response;
167
- }
168
-
169
- await performTokenExchangeAndSetCookies(
170
- request,
171
- resolvedConfigs,
172
- code,
173
- state,
174
- appUrl,
175
- );
176
-
177
- if (request.url.includes("sameDomainServerTokenExchange=true")) {
178
- console.log(
179
- "handleCallback sameDomainServerTokenExchange = true, returnining redirectUrl",
180
- appUrl,
181
- );
182
- return NextResponse.json({
183
- status: "success",
184
- redirectUrl: appUrl,
185
- });
186
- }
187
-
188
- // this is the case where a 'normal' redirect is happening
189
- if (serverTokenExchangeFromState(state)) {
190
- console.log(
191
- "handleCallback serverTokenExchangeFromState, redirect to appUrl",
192
- appUrl,
193
- );
194
- if (!appUrl) {
195
- throw new Error("appUrl undefined. Cannot redirect.");
196
- }
197
- return NextResponse.redirect(`${appUrl}`);
198
- }
199
- // return an empty HTML response so the iframe doesn't show any response
200
- // in the short moment between the redirect and the parent window
201
- // acknowledging the redirect and closing the iframe
202
- const response = new NextResponse(
203
- `<html><span style="display:none">${TOKEN_EXCHANGE_SUCCESS_TEXT}</span></html>`,
204
- );
205
- response.headers.set("Content-Type", "text/html; charset=utf-8");
206
- return response;
207
- }
208
-
209
- /**
210
- * If redirectPath is an absolute path, return it as-is.
211
- * Otherwise for relative paths, append it to the current domain.
212
- * @param redirectPath
213
- * @returns
214
- */
215
- const getAbsoluteRedirectPath = (
216
- redirectPath: string,
217
- currentBasePath: string,
218
- ) => new URL(redirectPath, currentBasePath).href;
219
-
220
- export async function handleLogout(
221
- request: NextRequest,
222
- config: AuthConfig,
223
- ): Promise<NextResponse> {
224
- const resolvedConfigs = resolveAuthConfig(config);
225
- const defaultRedirectPath = resolvedConfigs.loginUrl ?? "/";
226
- const redirectTarget =
227
- new URL(request.url).searchParams.get("redirect") || defaultRedirectPath;
228
-
229
- const isAbsoluteRedirect = /^(https?:\/\/|www\.).+/i.test(redirectTarget);
230
-
231
- const appUrl = request.nextUrl.searchParams.get("appUrl");
232
-
233
- const finalRedirectUrl = isAbsoluteRedirect
234
- ? redirectTarget
235
- : getAbsoluteRedirectPath(
236
- redirectTarget,
237
- new URL(appUrl ?? request.url).origin,
238
- );
239
-
240
- const response = NextResponse.redirect(finalRedirectUrl);
241
-
242
- await clearAuthCookies(config);
243
-
244
- try {
245
- revalidatePath(isAbsoluteRedirect ? finalRedirectUrl : redirectTarget);
246
- } catch (error) {
247
- logger.warn("Failed to revalidate path after logout:", error);
248
- }
249
-
250
- return response;
251
- }
252
-
253
- /**
254
- * Creates an authentication handler for Next.js API routes
255
- *
256
- * Usage:
257
- * ```ts
258
- * // app/api/auth/[...civicauth]/route.ts
259
- * import { handler } from '@civic/auth/nextjs'
260
- * export const GET = handler({
261
- * // optional config overrides
262
- * })
263
- * ```
264
- */
265
- export const handler =
266
- (authConfig = {}) =>
267
- async (request: NextRequest): Promise<NextResponse> => {
268
- const config = resolveAuthConfig(authConfig);
269
-
270
- try {
271
- const pathname = request.nextUrl.pathname;
272
- const pathSegments = pathname.split("/");
273
- const lastSegment = pathSegments[pathSegments.length - 1];
274
-
275
- switch (lastSegment) {
276
- case "challenge":
277
- return await handleChallenge(request, config);
278
- case "callback":
279
- return await handleCallback(request, config);
280
- case "logout":
281
- return await handleLogout(request, config);
282
- default:
283
- throw new AuthError(`Invalid auth route: ${pathname}`, 404);
284
- }
285
- } catch (error) {
286
- logger.error("Auth handler error:", error);
287
-
288
- const status = error instanceof AuthError ? error.status : 500;
289
- const message =
290
- error instanceof Error ? error.message : "Authentication failed";
291
-
292
- const response = NextResponse.json({ error: message }, { status });
293
-
294
- clearAuthCookies(config);
295
- return response;
296
- }
297
- };
@@ -1,9 +0,0 @@
1
- import type { AuthConfigWithDefaults } from "@/nextjs/config.js";
2
-
3
- export const resolveCallbackUrl = (
4
- config: AuthConfigWithDefaults,
5
- baseUrl?: string,
6
- ): string => {
7
- const callbackUrl = new URL(config?.callbackUrl, baseUrl).toString();
8
- return callbackUrl.toString();
9
- };
@@ -1,32 +0,0 @@
1
- "use client";
2
- import React from "react";
3
- import type { DisplayMode } from "@/types.js";
4
- import { useUser } from "@/reactjs/hooks/useUser.js";
5
-
6
- const SignInButton = ({
7
- displayMode,
8
- className,
9
- }: {
10
- displayMode?: DisplayMode;
11
- className?: string;
12
- }) => {
13
- const { signIn } = useUser();
14
-
15
- return (
16
- <button
17
- data-testid="sign-in-button"
18
- style={{
19
- borderRadius: "9999px",
20
- border: "1px solid #6b7280",
21
- padding: "0.75rem 1rem",
22
- transition: "background-color 0.2s",
23
- }}
24
- className={className}
25
- onClick={() => signIn(displayMode)}
26
- >
27
- Sign In
28
- </button>
29
- );
30
- };
31
-
32
- export { SignInButton };