@civic/auth 0.1.3 → 0.1.4-beta.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 (752) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/README.md +13 -10
  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/GetUser.d.ts.map +1 -1
  17. package/dist/cjs/nextjs/GetUser.js +2 -13
  18. package/dist/cjs/nextjs/GetUser.js.map +1 -1
  19. package/dist/cjs/nextjs/config.d.ts.map +1 -1
  20. package/dist/cjs/nextjs/config.js +12 -0
  21. package/dist/cjs/nextjs/config.js.map +1 -1
  22. package/dist/cjs/nextjs/hooks/index.d.ts +1 -1
  23. package/dist/cjs/nextjs/hooks/index.d.ts.map +1 -1
  24. package/dist/cjs/nextjs/hooks/index.js +3 -3
  25. package/dist/cjs/nextjs/hooks/index.js.map +1 -1
  26. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts +4 -1
  27. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  28. package/dist/cjs/nextjs/hooks/useUserCookie.js +43 -15
  29. package/dist/cjs/nextjs/hooks/useUserCookie.js.map +1 -1
  30. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +5 -1
  31. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  32. package/dist/cjs/nextjs/providers/NextAuthProvider.js +74 -35
  33. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -1
  34. package/dist/cjs/nextjs/routeHandler.js +2 -2
  35. package/dist/cjs/nextjs/routeHandler.js.map +1 -1
  36. package/dist/cjs/reactjs/components/UserButton.js +20 -10
  37. package/dist/cjs/reactjs/components/UserButton.js.map +1 -1
  38. package/dist/cjs/reactjs/hooks/index.d.ts +0 -1
  39. package/dist/cjs/reactjs/hooks/index.d.ts.map +1 -1
  40. package/dist/cjs/reactjs/hooks/index.js +1 -3
  41. package/dist/cjs/reactjs/hooks/index.js.map +1 -1
  42. package/dist/cjs/services/AuthenticationService.d.ts +4 -1
  43. package/dist/cjs/services/AuthenticationService.d.ts.map +1 -1
  44. package/dist/cjs/services/AuthenticationService.js +38 -7
  45. package/dist/cjs/services/AuthenticationService.js.map +1 -1
  46. package/dist/cjs/shared/components/BlockDisplay.d.ts +7 -0
  47. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +1 -0
  48. package/dist/cjs/shared/components/BlockDisplay.js +31 -0
  49. package/dist/cjs/shared/components/BlockDisplay.js.map +1 -0
  50. package/dist/cjs/shared/components/CivicAuthIframe.js +18 -8
  51. package/dist/cjs/shared/components/CivicAuthIframe.js.map +1 -1
  52. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  53. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +39 -20
  54. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +1 -1
  55. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +7 -0
  56. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -0
  57. package/dist/cjs/shared/components/IFrameAndLoading.js +28 -0
  58. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -0
  59. package/dist/cjs/shared/hooks/index.d.ts +5 -1
  60. package/dist/cjs/shared/hooks/index.d.ts.map +1 -1
  61. package/dist/cjs/shared/hooks/index.js +11 -3
  62. package/dist/cjs/shared/hooks/index.js.map +1 -1
  63. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  64. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  65. package/dist/cjs/shared/hooks/useCivicAuthConfig.js +13 -0
  66. package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +1 -0
  67. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  68. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  69. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +16 -0
  70. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  71. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts +3 -0
  72. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  73. package/dist/cjs/shared/hooks/useCurrentUrl.js +27 -0
  74. package/dist/cjs/shared/hooks/useCurrentUrl.js.map +1 -0
  75. package/dist/cjs/shared/hooks/useIsInIframe.d.ts +3 -0
  76. package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +1 -0
  77. package/dist/cjs/shared/hooks/useIsInIframe.js +17 -0
  78. package/dist/cjs/shared/hooks/useIsInIframe.js.map +1 -0
  79. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  80. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  81. package/dist/cjs/shared/hooks/useOAuthEndpoints.js +17 -0
  82. package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +1 -0
  83. package/dist/cjs/shared/hooks/useRefresh.d.ts +4 -0
  84. package/dist/cjs/shared/hooks/useRefresh.d.ts.map +1 -0
  85. package/dist/cjs/shared/hooks/useRefresh.js +41 -0
  86. package/dist/cjs/shared/hooks/useRefresh.js.map +1 -0
  87. package/dist/cjs/shared/hooks/useSession.d.ts +1 -1
  88. package/dist/cjs/shared/hooks/useSession.d.ts.map +1 -1
  89. package/dist/cjs/shared/hooks/useSignIn.d.ts +14 -0
  90. package/dist/cjs/shared/hooks/useSignIn.d.ts.map +1 -0
  91. package/dist/cjs/shared/hooks/useSignIn.js +74 -0
  92. package/dist/cjs/shared/hooks/useSignIn.js.map +1 -0
  93. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  94. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  95. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +30 -0
  96. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  97. package/dist/cjs/shared/lib/session.d.ts +1 -1
  98. package/dist/cjs/shared/lib/session.d.ts.map +1 -1
  99. package/dist/cjs/shared/lib/session.js +12 -1
  100. package/dist/cjs/shared/lib/session.js.map +1 -1
  101. package/dist/cjs/shared/lib/types.d.ts +14 -1
  102. package/dist/cjs/shared/lib/types.d.ts.map +1 -1
  103. package/dist/cjs/shared/lib/types.js +2 -0
  104. package/dist/cjs/shared/lib/types.js.map +1 -1
  105. package/dist/cjs/shared/lib/util.d.ts.map +1 -1
  106. package/dist/cjs/shared/lib/util.js +28 -9
  107. package/dist/cjs/shared/lib/util.js.map +1 -1
  108. package/dist/cjs/shared/providers/AuthProvider.d.ts +3 -2
  109. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +1 -1
  110. package/dist/cjs/shared/providers/AuthProvider.js +53 -244
  111. package/dist/cjs/shared/providers/AuthProvider.js.map +1 -1
  112. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  113. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  114. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +80 -0
  115. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +1 -0
  116. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  117. package/dist/cjs/shared/providers/CivicAuthProvider.js +23 -6
  118. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +1 -1
  119. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  120. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  121. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +183 -0
  122. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  123. package/dist/cjs/shared/providers/IframeProvider.d.ts +7 -4
  124. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +1 -1
  125. package/dist/cjs/shared/providers/IframeProvider.js +37 -9
  126. package/dist/cjs/shared/providers/IframeProvider.js.map +1 -1
  127. package/dist/cjs/shared/providers/SessionProvider.d.ts +10 -4
  128. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +1 -1
  129. package/dist/cjs/shared/providers/SessionProvider.js +32 -12
  130. package/dist/cjs/shared/providers/SessionProvider.js.map +1 -1
  131. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -1
  132. package/dist/cjs/shared/providers/TokenProvider.js +29 -30
  133. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -1
  134. package/dist/cjs/shared/providers/UserProvider.d.ts +6 -4
  135. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -1
  136. package/dist/cjs/shared/providers/UserProvider.js +49 -26
  137. package/dist/cjs/shared/providers/UserProvider.js.map +1 -1
  138. package/dist/cjs/types.d.ts +5 -5
  139. package/dist/cjs/types.d.ts.map +1 -1
  140. package/dist/cjs/types.js +4 -0
  141. package/dist/cjs/types.js.map +1 -1
  142. package/dist/cjs/utils.d.ts.map +1 -1
  143. package/dist/esm/browser/storage.d.ts +3 -0
  144. package/dist/esm/browser/storage.d.ts.map +1 -1
  145. package/dist/esm/browser/storage.js +8 -0
  146. package/dist/esm/browser/storage.js.map +1 -1
  147. package/dist/esm/lib/cookies.d.ts +2 -2
  148. package/dist/esm/lib/cookies.d.ts.map +1 -1
  149. package/dist/esm/lib/cookies.js +7 -5
  150. package/dist/esm/lib/cookies.js.map +1 -1
  151. package/dist/esm/lib/postMessage.js +1 -1
  152. package/dist/esm/lib/postMessage.js.map +1 -1
  153. package/dist/esm/lib/windowUtil.d.ts.map +1 -1
  154. package/dist/esm/lib/windowUtil.js +1 -0
  155. package/dist/esm/lib/windowUtil.js.map +1 -1
  156. package/dist/esm/nextjs/GetUser.d.ts.map +1 -1
  157. package/dist/esm/nextjs/GetUser.js +2 -13
  158. package/dist/esm/nextjs/GetUser.js.map +1 -1
  159. package/dist/esm/nextjs/config.d.ts.map +1 -1
  160. package/dist/esm/nextjs/config.js +12 -0
  161. package/dist/esm/nextjs/config.js.map +1 -1
  162. package/dist/esm/nextjs/hooks/index.d.ts +1 -1
  163. package/dist/esm/nextjs/hooks/index.d.ts.map +1 -1
  164. package/dist/esm/nextjs/hooks/index.js +1 -1
  165. package/dist/esm/nextjs/hooks/index.js.map +1 -1
  166. package/dist/esm/nextjs/hooks/useUserCookie.d.ts +4 -1
  167. package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  168. package/dist/esm/nextjs/hooks/useUserCookie.js +45 -17
  169. package/dist/esm/nextjs/hooks/useUserCookie.js.map +1 -1
  170. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +5 -1
  171. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  172. package/dist/esm/nextjs/providers/NextAuthProvider.js +59 -30
  173. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -1
  174. package/dist/esm/nextjs/routeHandler.js +2 -2
  175. package/dist/esm/nextjs/routeHandler.js.map +1 -1
  176. package/dist/esm/reactjs/components/UserButton.js +3 -3
  177. package/dist/esm/reactjs/components/UserButton.js.map +1 -1
  178. package/dist/esm/reactjs/hooks/index.d.ts +0 -1
  179. package/dist/esm/reactjs/hooks/index.d.ts.map +1 -1
  180. package/dist/esm/reactjs/hooks/index.js +0 -1
  181. package/dist/esm/reactjs/hooks/index.js.map +1 -1
  182. package/dist/esm/services/AuthenticationService.d.ts +4 -1
  183. package/dist/esm/services/AuthenticationService.d.ts.map +1 -1
  184. package/dist/esm/services/AuthenticationService.js +39 -8
  185. package/dist/esm/services/AuthenticationService.js.map +1 -1
  186. package/dist/esm/shared/components/BlockDisplay.d.ts +7 -0
  187. package/dist/esm/shared/components/BlockDisplay.d.ts.map +1 -0
  188. package/dist/esm/shared/components/BlockDisplay.js +25 -0
  189. package/dist/esm/shared/components/BlockDisplay.js.map +1 -0
  190. package/dist/esm/shared/components/CivicAuthIframe.js +1 -1
  191. package/dist/esm/shared/components/CivicAuthIframe.js.map +1 -1
  192. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  193. package/dist/esm/shared/components/CivicAuthIframeContainer.js +23 -14
  194. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +1 -1
  195. package/dist/esm/shared/components/IFrameAndLoading.d.ts +7 -0
  196. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -0
  197. package/dist/esm/shared/components/IFrameAndLoading.js +22 -0
  198. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -0
  199. package/dist/esm/shared/hooks/index.d.ts +5 -1
  200. package/dist/esm/shared/hooks/index.d.ts.map +1 -1
  201. package/dist/esm/shared/hooks/index.js +5 -1
  202. package/dist/esm/shared/hooks/index.js.map +1 -1
  203. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  204. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  205. package/dist/esm/shared/hooks/useCivicAuthConfig.js +10 -0
  206. package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +1 -0
  207. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  208. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  209. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +13 -0
  210. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  211. package/dist/esm/shared/hooks/useCurrentUrl.d.ts +3 -0
  212. package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  213. package/dist/esm/shared/hooks/useCurrentUrl.js +24 -0
  214. package/dist/esm/shared/hooks/useCurrentUrl.js.map +1 -0
  215. package/dist/esm/shared/hooks/useIsInIframe.d.ts +3 -0
  216. package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +1 -0
  217. package/dist/esm/shared/hooks/useIsInIframe.js +14 -0
  218. package/dist/esm/shared/hooks/useIsInIframe.js.map +1 -0
  219. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  220. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  221. package/dist/esm/shared/hooks/useOAuthEndpoints.js +14 -0
  222. package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +1 -0
  223. package/dist/esm/shared/hooks/useRefresh.d.ts +4 -0
  224. package/dist/esm/shared/hooks/useRefresh.d.ts.map +1 -0
  225. package/dist/esm/shared/hooks/useRefresh.js +38 -0
  226. package/dist/esm/shared/hooks/useRefresh.js.map +1 -0
  227. package/dist/esm/shared/hooks/useSession.d.ts +1 -1
  228. package/dist/esm/shared/hooks/useSession.d.ts.map +1 -1
  229. package/dist/esm/shared/hooks/useSignIn.d.ts +14 -0
  230. package/dist/esm/shared/hooks/useSignIn.d.ts.map +1 -0
  231. package/dist/esm/shared/hooks/useSignIn.js +71 -0
  232. package/dist/esm/shared/hooks/useSignIn.js.map +1 -0
  233. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  234. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  235. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js +30 -0
  236. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  237. package/dist/esm/shared/lib/session.d.ts +1 -1
  238. package/dist/esm/shared/lib/session.d.ts.map +1 -1
  239. package/dist/esm/shared/lib/session.js +12 -1
  240. package/dist/esm/shared/lib/session.js.map +1 -1
  241. package/dist/esm/shared/lib/types.d.ts +14 -1
  242. package/dist/esm/shared/lib/types.d.ts.map +1 -1
  243. package/dist/esm/shared/lib/types.js +2 -0
  244. package/dist/esm/shared/lib/types.js.map +1 -1
  245. package/dist/esm/shared/lib/util.d.ts.map +1 -1
  246. package/dist/esm/shared/lib/util.js +11 -2
  247. package/dist/esm/shared/lib/util.js.map +1 -1
  248. package/dist/esm/shared/providers/AuthProvider.d.ts +3 -2
  249. package/dist/esm/shared/providers/AuthProvider.d.ts.map +1 -1
  250. package/dist/esm/shared/providers/AuthProvider.js +37 -238
  251. package/dist/esm/shared/providers/AuthProvider.js.map +1 -1
  252. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  253. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  254. package/dist/esm/shared/providers/CivicAuthConfigContext.js +43 -0
  255. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +1 -0
  256. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  257. package/dist/esm/shared/providers/CivicAuthProvider.js +23 -6
  258. package/dist/esm/shared/providers/CivicAuthProvider.js.map +1 -1
  259. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  260. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  261. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +146 -0
  262. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  263. package/dist/esm/shared/providers/IframeProvider.d.ts +7 -4
  264. package/dist/esm/shared/providers/IframeProvider.d.ts.map +1 -1
  265. package/dist/esm/shared/providers/IframeProvider.js +21 -3
  266. package/dist/esm/shared/providers/IframeProvider.js.map +1 -1
  267. package/dist/esm/shared/providers/SessionProvider.d.ts +10 -4
  268. package/dist/esm/shared/providers/SessionProvider.d.ts.map +1 -1
  269. package/dist/esm/shared/providers/SessionProvider.js +15 -5
  270. package/dist/esm/shared/providers/SessionProvider.js.map +1 -1
  271. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -1
  272. package/dist/esm/shared/providers/TokenProvider.js +13 -24
  273. package/dist/esm/shared/providers/TokenProvider.js.map +1 -1
  274. package/dist/esm/shared/providers/UserProvider.d.ts +6 -4
  275. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -1
  276. package/dist/esm/shared/providers/UserProvider.js +33 -20
  277. package/dist/esm/shared/providers/UserProvider.js.map +1 -1
  278. package/dist/esm/types.d.ts +5 -5
  279. package/dist/esm/types.d.ts.map +1 -1
  280. package/dist/esm/types.js +3 -1
  281. package/dist/esm/types.js.map +1 -1
  282. package/dist/esm/utils.d.ts.map +1 -1
  283. package/dist/src/browser/storage.d.ts +3 -0
  284. package/dist/src/browser/storage.d.ts.map +1 -1
  285. package/dist/src/browser/storage.js +8 -0
  286. package/dist/src/browser/storage.js.map +1 -1
  287. package/dist/src/lib/cookies.d.ts +2 -2
  288. package/dist/src/lib/cookies.d.ts.map +1 -1
  289. package/dist/src/lib/cookies.js +7 -5
  290. package/dist/src/lib/cookies.js.map +1 -1
  291. package/dist/src/lib/postMessage.js +1 -1
  292. package/dist/src/lib/postMessage.js.map +1 -1
  293. package/dist/src/lib/windowUtil.d.ts.map +1 -1
  294. package/dist/src/lib/windowUtil.js +1 -0
  295. package/dist/src/lib/windowUtil.js.map +1 -1
  296. package/dist/src/nextjs/GetUser.d.ts.map +1 -1
  297. package/dist/src/nextjs/GetUser.js +2 -13
  298. package/dist/src/nextjs/GetUser.js.map +1 -1
  299. package/dist/src/nextjs/config.d.ts.map +1 -1
  300. package/dist/src/nextjs/config.js +12 -0
  301. package/dist/src/nextjs/config.js.map +1 -1
  302. package/dist/src/nextjs/hooks/index.d.ts +1 -1
  303. package/dist/src/nextjs/hooks/index.d.ts.map +1 -1
  304. package/dist/src/nextjs/hooks/index.js +1 -1
  305. package/dist/src/nextjs/hooks/index.js.map +1 -1
  306. package/dist/src/nextjs/hooks/useRefresh.d.ts +4 -0
  307. package/dist/src/nextjs/hooks/useRefresh.d.ts.map +1 -0
  308. package/dist/src/nextjs/hooks/useRefresh.js +38 -0
  309. package/dist/src/nextjs/hooks/useRefresh.js.map +1 -0
  310. package/dist/src/nextjs/hooks/useUserCookie.d.ts +4 -1
  311. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  312. package/dist/src/nextjs/hooks/useUserCookie.js +45 -17
  313. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -1
  314. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +5 -1
  315. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  316. package/dist/src/nextjs/providers/NextAuthProvider.js +59 -30
  317. package/dist/src/nextjs/providers/NextAuthProvider.js.map +1 -1
  318. package/dist/src/nextjs/routeHandler.js +2 -2
  319. package/dist/src/nextjs/routeHandler.js.map +1 -1
  320. package/dist/src/reactjs/components/UserButton.js +3 -3
  321. package/dist/src/reactjs/components/UserButton.js.map +1 -1
  322. package/dist/src/reactjs/hooks/index.d.ts +0 -1
  323. package/dist/src/reactjs/hooks/index.d.ts.map +1 -1
  324. package/dist/src/reactjs/hooks/index.js +0 -1
  325. package/dist/src/reactjs/hooks/index.js.map +1 -1
  326. package/dist/src/reactjs/hooks/useRefresh.d.ts +4 -0
  327. package/dist/src/reactjs/hooks/useRefresh.d.ts.map +1 -0
  328. package/dist/src/reactjs/hooks/useRefresh.js +28 -0
  329. package/dist/src/reactjs/hooks/useRefresh.js.map +1 -0
  330. package/dist/src/services/AuthenticationService.d.ts +4 -1
  331. package/dist/src/services/AuthenticationService.d.ts.map +1 -1
  332. package/dist/src/services/AuthenticationService.js +39 -8
  333. package/dist/src/services/AuthenticationService.js.map +1 -1
  334. package/dist/src/shared/components/BlockDisplay.d.ts +7 -0
  335. package/dist/src/shared/components/BlockDisplay.d.ts.map +1 -0
  336. package/dist/src/shared/components/BlockDisplay.js +25 -0
  337. package/dist/src/shared/components/BlockDisplay.js.map +1 -0
  338. package/dist/src/shared/components/CivicAuthIframe.js +1 -1
  339. package/dist/src/shared/components/CivicAuthIframe.js.map +1 -1
  340. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  341. package/dist/src/shared/components/CivicAuthIframeContainer.js +23 -14
  342. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +1 -1
  343. package/dist/src/shared/components/IFrameAndLoading.d.ts +7 -0
  344. package/dist/src/shared/components/IFrameAndLoading.d.ts.map +1 -0
  345. package/dist/src/shared/components/IFrameAndLoading.js +22 -0
  346. package/dist/src/shared/components/IFrameAndLoading.js.map +1 -0
  347. package/dist/src/shared/hooks/index.d.ts +5 -1
  348. package/dist/src/shared/hooks/index.d.ts.map +1 -1
  349. package/dist/src/shared/hooks/index.js +5 -1
  350. package/dist/src/shared/hooks/index.js.map +1 -1
  351. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  352. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  353. package/dist/src/shared/hooks/useCivicAuthConfig.js +10 -0
  354. package/dist/src/shared/hooks/useCivicAuthConfig.js.map +1 -0
  355. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  356. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  357. package/dist/src/shared/hooks/useClientTokenExchangeSession.js +13 -0
  358. package/dist/src/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  359. package/dist/src/shared/hooks/useCurrentUrl.d.ts +3 -0
  360. package/dist/src/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  361. package/dist/src/shared/hooks/useCurrentUrl.js +24 -0
  362. package/dist/src/shared/hooks/useCurrentUrl.js.map +1 -0
  363. package/dist/src/shared/hooks/useIsInIframe.d.ts +3 -0
  364. package/dist/src/shared/hooks/useIsInIframe.d.ts.map +1 -0
  365. package/dist/src/shared/hooks/useIsInIframe.js +14 -0
  366. package/dist/src/shared/hooks/useIsInIframe.js.map +1 -0
  367. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  368. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  369. package/dist/src/shared/hooks/useOAuthEndpoints.js +14 -0
  370. package/dist/src/shared/hooks/useOAuthEndpoints.js.map +1 -0
  371. package/dist/src/shared/hooks/useRefresh.d.ts +4 -0
  372. package/dist/src/shared/hooks/useRefresh.d.ts.map +1 -0
  373. package/dist/src/shared/hooks/useRefresh.js +38 -0
  374. package/dist/src/shared/hooks/useRefresh.js.map +1 -0
  375. package/dist/src/shared/hooks/useSession.d.ts +1 -1
  376. package/dist/src/shared/hooks/useSession.d.ts.map +1 -1
  377. package/dist/src/shared/hooks/useSignIn.d.ts +14 -0
  378. package/dist/src/shared/hooks/useSignIn.d.ts.map +1 -0
  379. package/dist/src/shared/hooks/useSignIn.js +71 -0
  380. package/dist/src/shared/hooks/useSignIn.js.map +1 -0
  381. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  382. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  383. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +30 -0
  384. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  385. package/dist/src/shared/lib/session.d.ts +1 -1
  386. package/dist/src/shared/lib/session.d.ts.map +1 -1
  387. package/dist/src/shared/lib/session.js +12 -1
  388. package/dist/src/shared/lib/session.js.map +1 -1
  389. package/dist/src/shared/lib/types.d.ts +14 -1
  390. package/dist/src/shared/lib/types.d.ts.map +1 -1
  391. package/dist/src/shared/lib/types.js +2 -0
  392. package/dist/src/shared/lib/types.js.map +1 -1
  393. package/dist/src/shared/lib/util.d.ts.map +1 -1
  394. package/dist/src/shared/lib/util.js +11 -2
  395. package/dist/src/shared/lib/util.js.map +1 -1
  396. package/dist/src/shared/providers/AuthProvider.d.ts +3 -2
  397. package/dist/src/shared/providers/AuthProvider.d.ts.map +1 -1
  398. package/dist/src/shared/providers/AuthProvider.js +37 -238
  399. package/dist/src/shared/providers/AuthProvider.js.map +1 -1
  400. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  401. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  402. package/dist/src/shared/providers/CivicAuthConfigContext.js +43 -0
  403. package/dist/src/shared/providers/CivicAuthConfigContext.js.map +1 -0
  404. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  405. package/dist/src/shared/providers/CivicAuthProvider.js +23 -6
  406. package/dist/src/shared/providers/CivicAuthProvider.js.map +1 -1
  407. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  408. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  409. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js +146 -0
  410. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  411. package/dist/src/shared/providers/IframeProvider.d.ts +7 -4
  412. package/dist/src/shared/providers/IframeProvider.d.ts.map +1 -1
  413. package/dist/src/shared/providers/IframeProvider.js +21 -3
  414. package/dist/src/shared/providers/IframeProvider.js.map +1 -1
  415. package/dist/src/shared/providers/SessionProvider.d.ts +10 -4
  416. package/dist/src/shared/providers/SessionProvider.d.ts.map +1 -1
  417. package/dist/src/shared/providers/SessionProvider.js +15 -5
  418. package/dist/src/shared/providers/SessionProvider.js.map +1 -1
  419. package/dist/src/shared/providers/TokenProvider.d.ts.map +1 -1
  420. package/dist/src/shared/providers/TokenProvider.js +13 -24
  421. package/dist/src/shared/providers/TokenProvider.js.map +1 -1
  422. package/dist/src/shared/providers/UserProvider.d.ts +6 -4
  423. package/dist/src/shared/providers/UserProvider.d.ts.map +1 -1
  424. package/dist/src/shared/providers/UserProvider.js +33 -20
  425. package/dist/src/shared/providers/UserProvider.js.map +1 -1
  426. package/dist/src/types.d.ts +5 -5
  427. package/dist/src/types.d.ts.map +1 -1
  428. package/dist/src/types.js +3 -1
  429. package/dist/src/types.js.map +1 -1
  430. package/dist/test/integration/sdk.test.d.ts.map +1 -1
  431. package/dist/test/integration/sdk.test.js +39 -33
  432. package/dist/test/integration/sdk.test.js.map +1 -1
  433. package/dist/test/unit/nextjs/NextAuthProvider.test.js +8 -6
  434. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +1 -1
  435. package/dist/test/unit/nextjs/getUser.test.js +2 -16
  436. package/dist/test/unit/nextjs/getUser.test.js.map +1 -1
  437. package/dist/test/unit/server/refresh.test.d.ts.map +1 -0
  438. package/dist/test/unit/services/AuthenticationService.test.js +18 -1
  439. package/dist/test/unit/services/AuthenticationService.test.js.map +1 -1
  440. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +12 -10
  441. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +1 -1
  442. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  443. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  444. package/dist/tsconfig.tsbuildinfo +1 -1
  445. package/package.json +7 -1
  446. package/.eslintignore +0 -3
  447. package/.eslintrc.json +0 -10
  448. package/.prettierignore +0 -3
  449. package/.prettierrc +0 -1
  450. package/.turbo/turbo-build.log +0 -13
  451. package/.turbo/turbo-lint$colon$fix.log +0 -10
  452. package/.turbo/turbo-test.log +0 -1153
  453. package/dist/cjs/nextjs/hooks/useTokenCookie.d.ts +0 -3
  454. package/dist/cjs/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  455. package/dist/cjs/nextjs/hooks/useTokenCookie.js +0 -41
  456. package/dist/cjs/nextjs/hooks/useTokenCookie.js.map +0 -1
  457. package/dist/cjs/shared/hooks/useConfig.d.ts +0 -3
  458. package/dist/cjs/shared/hooks/useConfig.d.ts.map +0 -1
  459. package/dist/cjs/shared/hooks/useConfig.js +0 -16
  460. package/dist/cjs/shared/hooks/useConfig.js.map +0 -1
  461. package/dist/cjs/shared/providers/ConfigProvider.d.ts +0 -21
  462. package/dist/cjs/shared/providers/ConfigProvider.d.ts.map +0 -1
  463. package/dist/cjs/shared/providers/ConfigProvider.js +0 -46
  464. package/dist/cjs/shared/providers/ConfigProvider.js.map +0 -1
  465. package/dist/esm/nextjs/hooks/useTokenCookie.d.ts +0 -3
  466. package/dist/esm/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  467. package/dist/esm/nextjs/hooks/useTokenCookie.js +0 -37
  468. package/dist/esm/nextjs/hooks/useTokenCookie.js.map +0 -1
  469. package/dist/esm/shared/hooks/useConfig.d.ts +0 -3
  470. package/dist/esm/shared/hooks/useConfig.d.ts.map +0 -1
  471. package/dist/esm/shared/hooks/useConfig.js +0 -13
  472. package/dist/esm/shared/hooks/useConfig.js.map +0 -1
  473. package/dist/esm/shared/providers/ConfigProvider.d.ts +0 -21
  474. package/dist/esm/shared/providers/ConfigProvider.d.ts.map +0 -1
  475. package/dist/esm/shared/providers/ConfigProvider.js +0 -19
  476. package/dist/esm/shared/providers/ConfigProvider.js.map +0 -1
  477. package/dist/src/config.d.ts +0 -3
  478. package/dist/src/config.js +0 -5
  479. package/dist/src/config.js.map +0 -1
  480. package/dist/src/constants.d.ts +0 -9
  481. package/dist/src/constants.d.ts.map +0 -1
  482. package/dist/src/constants.js +0 -17
  483. package/dist/src/constants.js.map +0 -1
  484. package/dist/src/index.d.ts +0 -4
  485. package/dist/src/index.js +0 -2
  486. package/dist/src/index.js.map +0 -1
  487. package/dist/src/lib/jwt.d.ts +0 -3
  488. package/dist/src/lib/jwt.js +0 -9
  489. package/dist/src/lib/jwt.js.map +0 -1
  490. package/dist/src/lib/logger.d.ts +0 -26
  491. package/dist/src/lib/logger.d.ts.map +0 -1
  492. package/dist/src/lib/logger.js +0 -55
  493. package/dist/src/lib/logger.js.map +0 -1
  494. package/dist/src/lib/oauth.d.ts +0 -19
  495. package/dist/src/lib/oauth.js +0 -60
  496. package/dist/src/lib/oauth.js.map +0 -1
  497. package/dist/src/lib/postMessage.d.ts +0 -4
  498. package/dist/src/lib/windowUtil.d.ts +0 -4
  499. package/dist/src/nextjs/GetUser.d.ts +0 -6
  500. package/dist/src/nextjs/config.d.ts +0 -178
  501. package/dist/src/nextjs/cookies.d.ts +0 -30
  502. package/dist/src/nextjs/cookies.js +0 -112
  503. package/dist/src/nextjs/cookies.js.map +0 -1
  504. package/dist/src/nextjs/index.d.ts +0 -7
  505. package/dist/src/nextjs/index.js +0 -6
  506. package/dist/src/nextjs/index.js.map +0 -1
  507. package/dist/src/nextjs/middleware/index.d.ts +0 -2
  508. package/dist/src/nextjs/middleware/index.js +0 -2
  509. package/dist/src/nextjs/middleware/index.js.map +0 -1
  510. package/dist/src/nextjs/middleware.d.ts +0 -59
  511. package/dist/src/nextjs/middleware.js +0 -107
  512. package/dist/src/nextjs/middleware.js.map +0 -1
  513. package/dist/src/nextjs/routeHandler.d.ts +0 -18
  514. package/dist/src/nextjs/utils.d.ts +0 -3
  515. package/dist/src/nextjs/utils.js +0 -5
  516. package/dist/src/nextjs/utils.js.map +0 -1
  517. package/dist/src/reactjs/components/SignInButton.d.ts +0 -8
  518. package/dist/src/reactjs/components/SignInButton.js +0 -14
  519. package/dist/src/reactjs/components/SignInButton.js.map +0 -1
  520. package/dist/src/reactjs/components/SignOutButton.d.ts +0 -6
  521. package/dist/src/reactjs/components/SignOutButton.js +0 -14
  522. package/dist/src/reactjs/components/SignOutButton.js.map +0 -1
  523. package/dist/src/reactjs/components/UserButton.d.ts +0 -8
  524. package/dist/src/reactjs/components/index.d.ts +0 -6
  525. package/dist/src/reactjs/components/index.js +0 -6
  526. package/dist/src/reactjs/components/index.js.map +0 -1
  527. package/dist/src/reactjs/hooks/useAuth.d.ts +0 -3
  528. package/dist/src/reactjs/hooks/useAuth.js +0 -12
  529. package/dist/src/reactjs/hooks/useAuth.js.map +0 -1
  530. package/dist/src/reactjs/hooks/useUser.d.ts +0 -4
  531. package/dist/src/reactjs/hooks/useUser.js +0 -12
  532. package/dist/src/reactjs/hooks/useUser.js.map +0 -1
  533. package/dist/src/reactjs/index.d.ts +0 -6
  534. package/dist/src/reactjs/index.js +0 -8
  535. package/dist/src/reactjs/index.js.map +0 -1
  536. package/dist/src/reactjs/providers/index.d.ts +0 -8
  537. package/dist/src/reactjs/providers/index.js +0 -7
  538. package/dist/src/reactjs/providers/index.js.map +0 -1
  539. package/dist/src/server/ServerAuthenticationResolver.d.ts +0 -19
  540. package/dist/src/server/ServerAuthenticationResolver.js +0 -61
  541. package/dist/src/server/ServerAuthenticationResolver.js.map +0 -1
  542. package/dist/src/server/config.d.ts +0 -9
  543. package/dist/src/server/config.js +0 -2
  544. package/dist/src/server/config.js.map +0 -1
  545. package/dist/src/server/index.d.ts +0 -7
  546. package/dist/src/server/index.js +0 -5
  547. package/dist/src/server/index.js.map +0 -1
  548. package/dist/src/server/login.d.ts +0 -17
  549. package/dist/src/server/login.js +0 -37
  550. package/dist/src/server/login.js.map +0 -1
  551. package/dist/src/server/refresh.d.ts +0 -7
  552. package/dist/src/server/refresh.js +0 -13
  553. package/dist/src/server/refresh.js.map +0 -1
  554. package/dist/src/services/PKCE.d.ts +0 -20
  555. package/dist/src/services/PKCE.js +0 -44
  556. package/dist/src/services/PKCE.js.map +0 -1
  557. package/dist/src/services/types.d.ts +0 -23
  558. package/dist/src/services/types.js +0 -7
  559. package/dist/src/services/types.js.map +0 -1
  560. package/dist/src/shared/components/CivicAuthIframe.d.ts +0 -8
  561. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts +0 -9
  562. package/dist/src/shared/components/CloseIcon.d.ts +0 -4
  563. package/dist/src/shared/components/CloseIcon.d.ts.map +0 -1
  564. package/dist/src/shared/components/CloseIcon.js +0 -6
  565. package/dist/src/shared/components/CloseIcon.js.map +0 -1
  566. package/dist/src/shared/components/LoadingIcon.d.ts +0 -4
  567. package/dist/src/shared/components/LoadingIcon.d.ts.map +0 -1
  568. package/dist/src/shared/components/LoadingIcon.js +0 -30
  569. package/dist/src/shared/components/LoadingIcon.js.map +0 -1
  570. package/dist/src/shared/hooks/useAuth.d.ts +0 -3
  571. package/dist/src/shared/hooks/useAuth.js +0 -12
  572. package/dist/src/shared/hooks/useAuth.js.map +0 -1
  573. package/dist/src/shared/hooks/useIframe.d.ts +0 -3
  574. package/dist/src/shared/hooks/useIframe.js +0 -13
  575. package/dist/src/shared/hooks/useIframe.js.map +0 -1
  576. package/dist/src/shared/hooks/useSession.js +0 -13
  577. package/dist/src/shared/hooks/useSession.js.map +0 -1
  578. package/dist/src/shared/hooks/useToken.d.ts +0 -3
  579. package/dist/src/shared/hooks/useToken.js +0 -12
  580. package/dist/src/shared/hooks/useToken.js.map +0 -1
  581. package/dist/src/shared/lib/UserSession.d.ts +0 -12
  582. package/dist/src/shared/lib/UserSession.js +0 -20
  583. package/dist/src/shared/lib/UserSession.js.map +0 -1
  584. package/dist/src/shared/lib/storage.d.ts +0 -25
  585. package/dist/src/shared/lib/storage.js +0 -17
  586. package/dist/src/shared/lib/storage.js.map +0 -1
  587. package/dist/src/shared/lib/util.d.ts +0 -33
  588. package/dist/src/shared/providers/AuthContext.d.ts +0 -10
  589. package/dist/src/shared/providers/AuthContext.js +0 -3
  590. package/dist/src/shared/providers/AuthContext.js.map +0 -1
  591. package/dist/src/shared/providers/CivicAuthProvider.d.ts +0 -6
  592. package/dist/src/shared/providers/TokenProvider.d.ts +0 -18
  593. package/dist/src/utils.d.ts +0 -15
  594. package/dist/src/utils.d.ts.map +0 -1
  595. package/dist/src/utils.js +0 -43
  596. package/dist/src/utils.js.map +0 -1
  597. package/dist/test/integration/sdk.test.d.ts +0 -2
  598. package/dist/test/support/fixtures.d.ts +0 -26
  599. package/dist/test/support/fixtures.d.ts.map +0 -1
  600. package/dist/test/support/fixtures.js +0 -55
  601. package/dist/test/support/fixtures.js.map +0 -1
  602. package/dist/test/support/tokens.json +0 -26
  603. package/dist/test/unit/lib/oauth.test.d.ts +0 -2
  604. package/dist/test/unit/lib/oauth.test.js +0 -55
  605. package/dist/test/unit/lib/oauth.test.js.map +0 -1
  606. package/dist/test/unit/logger.test.d.ts +0 -2
  607. package/dist/test/unit/logger.test.d.ts.map +0 -1
  608. package/dist/test/unit/logger.test.js +0 -141
  609. package/dist/test/unit/logger.test.js.map +0 -1
  610. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +0 -2
  611. package/dist/test/unit/nextjs/config.test.d.ts +0 -2
  612. package/dist/test/unit/nextjs/config.test.js +0 -189
  613. package/dist/test/unit/nextjs/config.test.js.map +0 -1
  614. package/dist/test/unit/nextjs/getUser.test.d.ts +0 -2
  615. package/dist/test/unit/nextjs/middleware.test.d.ts +0 -2
  616. package/dist/test/unit/nextjs/middleware.test.js +0 -113
  617. package/dist/test/unit/nextjs/middleware.test.js.map +0 -1
  618. package/dist/test/unit/nextjs/utils.test.d.ts +0 -2
  619. package/dist/test/unit/nextjs/utils.test.js +0 -13
  620. package/dist/test/unit/nextjs/utils.test.js.map +0 -1
  621. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +0 -2
  622. package/dist/test/unit/publicApi/apiSnapshot.test.js +0 -10
  623. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +0 -1
  624. package/dist/test/unit/react/components/SignInButton.test.d.ts +0 -2
  625. package/dist/test/unit/react/components/SignInButton.test.js +0 -31
  626. package/dist/test/unit/react/components/SignInButton.test.js.map +0 -1
  627. package/dist/test/unit/react/components/SignOutButton.test.d.ts +0 -2
  628. package/dist/test/unit/react/components/SignOutButton.test.js +0 -30
  629. package/dist/test/unit/react/components/SignOutButton.test.js.map +0 -1
  630. package/dist/test/unit/server/login.test.d.ts +0 -2
  631. package/dist/test/unit/server/login.test.js +0 -127
  632. package/dist/test/unit/server/login.test.js.map +0 -1
  633. package/dist/test/unit/server/session.test.d.ts +0 -2
  634. package/dist/test/unit/server/session.test.js +0 -41
  635. package/dist/test/unit/server/session.test.js.map +0 -1
  636. package/dist/test/unit/services/AuthenticationService.test.d.ts +0 -2
  637. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +0 -2
  638. package/dist/test/unit/services/ServerAuthenticationResolver.test.js +0 -74
  639. package/dist/test/unit/services/ServerAuthenticationResolver.test.js.map +0 -1
  640. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +0 -2
  641. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js +0 -61
  642. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js.map +0 -1
  643. package/dist/test/unit/shared/UserSession.test.d.ts +0 -2
  644. package/dist/test/unit/shared/UserSession.test.js +0 -37
  645. package/dist/test/unit/shared/UserSession.test.js.map +0 -1
  646. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +0 -2
  647. package/dist/test/unit/shared/storage.test.d.ts +0 -2
  648. package/dist/test/unit/shared/storage.test.js +0 -53
  649. package/dist/test/unit/shared/storage.test.js.map +0 -1
  650. package/dist/test/unit/utils.test.d.ts +0 -2
  651. package/dist/test/unit/utils.test.d.ts.map +0 -1
  652. package/dist/test/unit/utils.test.js +0 -40
  653. package/dist/test/unit/utils.test.js.map +0 -1
  654. package/dist/vitest.config.d.ts +0 -3
  655. package/dist/vitest.config.d.ts.map +0 -1
  656. package/dist/vitest.config.js +0 -40
  657. package/dist/vitest.config.js.map +0 -1
  658. package/src/browser/storage.ts +0 -11
  659. package/src/config.ts +0 -6
  660. package/src/constants.ts +0 -29
  661. package/src/index.ts +0 -16
  662. package/src/lib/cookies.ts +0 -28
  663. package/src/lib/jwt.ts +0 -15
  664. package/src/lib/logger.ts +0 -72
  665. package/src/lib/oauth.ts +0 -83
  666. package/src/lib/postMessage.ts +0 -22
  667. package/src/lib/windowUtil.ts +0 -29
  668. package/src/nextjs/GetUser.ts +0 -22
  669. package/src/nextjs/config.ts +0 -203
  670. package/src/nextjs/cookies.ts +0 -162
  671. package/src/nextjs/hooks/index.ts +0 -1
  672. package/src/nextjs/hooks/useTokenCookie.ts +0 -41
  673. package/src/nextjs/hooks/useUserCookie.ts +0 -41
  674. package/src/nextjs/index.ts +0 -20
  675. package/src/nextjs/middleware/index.ts +0 -1
  676. package/src/nextjs/middleware.ts +0 -155
  677. package/src/nextjs/providers/NextAuthProvider.tsx +0 -87
  678. package/src/nextjs/routeHandler.ts +0 -297
  679. package/src/nextjs/utils.ts +0 -9
  680. package/src/reactjs/components/SignInButton.tsx +0 -32
  681. package/src/reactjs/components/SignOutButton.tsx +0 -24
  682. package/src/reactjs/components/UserButton.tsx +0 -239
  683. package/src/reactjs/components/index.ts +0 -5
  684. package/src/reactjs/hooks/index.ts +0 -6
  685. package/src/reactjs/hooks/useAuth.ts +0 -15
  686. package/src/reactjs/hooks/useUser.ts +0 -20
  687. package/src/reactjs/index.ts +0 -19
  688. package/src/reactjs/providers/index.ts +0 -27
  689. package/src/server/ServerAuthenticationResolver.ts +0 -107
  690. package/src/server/config.ts +0 -9
  691. package/src/server/index.ts +0 -13
  692. package/src/server/login.ts +0 -59
  693. package/src/server/refresh.ts +0 -23
  694. package/src/services/AuthenticationService.ts +0 -329
  695. package/src/services/PKCE.ts +0 -45
  696. package/src/services/types.ts +0 -54
  697. package/src/shared/components/CivicAuthIframe.tsx +0 -26
  698. package/src/shared/components/CivicAuthIframeContainer.tsx +0 -195
  699. package/src/shared/components/CloseIcon.tsx +0 -21
  700. package/src/shared/components/LoadingIcon.tsx +0 -53
  701. package/src/shared/hooks/index.ts +0 -4
  702. package/src/shared/hooks/useAuth.ts +0 -15
  703. package/src/shared/hooks/useConfig.ts +0 -14
  704. package/src/shared/hooks/useIframe.ts +0 -14
  705. package/src/shared/hooks/useSession.ts +0 -14
  706. package/src/shared/hooks/useToken.ts +0 -15
  707. package/src/shared/lib/GenericAuthenticationRefresher.ts +0 -75
  708. package/src/shared/lib/UserSession.ts +0 -25
  709. package/src/shared/lib/session.ts +0 -11
  710. package/src/shared/lib/storage.ts +0 -40
  711. package/src/shared/lib/types.ts +0 -26
  712. package/src/shared/lib/util.ts +0 -212
  713. package/src/shared/providers/AuthContext.tsx +0 -11
  714. package/src/shared/providers/AuthProvider.tsx +0 -397
  715. package/src/shared/providers/CivicAuthProvider.tsx +0 -31
  716. package/src/shared/providers/ConfigProvider.tsx +0 -50
  717. package/src/shared/providers/IframeProvider.tsx +0 -34
  718. package/src/shared/providers/SessionProvider.tsx +0 -29
  719. package/src/shared/providers/TokenProvider.tsx +0 -78
  720. package/src/shared/providers/UserProvider.tsx +0 -80
  721. package/src/types.ts +0 -227
  722. package/src/utils.ts +0 -58
  723. package/test/integration/sdk.test.tsx +0 -266
  724. package/test/support/fixtures.ts +0 -56
  725. package/test/support/tokens.json +0 -26
  726. package/test/unit/lib/oauth.test.ts +0 -72
  727. package/test/unit/logger.test.ts +0 -175
  728. package/test/unit/nextjs/NextAuthProvider.test.tsx +0 -38
  729. package/test/unit/nextjs/config.test.ts +0 -218
  730. package/test/unit/nextjs/getUser.test.ts +0 -41
  731. package/test/unit/nextjs/middleware.test.ts +0 -138
  732. package/test/unit/nextjs/routeHandler.test.ts.skipped +0 -369
  733. package/test/unit/nextjs/utils.test.ts +0 -17
  734. package/test/unit/publicApi/__snapshots__/apiSnapshot.test.ts.snap +0 -17
  735. package/test/unit/publicApi/apiSnapshot.test.ts +0 -11
  736. package/test/unit/react/components/SignInButton.test.tsx +0 -50
  737. package/test/unit/react/components/SignOutButton.test.tsx +0 -49
  738. package/test/unit/server/login.test.ts +0 -181
  739. package/test/unit/server/session.test.ts +0 -51
  740. package/test/unit/services/AuthenticationService.test.ts +0 -152
  741. package/test/unit/services/ServerAuthenticationResolver.test.ts +0 -115
  742. package/test/unit/shared/GenericAuthenticationRefresher.test.ts +0 -89
  743. package/test/unit/shared/UserSession.test.ts +0 -42
  744. package/test/unit/shared/components/CivicAuthIframeContainer.test.tsx +0 -154
  745. package/test/unit/shared/storage.test.ts +0 -67
  746. package/test/unit/utils.test.ts +0 -48
  747. package/tsconfig.build.json +0 -9
  748. package/tsconfig.cjs.json +0 -8
  749. package/tsconfig.esm.json +0 -7
  750. package/tsconfig.json +0 -42
  751. package/tsconfig.tsbuildinfo +0 -1
  752. package/vitest.config.ts +0 -41
@@ -16,49 +16,72 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
16
16
  }) : function(o, v) {
17
17
  o["default"] = v;
18
18
  });
19
- var __importStar = (this && this.__importStar) || function (mod) {
20
- if (mod && mod.__esModule) return mod;
21
- var result = {};
22
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
23
- __setModuleDefault(result, mod);
24
- return result;
25
- };
19
+ var __importStar = (this && this.__importStar) || (function () {
20
+ var ownKeys = function(o) {
21
+ ownKeys = Object.getOwnPropertyNames || function (o) {
22
+ var ar = [];
23
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
24
+ return ar;
25
+ };
26
+ return ownKeys(o);
27
+ };
28
+ return function (mod) {
29
+ if (mod && mod.__esModule) return mod;
30
+ var result = {};
31
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
32
+ __setModuleDefault(result, mod);
33
+ return result;
34
+ };
35
+ })();
26
36
  Object.defineProperty(exports, "__esModule", { value: true });
27
37
  exports.UserContext = exports.UserProvider = void 0;
28
38
  const react_1 = __importStar(require("react"));
29
- const react_query_1 = require("@tanstack/react-query");
30
- const useAuth_js_1 = require("../../shared/hooks/useAuth.js");
31
- const useToken_js_1 = require("../../shared/hooks/useToken.js");
32
39
  const useSession_js_1 = require("../../shared/hooks/useSession.js");
33
40
  const UserSession_js_1 = require("../../shared/lib/UserSession.js");
41
+ const useToken_js_1 = require("../hooks/useToken.js");
34
42
  const UserContext = (0, react_1.createContext)(null);
35
43
  exports.UserContext = UserContext;
36
- const UserProvider = ({ children, storage, user: inputUser, signOut: inputSignOut, }) => {
37
- const { isLoading: authLoading, error: authError } = (0, useAuth_js_1.useAuth)();
38
- const session = (0, useSession_js_1.useSession)();
39
- const { accessToken, idToken } = (0, useToken_js_1.useToken)();
40
- const { signIn, signOut } = (0, useAuth_js_1.useAuth)();
41
- const fetchUser = async () => {
42
- if (!accessToken) {
44
+ const UserProvider = ({ children, storage, user: inputUser = null, signOut, signIn, }) => {
45
+ const { error: authError, isLoading: authLoading } = (0, useSession_js_1.useSession)();
46
+ const { data: session } = (0, useSession_js_1.useSession)();
47
+ const tokens = (0, useToken_js_1.useToken)();
48
+ const [userLoading, setUserLoading] = (0, react_1.useState)(false);
49
+ const [userError, setUserError] = (0, react_1.useState)(null);
50
+ const [user, setUser] = (0, react_1.useState)(null);
51
+ const fetchUser = (0, react_1.useCallback)(async () => {
52
+ if (!session?.idToken) {
43
53
  return null;
44
54
  }
45
55
  const userSession = new UserSession_js_1.GenericUserSession(storage);
46
56
  return userSession.get();
47
- };
48
- const { data: user, isLoading: userLoading, error: userError, } = (0, react_query_1.useQuery)({
49
- queryKey: ["user", session?.idToken],
50
- queryFn: fetchUser,
51
- enabled: !!session?.idToken, // Only run the query if we have an access token
52
- });
57
+ }, [session?.idToken, storage]);
58
+ (0, react_1.useEffect)(() => {
59
+ if (!session?.idToken) {
60
+ setUser(null);
61
+ return;
62
+ }
63
+ if (session?.idToken) {
64
+ setUserLoading(true);
65
+ fetchUser()
66
+ .then((user) => {
67
+ setUserLoading(false);
68
+ setUser(user);
69
+ })
70
+ .catch((error) => {
71
+ setUserLoading(false);
72
+ setUserError(error);
73
+ });
74
+ }
75
+ }, [fetchUser, session?.idToken]);
53
76
  const isLoading = authLoading || userLoading;
54
77
  const error = authError || userError;
55
- const userWithIdToken = user ? { ...user, idToken } : null;
56
78
  return (react_1.default.createElement(UserContext.Provider, { value: {
57
- user: (inputUser || userWithIdToken) ?? null,
79
+ ...tokens,
80
+ user: (inputUser || user) ?? null,
58
81
  isLoading,
59
82
  error,
60
83
  signIn,
61
- signOut: inputSignOut || signOut,
84
+ signOut,
62
85
  } }, children));
63
86
  };
64
87
  exports.UserProvider = UserProvider;
@@ -1 +1 @@
1
- {"version":3,"file":"UserProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;AAEb,+CAA6C;AAG7C,uDAAiD;AAGjD,0DAAoD;AACpD,4DAAsD;AACtD,gEAA0D;AAE1D,gEAAiE;AASjE,MAAM,WAAW,GAAG,IAAA,qBAAa,EAAyB,IAAI,CAAC,CAAC;AA0DzC,kCAAW;AAxDlC,MAAM,YAAY,GAAG,CAAwB,EAC3C,QAAQ,EACR,OAAO,EACP,IAAI,EAAE,SAAS,EACf,OAAO,EAAE,YAAY,GAMtB,EAAE,EAAE;IACH,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAA,oBAAO,GAAE,CAAC;IAC/D,MAAM,OAAO,GAAG,IAAA,0BAAU,GAAE,CAAC;IAC7B,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,IAAA,sBAAQ,GAAE,CAAC;IAC5C,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,IAAA,oBAAO,GAAE,CAAC;IAEtC,MAAM,SAAS,GAAG,KAAK,IAA0B,EAAE;QACjD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,WAAW,GAAG,IAAI,mCAAkB,CAAC,OAAO,CAAC,CAAC;QACpD,OAAO,WAAW,CAAC,GAAG,EAAE,CAAC;IAC3B,CAAC,CAAC;IAEF,MAAM,EACJ,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,WAAW,EACtB,KAAK,EAAE,SAAS,GACjB,GAA0C,IAAA,sBAAQ,EAAC;QAClD,QAAQ,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC;QACpC,OAAO,EAAE,SAAS;QAClB,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,gDAAgD;KAC9E,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,WAAW,IAAI,WAAW,CAAC;IAC7C,MAAM,KAAK,GAAG,SAAS,IAAI,SAAS,CAAC;IAErC,MAAM,eAAe,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IAE3D,OAAO,CACL,8BAAC,WAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,IAAI,EAAE,CAAC,SAAS,IAAI,eAAe,CAAC,IAAI,IAAI;YAC5C,SAAS;YACT,KAAK;YACL,MAAM;YACN,OAAO,EAAE,YAAY,IAAI,OAAO;SACjC,IAEA,QAAQ,CACY,CACxB,CAAC;AACJ,CAAC,CAAC;AAIO,oCAAY","sourcesContent":["\"use client\";\n\nimport React, { createContext } from \"react\";\nimport type { ReactNode } from \"react\";\nimport type { UseQueryResult } from \"@tanstack/react-query\";\nimport { useQuery } from \"@tanstack/react-query\";\nimport type { JWT } from \"oslo/jwt\";\nimport type { AuthStorage, EmptyObject, User } from \"@/types.js\";\nimport { useAuth } from \"@/shared/hooks/useAuth.js\";\nimport { useToken } from \"@/shared/hooks/useToken.js\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { AuthContextType } from \"@/shared/providers/AuthContext.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\n\ntype UserContextType<\n T extends Record<string, unknown> & JWT[\"payload\"] = Record<string, unknown> &\n JWT[\"payload\"],\n> = {\n user: User<T> | null;\n} & Omit<AuthContextType, \"isAuthenticated\">;\n\nconst UserContext = createContext<UserContextType | null>(null);\n\nconst UserProvider = <T extends EmptyObject>({\n children,\n storage,\n user: inputUser,\n signOut: inputSignOut,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user?: User<T> | null;\n signOut?: () => Promise<void>;\n}) => {\n const { isLoading: authLoading, error: authError } = useAuth();\n const session = useSession();\n const { accessToken, idToken } = useToken();\n const { signIn, signOut } = useAuth();\n\n const fetchUser = async (): Promise<User | null> => {\n if (!accessToken) {\n return null;\n }\n const userSession = new GenericUserSession(storage);\n return userSession.get();\n };\n\n const {\n data: user,\n isLoading: userLoading,\n error: userError,\n }: UseQueryResult<User<T> | null, Error> = useQuery({\n queryKey: [\"user\", session?.idToken],\n queryFn: fetchUser,\n enabled: !!session?.idToken, // Only run the query if we have an access token\n });\n\n const isLoading = authLoading || userLoading;\n const error = authError || userError;\n\n const userWithIdToken = user ? { ...user, idToken } : null;\n\n return (\n <UserContext.Provider\n value={{\n user: (inputUser || userWithIdToken) ?? null,\n isLoading,\n error,\n signIn,\n signOut: inputSignOut || signOut,\n }}\n >\n {children}\n </UserContext.Provider>\n );\n};\n\nexport type { UserContextType };\n\nexport { UserProvider, UserContext };\n"]}
1
+ {"version":3,"file":"UserProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEb,+CAA+E;AAI/E,gEAA0D;AAE1D,gEAAiE;AAEjE,sDAAgD;AAUhD,MAAM,WAAW,GAAG,IAAA,qBAAa,EAAyB,IAAI,CAAC,CAAC;AAsEzC,kCAAW;AApElC,MAAM,YAAY,GAAG,CAAwB,EAC3C,QAAQ,EACR,OAAO,EACP,IAAI,EAAE,SAAS,GAAG,IAAI,EACtB,OAAO,EACP,MAAM,GAOP,EAAE,EAAE;IACH,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,IAAA,0BAAU,GAAE,CAAC;IAClE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAA,0BAAU,GAAE,CAAC;IACvC,MAAM,MAAM,GAAG,IAAA,sBAAQ,GAAE,CAAC;IAC1B,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IAC/D,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,IAAA,gBAAQ,EAAe,IAAI,CAAC,CAAC;IAC/D,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,IAAA,gBAAQ,EAAc,IAAI,CAAC,CAAC;IAEpD,MAAM,SAAS,GAAG,IAAA,mBAAW,EAAC,KAAK,IAA0B,EAAE;QAC7D,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,WAAW,GAAG,IAAI,mCAAkB,CAAC,OAAO,CAAC,CAAC;QACpD,OAAO,WAAW,CAAC,GAAG,EAAE,CAAC;IAC3B,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAEhC,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YACtB,OAAO,CAAC,IAAI,CAAC,CAAC;YACd,OAAO;QACT,CAAC;QACD,IAAI,OAAO,EAAE,OAAO,EAAE,CAAC;YACrB,cAAc,CAAC,IAAI,CAAC,CAAC;YACrB,SAAS,EAAE;iBACR,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;gBACb,cAAc,CAAC,KAAK,CAAC,CAAC;gBACtB,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC,CAAC;iBACD,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;gBACf,cAAc,CAAC,KAAK,CAAC,CAAC;gBACtB,YAAY,CAAC,KAAK,CAAC,CAAC;YACtB,CAAC,CAAC,CAAC;QACP,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAElC,MAAM,SAAS,GAAG,WAAW,IAAI,WAAW,CAAC;IAC7C,MAAM,KAAK,GAAG,SAAS,IAAI,SAAS,CAAC;IAErC,OAAO,CACL,8BAAC,WAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,GAAG,MAAM;YACT,IAAI,EAAE,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,IAAI;YACjC,SAAS;YACT,KAAK;YACL,MAAM;YACN,OAAO;SACR,IAEA,QAAQ,CACY,CACxB,CAAC;AACJ,CAAC,CAAC;AAIO,oCAAY","sourcesContent":["\"use client\";\n\nimport React, { createContext, useCallback, useEffect, useState } from \"react\";\nimport type { ReactNode } from \"react\";\nimport type { JWT } from \"oslo/jwt\";\nimport type { AuthStorage, DisplayMode, EmptyObject, User } from \"@/types.js\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { AuthContextType } from \"@/shared/providers/AuthContext.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport type { TokenContextType } from \"./TokenProvider.js\";\nimport { useToken } from \"../hooks/useToken.js\";\n\ntype UserContextType<\n T extends Record<string, unknown> & JWT[\"payload\"] = Record<string, unknown> &\n JWT[\"payload\"],\n> = {\n user: User<T> | null;\n} & Omit<TokenContextType, \"isLoading\" | \"error\" | \"refreshToken\"> &\n Omit<AuthContextType, \"isAuthenticated\">;\n\nconst UserContext = createContext<UserContextType | null>(null);\n\nconst UserProvider = <T extends EmptyObject>({\n children,\n storage,\n user: inputUser = null,\n signOut,\n signIn,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user?: User<T> | null;\n signOut: () => Promise<void>;\n signIn: (displayMode?: DisplayMode) => Promise<void>;\n}) => {\n const { error: authError, isLoading: authLoading } = useSession();\n const { data: session } = useSession();\n const tokens = useToken();\n const [userLoading, setUserLoading] = useState<boolean>(false);\n const [userError, setUserError] = useState<Error | null>(null);\n const [user, setUser] = useState<User | null>(null);\n\n const fetchUser = useCallback(async (): Promise<User | null> => {\n if (!session?.idToken) {\n return null;\n }\n const userSession = new GenericUserSession(storage);\n return userSession.get();\n }, [session?.idToken, storage]);\n\n useEffect(() => {\n if (!session?.idToken) {\n setUser(null);\n return;\n }\n if (session?.idToken) {\n setUserLoading(true);\n fetchUser()\n .then((user) => {\n setUserLoading(false);\n setUser(user);\n })\n .catch((error) => {\n setUserLoading(false);\n setUserError(error);\n });\n }\n }, [fetchUser, session?.idToken]);\n\n const isLoading = authLoading || userLoading;\n const error = authError || userError;\n\n return (\n <UserContext.Provider\n value={{\n ...tokens,\n user: (inputUser || user) ?? null,\n isLoading,\n error,\n signIn,\n signOut,\n }}\n >\n {children}\n </UserContext.Provider>\n );\n};\n\nexport type { UserContextType };\n\nexport { UserProvider, UserContext };\n"]}
@@ -55,6 +55,7 @@ type SessionData = {
55
55
  };
56
56
  type OIDCTokenResponseBody = TokenResponseBody & {
57
57
  id_token: string;
58
+ timestamp?: number;
58
59
  };
59
60
  type ParsedTokens = {
60
61
  id_token: JWTPayload;
@@ -90,11 +91,9 @@ type IdTokenPayload = JWTPayload & {
90
91
  type IdToken = Omit<JWT, "payload"> & {
91
92
  payload: IdTokenPayload;
92
93
  };
94
+ declare const tokenKeys: string[];
93
95
  type Tokens = {
94
- idToken: string;
95
- accessToken: string;
96
- refreshToken: string;
97
- forwardedTokens: ForwardedTokens;
96
+ [K in (typeof tokenKeys)[number]]: K extends "forwardedTokens" ? ForwardedTokens : string;
98
97
  };
99
98
  type BaseUser = {
100
99
  id: string;
@@ -105,7 +104,7 @@ type BaseUser = {
105
104
  picture?: string;
106
105
  updated_at?: Date;
107
106
  };
108
- type User<T extends UnknownObject = EmptyObject> = BaseUser & Partial<Tokens> & T;
107
+ type User<T extends UnknownObject = EmptyObject> = BaseUser & T;
109
108
  type OpenIdConfiguration = {
110
109
  authorization_endpoint: string;
111
110
  claims_parameter_supported: boolean;
@@ -139,6 +138,7 @@ type LoginPostMessage = {
139
138
  };
140
139
  };
141
140
  export type { LoginPostMessage, AuthSessionService, TokenService, UserInfoService, ResourceService, AuthRequest, Tokens, Endpoints, Config, SessionData, OIDCTokenResponseBody, ParsedTokens, BaseUser, User, DisplayMode, UnknownObject, EmptyObject, ForwardedTokens, ForwardedTokensJWT, JWTPayload, IdTokenPayload, IdToken, OpenIdConfiguration, };
141
+ export { tokenKeys };
142
142
  export interface AuthStorage {
143
143
  get(key: string): Promise<string | null>;
144
144
  set(key: string, value: string): Promise<void>;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
package/dist/cjs/types.js CHANGED
@@ -1,3 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.tokenKeys = void 0;
4
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
5
+ const tokenKeys = ["idToken", "accessToken", "refreshToken", "forwardedTokens"];
6
+ exports.tokenKeys = tokenKeys;
3
7
  //# sourceMappingURL=types.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"","sourcesContent":["import type { TokenResponseBody } from \"oslo/oauth2\";\nimport type { JWT } from \"oslo/jwt\";\n\ntype UnknownObject = Record<string, unknown>;\ntype EmptyObject = Record<string, never>;\n\n// Display modes for the auth flow\ntype DisplayMode = \"iframe\" | \"redirect\" | \"new_tab\" | \"custom_tab\";\n\n// Combined Auth and Session Service\ninterface AuthSessionService {\n // TODO DK NOTES: Should be in BrowserAuthSessionService, not relevant on backend\n loadAuthorizationUrl(\n authorizationURL: string,\n displayMode: DisplayMode,\n ): void;\n // TODO DK NOTES: overrideDisplayMode parameter not appropriate here - also - do we need both this and the above in the interface?\n getAuthorizationUrl(\n scopes: string[],\n overrideDisplayMode: DisplayMode,\n nonce?: string,\n ): Promise<string>;\n // TODO DK NOTES: display mode should be in browser version only. Also, do we need this and the above two in the top-level interface?\n signIn(\n displayMode: DisplayMode,\n scopes: string[],\n nonce?: string,\n ): Promise<void>;\n // TODO DK NOTES: Input should be an auth code - do not assume it comes via an url\n tokenExchange(responseUrl: string): Promise<SessionData>;\n // TODO DK NOTES: Should be async for flexibility\n getSessionData(): SessionData;\n // TODO DK NOTES: Should be async for flexibility\n updateSessionData(data: SessionData): void;\n getUserInfoService(): Promise<UserInfoService>;\n}\n\n// Token Service\ninterface TokenService {\n exchangeCodeForTokens(authCode: string): Promise<Tokens>;\n validateIdToken(idToken: string, nonce: string): boolean;\n refreshAccessToken(refreshToken: string): Promise<Tokens>;\n}\n\n// User Info Service\ninterface UserInfoService {\n getUserInfo<T extends UnknownObject>(\n accessToken: string,\n idToken: string | null,\n ): Promise<User<T> | null>;\n}\n\n// Resource Service\ninterface ResourceService {\n getProtectedResource(accessToken: string): Promise<unknown>;\n}\n\n// Auth Request (for internal use in AuthSessionService)\ntype AuthRequest = {\n clientId: string;\n redirectUri: string;\n state: string;\n nonce: string;\n scope: string;\n};\n\ntype Endpoints = {\n jwks: string;\n auth: string;\n token: string;\n userinfo: string;\n challenge?: string;\n};\n\ntype Config = {\n oauthServer: string;\n endpoints?: Endpoints;\n};\n\ntype SessionData = {\n authenticated: boolean; // TODO can this be inferred from the presence of the tokens?\n state?: string;\n accessToken?: string;\n refreshToken?: string;\n idToken?: string;\n timestamp?: number;\n expiresIn?: number;\n codeVerifier?: string;\n displayMode?: DisplayMode;\n openerUrl?: string;\n};\n\ntype OIDCTokenResponseBody = TokenResponseBody & { id_token: string };\n\ntype ParsedTokens = {\n id_token: JWTPayload;\n access_token: JWTPayload;\n refresh_token?: string;\n};\n\n// The format we expose to the frontend via hooks\ntype ForwardedTokens = Record<\n string,\n {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n }\n>;\n\n// The format in the JWT payload\ntype ForwardedTokensJWT = Record<\n string,\n {\n id_token?: string;\n access_token?: string;\n refresh_token?: string;\n scope?: string;\n }\n>;\n\ntype JWTPayload = JWT[\"payload\"] & {\n iss: string;\n aud: string;\n sub: string;\n iat: number;\n exp: number;\n};\n\ntype IdTokenPayload = JWTPayload & {\n forwardedTokens?: ForwardedTokensJWT;\n email?: string;\n name?: string;\n picture?: string;\n nonce: string;\n at_hash: string;\n};\n\ntype IdToken = Omit<JWT, \"payload\"> & {\n payload: IdTokenPayload;\n};\n\ntype Tokens = {\n idToken: string;\n accessToken: string;\n refreshToken: string;\n forwardedTokens: ForwardedTokens;\n};\n\n// Base user interface\ntype BaseUser = {\n id: string;\n email?: string;\n name?: string;\n given_name?: string;\n family_name?: string;\n picture?: string;\n updated_at?: Date;\n};\n\ntype User<T extends UnknownObject = EmptyObject> = BaseUser &\n Partial<Tokens> &\n T;\n\ntype OpenIdConfiguration = {\n authorization_endpoint: string;\n claims_parameter_supported: boolean;\n claims_supported: string[];\n code_challenge_methods_supported: string[];\n end_session_endpoint: string;\n grant_types_supported: string[];\n issuer: string;\n jwks_uri: string;\n authorization_response_iss_parameter_supported: boolean;\n response_modes_supported: string[];\n response_types_supported: string[];\n scopes_supported: string[];\n subject_types_supported: string[];\n token_endpoint_auth_methods_supported: string[];\n token_endpoint_auth_signing_alg_values_supported: string[];\n token_endpoint: string;\n id_token_signing_alg_values_supported: string[];\n pushed_authorization_request_endpoint: string;\n request_parameter_supported: boolean;\n request_uri_parameter_supported: boolean;\n userinfo_endpoint: string;\n claim_types_supported: string[];\n};\n\ntype LoginPostMessage = {\n source: string;\n type: string;\n clientId: string;\n data: {\n url: string;\n };\n};\nexport type {\n LoginPostMessage,\n AuthSessionService,\n TokenService,\n UserInfoService,\n ResourceService,\n AuthRequest,\n Tokens,\n Endpoints,\n Config,\n SessionData,\n OIDCTokenResponseBody,\n ParsedTokens,\n BaseUser,\n User,\n DisplayMode,\n UnknownObject,\n EmptyObject,\n ForwardedTokens,\n ForwardedTokensJWT,\n JWTPayload,\n IdTokenPayload,\n IdToken,\n OpenIdConfiguration,\n};\n\nexport interface AuthStorage {\n get(key: string): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n}\n"]}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":";;;AAiJA,6DAA6D;AAC7D,MAAM,SAAS,GAAG,CAAC,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,iBAAiB,CAAC,CAAC;AAgFvE,8BAAS","sourcesContent":["import type { TokenResponseBody } from \"oslo/oauth2\";\nimport type { JWT } from \"oslo/jwt\";\n\ntype UnknownObject = Record<string, unknown>;\ntype EmptyObject = Record<string, never>;\n\n// Display modes for the auth flow\ntype DisplayMode = \"iframe\" | \"redirect\" | \"new_tab\" | \"custom_tab\";\n\n// Combined Auth and Session Service\ninterface AuthSessionService {\n // TODO DK NOTES: Should be in BrowserAuthSessionService, not relevant on backend\n loadAuthorizationUrl(\n authorizationURL: string,\n displayMode: DisplayMode,\n ): void;\n // TODO DK NOTES: overrideDisplayMode parameter not appropriate here - also - do we need both this and the above in the interface?\n getAuthorizationUrl(\n scopes: string[],\n overrideDisplayMode: DisplayMode,\n nonce?: string,\n ): Promise<string>;\n // TODO DK NOTES: display mode should be in browser version only. Also, do we need this and the above two in the top-level interface?\n signIn(\n displayMode: DisplayMode,\n scopes: string[],\n nonce?: string,\n ): Promise<void>;\n // TODO DK NOTES: Input should be an auth code - do not assume it comes via an url\n tokenExchange(responseUrl: string): Promise<SessionData>;\n // TODO DK NOTES: Should be async for flexibility\n getSessionData(): SessionData;\n // TODO DK NOTES: Should be async for flexibility\n updateSessionData(data: SessionData): void;\n getUserInfoService(): Promise<UserInfoService>;\n}\n\n// Token Service\ninterface TokenService {\n exchangeCodeForTokens(authCode: string): Promise<Tokens>;\n validateIdToken(idToken: string, nonce: string): boolean;\n refreshAccessToken(refreshToken: string): Promise<Tokens>;\n}\n\n// User Info Service\ninterface UserInfoService {\n getUserInfo<T extends UnknownObject>(\n accessToken: string,\n idToken: string | null,\n ): Promise<User<T> | null>;\n}\n\n// Resource Service\ninterface ResourceService {\n getProtectedResource(accessToken: string): Promise<unknown>;\n}\n\n// Auth Request (for internal use in AuthSessionService)\ntype AuthRequest = {\n clientId: string;\n redirectUri: string;\n state: string;\n nonce: string;\n scope: string;\n};\n\ntype Endpoints = {\n jwks: string;\n auth: string;\n token: string;\n userinfo: string;\n challenge?: string;\n};\n\ntype Config = {\n oauthServer: string;\n endpoints?: Endpoints;\n};\n\ntype SessionData = {\n authenticated: boolean; // TODO can this be inferred from the presence of the tokens?\n state?: string;\n accessToken?: string;\n refreshToken?: string;\n idToken?: string;\n timestamp?: number;\n expiresIn?: number;\n codeVerifier?: string;\n displayMode?: DisplayMode;\n openerUrl?: string;\n};\n\ntype OIDCTokenResponseBody = TokenResponseBody & {\n id_token: string;\n timestamp?: number;\n};\n\ntype ParsedTokens = {\n id_token: JWTPayload;\n access_token: JWTPayload;\n refresh_token?: string;\n};\n\n// The format we expose to the frontend via hooks\ntype ForwardedTokens = Record<\n string,\n {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n }\n>;\n\n// The format in the JWT payload\ntype ForwardedTokensJWT = Record<\n string,\n {\n id_token?: string;\n access_token?: string;\n refresh_token?: string;\n scope?: string;\n }\n>;\n\ntype JWTPayload = JWT[\"payload\"] & {\n iss: string;\n aud: string;\n sub: string;\n iat: number;\n exp: number;\n};\n\ntype IdTokenPayload = JWTPayload & {\n forwardedTokens?: ForwardedTokensJWT;\n email?: string;\n name?: string;\n picture?: string;\n nonce: string;\n at_hash: string;\n};\n\ntype IdToken = Omit<JWT, \"payload\"> & {\n payload: IdTokenPayload;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst tokenKeys = [\"idToken\", \"accessToken\", \"refreshToken\", \"forwardedTokens\"];\n\n// Derive the Tokens type from the array\ntype Tokens = {\n [K in (typeof tokenKeys)[number]]: K extends \"forwardedTokens\"\n ? ForwardedTokens\n : string;\n};\n\n// Base user interface\ntype BaseUser = {\n id: string;\n email?: string;\n name?: string;\n given_name?: string;\n family_name?: string;\n picture?: string;\n updated_at?: Date;\n};\n\ntype User<T extends UnknownObject = EmptyObject> = BaseUser & T;\n\ntype OpenIdConfiguration = {\n authorization_endpoint: string;\n claims_parameter_supported: boolean;\n claims_supported: string[];\n code_challenge_methods_supported: string[];\n end_session_endpoint: string;\n grant_types_supported: string[];\n issuer: string;\n jwks_uri: string;\n authorization_response_iss_parameter_supported: boolean;\n response_modes_supported: string[];\n response_types_supported: string[];\n scopes_supported: string[];\n subject_types_supported: string[];\n token_endpoint_auth_methods_supported: string[];\n token_endpoint_auth_signing_alg_values_supported: string[];\n token_endpoint: string;\n id_token_signing_alg_values_supported: string[];\n pushed_authorization_request_endpoint: string;\n request_parameter_supported: boolean;\n request_uri_parameter_supported: boolean;\n userinfo_endpoint: string;\n claim_types_supported: string[];\n};\n\ntype LoginPostMessage = {\n source: string;\n type: string;\n clientId: string;\n data: {\n url: string;\n };\n};\nexport type {\n LoginPostMessage,\n AuthSessionService,\n TokenService,\n UserInfoService,\n ResourceService,\n AuthRequest,\n Tokens,\n Endpoints,\n Config,\n SessionData,\n OIDCTokenResponseBody,\n ParsedTokens,\n BaseUser,\n User,\n DisplayMode,\n UnknownObject,\n EmptyObject,\n ForwardedTokens,\n ForwardedTokensJWT,\n JWTPayload,\n IdTokenPayload,\n IdToken,\n OpenIdConfiguration,\n};\nexport { tokenKeys };\nexport interface AuthStorage {\n get(key: string): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,QAAA,MAAM,cAAc,QAAO,OAsB1B,CAAC;AAOF,KAAK,gBAAgB,CAAC,CAAC,IAAI;KACxB,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC3D,CAAC;AACF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,GAAG,CAAY,IAAP,MAAM,CAAC,GAAG,OAAO,GAAE,OAC/D,CAAC,KACL,gBAAgB,CAAC,CAAC,CAapB,CAAC;AAEF,OAAO,EAAE,cAAc,EAAE,CAAC"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,QAAA,MAAM,cAAc,QAAO,OAsB1B,CAAC;AAOF,KAAK,gBAAgB,CAAC,CAAC,IAAI;KACxB,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC3D,CAAC;AACF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,GAAG,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,GAAE,OAC/D,CAAC,KACL,gBAAgB,CAAC,CAAC,CAapB,CAAC;AAEF,OAAO,EAAE,cAAc,EAAE,CAAC"}
@@ -1,5 +1,8 @@
1
1
  import type { AuthStorage } from "../types.js";
2
+ import { EventEmitter } from "eventemitter3";
2
3
  export declare class LocalStorageAdapter implements AuthStorage {
4
+ static _emitter: EventEmitter;
5
+ static get emitter(): EventEmitter;
3
6
  get(key: string): Promise<string>;
4
7
  set(key: string, value: string): Promise<void>;
5
8
  }
@@ -1 +1 @@
1
- {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../src/browser/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,qBAAa,mBAAoB,YAAW,WAAW;IAC/C,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAIjC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGrD"}
1
+ {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../src/browser/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7C,qBAAa,mBAAoB,YAAW,WAAW;IACrD,MAAM,CAAC,QAAQ,EAAE,YAAY,CAAC;IAC9B,MAAM,KAAK,OAAO,IAAI,YAAY,CAKjC;IACK,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAIjC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGrD"}
@@ -1,4 +1,12 @@
1
+ import { EventEmitter } from "eventemitter3";
1
2
  export class LocalStorageAdapter {
3
+ static _emitter;
4
+ static get emitter() {
5
+ if (!LocalStorageAdapter._emitter) {
6
+ LocalStorageAdapter._emitter = new EventEmitter();
7
+ }
8
+ return LocalStorageAdapter._emitter;
9
+ }
2
10
  async get(key) {
3
11
  return Promise.resolve(localStorage.getItem(key) || "");
4
12
  }
@@ -1 +1 @@
1
- {"version":3,"file":"storage.js","sourceRoot":"","sources":["../../../src/browser/storage.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,mBAAmB;IAC9B,KAAK,CAAC,GAAG,CAAC,GAAW;QACnB,OAAO,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,GAAW,EAAE,KAAa;QAClC,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACnC,CAAC;CACF","sourcesContent":["import type { AuthStorage } from \"@/types.js\";\n\nexport class LocalStorageAdapter implements AuthStorage {\n async get(key: string): Promise<string> {\n return Promise.resolve(localStorage.getItem(key) || \"\");\n }\n\n async set(key: string, value: string): Promise<void> {\n localStorage.setItem(key, value);\n }\n}\n"]}
1
+ {"version":3,"file":"storage.js","sourceRoot":"","sources":["../../../src/browser/storage.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7C,MAAM,OAAO,mBAAmB;IAC9B,MAAM,CAAC,QAAQ,CAAe;IAC9B,MAAM,KAAK,OAAO;QAChB,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,CAAC;YAClC,mBAAmB,CAAC,QAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QACpD,CAAC;QACD,OAAO,mBAAmB,CAAC,QAAQ,CAAC;IACtC,CAAC;IACD,KAAK,CAAC,GAAG,CAAC,GAAW;QACnB,OAAO,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,GAAW,EAAE,KAAa;QAClC,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACnC,CAAC;CACF","sourcesContent":["import type { AuthStorage } from \"@/types.js\";\nimport { EventEmitter } from \"eventemitter3\";\n\nexport class LocalStorageAdapter implements AuthStorage {\n static _emitter: EventEmitter;\n static get emitter(): EventEmitter {\n if (!LocalStorageAdapter._emitter) {\n LocalStorageAdapter._emitter = new EventEmitter();\n }\n return LocalStorageAdapter._emitter;\n }\n async get(key: string): Promise<string> {\n return Promise.resolve(localStorage.getItem(key) || \"\");\n }\n\n async set(key: string, value: string): Promise<void> {\n localStorage.setItem(key, value);\n }\n}\n"]}
@@ -1,7 +1,7 @@
1
- declare const getWindowCookieValue: ({ key, window, parseJson, }: {
1
+ declare const getWindowCookieValue: (requests: {
2
2
  key: string;
3
3
  window: Window;
4
4
  parseJson?: boolean;
5
- }) => any;
5
+ }[]) => Record<string, string | Record<string, unknown>> | null;
6
6
  export { getWindowCookieValue };
7
7
  //# sourceMappingURL=cookies.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"cookies.d.ts","sourceRoot":"","sources":["../../../src/lib/cookies.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,oBAAoB,gCAIvB;IACD,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,QAkBA,CAAC;AACF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
1
+ {"version":3,"file":"cookies.d.ts","sourceRoot":"","sources":["../../../src/lib/cookies.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,oBAAoB,aACd;IACR,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,EAAE,4DAqBJ,CAAC;AACF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
@@ -1,23 +1,25 @@
1
- const getWindowCookieValue = ({ key, window, parseJson = false, }) => {
1
+ const getWindowCookieValue = (requests) => {
2
2
  const cookie = window.document.cookie;
3
3
  if (!cookie)
4
4
  return null;
5
5
  const cookies = cookie.split(";");
6
+ const response = {};
6
7
  for (const c of cookies) {
7
8
  const [name, value] = c.trim().split("=");
8
- if (value && name === key) {
9
+ const request = requests.find((r) => r.key === name);
10
+ if (value && request) {
9
11
  try {
10
12
  const decodeURIComponentValue = decodeURIComponent(value);
11
- return parseJson
13
+ response[request.key] = request.parseJson
12
14
  ? JSON.parse(decodeURIComponentValue)
13
15
  : decodeURIComponentValue;
14
16
  }
15
17
  catch {
16
- return value;
18
+ response[request.key] = value;
17
19
  }
18
20
  }
19
21
  }
20
- return null;
22
+ return response;
21
23
  };
22
24
  export { getWindowCookieValue };
23
25
  //# sourceMappingURL=cookies.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"cookies.js","sourceRoot":"","sources":["../../../src/lib/cookies.ts"],"names":[],"mappings":"AAAA,MAAM,oBAAoB,GAAG,CAAC,EAC5B,GAAG,EACH,MAAM,EACN,SAAS,GAAG,KAAK,GAKlB,EAAE,EAAE;IACH,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;IACtC,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IACzB,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAClC,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE,CAAC;QACxB,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC1C,IAAI,KAAK,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC;YAC1B,IAAI,CAAC;gBACH,MAAM,uBAAuB,GAAG,kBAAkB,CAAC,KAAK,CAAC,CAAC;gBAC1D,OAAO,SAAS;oBACd,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,uBAAuB,CAAC;oBACrC,CAAC,CAAC,uBAAuB,CAAC;YAC9B,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AACF,OAAO,EAAE,oBAAoB,EAAE,CAAC","sourcesContent":["const getWindowCookieValue = ({\n key,\n window,\n parseJson = false,\n}: {\n key: string;\n window: Window;\n parseJson?: boolean;\n}) => {\n const cookie = window.document.cookie;\n if (!cookie) return null;\n const cookies = cookie.split(\";\");\n for (const c of cookies) {\n const [name, value] = c.trim().split(\"=\");\n if (value && name === key) {\n try {\n const decodeURIComponentValue = decodeURIComponent(value);\n return parseJson\n ? JSON.parse(decodeURIComponentValue)\n : decodeURIComponentValue;\n } catch {\n return value;\n }\n }\n }\n return null;\n};\nexport { getWindowCookieValue };\n"]}
1
+ {"version":3,"file":"cookies.js","sourceRoot":"","sources":["../../../src/lib/cookies.ts"],"names":[],"mappings":"AAAA,MAAM,oBAAoB,GAAG,CAC3B,QAIG,EACH,EAAE;IACF,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;IACtC,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IACzB,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAClC,MAAM,QAAQ,GAAqD,EAAE,CAAC;IACtE,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE,CAAC;QACxB,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC1C,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC;QACrD,IAAI,KAAK,IAAI,OAAO,EAAE,CAAC;YACrB,IAAI,CAAC;gBACH,MAAM,uBAAuB,GAAG,kBAAkB,CAAC,KAAK,CAAC,CAAC;gBAC1D,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,SAAS;oBACvC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,uBAAuB,CAAC;oBACrC,CAAC,CAAC,uBAAuB,CAAC;YAC9B,CAAC;YAAC,MAAM,CAAC;gBACP,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YAChC,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC,CAAC;AACF,OAAO,EAAE,oBAAoB,EAAE,CAAC","sourcesContent":["const getWindowCookieValue = (\n requests: {\n key: string;\n window: Window;\n parseJson?: boolean;\n }[],\n) => {\n const cookie = window.document.cookie;\n if (!cookie) return null;\n const cookies = cookie.split(\";\");\n const response: Record<string, string | Record<string, unknown>> = {};\n for (const c of cookies) {\n const [name, value] = c.trim().split(\"=\");\n const request = requests.find((r) => r.key === name);\n if (value && request) {\n try {\n const decodeURIComponentValue = decodeURIComponent(value);\n response[request.key] = request.parseJson\n ? JSON.parse(decodeURIComponentValue)\n : decodeURIComponentValue;\n } catch {\n response[request.key] = value;\n }\n }\n }\n return response;\n};\nexport { getWindowCookieValue };\n"]}
@@ -1,6 +1,6 @@
1
1
  const validateLoginAppPostMessage = (event, clientId) => {
2
2
  const caseEvent = event;
3
- console.log("caseEvent", caseEvent);
3
+ // console.log("caseEvent", caseEvent);
4
4
  if (!caseEvent.clientId ||
5
5
  !caseEvent.data.url ||
6
6
  !caseEvent.source ||
@@ -1 +1 @@
1
- {"version":3,"file":"postMessage.js","sourceRoot":"","sources":["../../../src/lib/postMessage.ts"],"names":[],"mappings":"AAEA,MAAM,2BAA2B,GAAG,CAClC,KAAuB,EACvB,QAAgB,EACP,EAAE;IACX,MAAM,SAAS,GAAG,KAAyB,CAAC;IAC5C,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IACpC,IACE,CAAC,SAAS,CAAC,QAAQ;QACnB,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG;QACnB,CAAC,SAAS,CAAC,MAAM;QACjB,CAAC,SAAS,CAAC,IAAI;QACf,SAAS,CAAC,QAAQ,KAAK,QAAQ;QAC/B,SAAS,CAAC,MAAM,KAAK,eAAe,EACpC,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC","sourcesContent":["import type { LoginPostMessage } from \"@/types.js\";\n\nconst validateLoginAppPostMessage = (\n event: LoginPostMessage,\n clientId: string,\n): boolean => {\n const caseEvent = event as LoginPostMessage;\n console.log(\"caseEvent\", caseEvent);\n if (\n !caseEvent.clientId ||\n !caseEvent.data.url ||\n !caseEvent.source ||\n !caseEvent.type ||\n caseEvent.clientId !== clientId ||\n caseEvent.source !== \"civicloginApp\"\n ) {\n return false;\n }\n return true;\n};\n\nexport { validateLoginAppPostMessage };\n"]}
1
+ {"version":3,"file":"postMessage.js","sourceRoot":"","sources":["../../../src/lib/postMessage.ts"],"names":[],"mappings":"AAEA,MAAM,2BAA2B,GAAG,CAClC,KAAuB,EACvB,QAAgB,EACP,EAAE;IACX,MAAM,SAAS,GAAG,KAAyB,CAAC;IAC5C,uCAAuC;IACvC,IACE,CAAC,SAAS,CAAC,QAAQ;QACnB,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG;QACnB,CAAC,SAAS,CAAC,MAAM;QACjB,CAAC,SAAS,CAAC,IAAI;QACf,SAAS,CAAC,QAAQ,KAAK,QAAQ;QAC/B,SAAS,CAAC,MAAM,KAAK,eAAe,EACpC,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC","sourcesContent":["import type { LoginPostMessage } from \"@/types.js\";\n\nconst validateLoginAppPostMessage = (\n event: LoginPostMessage,\n clientId: string,\n): boolean => {\n const caseEvent = event as LoginPostMessage;\n // console.log(\"caseEvent\", caseEvent);\n if (\n !caseEvent.clientId ||\n !caseEvent.data.url ||\n !caseEvent.source ||\n !caseEvent.type ||\n caseEvent.clientId !== clientId ||\n caseEvent.source !== \"civicloginApp\"\n ) {\n return false;\n }\n return true;\n};\n\nexport { validateLoginAppPostMessage };\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"windowUtil.d.ts","sourceRoot":"","sources":["../../../src/lib/windowUtil.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,gBAAgB,WAAY,MAAM,KAAG,OAc1C,CAAC;AAEF,QAAA,MAAM,yBAAyB,mBAAoB,MAAM,EAAE,SAU1D,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,CAAC"}
1
+ {"version":3,"file":"windowUtil.d.ts","sourceRoot":"","sources":["../../../src/lib/windowUtil.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,gBAAgB,WAAY,MAAM,KAAG,OAc1C,CAAC;AAEF,QAAA,MAAM,yBAAyB,mBAAoB,MAAM,EAAE,SAW1D,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,CAAC"}
@@ -21,6 +21,7 @@ const removeParamsWithoutReload = (paramsToRemove) => {
21
21
  });
22
22
  try {
23
23
  window.history.replaceState({}, "", url);
24
+ window.dispatchEvent(new Event("popstate"));
24
25
  }
25
26
  catch (error) {
26
27
  console.warn("window.history.replaceState failed", error);
@@ -1 +1 @@
1
- {"version":3,"file":"windowUtil.js","sourceRoot":"","sources":["../../../src/lib/windowUtil.ts"],"names":[],"mappings":"AAAA,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAW,EAAE;IACnD,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;QAClC,iEAAiE;QACjE,IAAI,CAAC;YACH,IAAI,MAAM,EAAE,YAAY,EAAE,EAAE,KAAK,mBAAmB,EAAE,CAAC;gBACrD,OAAO,IAAI,CAAC;YACd,CAAC;YACD,6DAA6D;QAC/D,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;YACZ,6CAA6C;YAC7C,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,MAAM,yBAAyB,GAAG,CAAC,cAAwB,EAAE,EAAE;IAC7D,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC1C,cAAc,CAAC,OAAO,CAAC,CAAC,KAAa,EAAE,EAAE;QACvC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IACH,IAAI,CAAC;QACH,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;IAC3C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAC;IAC5D,CAAC;AACH,CAAC,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,CAAC","sourcesContent":["const isWindowInIframe = (window: Window): boolean => {\n if (typeof window !== \"undefined\") {\n // use the window width to determine if we're in an iframe or not\n try {\n if (window?.frameElement?.id === \"civic-auth-iframe\") {\n return true;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (_e) {\n // If we get an error, we're not in an iframe\n return false;\n }\n }\n return false;\n};\n\nconst removeParamsWithoutReload = (paramsToRemove: string[]) => {\n const url = new URL(window.location.href);\n paramsToRemove.forEach((param: string) => {\n url.searchParams.delete(param);\n });\n try {\n window.history.replaceState({}, \"\", url);\n } catch (error) {\n console.warn(\"window.history.replaceState failed\", error);\n }\n};\n\nexport { isWindowInIframe, removeParamsWithoutReload };\n"]}
1
+ {"version":3,"file":"windowUtil.js","sourceRoot":"","sources":["../../../src/lib/windowUtil.ts"],"names":[],"mappings":"AAAA,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAW,EAAE;IACnD,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;QAClC,iEAAiE;QACjE,IAAI,CAAC;YACH,IAAI,MAAM,EAAE,YAAY,EAAE,EAAE,KAAK,mBAAmB,EAAE,CAAC;gBACrD,OAAO,IAAI,CAAC;YACd,CAAC;YACD,6DAA6D;QAC/D,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;YACZ,6CAA6C;YAC7C,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,MAAM,yBAAyB,GAAG,CAAC,cAAwB,EAAE,EAAE;IAC7D,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC1C,cAAc,CAAC,OAAO,CAAC,CAAC,KAAa,EAAE,EAAE;QACvC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IACH,IAAI,CAAC;QACH,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QACzC,MAAM,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC;IAC9C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAC;IAC5D,CAAC;AACH,CAAC,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,CAAC","sourcesContent":["const isWindowInIframe = (window: Window): boolean => {\n if (typeof window !== \"undefined\") {\n // use the window width to determine if we're in an iframe or not\n try {\n if (window?.frameElement?.id === \"civic-auth-iframe\") {\n return true;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (_e) {\n // If we get an error, we're not in an iframe\n return false;\n }\n }\n return false;\n};\n\nconst removeParamsWithoutReload = (paramsToRemove: string[]) => {\n const url = new URL(window.location.href);\n paramsToRemove.forEach((param: string) => {\n url.searchParams.delete(param);\n });\n try {\n window.history.replaceState({}, \"\", url);\n window.dispatchEvent(new Event(\"popstate\"));\n } catch (error) {\n console.warn(\"window.history.replaceState failed\", error);\n }\n};\n\nexport { isWindowInIframe, removeParamsWithoutReload };\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"GetUser.d.ts","sourceRoot":"","sources":["../../../src/nextjs/GetUser.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAKvC,eAAO,MAAM,OAAO,QAAa,OAAO,CAAC,IAAI,GAAG,IAAI,CAanD,CAAC"}
1
+ {"version":3,"file":"GetUser.d.ts","sourceRoot":"","sources":["../../../src/nextjs/GetUser.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAIvC,eAAO,MAAM,OAAO,QAAa,OAAO,CAAC,IAAI,GAAG,IAAI,CAGnD,CAAC"}
@@ -1,18 +1,7 @@
1
- import { GenericUserSession } from "../shared/lib/UserSession.js";
2
1
  import { NextjsClientStorage } from "../nextjs/cookies.js";
3
- import { retrieveTokens } from "../shared/lib/util.js";
2
+ import { getUser as getSessionUser } from "../shared/lib/session.js";
4
3
  export const getUser = async () => {
5
4
  const clientStorage = new NextjsClientStorage();
6
- const userSession = new GenericUserSession(clientStorage);
7
- const tokens = await retrieveTokens(clientStorage);
8
- const user = await userSession.get();
9
- if (!user || !tokens)
10
- return null;
11
- return {
12
- ...user,
13
- idToken: tokens.id_token,
14
- accessToken: tokens.access_token,
15
- refreshToken: tokens.refresh_token ?? "",
16
- };
5
+ return getSessionUser(clientStorage);
17
6
  };
18
7
  //# sourceMappingURL=GetUser.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"GetUser.js","sourceRoot":"","sources":["../../../src/nextjs/GetUser.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,IAA0B,EAAE;IACtD,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,MAAM,WAAW,GAAG,IAAI,kBAAkB,CAAC,aAAa,CAAC,CAAC;IAC1D,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,aAAa,CAAC,CAAC;IACnD,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,GAAG,EAAE,CAAC;IACrC,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IAElC,OAAO;QACL,GAAG,IAAK;QACR,OAAO,EAAE,MAAM,CAAC,QAAQ;QACxB,WAAW,EAAE,MAAM,CAAC,YAAY;QAChC,YAAY,EAAE,MAAM,CAAC,aAAa,IAAI,EAAE;KACjC,CAAC;AACZ,CAAC,CAAC","sourcesContent":["/**\n * Used on the server-side to get the user object from the cookie\n */\nimport type { User } from \"@/types.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport { NextjsClientStorage } from \"@/nextjs/cookies.js\";\nimport { retrieveTokens } from \"@/shared/lib/util.js\";\n\nexport const getUser = async (): Promise<User | null> => {\n const clientStorage = new NextjsClientStorage();\n const userSession = new GenericUserSession(clientStorage);\n const tokens = await retrieveTokens(clientStorage);\n const user = await userSession.get();\n if (!user || !tokens) return null;\n\n return {\n ...user!,\n idToken: tokens.id_token,\n accessToken: tokens.access_token,\n refreshToken: tokens.refresh_token ?? \"\",\n } as User;\n};\n"]}
1
+ {"version":3,"file":"GetUser.js","sourceRoot":"","sources":["../../../src/nextjs/GetUser.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEpE,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,IAA0B,EAAE;IACtD,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,cAAc,CAAC,aAAa,CAAC,CAAC;AACvC,CAAC,CAAC","sourcesContent":["/**\n * Used on the server-side to get the user object from the cookie\n */\nimport type { User } from \"@/types.js\";\nimport { NextjsClientStorage } from \"@/nextjs/cookies.js\";\nimport { getUser as getSessionUser } from \"@/shared/lib/session.js\";\n\nexport const getUser = async (): Promise<User | null> => {\n const clientStorage = new NextjsClientStorage();\n return getSessionUser(clientStorage);\n};\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/nextjs/config.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAGvC,OAAO,EAEL,KAAK,YAAY,EAEjB,KAAK,kBAAkB,EACxB,MAAM,uBAAuB,CAAC;AAK/B,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,EAAE,kBAAkB,CAAC;IAC3B,IAAI,EAAE,YAAY,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,mBAAmB,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAC;AAEzD,MAAM,MAAM,iBAAiB,GAAG,sBAAsB,CAAC;AAGvD;;GAEG;AACH,eAAO,MAAM,iBAAiB,EAAE,IAAI,CAAC,sBAAsB,EAAE,UAAU,CAiDtE,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,eAAO,MAAM,iBAAiB,YACpB,UAAU,KACjB,sBA0CF,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,eAAO,MAAM,qBAAqB,eACpB,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,UAAU,CAAC,mBAE1C,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAwB8gc,CAAC;6BAAsG,CAAC;;;sBAAke,CAAC;yBAA4H,CAAC;;;qBAA+H,CAAC;;;;;;;;;;;;;;;;;;iBAA8pE,CAAC;;;;;;;6BAAg6C,CAAC;sBAAoC,CAAC;;aAAoC,CAAC;;6BAA0D,CAAC;oBAA8B,CAAC;0BAAkE,CAAC;;qBAA2C,CAAC;mBAAiC,CAAC;;wBAA+C,CAAC;eAAmD,CAAC;iBAA4C,CAAC;2BAAyC,CAAC;;;;;;;;;yBAA4zC,CAAC;6BAAwC,CAAC;;;eAAkD,CAAC;mBAAuB,CAAC;;;;CADv1oB,CAAC"}
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/nextjs/config.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAGvC,OAAO,EAEL,KAAK,YAAY,EAEjB,KAAK,kBAAkB,EACxB,MAAM,uBAAuB,CAAC;AAK/B,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,EAAE,kBAAkB,CAAC;IAC3B,IAAI,EAAE,YAAY,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,mBAAmB,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAC;AAEzD,MAAM,MAAM,iBAAiB,GAAG,sBAAsB,CAAC;AAGvD;;GAEG;AACH,eAAO,MAAM,iBAAiB,EAAE,IAAI,CAAC,sBAAsB,EAAE,UAAU,CA6DtE,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,eAAO,MAAM,iBAAiB,YACpB,UAAU,KACjB,sBA0CF,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,eAAO,MAAM,qBAAqB,eACpB,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,UAAU,CAAC,mBAE1C,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAwBiub,CAAC;6BAAsG,CAAC;;;sBAAke,CAAC;yBAA4H,CAAC;;;qBAA+H,CAAC;;;;;;;;;;;;;;;;;;iBAA8pE,CAAC;;;;;;;6BAAg6C,CAAC;sBAAoC,CAAC;;aAAoC,CAAC;;6BAA0D,CAAC;oBAA8B,CAAC;0BAAkE,CAAC;;qBAA2C,CAAC;mBAAiC,CAAC;;wBAA+C,CAAC;eAAmD,CAAC;iBAA4C,CAAC;2BAAyC,CAAC;;;;;;;;;yBAA4zC,CAAC;6BAAwC,CAAC;;;eAAkD,CAAC;mBAAuB,CAAC;;;;CAD1ioB,CAAC"}
@@ -35,6 +35,18 @@ export const defaultAuthConfig = {
35
35
  sameSite: "strict",
36
36
  path: "/",
37
37
  },
38
+ [OAuthTokens.EXPIRES_IN]: {
39
+ secure: defaultServerSecure,
40
+ httpOnly: true,
41
+ sameSite: "strict",
42
+ path: "/",
43
+ },
44
+ [OAuthTokens.TIMESTAMP]: {
45
+ secure: defaultServerSecure,
46
+ httpOnly: true,
47
+ sameSite: "strict",
48
+ path: "/",
49
+ },
38
50
  [CodeVerifier.COOKIE_NAME]: {
39
51
  secure: defaultServerSecure,
40
52
  httpOnly: true,
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/nextjs/config.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable turbo/no-undeclared-env-vars */\nimport type { NextConfig } from \"next\";\nimport { loggers } from \"@/lib/logger.js\";\nimport { withoutUndefined } from \"@/utils.js\";\nimport {\n CodeVerifier,\n type CookieConfig,\n OAuthTokens,\n type TokensCookieConfig,\n} from \"@/shared/lib/types.js\";\nimport { DEFAULT_AUTH_SERVER } from \"@/constants.js\";\n\nconst logger = loggers.nextjs.handlers.auth;\n\nexport type CookiesConfigObject = {\n tokens: TokensCookieConfig;\n user: CookieConfig;\n};\n\nexport type AuthConfigWithDefaults = {\n clientId: string;\n oauthServer: string;\n callbackUrl: string;\n loginUrl: string;\n logoutUrl: string;\n challengeUrl: string;\n include: string[];\n exclude: string[];\n cookies: CookiesConfigObject;\n};\n\nexport type AuthConfig = Partial<AuthConfigWithDefaults>;\n\nexport type DefinedAuthConfig = AuthConfigWithDefaults;\n\nconst defaultServerSecure = !(process.env.NODE_ENV === \"development\");\n/**\n * Default configuration values that will be used if not overridden\n */\nexport const defaultAuthConfig: Omit<AuthConfigWithDefaults, \"clientId\"> = {\n oauthServer: DEFAULT_AUTH_SERVER,\n callbackUrl: \"/api/auth/callback\",\n challengeUrl: \"/api/auth/challenge\",\n logoutUrl: \"/api/auth/logout\",\n loginUrl: \"/\",\n include: [\"/*\"],\n exclude: [],\n cookies: {\n tokens: {\n [OAuthTokens.ID_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [OAuthTokens.ACCESS_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [OAuthTokens.REFRESH_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [CodeVerifier.COOKIE_NAME]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [CodeVerifier.APP_URL]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n },\n user: {\n secure: defaultServerSecure,\n httpOnly: false,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: 60 * 60, // 1 hour\n },\n },\n};\n\n/**\n * Resolves the authentication configuration by combining:\n * 1. Default values\n * 2. Environment variables (set internally by the plugin)\n * 3. Explicitly passed configuration\n *\n * Note: Developers should not set _civic_auth_* environment variables directly.\n * Instead, pass configuration to the createCivicAuthPlugin in next.config.js:\n *\n * @example\n * ```js\n * // next.config.js\n * export default createCivicAuthPlugin({\n * callbackUrl: '/custom/callback',\n * })\n * ```\n */\nexport const resolveAuthConfig = (\n config: AuthConfig = {},\n): AuthConfigWithDefaults => {\n // Read configuration that was set by the plugin via environment variables\n const configFromEnv = withoutUndefined({\n clientId: process.env._civic_auth_client_id,\n oauthServer: process.env._civic_oauth_server,\n callbackUrl: process.env._civic_auth_callback_url,\n challengeUrl: process.env._civic_auth_challenge_url,\n loginUrl: process.env._civic_auth_login_url,\n logoutUrl: process.env._civic_auth_logout_url,\n include: process.env._civic_auth_includes?.split(\",\"),\n exclude: process.env._civic_auth_excludes?.split(\",\"),\n cookies: process.env._civic_auth_cookie_config\n ? JSON.parse(process.env._civic_auth_cookie_config)\n : undefined,\n }) as AuthConfig;\n const mergedConfig = {\n ...defaultAuthConfig,\n ...configFromEnv, // Apply plugin-set config\n ...config, // Override with directly passed config\n cookies: {\n tokens: {\n ...defaultAuthConfig.cookies.tokens,\n ...(configFromEnv?.cookies?.tokens || {}),\n ...(config.cookies?.tokens || {}),\n },\n user: {\n ...defaultAuthConfig.cookies.user,\n ...(configFromEnv?.cookies?.user || {}),\n ...(config.cookies?.user || {}),\n },\n },\n };\n\n logger.debug(\n \"Config from environment:\",\n JSON.stringify(configFromEnv, null, 2),\n );\n logger.debug(\"Resolved config:\", JSON.stringify(mergedConfig, null, 2));\n if (mergedConfig.clientId === undefined) {\n throw new Error(\"Civic Auth client ID is required\");\n }\n return mergedConfig as AuthConfigWithDefaults & { clientId: string };\n};\n\n/**\n * Creates a Next.js plugin that handles auth configuration.\n *\n * This is the main configuration point for the auth system.\n * Do not set _civic_auth_* environment variables directly - instead,\n * pass your configuration here:\n *\n * @example\n * ```js\n * // next.config.js\n * export default createCivicAuthPlugin({\n * clientId: 'my-client-id',\n * callbackUrl: '/custom/callback',\n * loginUrl: '/custom/login',\n * logoutUrl: '/custom/logout',\n * include: ['/protected/*'],\n * exclude: ['/public/*']\n * })\n * ```\n *\n * The plugin sets internal environment variables that are used by\n * the auth system. These variables should not be set manually.\n */\nexport const createCivicAuthPlugin = (\n authConfig: AuthConfig & Pick<Required<AuthConfig>, \"clientId\">,\n) => {\n return (nextConfig?: NextConfig) => {\n logger.debug(\n \"createCivicAuthPlugin nextConfig\",\n JSON.stringify(nextConfig, null, 2),\n );\n const resolvedConfig = resolveAuthConfig({ ...authConfig });\n return {\n ...nextConfig,\n env: {\n ...nextConfig?.env,\n // Internal environment variables - do not set these manually\n _civic_auth_client_id: resolvedConfig.clientId,\n _civic_oauth_server: resolvedConfig.oauthServer,\n _civic_auth_callback_url: resolvedConfig.callbackUrl,\n _civic_auth_challenge_url: resolvedConfig.challengeUrl,\n _civic_auth_login_url: resolvedConfig.loginUrl,\n _civic_auth_logout_url: resolvedConfig.logoutUrl,\n _civic_auth_includes: resolvedConfig.include.join(\",\"),\n _civic_auth_excludes: resolvedConfig.exclude.join(\",\"),\n _civic_auth_cookie_config: JSON.stringify(resolvedConfig.cookies),\n },\n };\n };\n};\n"]}
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/nextjs/config.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable turbo/no-undeclared-env-vars */\nimport type { NextConfig } from \"next\";\nimport { loggers } from \"@/lib/logger.js\";\nimport { withoutUndefined } from \"@/utils.js\";\nimport {\n CodeVerifier,\n type CookieConfig,\n OAuthTokens,\n type TokensCookieConfig,\n} from \"@/shared/lib/types.js\";\nimport { DEFAULT_AUTH_SERVER } from \"@/constants.js\";\n\nconst logger = loggers.nextjs.handlers.auth;\n\nexport type CookiesConfigObject = {\n tokens: TokensCookieConfig;\n user: CookieConfig;\n};\n\nexport type AuthConfigWithDefaults = {\n clientId: string;\n oauthServer: string;\n callbackUrl: string;\n loginUrl: string;\n logoutUrl: string;\n challengeUrl: string;\n include: string[];\n exclude: string[];\n cookies: CookiesConfigObject;\n};\n\nexport type AuthConfig = Partial<AuthConfigWithDefaults>;\n\nexport type DefinedAuthConfig = AuthConfigWithDefaults;\n\nconst defaultServerSecure = !(process.env.NODE_ENV === \"development\");\n/**\n * Default configuration values that will be used if not overridden\n */\nexport const defaultAuthConfig: Omit<AuthConfigWithDefaults, \"clientId\"> = {\n oauthServer: DEFAULT_AUTH_SERVER,\n callbackUrl: \"/api/auth/callback\",\n challengeUrl: \"/api/auth/challenge\",\n logoutUrl: \"/api/auth/logout\",\n loginUrl: \"/\",\n include: [\"/*\"],\n exclude: [],\n cookies: {\n tokens: {\n [OAuthTokens.ID_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [OAuthTokens.ACCESS_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [OAuthTokens.REFRESH_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [OAuthTokens.EXPIRES_IN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [OAuthTokens.TIMESTAMP]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [CodeVerifier.COOKIE_NAME]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n [CodeVerifier.APP_URL]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n },\n },\n user: {\n secure: defaultServerSecure,\n httpOnly: false,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: 60 * 60, // 1 hour\n },\n },\n};\n\n/**\n * Resolves the authentication configuration by combining:\n * 1. Default values\n * 2. Environment variables (set internally by the plugin)\n * 3. Explicitly passed configuration\n *\n * Note: Developers should not set _civic_auth_* environment variables directly.\n * Instead, pass configuration to the createCivicAuthPlugin in next.config.js:\n *\n * @example\n * ```js\n * // next.config.js\n * export default createCivicAuthPlugin({\n * callbackUrl: '/custom/callback',\n * })\n * ```\n */\nexport const resolveAuthConfig = (\n config: AuthConfig = {},\n): AuthConfigWithDefaults => {\n // Read configuration that was set by the plugin via environment variables\n const configFromEnv = withoutUndefined({\n clientId: process.env._civic_auth_client_id,\n oauthServer: process.env._civic_oauth_server,\n callbackUrl: process.env._civic_auth_callback_url,\n challengeUrl: process.env._civic_auth_challenge_url,\n loginUrl: process.env._civic_auth_login_url,\n logoutUrl: process.env._civic_auth_logout_url,\n include: process.env._civic_auth_includes?.split(\",\"),\n exclude: process.env._civic_auth_excludes?.split(\",\"),\n cookies: process.env._civic_auth_cookie_config\n ? JSON.parse(process.env._civic_auth_cookie_config)\n : undefined,\n }) as AuthConfig;\n const mergedConfig = {\n ...defaultAuthConfig,\n ...configFromEnv, // Apply plugin-set config\n ...config, // Override with directly passed config\n cookies: {\n tokens: {\n ...defaultAuthConfig.cookies.tokens,\n ...(configFromEnv?.cookies?.tokens || {}),\n ...(config.cookies?.tokens || {}),\n },\n user: {\n ...defaultAuthConfig.cookies.user,\n ...(configFromEnv?.cookies?.user || {}),\n ...(config.cookies?.user || {}),\n },\n },\n };\n\n logger.debug(\n \"Config from environment:\",\n JSON.stringify(configFromEnv, null, 2),\n );\n logger.debug(\"Resolved config:\", JSON.stringify(mergedConfig, null, 2));\n if (mergedConfig.clientId === undefined) {\n throw new Error(\"Civic Auth client ID is required\");\n }\n return mergedConfig as AuthConfigWithDefaults & { clientId: string };\n};\n\n/**\n * Creates a Next.js plugin that handles auth configuration.\n *\n * This is the main configuration point for the auth system.\n * Do not set _civic_auth_* environment variables directly - instead,\n * pass your configuration here:\n *\n * @example\n * ```js\n * // next.config.js\n * export default createCivicAuthPlugin({\n * clientId: 'my-client-id',\n * callbackUrl: '/custom/callback',\n * loginUrl: '/custom/login',\n * logoutUrl: '/custom/logout',\n * include: ['/protected/*'],\n * exclude: ['/public/*']\n * })\n * ```\n *\n * The plugin sets internal environment variables that are used by\n * the auth system. These variables should not be set manually.\n */\nexport const createCivicAuthPlugin = (\n authConfig: AuthConfig & Pick<Required<AuthConfig>, \"clientId\">,\n) => {\n return (nextConfig?: NextConfig) => {\n logger.debug(\n \"createCivicAuthPlugin nextConfig\",\n JSON.stringify(nextConfig, null, 2),\n );\n const resolvedConfig = resolveAuthConfig({ ...authConfig });\n return {\n ...nextConfig,\n env: {\n ...nextConfig?.env,\n // Internal environment variables - do not set these manually\n _civic_auth_client_id: resolvedConfig.clientId,\n _civic_oauth_server: resolvedConfig.oauthServer,\n _civic_auth_callback_url: resolvedConfig.callbackUrl,\n _civic_auth_challenge_url: resolvedConfig.challengeUrl,\n _civic_auth_login_url: resolvedConfig.loginUrl,\n _civic_auth_logout_url: resolvedConfig.logoutUrl,\n _civic_auth_includes: resolvedConfig.include.join(\",\"),\n _civic_auth_excludes: resolvedConfig.exclude.join(\",\"),\n _civic_auth_cookie_config: JSON.stringify(resolvedConfig.cookies),\n },\n };\n };\n};\n"]}
@@ -1,2 +1,2 @@
1
- export { useTokenCookie } from "../../nextjs/hooks/useTokenCookie.js";
1
+ export { useUserCookie } from "../../nextjs/hooks/useUserCookie.js";
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC"}
@@ -1,2 +1,2 @@
1
- export { useTokenCookie } from "../../nextjs/hooks/useTokenCookie.js";
1
+ export { useUserCookie } from "../../nextjs/hooks/useUserCookie.js";
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/nextjs/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC","sourcesContent":["export { useTokenCookie } from \"@/nextjs/hooks/useTokenCookie.js\";\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/nextjs/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC","sourcesContent":["export { useUserCookie } from \"@/nextjs/hooks/useUserCookie.js\";\n"]}
@@ -1,3 +1,6 @@
1
1
  import type { EmptyObject, User } from "../../types.js";
2
- export declare const useUserCookie: <T extends EmptyObject>() => User<T> | null;
2
+ export declare const useUserCookie: <T extends EmptyObject>() => {
3
+ user: User<T> | null;
4
+ idToken: string | undefined;
5
+ };
3
6
  //# sourceMappingURL=useUserCookie.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useUserCookie.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/hooks/useUserCookie.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAUpD,eAAO,MAAM,aAAa,GAAI,CAAC,SAAS,WAAW,qBAyBlD,CAAC"}
1
+ {"version":3,"file":"useUserCookie.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/hooks/useUserCookie.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAqBpD,eAAO,MAAM,aAAa,GAAI,CAAC,SAAS,WAAW;;;CAkDlD,CAAC"}