@civic/auth 0.3.1 → 0.3.2-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 (686) hide show
  1. package/dist/cjs/nextjs/config.d.ts.map +1 -1
  2. package/dist/cjs/nextjs/config.js +1 -1
  3. package/dist/cjs/nextjs/config.js.map +1 -1
  4. package/dist/cjs/nextjs/index.d.ts +2 -2
  5. package/dist/cjs/nextjs/index.d.ts.map +1 -1
  6. package/dist/cjs/nextjs/index.js.map +1 -1
  7. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +1 -5
  8. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  9. package/dist/cjs/nextjs/providers/NextAuthProvider.js +5 -45
  10. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -1
  11. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts +1 -1
  12. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -1
  13. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js +16 -23
  14. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js.map +1 -1
  15. package/dist/cjs/reactjs/components/SignInButton.d.ts +4 -3
  16. package/dist/cjs/reactjs/components/SignInButton.d.ts.map +1 -1
  17. package/dist/cjs/reactjs/components/SignInButton.js +5 -9
  18. package/dist/cjs/reactjs/components/SignInButton.js.map +1 -1
  19. package/dist/cjs/reactjs/components/SignOutButton.d.ts +4 -3
  20. package/dist/cjs/reactjs/components/SignOutButton.d.ts.map +1 -1
  21. package/dist/cjs/reactjs/components/SignOutButton.js +4 -8
  22. package/dist/cjs/reactjs/components/SignOutButton.js.map +1 -1
  23. package/dist/cjs/reactjs/components/UserButton.d.ts +6 -3
  24. package/dist/cjs/reactjs/components/UserButton.d.ts.map +1 -1
  25. package/dist/cjs/reactjs/components/UserButton.js +69 -109
  26. package/dist/cjs/reactjs/components/UserButton.js.map +1 -1
  27. package/dist/cjs/reactjs/providers/AuthProvider.d.ts +1 -2
  28. package/dist/cjs/reactjs/providers/AuthProvider.d.ts.map +1 -1
  29. package/dist/cjs/reactjs/providers/AuthProvider.js +3 -37
  30. package/dist/cjs/reactjs/providers/AuthProvider.js.map +1 -1
  31. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts +1 -2
  32. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts.map +1 -1
  33. package/dist/cjs/reactjs/providers/CivicAuthProvider.js +4 -13
  34. package/dist/cjs/reactjs/providers/CivicAuthProvider.js.map +1 -1
  35. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +1 -1
  36. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -1
  37. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js +3 -35
  38. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -1
  39. package/dist/cjs/shared/components/BlockDisplay.d.ts +1 -2
  40. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +1 -1
  41. package/dist/cjs/shared/components/BlockDisplay.js +4 -8
  42. package/dist/cjs/shared/components/BlockDisplay.js.map +1 -1
  43. package/dist/cjs/shared/components/CivicAuthIframe.js +16 -17
  44. package/dist/cjs/shared/components/CivicAuthIframe.js.map +1 -1
  45. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts +2 -2
  46. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  47. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +29 -68
  48. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +1 -1
  49. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts +1 -2
  50. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -1
  51. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js +9 -15
  52. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -1
  53. package/dist/cjs/shared/components/CloseIcon.d.ts +1 -2
  54. package/dist/cjs/shared/components/CloseIcon.d.ts.map +1 -1
  55. package/dist/cjs/shared/components/CloseIcon.js +2 -7
  56. package/dist/cjs/shared/components/CloseIcon.js.map +1 -1
  57. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +1 -2
  58. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -1
  59. package/dist/cjs/shared/components/IFrameAndLoading.js +5 -47
  60. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -1
  61. package/dist/cjs/shared/components/LoadingIcon.d.ts +1 -2
  62. package/dist/cjs/shared/components/LoadingIcon.d.ts.map +1 -1
  63. package/dist/cjs/shared/components/LoadingIcon.js +19 -27
  64. package/dist/cjs/shared/components/LoadingIcon.js.map +1 -1
  65. package/dist/cjs/shared/components/SVGLoading.js +11 -24
  66. package/dist/cjs/shared/components/SVGLoading.js.map +1 -1
  67. package/dist/cjs/shared/lib/UserSession.d.ts +4 -2
  68. package/dist/cjs/shared/lib/UserSession.d.ts.map +1 -1
  69. package/dist/cjs/shared/lib/UserSession.js.map +1 -1
  70. package/dist/cjs/shared/lib/session.d.ts +2 -2
  71. package/dist/cjs/shared/lib/session.d.ts.map +1 -1
  72. package/dist/cjs/shared/lib/session.js +8 -5
  73. package/dist/cjs/shared/lib/session.js.map +1 -1
  74. package/dist/cjs/shared/lib/types.d.ts +1 -0
  75. package/dist/cjs/shared/lib/types.d.ts.map +1 -1
  76. package/dist/cjs/shared/lib/types.js +2 -1
  77. package/dist/cjs/shared/lib/types.js.map +1 -1
  78. package/dist/cjs/shared/lib/util.d.ts.map +1 -1
  79. package/dist/cjs/shared/lib/util.js +1 -0
  80. package/dist/cjs/shared/lib/util.js.map +1 -1
  81. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +1 -1
  82. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +1 -1
  83. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +3 -35
  84. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +1 -1
  85. package/dist/cjs/shared/providers/IframeProvider.d.ts +1 -1
  86. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +1 -1
  87. package/dist/cjs/shared/providers/IframeProvider.js +4 -36
  88. package/dist/cjs/shared/providers/IframeProvider.js.map +1 -1
  89. package/dist/cjs/shared/providers/SessionProvider.d.ts +1 -1
  90. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +1 -1
  91. package/dist/cjs/shared/providers/SessionProvider.js +4 -36
  92. package/dist/cjs/shared/providers/SessionProvider.js.map +1 -1
  93. package/dist/cjs/shared/providers/TokenProvider.d.ts +1 -1
  94. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -1
  95. package/dist/cjs/shared/providers/TokenProvider.js +3 -35
  96. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -1
  97. package/dist/cjs/shared/providers/UserProvider.d.ts +1 -1
  98. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -1
  99. package/dist/cjs/shared/providers/UserProvider.js +4 -36
  100. package/dist/cjs/shared/providers/UserProvider.js.map +1 -1
  101. package/dist/cjs/shared/version.d.ts +1 -1
  102. package/dist/cjs/shared/version.d.ts.map +1 -1
  103. package/dist/cjs/shared/version.js +1 -1
  104. package/dist/cjs/shared/version.js.map +1 -1
  105. package/dist/cjs/types.d.ts +8 -10
  106. package/dist/cjs/types.d.ts.map +1 -1
  107. package/dist/cjs/types.js +3 -2
  108. package/dist/cjs/types.js.map +1 -1
  109. package/dist/esm/nextjs/config.d.ts.map +1 -1
  110. package/dist/esm/nextjs/config.js +1 -1
  111. package/dist/esm/nextjs/config.js.map +1 -1
  112. package/dist/esm/nextjs/index.d.ts +2 -2
  113. package/dist/esm/nextjs/index.d.ts.map +1 -1
  114. package/dist/esm/nextjs/index.js.map +1 -1
  115. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +1 -5
  116. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  117. package/dist/esm/nextjs/providers/NextAuthProvider.js +4 -11
  118. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -1
  119. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts +1 -1
  120. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -1
  121. package/dist/esm/reactjs/components/ButtonContentOrLoader.js +16 -19
  122. package/dist/esm/reactjs/components/ButtonContentOrLoader.js.map +1 -1
  123. package/dist/esm/reactjs/components/SignInButton.d.ts +4 -3
  124. package/dist/esm/reactjs/components/SignInButton.d.ts.map +1 -1
  125. package/dist/esm/reactjs/components/SignInButton.js +5 -6
  126. package/dist/esm/reactjs/components/SignInButton.js.map +1 -1
  127. package/dist/esm/reactjs/components/SignOutButton.d.ts +4 -3
  128. package/dist/esm/reactjs/components/SignOutButton.d.ts.map +1 -1
  129. package/dist/esm/reactjs/components/SignOutButton.js +5 -5
  130. package/dist/esm/reactjs/components/SignOutButton.js.map +1 -1
  131. package/dist/esm/reactjs/components/UserButton.d.ts +6 -3
  132. package/dist/esm/reactjs/components/UserButton.d.ts.map +1 -1
  133. package/dist/esm/reactjs/components/UserButton.js +69 -76
  134. package/dist/esm/reactjs/components/UserButton.js.map +1 -1
  135. package/dist/esm/reactjs/providers/AuthProvider.d.ts +1 -2
  136. package/dist/esm/reactjs/providers/AuthProvider.d.ts.map +1 -1
  137. package/dist/esm/reactjs/providers/AuthProvider.js +2 -3
  138. package/dist/esm/reactjs/providers/AuthProvider.js.map +1 -1
  139. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts +1 -2
  140. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts.map +1 -1
  141. package/dist/esm/reactjs/providers/CivicAuthProvider.js +4 -9
  142. package/dist/esm/reactjs/providers/CivicAuthProvider.js.map +1 -1
  143. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +1 -1
  144. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -1
  145. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js +2 -1
  146. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -1
  147. package/dist/esm/shared/components/BlockDisplay.d.ts +1 -2
  148. package/dist/esm/shared/components/BlockDisplay.d.ts.map +1 -1
  149. package/dist/esm/shared/components/BlockDisplay.js +4 -4
  150. package/dist/esm/shared/components/BlockDisplay.js.map +1 -1
  151. package/dist/esm/shared/components/CivicAuthIframe.js +16 -17
  152. package/dist/esm/shared/components/CivicAuthIframe.js.map +1 -1
  153. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts +2 -2
  154. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  155. package/dist/esm/shared/components/CivicAuthIframeContainer.js +28 -34
  156. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +1 -1
  157. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts +1 -2
  158. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -1
  159. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js +9 -11
  160. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -1
  161. package/dist/esm/shared/components/CloseIcon.d.ts +1 -2
  162. package/dist/esm/shared/components/CloseIcon.d.ts.map +1 -1
  163. package/dist/esm/shared/components/CloseIcon.js +2 -3
  164. package/dist/esm/shared/components/CloseIcon.js.map +1 -1
  165. package/dist/esm/shared/components/IFrameAndLoading.d.ts +1 -2
  166. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -1
  167. package/dist/esm/shared/components/IFrameAndLoading.js +4 -13
  168. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -1
  169. package/dist/esm/shared/components/LoadingIcon.d.ts +1 -2
  170. package/dist/esm/shared/components/LoadingIcon.d.ts.map +1 -1
  171. package/dist/esm/shared/components/LoadingIcon.js +19 -23
  172. package/dist/esm/shared/components/LoadingIcon.js.map +1 -1
  173. package/dist/esm/shared/components/SVGLoading.js +11 -20
  174. package/dist/esm/shared/components/SVGLoading.js.map +1 -1
  175. package/dist/esm/shared/lib/UserSession.d.ts +4 -2
  176. package/dist/esm/shared/lib/UserSession.d.ts.map +1 -1
  177. package/dist/esm/shared/lib/UserSession.js.map +1 -1
  178. package/dist/esm/shared/lib/session.d.ts +2 -2
  179. package/dist/esm/shared/lib/session.d.ts.map +1 -1
  180. package/dist/esm/shared/lib/session.js +9 -6
  181. package/dist/esm/shared/lib/session.js.map +1 -1
  182. package/dist/esm/shared/lib/types.d.ts +1 -0
  183. package/dist/esm/shared/lib/types.d.ts.map +1 -1
  184. package/dist/esm/shared/lib/types.js +1 -0
  185. package/dist/esm/shared/lib/types.js.map +1 -1
  186. package/dist/esm/shared/lib/util.d.ts.map +1 -1
  187. package/dist/esm/shared/lib/util.js +2 -1
  188. package/dist/esm/shared/lib/util.js.map +1 -1
  189. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +1 -1
  190. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +1 -1
  191. package/dist/esm/shared/providers/CivicAuthConfigContext.js +2 -1
  192. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +1 -1
  193. package/dist/esm/shared/providers/IframeProvider.d.ts +1 -1
  194. package/dist/esm/shared/providers/IframeProvider.d.ts.map +1 -1
  195. package/dist/esm/shared/providers/IframeProvider.js +3 -2
  196. package/dist/esm/shared/providers/IframeProvider.js.map +1 -1
  197. package/dist/esm/shared/providers/SessionProvider.d.ts +1 -1
  198. package/dist/esm/shared/providers/SessionProvider.d.ts.map +1 -1
  199. package/dist/esm/shared/providers/SessionProvider.js +3 -2
  200. package/dist/esm/shared/providers/SessionProvider.js.map +1 -1
  201. package/dist/esm/shared/providers/TokenProvider.d.ts +1 -1
  202. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -1
  203. package/dist/esm/shared/providers/TokenProvider.js +2 -1
  204. package/dist/esm/shared/providers/TokenProvider.js.map +1 -1
  205. package/dist/esm/shared/providers/UserProvider.d.ts +1 -1
  206. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -1
  207. package/dist/esm/shared/providers/UserProvider.js +3 -2
  208. package/dist/esm/shared/providers/UserProvider.js.map +1 -1
  209. package/dist/esm/shared/version.d.ts +1 -1
  210. package/dist/esm/shared/version.d.ts.map +1 -1
  211. package/dist/esm/shared/version.js +1 -1
  212. package/dist/esm/shared/version.js.map +1 -1
  213. package/dist/esm/types.d.ts +8 -10
  214. package/dist/esm/types.d.ts.map +1 -1
  215. package/dist/esm/types.js +2 -2
  216. package/dist/esm/types.js.map +1 -1
  217. package/dist/generateVersion.d.ts +2 -0
  218. package/dist/generateVersion.d.ts.map +1 -0
  219. package/dist/generateVersion.js +12 -0
  220. package/dist/generateVersion.js.map +1 -0
  221. package/dist/package.json +118 -0
  222. package/dist/src/browser/storage.d.ts +9 -0
  223. package/dist/src/browser/storage.d.ts.map +1 -0
  224. package/dist/src/browser/storage.js +17 -0
  225. package/dist/src/browser/storage.js.map +1 -0
  226. package/dist/src/config.d.ts +3 -0
  227. package/dist/src/config.d.ts.map +1 -0
  228. package/dist/src/config.js +5 -0
  229. package/dist/src/config.js.map +1 -0
  230. package/dist/src/constants.d.ts +8 -0
  231. package/dist/src/constants.d.ts.map +1 -0
  232. package/dist/src/constants.js +16 -0
  233. package/dist/src/constants.js.map +1 -0
  234. package/dist/src/index.d.ts +6 -0
  235. package/dist/src/index.d.ts.map +1 -0
  236. package/dist/src/index.js +4 -0
  237. package/dist/src/index.js.map +1 -0
  238. package/dist/src/lib/cookies.d.ts +7 -0
  239. package/dist/src/lib/cookies.d.ts.map +1 -0
  240. package/dist/src/lib/cookies.js +25 -0
  241. package/dist/src/lib/cookies.js.map +1 -0
  242. package/dist/src/lib/jwt.d.ts +3 -0
  243. package/dist/src/lib/jwt.d.ts.map +1 -0
  244. package/dist/src/lib/jwt.js +9 -0
  245. package/dist/src/lib/jwt.js.map +1 -0
  246. package/dist/src/lib/logger.d.ts +26 -0
  247. package/dist/src/lib/logger.d.ts.map +1 -0
  248. package/dist/src/lib/logger.js +55 -0
  249. package/dist/src/lib/logger.js.map +1 -0
  250. package/dist/src/lib/oauth.d.ts +19 -0
  251. package/dist/src/lib/oauth.d.ts.map +1 -0
  252. package/dist/src/lib/oauth.js +61 -0
  253. package/dist/src/lib/oauth.js.map +1 -0
  254. package/dist/src/lib/obj.d.ts +3 -0
  255. package/dist/src/lib/obj.d.ts.map +1 -0
  256. package/dist/src/lib/obj.js +18 -0
  257. package/dist/src/lib/obj.js.map +1 -0
  258. package/dist/src/lib/postMessage.d.ts +4 -0
  259. package/dist/src/lib/postMessage.d.ts.map +1 -0
  260. package/dist/src/lib/postMessage.js +15 -0
  261. package/dist/src/lib/postMessage.js.map +1 -0
  262. package/dist/src/lib/windowUtil.d.ts +4 -0
  263. package/dist/src/lib/windowUtil.d.ts.map +1 -0
  264. package/dist/src/lib/windowUtil.js +31 -0
  265. package/dist/src/lib/windowUtil.js.map +1 -0
  266. package/dist/src/nextjs/GetUser.d.ts +6 -0
  267. package/dist/src/nextjs/GetUser.d.ts.map +1 -0
  268. package/dist/src/nextjs/GetUser.js +7 -0
  269. package/dist/src/nextjs/GetUser.js.map +1 -0
  270. package/dist/src/nextjs/config.d.ts +181 -0
  271. package/dist/src/nextjs/config.d.ts.map +1 -0
  272. package/dist/src/nextjs/config.js +177 -0
  273. package/dist/src/nextjs/config.js.map +1 -0
  274. package/dist/src/nextjs/cookies.d.ts +30 -0
  275. package/dist/src/nextjs/cookies.d.ts.map +1 -0
  276. package/dist/src/nextjs/cookies.js +112 -0
  277. package/dist/src/nextjs/cookies.js.map +1 -0
  278. package/dist/src/nextjs/hooks/index.d.ts +2 -0
  279. package/dist/src/nextjs/hooks/index.d.ts.map +1 -0
  280. package/dist/src/nextjs/hooks/index.js +2 -0
  281. package/dist/src/nextjs/hooks/index.js.map +1 -0
  282. package/dist/src/nextjs/hooks/usePrevious.d.ts +2 -0
  283. package/dist/src/nextjs/hooks/usePrevious.d.ts.map +1 -0
  284. package/dist/src/nextjs/hooks/usePrevious.js +9 -0
  285. package/dist/src/nextjs/hooks/usePrevious.js.map +1 -0
  286. package/dist/src/nextjs/hooks/useUserCookie.d.ts +8 -0
  287. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  288. package/dist/src/nextjs/hooks/useUserCookie.js +88 -0
  289. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -0
  290. package/dist/src/nextjs/index.d.ts +7 -0
  291. package/dist/src/nextjs/index.d.ts.map +1 -0
  292. package/dist/src/nextjs/index.js +8 -0
  293. package/dist/src/nextjs/index.js.map +1 -0
  294. package/dist/src/nextjs/middleware/index.d.ts +2 -0
  295. package/dist/src/nextjs/middleware/index.d.ts.map +1 -0
  296. package/dist/src/nextjs/middleware/index.js +4 -0
  297. package/dist/src/nextjs/middleware/index.js.map +1 -0
  298. package/dist/src/nextjs/middleware.d.ts +59 -0
  299. package/dist/src/nextjs/middleware.d.ts.map +1 -0
  300. package/dist/src/nextjs/middleware.js +107 -0
  301. package/dist/src/nextjs/middleware.js.map +1 -0
  302. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +13 -0
  303. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  304. package/dist/src/nextjs/providers/NextAuthProvider.js +94 -0
  305. package/dist/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  306. package/dist/src/nextjs/routeHandler.d.ts +19 -0
  307. package/dist/src/nextjs/routeHandler.d.ts.map +1 -0
  308. package/dist/src/nextjs/routeHandler.js +309 -0
  309. package/dist/src/nextjs/routeHandler.js.map +1 -0
  310. package/dist/src/nextjs/utils.d.ts +3 -0
  311. package/dist/src/nextjs/utils.d.ts.map +1 -0
  312. package/dist/src/nextjs/utils.js +5 -0
  313. package/dist/src/nextjs/utils.js.map +1 -0
  314. package/dist/src/reactjs/components/SignInButton.d.ts +8 -0
  315. package/dist/src/reactjs/components/SignInButton.d.ts.map +1 -0
  316. package/dist/src/reactjs/components/SignInButton.js +14 -0
  317. package/dist/src/reactjs/components/SignInButton.js.map +1 -0
  318. package/dist/src/reactjs/components/SignOutButton.d.ts +6 -0
  319. package/dist/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  320. package/dist/src/reactjs/components/SignOutButton.js +14 -0
  321. package/dist/src/reactjs/components/SignOutButton.js.map +1 -0
  322. package/dist/src/reactjs/components/UserButton.d.ts +6 -0
  323. package/dist/src/reactjs/components/UserButton.d.ts.map +1 -0
  324. package/dist/src/reactjs/components/UserButton.js +118 -0
  325. package/dist/src/reactjs/components/UserButton.js.map +1 -0
  326. package/dist/src/reactjs/components/index.d.ts +6 -0
  327. package/dist/src/reactjs/components/index.d.ts.map +1 -0
  328. package/dist/src/reactjs/components/index.js +6 -0
  329. package/dist/src/reactjs/components/index.js.map +1 -0
  330. package/dist/src/reactjs/hooks/index.d.ts +6 -0
  331. package/dist/src/reactjs/hooks/index.d.ts.map +1 -0
  332. package/dist/src/reactjs/hooks/index.js +6 -0
  333. package/dist/src/reactjs/hooks/index.js.map +1 -0
  334. package/dist/src/reactjs/hooks/useAuth.d.ts +3 -0
  335. package/dist/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  336. package/dist/src/reactjs/hooks/useAuth.js +12 -0
  337. package/dist/src/reactjs/hooks/useAuth.js.map +1 -0
  338. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  339. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  340. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.js +13 -0
  341. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  342. package/dist/src/reactjs/hooks/useUser.d.ts +4 -0
  343. package/dist/src/reactjs/hooks/useUser.d.ts.map +1 -0
  344. package/dist/src/reactjs/hooks/useUser.js +12 -0
  345. package/dist/src/reactjs/hooks/useUser.js.map +1 -0
  346. package/dist/src/reactjs/index.d.ts +6 -0
  347. package/dist/src/reactjs/index.d.ts.map +1 -0
  348. package/dist/src/reactjs/index.js +10 -0
  349. package/dist/src/reactjs/index.js.map +1 -0
  350. package/dist/src/reactjs/providers/AuthProvider.d.ts +11 -0
  351. package/dist/src/reactjs/providers/AuthProvider.d.ts.map +1 -0
  352. package/dist/src/reactjs/providers/AuthProvider.js +76 -0
  353. package/dist/src/reactjs/providers/AuthProvider.js.map +1 -0
  354. package/dist/src/reactjs/providers/CivicAuthProvider.d.ts +6 -0
  355. package/dist/src/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  356. package/dist/src/reactjs/providers/CivicAuthProvider.js +32 -0
  357. package/dist/src/reactjs/providers/CivicAuthProvider.js.map +1 -0
  358. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  359. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  360. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.js +148 -0
  361. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  362. package/dist/src/reactjs/providers/index.d.ts +8 -0
  363. package/dist/src/reactjs/providers/index.d.ts.map +1 -0
  364. package/dist/src/reactjs/providers/index.js +7 -0
  365. package/dist/src/reactjs/providers/index.js.map +1 -0
  366. package/dist/src/server/ServerAuthenticationResolver.d.ts +20 -0
  367. package/dist/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  368. package/dist/src/server/ServerAuthenticationResolver.js +67 -0
  369. package/dist/src/server/ServerAuthenticationResolver.js.map +1 -0
  370. package/dist/src/server/config.d.ts +10 -0
  371. package/dist/src/server/config.d.ts.map +1 -0
  372. package/dist/src/server/config.js +2 -0
  373. package/dist/src/server/config.js.map +1 -0
  374. package/dist/src/server/index.d.ts +7 -0
  375. package/dist/src/server/index.d.ts.map +1 -0
  376. package/dist/src/server/index.js +7 -0
  377. package/dist/src/server/index.js.map +1 -0
  378. package/dist/src/server/login.d.ts +21 -0
  379. package/dist/src/server/login.d.ts.map +1 -0
  380. package/dist/src/server/login.js +56 -0
  381. package/dist/src/server/login.js.map +1 -0
  382. package/dist/src/server/refresh.d.ts +7 -0
  383. package/dist/src/server/refresh.d.ts.map +1 -0
  384. package/dist/src/server/refresh.js +13 -0
  385. package/dist/src/server/refresh.js.map +1 -0
  386. package/dist/src/services/AuthenticationService.d.ts +91 -0
  387. package/dist/src/services/AuthenticationService.d.ts.map +1 -0
  388. package/dist/src/services/AuthenticationService.js +322 -0
  389. package/dist/src/services/AuthenticationService.js.map +1 -0
  390. package/dist/src/services/PKCE.d.ts +20 -0
  391. package/dist/src/services/PKCE.d.ts.map +1 -0
  392. package/dist/src/services/PKCE.js +44 -0
  393. package/dist/src/services/PKCE.js.map +1 -0
  394. package/dist/src/services/types.d.ts +24 -0
  395. package/dist/src/services/types.d.ts.map +1 -0
  396. package/dist/src/services/types.js +7 -0
  397. package/dist/src/services/types.js.map +1 -0
  398. package/dist/src/shared/components/BlockDisplay.d.ts +7 -0
  399. package/dist/src/shared/components/BlockDisplay.d.ts.map +1 -0
  400. package/dist/src/shared/components/BlockDisplay.js +25 -0
  401. package/dist/src/shared/components/BlockDisplay.js.map +1 -0
  402. package/dist/src/shared/components/CivicAuthIframe.d.ts +9 -0
  403. package/dist/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  404. package/dist/src/shared/components/CivicAuthIframe.js +8 -0
  405. package/dist/src/shared/components/CivicAuthIframe.js.map +1 -0
  406. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts +13 -0
  407. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  408. package/dist/src/shared/components/CivicAuthIframeContainer.js +138 -0
  409. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  410. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.d.ts +7 -0
  411. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  412. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.js +22 -0
  413. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  414. package/dist/src/shared/components/CloseIcon.d.ts +4 -0
  415. package/dist/src/shared/components/CloseIcon.d.ts.map +1 -0
  416. package/dist/src/shared/components/CloseIcon.js +6 -0
  417. package/dist/src/shared/components/CloseIcon.js.map +1 -0
  418. package/dist/src/shared/components/IFrameAndLoading.d.ts +8 -0
  419. package/dist/src/shared/components/IFrameAndLoading.d.ts.map +1 -0
  420. package/dist/src/shared/components/IFrameAndLoading.js +27 -0
  421. package/dist/src/shared/components/IFrameAndLoading.js.map +1 -0
  422. package/dist/src/shared/components/LoadingIcon.d.ts +4 -0
  423. package/dist/src/shared/components/LoadingIcon.d.ts.map +1 -0
  424. package/dist/src/shared/components/LoadingIcon.js +30 -0
  425. package/dist/src/shared/components/LoadingIcon.js.map +1 -0
  426. package/dist/src/shared/hooks/index.d.ts +11 -0
  427. package/dist/src/shared/hooks/index.d.ts.map +1 -0
  428. package/dist/src/shared/hooks/index.js +11 -0
  429. package/dist/src/shared/hooks/index.js.map +1 -0
  430. package/dist/src/shared/hooks/useAuth.d.ts +3 -0
  431. package/dist/src/shared/hooks/useAuth.d.ts.map +1 -0
  432. package/dist/src/shared/hooks/useAuth.js +12 -0
  433. package/dist/src/shared/hooks/useAuth.js.map +1 -0
  434. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  435. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  436. package/dist/src/shared/hooks/useCivicAuthConfig.js +10 -0
  437. package/dist/src/shared/hooks/useCivicAuthConfig.js.map +1 -0
  438. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  439. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  440. package/dist/src/shared/hooks/useClientTokenExchangeSession.js +13 -0
  441. package/dist/src/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  442. package/dist/src/shared/hooks/useCurrentUrl.d.ts +3 -0
  443. package/dist/src/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  444. package/dist/src/shared/hooks/useCurrentUrl.js +24 -0
  445. package/dist/src/shared/hooks/useCurrentUrl.js.map +1 -0
  446. package/dist/src/shared/hooks/useIframe.d.ts +3 -0
  447. package/dist/src/shared/hooks/useIframe.d.ts.map +1 -0
  448. package/dist/src/shared/hooks/useIframe.js +13 -0
  449. package/dist/src/shared/hooks/useIframe.js.map +1 -0
  450. package/dist/src/shared/hooks/useIsInIframe.d.ts +3 -0
  451. package/dist/src/shared/hooks/useIsInIframe.d.ts.map +1 -0
  452. package/dist/src/shared/hooks/useIsInIframe.js +14 -0
  453. package/dist/src/shared/hooks/useIsInIframe.js.map +1 -0
  454. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  455. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  456. package/dist/src/shared/hooks/useOAuthEndpoints.js +14 -0
  457. package/dist/src/shared/hooks/useOAuthEndpoints.js.map +1 -0
  458. package/dist/src/shared/hooks/useRefresh.d.ts +4 -0
  459. package/dist/src/shared/hooks/useRefresh.d.ts.map +1 -0
  460. package/dist/src/shared/hooks/useRefresh.js +38 -0
  461. package/dist/src/shared/hooks/useRefresh.js.map +1 -0
  462. package/dist/src/shared/hooks/useSession.d.ts +3 -0
  463. package/dist/src/shared/hooks/useSession.d.ts.map +1 -0
  464. package/dist/src/shared/hooks/useSession.js +13 -0
  465. package/dist/src/shared/hooks/useSession.js.map +1 -0
  466. package/dist/src/shared/hooks/useSignIn.d.ts +15 -0
  467. package/dist/src/shared/hooks/useSignIn.d.ts.map +1 -0
  468. package/dist/src/shared/hooks/useSignIn.js +126 -0
  469. package/dist/src/shared/hooks/useSignIn.js.map +1 -0
  470. package/dist/src/shared/hooks/useToken.d.ts +3 -0
  471. package/dist/src/shared/hooks/useToken.d.ts.map +1 -0
  472. package/dist/src/shared/hooks/useToken.js +12 -0
  473. package/dist/src/shared/hooks/useToken.js.map +1 -0
  474. package/dist/src/shared/hooks/useWindowFocused.d.ts +5 -0
  475. package/dist/src/shared/hooks/useWindowFocused.d.ts.map +1 -0
  476. package/dist/src/shared/hooks/useWindowFocused.js +21 -0
  477. package/dist/src/shared/hooks/useWindowFocused.js.map +1 -0
  478. package/dist/src/shared/index.d.ts +5 -0
  479. package/dist/src/shared/index.d.ts.map +1 -0
  480. package/dist/src/shared/index.js +16 -0
  481. package/dist/src/shared/index.js.map +1 -0
  482. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +20 -0
  483. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  484. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +73 -0
  485. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  486. package/dist/src/shared/lib/UserSession.d.ts +12 -0
  487. package/dist/src/shared/lib/UserSession.d.ts.map +1 -0
  488. package/dist/src/shared/lib/UserSession.js +20 -0
  489. package/dist/src/shared/lib/UserSession.js.map +1 -0
  490. package/dist/src/shared/lib/session.d.ts +3 -0
  491. package/dist/src/shared/lib/session.d.ts.map +1 -0
  492. package/dist/src/shared/lib/session.js +21 -0
  493. package/dist/src/shared/lib/session.js.map +1 -0
  494. package/dist/src/shared/lib/storage.d.ts +25 -0
  495. package/dist/src/shared/lib/storage.d.ts.map +1 -0
  496. package/dist/src/shared/lib/storage.js +17 -0
  497. package/dist/src/shared/lib/storage.js.map +1 -0
  498. package/dist/src/shared/lib/types.d.ts +36 -0
  499. package/dist/src/shared/lib/types.d.ts.map +1 -0
  500. package/dist/src/shared/lib/types.js +18 -0
  501. package/dist/src/shared/lib/types.js.map +1 -0
  502. package/dist/src/shared/lib/util.d.ts +34 -0
  503. package/dist/src/shared/lib/util.d.ts.map +1 -0
  504. package/dist/src/shared/lib/util.js +137 -0
  505. package/dist/src/shared/lib/util.js.map +1 -0
  506. package/dist/src/shared/providers/AuthContext.d.ts +11 -0
  507. package/dist/src/shared/providers/AuthContext.d.ts.map +1 -0
  508. package/dist/src/shared/providers/AuthContext.js +3 -0
  509. package/dist/src/shared/providers/AuthContext.js.map +1 -0
  510. package/dist/src/shared/providers/AuthProvider.d.ts +22 -0
  511. package/dist/src/shared/providers/AuthProvider.d.ts.map +1 -0
  512. package/dist/src/shared/providers/AuthProvider.js +72 -0
  513. package/dist/src/shared/providers/AuthProvider.js.map +1 -0
  514. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts +18 -0
  515. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  516. package/dist/src/shared/providers/CivicAuthConfigContext.js +52 -0
  517. package/dist/src/shared/providers/CivicAuthConfigContext.js.map +1 -0
  518. package/dist/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  519. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  520. package/dist/src/shared/providers/CivicAuthProvider.js +32 -0
  521. package/dist/src/shared/providers/CivicAuthProvider.js.map +1 -0
  522. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  523. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  524. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js +131 -0
  525. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  526. package/dist/src/shared/providers/IframeProvider.d.ts +22 -0
  527. package/dist/src/shared/providers/IframeProvider.d.ts.map +1 -0
  528. package/dist/src/shared/providers/IframeProvider.js +35 -0
  529. package/dist/src/shared/providers/IframeProvider.js.map +1 -0
  530. package/dist/src/shared/providers/SessionProvider.d.ts +19 -0
  531. package/dist/src/shared/providers/SessionProvider.d.ts.map +1 -0
  532. package/dist/src/shared/providers/SessionProvider.js +23 -0
  533. package/dist/src/shared/providers/SessionProvider.js.map +1 -0
  534. package/dist/src/shared/providers/TokenProvider.d.ts +18 -0
  535. package/dist/src/shared/providers/TokenProvider.d.ts.map +1 -0
  536. package/dist/src/shared/providers/TokenProvider.js +42 -0
  537. package/dist/src/shared/providers/TokenProvider.js.map +1 -0
  538. package/dist/src/shared/providers/UserProvider.d.ts +24 -0
  539. package/dist/src/shared/providers/UserProvider.d.ts.map +1 -0
  540. package/dist/src/shared/providers/UserProvider.js +52 -0
  541. package/dist/src/shared/providers/UserProvider.js.map +1 -0
  542. package/dist/src/shared/providers/types.d.ts +15 -0
  543. package/dist/src/shared/providers/types.d.ts.map +1 -0
  544. package/dist/src/shared/providers/types.js +2 -0
  545. package/dist/src/shared/providers/types.js.map +1 -0
  546. package/dist/src/shared/version.d.ts +2 -0
  547. package/dist/src/shared/version.d.ts.map +1 -0
  548. package/dist/src/shared/version.js +3 -0
  549. package/dist/src/shared/version.js.map +1 -0
  550. package/dist/src/types.d.ts +148 -0
  551. package/dist/src/types.d.ts.map +1 -0
  552. package/dist/src/types.js +4 -0
  553. package/dist/src/types.js.map +1 -0
  554. package/dist/src/utils.d.ts +15 -0
  555. package/dist/src/utils.d.ts.map +1 -0
  556. package/dist/src/utils.js +43 -0
  557. package/dist/src/utils.js.map +1 -0
  558. package/dist/src/version.d.ts +2 -0
  559. package/dist/src/version.d.ts.map +1 -0
  560. package/dist/src/version.js +3 -0
  561. package/dist/src/version.js.map +1 -0
  562. package/dist/test/integration/sdk.test.d.ts +2 -0
  563. package/dist/test/integration/sdk.test.d.ts.map +1 -0
  564. package/dist/test/integration/sdk.test.js +237 -0
  565. package/dist/test/integration/sdk.test.js.map +1 -0
  566. package/dist/test/support/fixtures.d.ts +26 -0
  567. package/dist/test/support/fixtures.d.ts.map +1 -0
  568. package/dist/test/support/fixtures.js +55 -0
  569. package/dist/test/support/fixtures.js.map +1 -0
  570. package/dist/test/support/tokens.json +26 -0
  571. package/dist/test/unit/lib/oauth.test.d.ts +2 -0
  572. package/dist/test/unit/lib/oauth.test.d.ts.map +1 -0
  573. package/dist/test/unit/lib/oauth.test.js +56 -0
  574. package/dist/test/unit/lib/oauth.test.js.map +1 -0
  575. package/dist/test/unit/lib/obj.test.d.ts +2 -0
  576. package/dist/test/unit/lib/obj.test.d.ts.map +1 -0
  577. package/dist/test/unit/lib/obj.test.js +37 -0
  578. package/dist/test/unit/lib/obj.test.js.map +1 -0
  579. package/dist/test/unit/logger.test.d.ts +2 -0
  580. package/dist/test/unit/logger.test.d.ts.map +1 -0
  581. package/dist/test/unit/logger.test.js +141 -0
  582. package/dist/test/unit/logger.test.js.map +1 -0
  583. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +2 -0
  584. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts.map +1 -0
  585. package/dist/test/unit/nextjs/NextAuthProvider.test.js +31 -0
  586. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +1 -0
  587. package/dist/test/unit/nextjs/config.test.d.ts +2 -0
  588. package/dist/test/unit/nextjs/config.test.d.ts.map +1 -0
  589. package/dist/test/unit/nextjs/config.test.js +203 -0
  590. package/dist/test/unit/nextjs/config.test.js.map +1 -0
  591. package/dist/test/unit/nextjs/getUser.test.d.ts +2 -0
  592. package/dist/test/unit/nextjs/getUser.test.d.ts.map +1 -0
  593. package/dist/test/unit/nextjs/getUser.test.js +22 -0
  594. package/dist/test/unit/nextjs/getUser.test.js.map +1 -0
  595. package/dist/test/unit/nextjs/handler.test.d.ts +2 -0
  596. package/dist/test/unit/nextjs/handler.test.d.ts.map +1 -0
  597. package/dist/test/unit/nextjs/handler.test.js +207 -0
  598. package/dist/test/unit/nextjs/handler.test.js.map +1 -0
  599. package/dist/test/unit/nextjs/middleware.test.d.ts +2 -0
  600. package/dist/test/unit/nextjs/middleware.test.d.ts.map +1 -0
  601. package/dist/test/unit/nextjs/middleware.test.js +113 -0
  602. package/dist/test/unit/nextjs/middleware.test.js.map +1 -0
  603. package/dist/test/unit/nextjs/utils.test.d.ts +2 -0
  604. package/dist/test/unit/nextjs/utils.test.d.ts.map +1 -0
  605. package/dist/test/unit/nextjs/utils.test.js +13 -0
  606. package/dist/test/unit/nextjs/utils.test.js.map +1 -0
  607. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +2 -0
  608. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts.map +1 -0
  609. package/dist/test/unit/publicApi/apiSnapshot.test.js +10 -0
  610. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +1 -0
  611. package/dist/test/unit/react/components/SignInButton.test.d.ts +2 -0
  612. package/dist/test/unit/react/components/SignInButton.test.d.ts.map +1 -0
  613. package/dist/test/unit/react/components/SignInButton.test.js +31 -0
  614. package/dist/test/unit/react/components/SignInButton.test.js.map +1 -0
  615. package/dist/test/unit/react/components/SignOutButton.test.d.ts +2 -0
  616. package/dist/test/unit/react/components/SignOutButton.test.d.ts.map +1 -0
  617. package/dist/test/unit/react/components/SignOutButton.test.js +30 -0
  618. package/dist/test/unit/react/components/SignOutButton.test.js.map +1 -0
  619. package/dist/test/unit/server/login.test.d.ts +2 -0
  620. package/dist/test/unit/server/login.test.d.ts.map +1 -0
  621. package/dist/test/unit/server/login.test.js +184 -0
  622. package/dist/test/unit/server/login.test.js.map +1 -0
  623. package/dist/test/unit/server/refresh.test.d.ts +2 -0
  624. package/dist/test/unit/server/refresh.test.d.ts.map +1 -0
  625. package/dist/test/unit/server/refresh.test.js +55 -0
  626. package/dist/test/unit/server/refresh.test.js.map +1 -0
  627. package/dist/test/unit/server/session.test.d.ts +2 -0
  628. package/dist/test/unit/server/session.test.d.ts.map +1 -0
  629. package/dist/test/unit/server/session.test.js +41 -0
  630. package/dist/test/unit/server/session.test.js.map +1 -0
  631. package/dist/test/unit/services/AuthenticationService.test.d.ts +2 -0
  632. package/dist/test/unit/services/AuthenticationService.test.d.ts.map +1 -0
  633. package/dist/test/unit/services/AuthenticationService.test.js +301 -0
  634. package/dist/test/unit/services/AuthenticationService.test.js.map +1 -0
  635. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +2 -0
  636. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts.map +1 -0
  637. package/dist/test/unit/services/ServerAuthenticationResolver.test.js +75 -0
  638. package/dist/test/unit/services/ServerAuthenticationResolver.test.js.map +1 -0
  639. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +2 -0
  640. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts.map +1 -0
  641. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js +144 -0
  642. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js.map +1 -0
  643. package/dist/test/unit/shared/UserSession.test.d.ts +2 -0
  644. package/dist/test/unit/shared/UserSession.test.d.ts.map +1 -0
  645. package/dist/test/unit/shared/UserSession.test.js +37 -0
  646. package/dist/test/unit/shared/UserSession.test.js.map +1 -0
  647. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +2 -0
  648. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts.map +1 -0
  649. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +122 -0
  650. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +1 -0
  651. package/dist/test/unit/shared/printVersion.test.d.ts +2 -0
  652. package/dist/test/unit/shared/printVersion.test.d.ts.map +1 -0
  653. package/dist/test/unit/shared/printVersion.test.js +39 -0
  654. package/dist/test/unit/shared/printVersion.test.js.map +1 -0
  655. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.d.ts +2 -0
  656. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.d.ts.map +1 -0
  657. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.js +108 -0
  658. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.js.map +1 -0
  659. package/dist/test/unit/shared/storage.test.d.ts +2 -0
  660. package/dist/test/unit/shared/storage.test.d.ts.map +1 -0
  661. package/dist/test/unit/shared/storage.test.js +53 -0
  662. package/dist/test/unit/shared/storage.test.js.map +1 -0
  663. package/dist/test/unit/utils.test.d.ts +2 -0
  664. package/dist/test/unit/utils.test.d.ts.map +1 -0
  665. package/dist/test/unit/utils.test.js +40 -0
  666. package/dist/test/unit/utils.test.js.map +1 -0
  667. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  668. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  669. package/dist/tsconfig.tsbuildinfo +1 -0
  670. package/dist/vitest.config.d.ts +3 -0
  671. package/dist/vitest.config.d.ts.map +1 -0
  672. package/dist/vitest.config.js +44 -0
  673. package/dist/vitest.config.js.map +1 -0
  674. package/package.json +20 -18
  675. package/dist/cjs/reactjs/components/LoadingSpinner.d.ts +0 -7
  676. package/dist/cjs/reactjs/components/LoadingSpinner.d.ts.map +0 -1
  677. package/dist/cjs/reactjs/components/LoadingSpinner.js +0 -33
  678. package/dist/cjs/reactjs/components/LoadingSpinner.js.map +0 -1
  679. package/dist/cjs/reactjs/hooks/useSignIn.d.ts +0 -6
  680. package/dist/cjs/reactjs/hooks/useSignIn.d.ts.map +0 -1
  681. package/dist/cjs/reactjs/hooks/useSignIn.js +0 -38
  682. package/dist/cjs/reactjs/hooks/useSignIn.js.map +0 -1
  683. package/dist/esm/reactjs/hooks/useSignIn.d.ts +0 -6
  684. package/dist/esm/reactjs/hooks/useSignIn.d.ts.map +0 -1
  685. package/dist/esm/reactjs/hooks/useSignIn.js +0 -34
  686. package/dist/esm/reactjs/hooks/useSignIn.js.map +0 -1
@@ -13,7 +13,7 @@ type SessionContextType = {
13
13
  error?: Error | null;
14
14
  isLoading: boolean;
15
15
  };
16
- declare const SessionProvider: ({ children, ...props }: SessionContextType) => React.JSX.Element;
16
+ declare const SessionProvider: ({ children, ...props }: SessionContextType) => import("@emotion/react/jsx-runtime").JSX.Element;
17
17
  export type { SessionContextType };
18
18
  export { SessionProvider, SessionContext };
19
19
  //# sourceMappingURL=SessionProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"SessionProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/SessionProvider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAwB,MAAM,OAAO,CAAC;AAE7C,MAAM,MAAM,qBAAqB,GAAG;IAClC,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC;IACzB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;CACpB,CAAC;AAaF,QAAA,MAAM,cAAc,sCAAuD,CAAC;AAE5E,KAAK,kBAAkB,GAAG;IACxB,QAAQ,EAAE,SAAS,CAAC;IACpB,IAAI,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC;IAC1B,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC;IACrB,SAAS,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,eAAe,2BAA4B,kBAAkB,sBAYlE,CAAC;AAEF,YAAY,EAAE,kBAAkB,EAAE,CAAC;AACnC,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,CAAC"}
1
+ {"version":3,"file":"SessionProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/SessionProvider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAwB,MAAM,OAAO,CAAC;AAE7C,MAAM,MAAM,qBAAqB,GAAG;IAClC,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC;IACzB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;CACpB,CAAC;AAaF,QAAA,MAAM,cAAc,sCAAuD,CAAC;AAE5E,KAAK,kBAAkB,GAAG;IACxB,QAAQ,EAAE,SAAS,CAAC;IACpB,IAAI,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC;IAC1B,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC;IACrB,SAAS,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,eAAe,2BAA4B,kBAAkB,qDAYlE,CAAC;AAEF,YAAY,EAAE,kBAAkB,EAAE,CAAC;AACnC,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,CAAC"}
@@ -1,41 +1,9 @@
1
1
  "use strict";
2
2
  "use client";
3
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
- if (k2 === undefined) k2 = k;
5
- var desc = Object.getOwnPropertyDescriptor(m, k);
6
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
- desc = { enumerable: true, get: function() { return m[k]; } };
8
- }
9
- Object.defineProperty(o, k2, desc);
10
- }) : (function(o, m, k, k2) {
11
- if (k2 === undefined) k2 = k;
12
- o[k2] = m[k];
13
- }));
14
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
15
- Object.defineProperty(o, "default", { enumerable: true, value: v });
16
- }) : function(o, v) {
17
- o["default"] = v;
18
- });
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
- })();
36
3
  Object.defineProperty(exports, "__esModule", { value: true });
37
4
  exports.SessionContext = exports.SessionProvider = void 0;
38
- const react_1 = __importStar(require("react"));
5
+ const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
6
+ const react_1 = require("react");
39
7
  const defaultSession = {
40
8
  data: {
41
9
  authenticated: false,
@@ -50,11 +18,11 @@ const defaultSession = {
50
18
  const SessionContext = (0, react_1.createContext)(defaultSession);
51
19
  exports.SessionContext = SessionContext;
52
20
  const SessionProvider = ({ children, ...props }) => {
53
- return (react_1.default.createElement(SessionContext.Provider, { value: {
21
+ return ((0, jsx_runtime_1.jsx)(SessionContext.Provider, { value: {
54
22
  ...props,
55
23
  data: props.data || null,
56
24
  error: props.error || null,
57
- } }, children));
25
+ }, children: children }));
58
26
  };
59
27
  exports.SessionProvider = SessionProvider;
60
28
  //# sourceMappingURL=SessionProvider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SessionProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/SessionProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGb,+CAA6C;AAO7C,MAAM,cAAc,GAA0B;IAC5C,IAAI,EAAE;QACJ,aAAa,EAAE,KAAK;QACpB,OAAO,EAAE,SAAS;QAClB,WAAW,EAAE,SAAS;QACtB,WAAW,EAAE,QAAQ;KACtB;IACD,KAAK,EAAE,IAAI;IACX,SAAS,EAAE,KAAK;CACjB,CAAC;AAEF,iEAAiE;AACjE,MAAM,cAAc,GAAG,IAAA,qBAAa,EAAwB,cAAc,CAAC,CAAC;AAwBlD,wCAAc;AAfxC,MAAM,eAAe,GAAG,CAAC,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAsB,EAAE,EAAE;IACrE,OAAO,CACL,8BAAC,cAAc,CAAC,QAAQ,IACtB,KAAK,EAAE;YACL,GAAG,KAAK;YACR,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,IAAI;YACxB,KAAK,EAAE,KAAK,CAAC,KAAK,IAAI,IAAI;SAC3B,IAEA,QAAQ,CACe,CAC3B,CAAC;AACJ,CAAC,CAAC;AAGO,0CAAe","sourcesContent":["\"use client\";\nimport type { SessionData } from \"@/types.js\";\nimport type { ReactNode } from \"react\";\nimport React, { createContext } from \"react\";\n\nexport type SessionProviderOutput = {\n data: SessionData | null;\n error: Error | null;\n isLoading: boolean;\n};\nconst defaultSession: SessionProviderOutput = {\n data: {\n authenticated: false,\n idToken: undefined,\n accessToken: undefined,\n displayMode: \"iframe\",\n },\n error: null,\n isLoading: false,\n};\n\n// Context for exposing session specifically to the TokenProvider\nconst SessionContext = createContext<SessionProviderOutput>(defaultSession);\n\ntype SessionContextType = {\n children: ReactNode;\n data?: SessionData | null;\n error?: Error | null;\n isLoading: boolean;\n};\n\nconst SessionProvider = ({ children, ...props }: SessionContextType) => {\n return (\n <SessionContext.Provider\n value={{\n ...props,\n data: props.data || null,\n error: props.error || null,\n }}\n >\n {children}\n </SessionContext.Provider>\n );\n};\n\nexport type { SessionContextType };\nexport { SessionProvider, SessionContext };\n"]}
1
+ {"version":3,"file":"SessionProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/SessionProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;AAGb,iCAA6C;AAO7C,MAAM,cAAc,GAA0B;IAC5C,IAAI,EAAE;QACJ,aAAa,EAAE,KAAK;QACpB,OAAO,EAAE,SAAS;QAClB,WAAW,EAAE,SAAS;QACtB,WAAW,EAAE,QAAQ;KACtB;IACD,KAAK,EAAE,IAAI;IACX,SAAS,EAAE,KAAK;CACjB,CAAC;AAEF,iEAAiE;AACjE,MAAM,cAAc,GAAG,IAAA,qBAAa,EAAwB,cAAc,CAAC,CAAC;AAwBlD,wCAAc;AAfxC,MAAM,eAAe,GAAG,CAAC,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAsB,EAAE,EAAE;IACrE,OAAO,CACL,uBAAC,cAAc,CAAC,QAAQ,IACtB,KAAK,EAAE;YACL,GAAG,KAAK;YACR,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,IAAI;YACxB,KAAK,EAAE,KAAK,CAAC,KAAK,IAAI,IAAI;SAC3B,YAEA,QAAQ,GACe,CAC3B,CAAC;AACJ,CAAC,CAAC;AAGO,0CAAe","sourcesContent":["\"use client\";\nimport type { SessionData } from \"@/types.js\";\nimport type { ReactNode } from \"react\";\nimport React, { createContext } from \"react\";\n\nexport type SessionProviderOutput = {\n data: SessionData | null;\n error: Error | null;\n isLoading: boolean;\n};\nconst defaultSession: SessionProviderOutput = {\n data: {\n authenticated: false,\n idToken: undefined,\n accessToken: undefined,\n displayMode: \"iframe\",\n },\n error: null,\n isLoading: false,\n};\n\n// Context for exposing session specifically to the TokenProvider\nconst SessionContext = createContext<SessionProviderOutput>(defaultSession);\n\ntype SessionContextType = {\n children: ReactNode;\n data?: SessionData | null;\n error?: Error | null;\n isLoading: boolean;\n};\n\nconst SessionProvider = ({ children, ...props }: SessionContextType) => {\n return (\n <SessionContext.Provider\n value={{\n ...props,\n data: props.data || null,\n error: props.error || null,\n }}\n >\n {children}\n </SessionContext.Provider>\n );\n};\n\nexport type { SessionContextType };\nexport { SessionProvider, SessionContext };\n"]}
@@ -11,7 +11,7 @@ type TokenContextType = {
11
11
  declare const TokenContext: React.Context<TokenContextType | undefined>;
12
12
  declare const TokenProvider: ({ children }: {
13
13
  children: ReactNode;
14
- }) => React.JSX.Element;
14
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
15
15
  export type { TokenContextType };
16
16
  export { TokenProvider, TokenContext };
17
17
  //# sourceMappingURL=TokenProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TokenProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/TokenProvider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAiC,MAAM,OAAO,CAAC;AAEtD,OAAO,KAAK,EAAE,eAAe,EAAW,MAAM,YAAY,CAAC;AAI3D,KAAK,gBAAgB,GAAG;IACtB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,eAAe,EAAE,eAAe,CAAC;IACjC,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;CACrB,CAAC;AAEF,QAAA,MAAM,YAAY,6CAAyD,CAAC;AAE5E,QAAA,MAAM,aAAa,iBAAkB;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,sBAsC3D,CAAC;AAEF,YAAY,EAAE,gBAAgB,EAAE,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC"}
1
+ {"version":3,"file":"TokenProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/TokenProvider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAiC,MAAM,OAAO,CAAC;AAEtD,OAAO,KAAK,EAAE,eAAe,EAAW,MAAM,YAAY,CAAC;AAI3D,KAAK,gBAAgB,GAAG;IACtB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,eAAe,EAAE,eAAe,CAAC;IACjC,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;CACrB,CAAC;AAEF,QAAA,MAAM,YAAY,6CAAyD,CAAC;AAE5E,QAAA,MAAM,aAAa,iBAAkB;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,qDAsC3D,CAAC;AAEF,YAAY,EAAE,gBAAgB,EAAE,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC"}
@@ -1,41 +1,9 @@
1
1
  "use strict";
2
2
  "use client";
3
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
- if (k2 === undefined) k2 = k;
5
- var desc = Object.getOwnPropertyDescriptor(m, k);
6
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
- desc = { enumerable: true, get: function() { return m[k]; } };
8
- }
9
- Object.defineProperty(o, k2, desc);
10
- }) : (function(o, m, k, k2) {
11
- if (k2 === undefined) k2 = k;
12
- o[k2] = m[k];
13
- }));
14
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
15
- Object.defineProperty(o, "default", { enumerable: true, value: v });
16
- }) : function(o, v) {
17
- o["default"] = v;
18
- });
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
- })();
36
3
  Object.defineProperty(exports, "__esModule", { value: true });
37
4
  exports.TokenContext = exports.TokenProvider = void 0;
38
- const react_1 = __importStar(require("react"));
5
+ const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
6
+ const react_1 = require("react");
39
7
  const useSession_js_1 = require("../../shared/hooks/useSession.js");
40
8
  const jwt_1 = require("oslo/jwt");
41
9
  const jwt_js_1 = require("../../lib/jwt.js");
@@ -68,7 +36,7 @@ const TokenProvider = ({ children }) => {
68
36
  isLoading,
69
37
  authError,
70
38
  ]);
71
- return (react_1.default.createElement(TokenContext.Provider, { value: value }, children));
39
+ return ((0, jsx_runtime_1.jsx)(TokenContext.Provider, { value: value, children: children }));
72
40
  };
73
41
  exports.TokenProvider = TokenProvider;
74
42
  //# sourceMappingURL=TokenProvider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TokenProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/TokenProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEb,+CAAsD;AACtD,gEAA0D;AAE1D,kCAAoC;AACpC,yCAA2D;AAU3D,MAAM,YAAY,GAAG,IAAA,qBAAa,EAA+B,SAAS,CAAC,CAAC;AA2CpD,oCAAY;AAzCpC,MAAM,aAAa,GAAG,CAAC,EAAE,QAAQ,EAA2B,EAAE,EAAE;IAC9D,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAA,0BAAU,GAAE,CAAC;IACrD,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAA,0BAAU,GAAE,CAAC;IAEvC,MAAM,YAAY,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE;QAChC,IAAI,CAAC,OAAO,EAAE,OAAO;YAAE,OAAO,IAAI,CAAC;QAEnC,MAAM,SAAS,GAAG,IAAA,cAAQ,EAAC,OAAO,CAAC,OAAO,CAAmB,CAAC;QAE9D,IAAI,CAAC,SAAS;YAAE,OAAO,IAAI,CAAC;QAE5B,MAAM,EAAE,eAAe,EAAE,GAAG,SAAS,CAAC,OAAO,CAAC;QAE9C,OAAO,eAAe;YACpB,CAAC,CAAC,IAAA,oCAA2B,EAAC,eAAe,CAAC;YAC9C,CAAC,CAAC,IAAI,CAAC;IACX,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAEvB,MAAM,KAAK,GAAG,IAAA,eAAO,EACnB,GAAG,EAAE,CAAC,CAAC;QACL,WAAW,EAAE,OAAO,EAAE,WAAW,IAAI,IAAI;QACzC,OAAO,EAAE,OAAO,EAAE,OAAO,IAAI,IAAI;QACjC,eAAe,EAAE,YAAY,IAAI,EAAE;QACnC,SAAS;QACT,KAAK,EAAE,SAAyB;KACjC,CAAC,EACF;QACE,OAAO,EAAE,WAAW;QACpB,OAAO,EAAE,OAAO;QAChB,YAAY;QACZ,SAAS;QACT,SAAS;KACV,CACF,CAAC;IAEF,OAAO,CACL,8BAAC,YAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,IAAG,QAAQ,CAAyB,CACxE,CAAC;AACJ,CAAC,CAAC;AAGO,sCAAa","sourcesContent":["\"use client\";\nimport type { ReactNode } from \"react\";\nimport React, { createContext, useMemo } from \"react\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { ForwardedTokens, IdToken } from \"@/types.js\";\nimport { parseJWT } from \"oslo/jwt\";\nimport { convertForwardedTokenFormat } from \"@/lib/jwt.js\";\n\ntype TokenContextType = {\n accessToken: string | null;\n idToken: string | null;\n forwardedTokens: ForwardedTokens;\n isLoading: boolean;\n error: Error | null;\n};\n\nconst TokenContext = createContext<TokenContextType | undefined>(undefined);\n\nconst TokenProvider = ({ children }: { children: ReactNode }) => {\n const { isLoading, error: authError } = useSession();\n const { data: session } = useSession();\n\n const decodeTokens = useMemo(() => {\n if (!session?.idToken) return null;\n\n const parsedJWT = parseJWT(session.idToken) as IdToken | null;\n\n if (!parsedJWT) return null;\n\n const { forwardedTokens } = parsedJWT.payload;\n\n return forwardedTokens\n ? convertForwardedTokenFormat(forwardedTokens)\n : null;\n }, [session?.idToken]);\n\n const value = useMemo(\n () => ({\n accessToken: session?.accessToken || null,\n idToken: session?.idToken || null,\n forwardedTokens: decodeTokens || {},\n isLoading,\n error: authError as Error | null,\n }),\n [\n session?.accessToken,\n session?.idToken,\n decodeTokens,\n isLoading,\n authError,\n ],\n );\n\n return (\n <TokenContext.Provider value={value}>{children}</TokenContext.Provider>\n );\n};\n\nexport type { TokenContextType };\nexport { TokenProvider, TokenContext };\n"]}
1
+ {"version":3,"file":"TokenProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/TokenProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;AAEb,iCAAsD;AACtD,gEAA0D;AAE1D,kCAAoC;AACpC,yCAA2D;AAU3D,MAAM,YAAY,GAAG,IAAA,qBAAa,EAA+B,SAAS,CAAC,CAAC;AA2CpD,oCAAY;AAzCpC,MAAM,aAAa,GAAG,CAAC,EAAE,QAAQ,EAA2B,EAAE,EAAE;IAC9D,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAA,0BAAU,GAAE,CAAC;IACrD,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAA,0BAAU,GAAE,CAAC;IAEvC,MAAM,YAAY,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE;QAChC,IAAI,CAAC,OAAO,EAAE,OAAO;YAAE,OAAO,IAAI,CAAC;QAEnC,MAAM,SAAS,GAAG,IAAA,cAAQ,EAAC,OAAO,CAAC,OAAO,CAAmB,CAAC;QAE9D,IAAI,CAAC,SAAS;YAAE,OAAO,IAAI,CAAC;QAE5B,MAAM,EAAE,eAAe,EAAE,GAAG,SAAS,CAAC,OAAO,CAAC;QAE9C,OAAO,eAAe;YACpB,CAAC,CAAC,IAAA,oCAA2B,EAAC,eAAe,CAAC;YAC9C,CAAC,CAAC,IAAI,CAAC;IACX,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAEvB,MAAM,KAAK,GAAG,IAAA,eAAO,EACnB,GAAG,EAAE,CAAC,CAAC;QACL,WAAW,EAAE,OAAO,EAAE,WAAW,IAAI,IAAI;QACzC,OAAO,EAAE,OAAO,EAAE,OAAO,IAAI,IAAI;QACjC,eAAe,EAAE,YAAY,IAAI,EAAE;QACnC,SAAS;QACT,KAAK,EAAE,SAAyB;KACjC,CAAC,EACF;QACE,OAAO,EAAE,WAAW;QACpB,OAAO,EAAE,OAAO;QAChB,YAAY;QACZ,SAAS;QACT,SAAS;KACV,CACF,CAAC;IAEF,OAAO,CACL,uBAAC,YAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,YAAG,QAAQ,GAAyB,CACxE,CAAC;AACJ,CAAC,CAAC;AAGO,sCAAa","sourcesContent":["\"use client\";\nimport type { ReactNode } from \"react\";\nimport React, { createContext, useMemo } from \"react\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { ForwardedTokens, IdToken } from \"@/types.js\";\nimport { parseJWT } from \"oslo/jwt\";\nimport { convertForwardedTokenFormat } from \"@/lib/jwt.js\";\n\ntype TokenContextType = {\n accessToken: string | null;\n idToken: string | null;\n forwardedTokens: ForwardedTokens;\n isLoading: boolean;\n error: Error | null;\n};\n\nconst TokenContext = createContext<TokenContextType | undefined>(undefined);\n\nconst TokenProvider = ({ children }: { children: ReactNode }) => {\n const { isLoading, error: authError } = useSession();\n const { data: session } = useSession();\n\n const decodeTokens = useMemo(() => {\n if (!session?.idToken) return null;\n\n const parsedJWT = parseJWT(session.idToken) as IdToken | null;\n\n if (!parsedJWT) return null;\n\n const { forwardedTokens } = parsedJWT.payload;\n\n return forwardedTokens\n ? convertForwardedTokenFormat(forwardedTokens)\n : null;\n }, [session?.idToken]);\n\n const value = useMemo(\n () => ({\n accessToken: session?.accessToken || null,\n idToken: session?.idToken || null,\n forwardedTokens: decodeTokens || {},\n isLoading,\n error: authError as Error | null,\n }),\n [\n session?.accessToken,\n session?.idToken,\n decodeTokens,\n isLoading,\n authError,\n ],\n );\n\n return (\n <TokenContext.Provider value={value}>{children}</TokenContext.Provider>\n );\n};\n\nexport type { TokenContextType };\nexport { TokenProvider, TokenContext };\n"]}
@@ -20,7 +20,7 @@ declare const UserProvider: <T extends UserContent>({ children, storage, user: i
20
20
  authStatus: AuthStatus;
21
21
  signIn: (displayMode?: DisplayMode) => Promise<void>;
22
22
  displayMode: DisplayMode;
23
- }) => React.JSX.Element;
23
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
24
24
  export type { UserContextType };
25
25
  export { UserProvider, UserContext };
26
26
  //# sourceMappingURL=UserProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"UserProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA0D,MAAM,OAAO,CAAC;AAC/E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,KAAK,EACV,UAAU,EACV,WAAW,EACX,WAAW,EACX,eAAe,EACf,IAAI,EACL,MAAM,YAAY,CAAC;AAEpB,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAIzE,KAAK,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC;AAC5D,KAAK,eAAe,CAAC,CAAC,SAAS,WAAW,GAAG,WAAW,IAAI;IAC1D,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;CACtB,GAAG;IACF,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC,GAAG,IAAI,CAAC,eAAe,EAAE,iBAAiB,CAAC,CAAC;AAE7C,QAAA,MAAM,WAAW,oDAA8C,CAAC;AAEhE,QAAA,MAAM,YAAY,GAAI,CAAC,SAAS,WAAW,qFAQxC;IACD,QAAQ,EAAE,SAAS,CAAC;IACpB,OAAO,EAAE,WAAW,CAAC;IACrB,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACrB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,UAAU,EAAE,UAAU,CAAC;IACvB,MAAM,EAAE,CAAC,WAAW,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,WAAW,EAAE,WAAW,CAAC;CAC1B,sBAgEA,CAAC;AAEF,YAAY,EAAE,eAAe,EAAE,CAAC;AAEhC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC"}
1
+ {"version":3,"file":"UserProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA0D,MAAM,OAAO,CAAC;AAC/E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,KAAK,EACV,UAAU,EACV,WAAW,EACX,WAAW,EACX,eAAe,EACf,IAAI,EACL,MAAM,YAAY,CAAC;AAEpB,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAIzE,KAAK,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC;AAC5D,KAAK,eAAe,CAAC,CAAC,SAAS,WAAW,GAAG,WAAW,IAAI;IAC1D,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;CACtB,GAAG;IACF,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC,GAAG,IAAI,CAAC,eAAe,EAAE,iBAAiB,CAAC,CAAC;AAE7C,QAAA,MAAM,WAAW,oDAA8C,CAAC;AAEhE,QAAA,MAAM,YAAY,GAAI,CAAC,SAAS,WAAW,qFAQxC;IACD,QAAQ,EAAE,SAAS,CAAC;IACpB,OAAO,EAAE,WAAW,CAAC;IACrB,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACrB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,UAAU,EAAE,UAAU,CAAC;IACvB,MAAM,EAAE,CAAC,WAAW,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,WAAW,EAAE,WAAW,CAAC;CAC1B,qDAgEA,CAAC;AAEF,YAAY,EAAE,eAAe,EAAE,CAAC;AAEhC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC"}
@@ -1,41 +1,9 @@
1
1
  "use strict";
2
2
  "use client";
3
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
- if (k2 === undefined) k2 = k;
5
- var desc = Object.getOwnPropertyDescriptor(m, k);
6
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
- desc = { enumerable: true, get: function() { return m[k]; } };
8
- }
9
- Object.defineProperty(o, k2, desc);
10
- }) : (function(o, m, k, k2) {
11
- if (k2 === undefined) k2 = k;
12
- o[k2] = m[k];
13
- }));
14
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
15
- Object.defineProperty(o, "default", { enumerable: true, value: v });
16
- }) : function(o, v) {
17
- o["default"] = v;
18
- });
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
- })();
36
3
  Object.defineProperty(exports, "__esModule", { value: true });
37
4
  exports.UserContext = exports.UserProvider = void 0;
38
- const react_1 = __importStar(require("react"));
5
+ const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
6
+ const react_1 = require("react");
39
7
  const useSession_js_1 = require("../../shared/hooks/useSession.js");
40
8
  const UserSession_js_1 = require("../../shared/lib/UserSession.js");
41
9
  const useToken_js_1 = require("../hooks/useToken.js");
@@ -86,7 +54,7 @@ const UserProvider = ({ children, storage, user: inputUser, signOut, authStatus,
86
54
  // If the user is passed in, we just use that.
87
55
  // We should not split user state management across multiple contexts
88
56
  const userValue = user ?? inputUser;
89
- return (react_1.default.createElement(UserContext.Provider, { value: {
57
+ return ((0, jsx_runtime_1.jsx)(UserContext.Provider, { value: {
90
58
  ...tokens,
91
59
  user: userValue,
92
60
  isLoading,
@@ -95,7 +63,7 @@ const UserProvider = ({ children, storage, user: inputUser, signOut, authStatus,
95
63
  signOut,
96
64
  authStatus,
97
65
  displayMode: displayMode || "iframe",
98
- } }, children));
66
+ }, children: children }));
99
67
  };
100
68
  exports.UserProvider = UserProvider;
101
69
  //# sourceMappingURL=UserProvider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"UserProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEb,+CAA+E;AAU/E,gEAA0D;AAE1D,gEAAiE;AACjE,sDAAgD;AAWhD,MAAM,WAAW,GAAG,IAAA,qBAAa,EAAyB,IAAI,CAAC,CAAC;AAsFzC,kCAAW;AApFlC,MAAM,YAAY,GAAG,CAAwB,EAC3C,QAAQ,EACR,OAAO,EACP,IAAI,EAAE,SAAS,EACf,OAAO,EACP,UAAU,EACV,MAAM,EACN,WAAW,GASZ,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,EAAiB,SAAS,CAAC,CAAC;IAE5D,MAAM,SAAS,GAAG,IAAA,mBAAW,EAAC,KAAK,IAA6B,EAAE;QAChE,IAAI,CAAC,OAAO,EAAE,OAAO;YAAE,OAAO,IAAI,CAAC;QACnC,MAAM,WAAW,GAAG,IAAI,mCAAkB,CAAI,OAAO,CAAC,CAAC;QACvD,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,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,CAAC,QAAQ,EAAE,EAAE;oBACnB,sGAAsG;oBACtG,sEAAsE;oBACtE,2EAA2E;oBAC3E,OAAO,IAAI,IAAI,QAAQ,CAAC;gBAC1B,CAAC,CAAC,CAAC;YACL,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;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,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,mEAAmE;IACnE,+DAA+D;IAC/D,kEAAkE;IAClE,oEAAoE;IACpE,mEAAmE;IACnE,8CAA8C;IAC9C,qEAAqE;IACrE,MAAM,SAAS,GAAG,IAAI,IAAI,SAAS,CAAC;IAEpC,OAAO,CACL,8BAAC,WAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,GAAG,MAAM;YACT,IAAI,EAAE,SAAS;YACf,SAAS;YACT,KAAK;YACL,MAAM;YACN,OAAO;YACP,UAAU;YACV,WAAW,EAAE,WAAW,IAAI,QAAQ;SACrC,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 {\n AuthStatus,\n AuthStorage,\n DisplayMode,\n ForwardedTokens,\n User,\n} 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 { useToken } from \"../hooks/useToken.js\";\n\ntype UserContent = Record<string, unknown> & JWT[\"payload\"];\ntype UserContextType<T extends UserContent = UserContent> = {\n user: User<T> | null;\n} & {\n accessToken?: string | null;\n idToken?: string | null;\n forwardedTokens?: ForwardedTokens;\n} & Omit<AuthContextType, \"isAuthenticated\">;\n\nconst UserContext = createContext<UserContextType | null>(null);\n\nconst UserProvider = <T extends UserContent>({\n children,\n storage,\n user: inputUser,\n signOut,\n authStatus,\n signIn,\n displayMode,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user: User<T> | null;\n signOut: () => Promise<void>;\n authStatus: AuthStatus;\n signIn: (displayMode?: DisplayMode) => Promise<void>;\n displayMode: DisplayMode;\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<T> | null>(inputUser);\n\n const fetchUser = useCallback(async (): Promise<User<T> | null> => {\n if (!session?.idToken) return null;\n const userSession = new GenericUserSession<T>(storage);\n return userSession.get();\n }, [session?.idToken, storage]);\n\n useEffect(() => {\n if (session?.idToken) {\n setUserLoading(true);\n fetchUser()\n .then((user) => {\n setUserLoading(false);\n setUser((prevUser) => {\n // we only want to update the user if it's set - if a user is passed in, don't assume it is wrong here\n // it could be just the fetchUser returned null for some other reason.\n // TODO consider cleaning this up in general to avoid needing context here.\n return user ?? prevUser;\n });\n })\n .catch((error) => {\n setUserLoading(false);\n setUserError(error);\n });\n } else {\n setUser(null);\n }\n }, [fetchUser, session?.idToken]);\n\n const isLoading = authLoading || userLoading;\n const error = authError ?? userError;\n\n // While we are passing a user as a prop _and_ storing it in state,\n // there is the case where the user is not set in the state yet\n // (setState is called but the rerender has not yet happened), but\n // is passed as a prop. In this case, we want to use the prop value.\n // A better solution is to avoid having multiple layers of context.\n // If the user is passed in, we just use that.\n // We should not split user state management across multiple contexts\n const userValue = user ?? inputUser;\n\n return (\n <UserContext.Provider\n value={{\n ...tokens,\n user: userValue,\n isLoading,\n error,\n signIn,\n signOut,\n authStatus,\n displayMode: displayMode || \"iframe\",\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,iCAA+E;AAU/E,gEAA0D;AAE1D,gEAAiE;AACjE,sDAAgD;AAWhD,MAAM,WAAW,GAAG,IAAA,qBAAa,EAAyB,IAAI,CAAC,CAAC;AAsFzC,kCAAW;AApFlC,MAAM,YAAY,GAAG,CAAwB,EAC3C,QAAQ,EACR,OAAO,EACP,IAAI,EAAE,SAAS,EACf,OAAO,EACP,UAAU,EACV,MAAM,EACN,WAAW,GASZ,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,EAAiB,SAAS,CAAC,CAAC;IAE5D,MAAM,SAAS,GAAG,IAAA,mBAAW,EAAC,KAAK,IAA6B,EAAE;QAChE,IAAI,CAAC,OAAO,EAAE,OAAO;YAAE,OAAO,IAAI,CAAC;QACnC,MAAM,WAAW,GAAG,IAAI,mCAAkB,CAAI,OAAO,CAAC,CAAC;QACvD,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,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,CAAC,QAAQ,EAAE,EAAE;oBACnB,sGAAsG;oBACtG,sEAAsE;oBACtE,2EAA2E;oBAC3E,OAAO,IAAI,IAAI,QAAQ,CAAC;gBAC1B,CAAC,CAAC,CAAC;YACL,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;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,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,mEAAmE;IACnE,+DAA+D;IAC/D,kEAAkE;IAClE,oEAAoE;IACpE,mEAAmE;IACnE,8CAA8C;IAC9C,qEAAqE;IACrE,MAAM,SAAS,GAAG,IAAI,IAAI,SAAS,CAAC;IAEpC,OAAO,CACL,uBAAC,WAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,GAAG,MAAM;YACT,IAAI,EAAE,SAAS;YACf,SAAS;YACT,KAAK;YACL,MAAM;YACN,OAAO;YACP,UAAU;YACV,WAAW,EAAE,WAAW,IAAI,QAAQ;SACrC,YAEA,QAAQ,GACY,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 {\n AuthStatus,\n AuthStorage,\n DisplayMode,\n ForwardedTokens,\n User,\n} 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 { useToken } from \"../hooks/useToken.js\";\n\ntype UserContent = Record<string, unknown> & JWT[\"payload\"];\ntype UserContextType<T extends UserContent = UserContent> = {\n user: User<T> | null;\n} & {\n accessToken?: string | null;\n idToken?: string | null;\n forwardedTokens?: ForwardedTokens;\n} & Omit<AuthContextType, \"isAuthenticated\">;\n\nconst UserContext = createContext<UserContextType | null>(null);\n\nconst UserProvider = <T extends UserContent>({\n children,\n storage,\n user: inputUser,\n signOut,\n authStatus,\n signIn,\n displayMode,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user: User<T> | null;\n signOut: () => Promise<void>;\n authStatus: AuthStatus;\n signIn: (displayMode?: DisplayMode) => Promise<void>;\n displayMode: DisplayMode;\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<T> | null>(inputUser);\n\n const fetchUser = useCallback(async (): Promise<User<T> | null> => {\n if (!session?.idToken) return null;\n const userSession = new GenericUserSession<T>(storage);\n return userSession.get();\n }, [session?.idToken, storage]);\n\n useEffect(() => {\n if (session?.idToken) {\n setUserLoading(true);\n fetchUser()\n .then((user) => {\n setUserLoading(false);\n setUser((prevUser) => {\n // we only want to update the user if it's set - if a user is passed in, don't assume it is wrong here\n // it could be just the fetchUser returned null for some other reason.\n // TODO consider cleaning this up in general to avoid needing context here.\n return user ?? prevUser;\n });\n })\n .catch((error) => {\n setUserLoading(false);\n setUserError(error);\n });\n } else {\n setUser(null);\n }\n }, [fetchUser, session?.idToken]);\n\n const isLoading = authLoading || userLoading;\n const error = authError ?? userError;\n\n // While we are passing a user as a prop _and_ storing it in state,\n // there is the case where the user is not set in the state yet\n // (setState is called but the rerender has not yet happened), but\n // is passed as a prop. In this case, we want to use the prop value.\n // A better solution is to avoid having multiple layers of context.\n // If the user is passed in, we just use that.\n // We should not split user state management across multiple contexts\n const userValue = user ?? inputUser;\n\n return (\n <UserContext.Provider\n value={{\n ...tokens,\n user: userValue,\n isLoading,\n error,\n signIn,\n signOut,\n authStatus,\n displayMode: displayMode || \"iframe\",\n }}\n >\n {children}\n </UserContext.Provider>\n );\n};\n\nexport type { UserContextType };\n\nexport { UserProvider, UserContext };\n"]}
@@ -1,2 +1,2 @@
1
- export declare const VERSION = "@civic/auth:0.3.1";
1
+ export declare const VERSION = "@civic/auth:0.3.2-beta.1";
2
2
  //# sourceMappingURL=version.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,OAAO,sBAAsB,CAAC"}
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,OAAO,6BAA6B,CAAC"}
@@ -2,5 +2,5 @@
2
2
  // This is an auto-generated file. Do not edit.
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.VERSION = void 0;
5
- exports.VERSION = "@civic/auth:0.3.1";
5
+ exports.VERSION = "@civic/auth:0.3.2-beta.1";
6
6
  //# sourceMappingURL=version.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":";AAAA,+CAA+C;;;AAElC,QAAA,OAAO,GAAG,mBAAmB,CAAC","sourcesContent":["// This is an auto-generated file. Do not edit.\n\nexport const VERSION = \"@civic/auth:0.3.1\";\n"]}
1
+ {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":";AAAA,+CAA+C;;;AAElC,QAAA,OAAO,GAAG,0BAA0B,CAAC","sourcesContent":["// This is an auto-generated file. Do not edit.\n\nexport const VERSION = \"@civic/auth:0.3.2-beta.1\";\n"]}
@@ -80,13 +80,11 @@ type ForwardedTokensJWT = Record<string, {
80
80
  refresh_token?: string;
81
81
  scope?: string;
82
82
  }>;
83
- type JWTPayload = JWT["payload"] & {
84
- iss: string;
85
- aud: string;
86
- sub: string;
87
- iat: number;
88
- exp: number;
83
+ declare const jwtPayloadKnownClaimsKeys: readonly ["iss", "aud", "sub", "iat", "exp"];
84
+ type JWTPayloadKnownClaims = {
85
+ [K in (typeof jwtPayloadKnownClaimsKeys)[number]]: string;
89
86
  };
87
+ type JWTPayload = JWT["payload"] & JWTPayloadKnownClaims;
90
88
  type IdTokenPayload = JWTPayload & {
91
89
  forwardedTokens?: ForwardedTokensJWT;
92
90
  email?: string;
@@ -98,7 +96,7 @@ type IdTokenPayload = JWTPayload & {
98
96
  type IdToken = Omit<JWT, "payload"> & {
99
97
  payload: IdTokenPayload;
100
98
  };
101
- declare const tokenKeys: string[];
99
+ declare const tokenKeys: readonly ["sub", "idToken", "accessToken", "refreshToken", "forwardedTokens"];
102
100
  export type OAuthTokens = {
103
101
  idToken?: string;
104
102
  accessToken?: string;
@@ -116,7 +114,7 @@ type BaseUser = {
116
114
  picture?: string;
117
115
  updated_at?: Date;
118
116
  };
119
- type User<T extends UnknownObject = EmptyObject> = BaseUser & T;
117
+ type User<T extends Record<string, unknown> = Record<string, never>> = BaseUser & (T | BaseUser);
120
118
  type OpenIdConfiguration = {
121
119
  authorization_endpoint: string;
122
120
  claims_parameter_supported: boolean;
@@ -158,8 +156,8 @@ export type IframeAuthMessage = {
158
156
  error?: string;
159
157
  };
160
158
  };
161
- 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, };
162
- export { tokenKeys };
159
+ export type { LoginPostMessage, AuthSessionService, TokenService, UserInfoService, ResourceService, AuthRequest, Tokens, Endpoints, Config, SessionData, OIDCTokenResponseBody, ParsedTokens, BaseUser, User, DisplayMode, UnknownObject, EmptyObject, ForwardedTokens, ForwardedTokensJWT, JWTPayloadKnownClaims, JWTPayload, IdTokenPayload, IdToken, OpenIdConfiguration, };
160
+ export { jwtPayloadKnownClaimsKeys, tokenKeys };
163
161
  export interface AuthStorage {
164
162
  get(key: string): Promise<string | null>;
165
163
  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,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.tokenKeys = exports.AuthStatus = void 0;
3
+ exports.tokenKeys = exports.jwtPayloadKnownClaimsKeys = exports.AuthStatus = void 0;
4
4
  var AuthStatus;
5
5
  (function (AuthStatus) {
6
6
  AuthStatus["AUTHENTICATED"] = "authenticated";
@@ -9,7 +9,8 @@ var AuthStatus;
9
9
  AuthStatus["ERROR"] = "error";
10
10
  AuthStatus["SIGNING_OUT"] = "signing_out";
11
11
  })(AuthStatus || (exports.AuthStatus = AuthStatus = {}));
12
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
12
+ const jwtPayloadKnownClaimsKeys = ["iss", "aud", "sub", "iat", "exp"];
13
+ exports.jwtPayloadKnownClaimsKeys = jwtPayloadKnownClaimsKeys;
13
14
  const tokenKeys = [
14
15
  "sub",
15
16
  "idToken",
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":";;;AAMA,IAAY,UAMX;AAND,WAAY,UAAU;IACpB,6CAA+B,CAAA;IAC/B,iDAAmC,CAAA;IACnC,+CAAiC,CAAA;IACjC,6BAAe,CAAA;IACf,yCAA2B,CAAA;AAC7B,CAAC,EANW,UAAU,0BAAV,UAAU,QAMrB;AA4ID,6DAA6D;AAC7D,MAAM,SAAS,GAAG;IAChB,KAAK;IACL,SAAS;IACT,aAAa;IACb,cAAc;IACd,iBAAiB;CAClB,CAAC;AAgGO,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\nexport enum AuthStatus {\n AUTHENTICATED = \"authenticated\",\n UNAUTHENTICATED = \"unauthenticated\",\n AUTHENTICATING = \"authenticating\",\n ERROR = \"error\",\n SIGNING_OUT = \"signing_out\",\n}\n// Display modes for the auth flow\ntype DisplayMode = \"iframe\" | \"redirect\" | \"new_tab\" | \"custom_tab\";\n\n// Combined Auth and Session Service\ninterface AuthSessionService {\n // TODO DK NOTES: Should be in BrowserAuthSessionService, not relevant on backend\n loadAuthorizationUrl(\n authorizationURL: string,\n displayMode: DisplayMode,\n ): void;\n // TODO DK NOTES: overrideDisplayMode parameter not appropriate here - also - do we need both this and the above in the interface?\n getAuthorizationUrl(\n scopes: string[],\n overrideDisplayMode: DisplayMode,\n nonce?: string,\n ): Promise<string>;\n // TODO DK NOTES: display mode should be in browser version only. Also, do we need this and the above two in the top-level interface?\n signIn(\n displayMode: DisplayMode,\n scopes: string[],\n nonce?: string,\n ): Promise<void>;\n // TODO DK NOTES: Input should be an auth code - do not assume it comes via an url\n tokenExchange(responseUrl: string): Promise<SessionData>;\n // TODO DK NOTES: Should be async for flexibility\n getSessionData(): SessionData;\n // TODO DK NOTES: Should be async for flexibility\n updateSessionData(data: SessionData): void;\n getUserInfoService(): Promise<UserInfoService>;\n}\n\n// Token Service\ninterface TokenService {\n exchangeCodeForTokens(authCode: string): Promise<Tokens>;\n validateIdToken(idToken: string, nonce: string): boolean;\n refreshAccessToken(refreshToken: string): Promise<Tokens>;\n}\n\n// User Info Service\ninterface UserInfoService {\n getUserInfo<T extends UnknownObject>(\n accessToken: string,\n idToken: string | null,\n ): Promise<User<T> | null>;\n}\n\n// Resource Service\ninterface ResourceService {\n getProtectedResource(accessToken: string): Promise<unknown>;\n}\n\n// Auth Request (for internal use in AuthSessionService)\ntype AuthRequest = {\n clientId: string;\n redirectUri: string;\n state: string;\n nonce: string;\n scope: string;\n};\n\ntype Endpoints = {\n jwks: string;\n auth: string;\n token: string;\n userinfo: string;\n challenge?: string;\n endsession: string;\n};\n\ntype Config = {\n oauthServer: string;\n endpoints?: Endpoints;\n};\n\ntype SessionData = {\n authenticated: boolean; // TODO can this be inferred from the presence of the tokens?\n state?: string;\n accessToken?: string;\n refreshToken?: string;\n idToken?: string;\n accessTokenExpiresAt?: number;\n codeVerifier?: string;\n displayMode?: DisplayMode;\n openerUrl?: string;\n};\n\ntype OIDCTokenResponseBody = TokenResponseBody & {\n id_token: string;\n access_token_expires_at?: number;\n};\n\ntype ParsedTokens = {\n id_token: JWTPayload;\n access_token: JWTPayload;\n refresh_token?: string;\n};\n\n// The format we expose to the frontend via hooks\ntype ForwardedTokens = Record<\n string,\n {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n }\n>;\n\n// The format in the JWT payload\ntype ForwardedTokensJWT = Record<\n string,\n {\n id_token?: string;\n access_token?: string;\n refresh_token?: string;\n scope?: string;\n }\n>;\n\ntype 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 = [\n \"sub\",\n \"idToken\",\n \"accessToken\",\n \"refreshToken\",\n \"forwardedTokens\",\n];\n\nexport type OAuthTokens = {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n};\n// Derive the Tokens type from the array\ntype Tokens = {\n [K in (typeof tokenKeys)[number]]: K extends \"forwardedTokens\"\n ? ForwardedTokens\n : string;\n};\n\n// Base user interface\ntype BaseUser = {\n id: string;\n email?: string;\n name?: string;\n given_name?: string;\n family_name?: string;\n picture?: string;\n updated_at?: Date;\n};\n\ntype User<T extends UnknownObject = EmptyObject> = 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};\n\nexport type IframeAuthMessage = {\n source: \"civicloginApp\";\n type: \"auth_error\" | \"auth_error_try_again\";\n clientId: string;\n data: {\n url?: string;\n error?: string;\n };\n};\n\nexport type {\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 delete(key: string): Promise<void>;\n}\n\nexport type IframeMode = \"embedded\" | \"modal\";\n"]}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":";;;AAMA,IAAY,UAMX;AAND,WAAY,UAAU;IACpB,6CAA+B,CAAA;IAC/B,iDAAmC,CAAA;IACnC,+CAAiC,CAAA;IACjC,6BAAe,CAAA;IACf,yCAA2B,CAAA;AAC7B,CAAC,EANW,UAAU,0BAAV,UAAU,QAMrB;AAuHD,MAAM,yBAAyB,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAU,CAAC;AA2HtE,8DAAyB;AAxGlC,MAAM,SAAS,GAAG;IAChB,KAAK;IACL,SAAS;IACT,aAAa;IACb,cAAc;IACd,iBAAiB;CACT,CAAC;AAkGyB,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\nexport enum AuthStatus {\n AUTHENTICATED = \"authenticated\",\n UNAUTHENTICATED = \"unauthenticated\",\n AUTHENTICATING = \"authenticating\",\n ERROR = \"error\",\n SIGNING_OUT = \"signing_out\",\n}\n// Display modes for the auth flow\ntype DisplayMode = \"iframe\" | \"redirect\" | \"new_tab\" | \"custom_tab\";\n\n// Combined Auth and Session Service\ninterface AuthSessionService {\n // TODO DK NOTES: Should be in BrowserAuthSessionService, not relevant on backend\n loadAuthorizationUrl(\n authorizationURL: string,\n displayMode: DisplayMode,\n ): void;\n // TODO DK NOTES: overrideDisplayMode parameter not appropriate here - also - do we need both this and the above in the interface?\n getAuthorizationUrl(\n scopes: string[],\n overrideDisplayMode: DisplayMode,\n nonce?: string,\n ): Promise<string>;\n // TODO DK NOTES: display mode should be in browser version only. Also, do we need this and the above two in the top-level interface?\n signIn(\n displayMode: DisplayMode,\n scopes: string[],\n nonce?: string,\n ): Promise<void>;\n // TODO DK NOTES: Input should be an auth code - do not assume it comes via an url\n tokenExchange(responseUrl: string): Promise<SessionData>;\n // TODO DK NOTES: Should be async for flexibility\n getSessionData(): SessionData;\n // TODO DK NOTES: Should be async for flexibility\n updateSessionData(data: SessionData): void;\n getUserInfoService(): Promise<UserInfoService>;\n}\n\n// Token Service\ninterface TokenService {\n exchangeCodeForTokens(authCode: string): Promise<Tokens>;\n validateIdToken(idToken: string, nonce: string): boolean;\n refreshAccessToken(refreshToken: string): Promise<Tokens>;\n}\n\n// User Info Service\ninterface UserInfoService {\n getUserInfo<T extends UnknownObject>(\n accessToken: string,\n idToken: string | null,\n ): Promise<User<T> | null>;\n}\n\n// Resource Service\ninterface ResourceService {\n getProtectedResource(accessToken: string): Promise<unknown>;\n}\n\n// Auth Request (for internal use in AuthSessionService)\ntype AuthRequest = {\n clientId: string;\n redirectUri: string;\n state: string;\n nonce: string;\n scope: string;\n};\n\ntype Endpoints = {\n jwks: string;\n auth: string;\n token: string;\n userinfo: string;\n challenge?: string;\n endsession: string;\n};\n\ntype Config = {\n oauthServer: string;\n endpoints?: Endpoints;\n};\n\ntype SessionData = {\n authenticated: boolean; // TODO can this be inferred from the presence of the tokens?\n state?: string;\n accessToken?: string;\n refreshToken?: string;\n idToken?: string;\n accessTokenExpiresAt?: number;\n codeVerifier?: string;\n displayMode?: DisplayMode;\n openerUrl?: string;\n};\n\ntype OIDCTokenResponseBody = TokenResponseBody & {\n id_token: string;\n access_token_expires_at?: number;\n};\n\ntype ParsedTokens = {\n id_token: JWTPayload;\n access_token: JWTPayload;\n refresh_token?: string;\n};\n\n// The format we expose to the frontend via hooks\ntype ForwardedTokens = Record<\n string,\n {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n }\n>;\n\n// The format in the JWT payload\ntype ForwardedTokensJWT = Record<\n string,\n {\n id_token?: string;\n access_token?: string;\n refresh_token?: string;\n scope?: string;\n }\n>;\n\nconst jwtPayloadKnownClaimsKeys = [\"iss\", \"aud\", \"sub\", \"iat\", \"exp\"] as const;\ntype JWTPayloadKnownClaims = {\n [K in (typeof jwtPayloadKnownClaimsKeys)[number]]: string;\n};\ntype JWTPayload = JWT[\"payload\"] & JWTPayloadKnownClaims;\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\nconst tokenKeys = [\n \"sub\",\n \"idToken\",\n \"accessToken\",\n \"refreshToken\",\n \"forwardedTokens\",\n] as const;\n\nexport type OAuthTokens = {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n};\n// Derive the Tokens type from the array\ntype Tokens = {\n [K in (typeof tokenKeys)[number]]: K extends \"forwardedTokens\"\n ? ForwardedTokens\n : string;\n};\n\n// Base user interface\ntype BaseUser = {\n id: string;\n email?: string;\n name?: string;\n given_name?: string;\n family_name?: string;\n picture?: string;\n updated_at?: Date;\n};\n\ntype User<T extends Record<string, unknown> = Record<string, never>> =\n BaseUser & (T | BaseUser);\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};\n\nexport type IframeAuthMessage = {\n source: \"civicloginApp\";\n type: \"auth_error\" | \"auth_error_try_again\";\n clientId: string;\n data: {\n url?: string;\n error?: string;\n };\n};\n\nexport type {\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 JWTPayloadKnownClaims,\n JWTPayload,\n IdTokenPayload,\n IdToken,\n OpenIdConfiguration,\n};\nexport { jwtPayloadKnownClaimsKeys, tokenKeys };\nexport interface AuthStorage {\n get(key: string): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n delete(key: string): Promise<void>;\n}\n\nexport type IframeMode = \"embedded\" | \"modal\";\n"]}
@@ -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;AAM/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,iBAAiB,EAAE,MAAM,CAAC;IAC1B,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,mBAAmB,CAAC;CAC9B,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,kBAAkB,GAAG,OAAO,CACpC,sBAAsB,GACtB;IACE,OAAO,CAAC,EAAE;QACR,MAAM,CAAC,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;QACrC,IAAI,CAAC,EAAE,YAAY,CAAC;KACrB,CAAC;CACH,CACJ,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG,kBAAkB,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAKnE;;GAEG;AACH,eAAO,MAAM,iBAAiB,EAAE,IAAI,CAAC,sBAAsB,EAAE,UAAU,CA+DtE,CAAC;AAEF;;;;;;;;;;;;;;;;;;;GAmBG;AACH,eAAO,MAAM,iBAAiB,YACpB,OAAO,CAAC,UAAU,CAAC,KAC1B,sBAoCF,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,eAAO,MAAM,qBAAqB,eAAgB,UAAU,mBACrC,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAyBy7Z,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;;;;CADlwmB,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;AAM/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,iBAAiB,EAAE,MAAM,CAAC;IAC1B,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,mBAAmB,CAAC;CAC9B,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,kBAAkB,GAAG,OAAO,CACpC,sBAAsB,GACtB;IACE,OAAO,CAAC,EAAE;QACR,MAAM,CAAC,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;QACrC,IAAI,CAAC,EAAE,YAAY,CAAC;KACrB,CAAC;CACH,CACJ,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG,kBAAkB,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAKnE;;GAEG;AACH,eAAO,MAAM,iBAAiB,EAAE,IAAI,CAAC,sBAAsB,EAAE,UAAU,CA+DtE,CAAC;AAEF;;;;;;;;;;;;;;;;;;;GAmBG;AACH,eAAO,MAAM,iBAAiB,YACpB,OAAO,CAAC,UAAU,CAAC,KAC1B,sBAoCF,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,eAAO,MAAM,qBAAqB,eAAgB,UAAU,mBACrC,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAyBw7Z,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;;;;CADjwmB,CAAC"}
@@ -17,7 +17,7 @@ export const defaultAuthConfig = {
17
17
  logoutUrl: "/api/auth/logout",
18
18
  logoutCallbackUrl: "/api/auth/logoutcallback",
19
19
  loginUrl: "/",
20
- include: ["/*"],
20
+ include: ["/**"],
21
21
  exclude: [],
22
22
  cookies: {
23
23
  tokens: {
@@ -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\";\nimport { merge } from \"ts-deepmerge\";\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 logoutCallbackUrl: string;\n challengeUrl: string;\n refreshUrl: string;\n include: string[];\n exclude: string[];\n cookies: CookiesConfigObject;\n};\n\n/**\n * All possible config values for Civic Auth\n */\nexport type OptionalAuthConfig = Partial<\n | AuthConfigWithDefaults\n | {\n cookies?: {\n tokens?: Partial<TokensCookieConfig>;\n user?: CookieConfig;\n };\n }\n>;\n\n/**\n * Configuration values that are required for Civic Auth to work.\n */\nexport type AuthConfig = OptionalAuthConfig & { clientId: string };\n\nconst defaultServerSecure = !(process.env.NODE_ENV === \"development\");\nconst defaultCookiesMaxAge = 60 * 60; // 1 hour\n\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 refreshUrl: \"/api/auth/refresh\",\n logoutUrl: \"/api/auth/logout\",\n logoutCallbackUrl: \"/api/auth/logoutcallback\",\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 maxAge: defaultCookiesMaxAge,\n },\n [OAuthTokens.ACCESS_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n [OAuthTokens.REFRESH_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n [OAuthTokens.ACCESS_TOKEN_EXPIRES_AT]: {\n secure: defaultServerSecure,\n httpOnly: false, // we need this to be available client-side\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n [CodeVerifier.COOKIE_NAME]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n [CodeVerifier.APP_URL]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n },\n user: {\n secure: defaultServerSecure,\n httpOnly: false, // we need this to be available client-side\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\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 * Config will be merged deeply, with arrays not merged, so that the\n * default include list (for example) [\"/*\"] will not be added\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: Partial<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 logoutCallbackUrl: process.env._civic_auth_logout_callback_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\n // Perform a deep merge of the configurations\n const mergedConfig = merge.withOptions(\n { mergeArrays: false },\n defaultAuthConfig,\n configFromEnv,\n config,\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\n if (mergedConfig.clientId === undefined) {\n throw new Error(\"Civic Auth client ID is required\");\n }\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 * The only required field is clientId.\n *\n * @example\n * ```js\n * // next.config.js\n * export default createCivicAuthPlugin({\n * clientId: 'my-client-id',\n * });\n * ```\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 * logoutCallbackUrl: '/custom/logoutcallback',\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 = (authConfig: AuthConfig) => {\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_logout_callback_url: resolvedConfig.logoutCallbackUrl,\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\";\nimport { merge } from \"ts-deepmerge\";\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 logoutCallbackUrl: string;\n challengeUrl: string;\n refreshUrl: string;\n include: string[];\n exclude: string[];\n cookies: CookiesConfigObject;\n};\n\n/**\n * All possible config values for Civic Auth\n */\nexport type OptionalAuthConfig = Partial<\n | AuthConfigWithDefaults\n | {\n cookies?: {\n tokens?: Partial<TokensCookieConfig>;\n user?: CookieConfig;\n };\n }\n>;\n\n/**\n * Configuration values that are required for Civic Auth to work.\n */\nexport type AuthConfig = OptionalAuthConfig & { clientId: string };\n\nconst defaultServerSecure = !(process.env.NODE_ENV === \"development\");\nconst defaultCookiesMaxAge = 60 * 60; // 1 hour\n\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 refreshUrl: \"/api/auth/refresh\",\n logoutUrl: \"/api/auth/logout\",\n logoutCallbackUrl: \"/api/auth/logoutcallback\",\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 maxAge: defaultCookiesMaxAge,\n },\n [OAuthTokens.ACCESS_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n [OAuthTokens.REFRESH_TOKEN]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n [OAuthTokens.ACCESS_TOKEN_EXPIRES_AT]: {\n secure: defaultServerSecure,\n httpOnly: false, // we need this to be available client-side\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n [CodeVerifier.COOKIE_NAME]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n [CodeVerifier.APP_URL]: {\n secure: defaultServerSecure,\n httpOnly: true,\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\n },\n },\n user: {\n secure: defaultServerSecure,\n httpOnly: false, // we need this to be available client-side\n sameSite: \"strict\",\n path: \"/\",\n maxAge: defaultCookiesMaxAge,\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 * Config will be merged deeply, with arrays not merged, so that the\n * default include list (for example) [\"/*\"] will not be added\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: Partial<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 logoutCallbackUrl: process.env._civic_auth_logout_callback_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\n // Perform a deep merge of the configurations\n const mergedConfig = merge.withOptions(\n { mergeArrays: false },\n defaultAuthConfig,\n configFromEnv,\n config,\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\n if (mergedConfig.clientId === undefined) {\n throw new Error(\"Civic Auth client ID is required\");\n }\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 * The only required field is clientId.\n *\n * @example\n * ```js\n * // next.config.js\n * export default createCivicAuthPlugin({\n * clientId: 'my-client-id',\n * });\n * ```\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 * logoutCallbackUrl: '/custom/logoutcallback',\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 = (authConfig: AuthConfig) => {\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_logout_callback_url: resolvedConfig.logoutCallbackUrl,\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,6 +1,6 @@
1
- import type { OAuthTokens, User } from "../types.js";
1
+ import type { EmptyObject, OAuthTokens, UnknownObject, User } from "../types.js";
2
2
  export { createCivicAuthPlugin, defaultAuthConfig } from "../nextjs/config.js";
3
- export declare const getUser: () => Promise<User | null>;
3
+ export declare const getUser: <T extends UnknownObject = EmptyObject>() => Promise<User<T> | null>;
4
4
  export declare const getTokens: () => Promise<OAuthTokens | null>;
5
5
  export { handler } from "../nextjs/routeHandler.js";
6
6
  export { NextjsCookieStorage } from "../nextjs/cookies.js";
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/nextjs/index.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAEpD,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAE9E,eAAO,MAAM,OAAO,QAAa,OAAO,CAAC,IAAI,GAAG,IAAI,CAGnD,CAAC;AACF,eAAO,MAAM,SAAS,QAAa,OAAO,CAAC,WAAW,GAAG,IAAI,CAG5D,CAAC;AACF,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,YAAY,EACV,UAAU,EACV,mBAAmB,EACnB,sBAAsB,GACvB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,qBAAqB,IAAI,iBAAiB,EAC1C,KAAK,0BAA0B,IAAI,iBAAiB,GACrD,MAAM,wCAAwC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/nextjs/index.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,aAAa,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAEhF,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAE9E,eAAO,MAAM,OAAO,GAClB,CAAC,SAAS,aAAa,qBACpB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAG1B,CAAC;AACF,eAAO,MAAM,SAAS,QAAa,OAAO,CAAC,WAAW,GAAG,IAAI,CAG5D,CAAC;AACF,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,YAAY,EACV,UAAU,EACV,mBAAmB,EACnB,sBAAsB,GACvB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,qBAAqB,IAAI,iBAAiB,EAC1C,KAAK,0BAA0B,IAAI,iBAAiB,GACrD,MAAM,wCAAwC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/nextjs/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,YAAY,EAAE,CAAC;AACf,OAAO,EACL,SAAS,IAAI,gBAAgB,EAC7B,OAAO,IAAI,cAAc,GAC1B,MAAM,yBAAyB,CAAC;AAGjC,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAE9E,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;AACF,MAAM,CAAC,MAAM,SAAS,GAAG,KAAK,IAAiC,EAAE;IAC/D,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,gBAAgB,CAAC,aAAa,CAAC,CAAC;AACzC,CAAC,CAAC;AACF,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAM1D,OAAO,EACL,qBAAqB,IAAI,iBAAiB,GAE3C,MAAM,wCAAwC,CAAC","sourcesContent":["import { NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nimport { printVersion } from \"@/shared/index.js\";\nprintVersion();\nimport {\n getTokens as getSessionTokens,\n getUser as getSessionUser,\n} from \"@/shared/lib/session.js\";\nimport type { OAuthTokens, User } from \"@/types.js\";\n\nexport { createCivicAuthPlugin, defaultAuthConfig } from \"@/nextjs/config.js\";\n\nexport const getUser = async (): Promise<User | null> => {\n const clientStorage = new NextjsCookieStorage();\n return getSessionUser(clientStorage);\n};\nexport const getTokens = async (): Promise<OAuthTokens | null> => {\n const clientStorage = new NextjsCookieStorage();\n return getSessionTokens(clientStorage);\n};\nexport { handler } from \"@/nextjs/routeHandler.js\";\nexport { NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nexport type {\n AuthConfig,\n CookiesConfigObject,\n AuthConfigWithDefaults,\n} from \"@/nextjs/config.js\";\nexport {\n CivicNextAuthProvider as CivicAuthProvider,\n type NextCivicAuthProviderProps as AuthProviderProps,\n} from \"@/nextjs/providers/NextAuthProvider.js\";\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/nextjs/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,YAAY,EAAE,CAAC;AACf,OAAO,EACL,SAAS,IAAI,gBAAgB,EAC7B,OAAO,IAAI,cAAc,GAC1B,MAAM,yBAAyB,CAAC;AAGjC,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAE9E,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,IAEC,EAAE;IAC7B,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,cAAc,CAAI,aAAa,CAAC,CAAC;AAC1C,CAAC,CAAC;AACF,MAAM,CAAC,MAAM,SAAS,GAAG,KAAK,IAAiC,EAAE;IAC/D,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,gBAAgB,CAAC,aAAa,CAAC,CAAC;AACzC,CAAC,CAAC;AACF,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAM1D,OAAO,EACL,qBAAqB,IAAI,iBAAiB,GAE3C,MAAM,wCAAwC,CAAC","sourcesContent":["import { NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nimport { printVersion } from \"@/shared/index.js\";\nprintVersion();\nimport {\n getTokens as getSessionTokens,\n getUser as getSessionUser,\n} from \"@/shared/lib/session.js\";\nimport type { EmptyObject, OAuthTokens, UnknownObject, User } from \"@/types.js\";\n\nexport { createCivicAuthPlugin, defaultAuthConfig } from \"@/nextjs/config.js\";\n\nexport const getUser = async <\n T extends UnknownObject = EmptyObject,\n>(): Promise<User<T> | null> => {\n const clientStorage = new NextjsCookieStorage();\n return getSessionUser<T>(clientStorage);\n};\nexport const getTokens = async (): Promise<OAuthTokens | null> => {\n const clientStorage = new NextjsCookieStorage();\n return getSessionTokens(clientStorage);\n};\nexport { handler } from \"@/nextjs/routeHandler.js\";\nexport { NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nexport type {\n AuthConfig,\n CookiesConfigObject,\n AuthConfigWithDefaults,\n} from \"@/nextjs/config.js\";\nexport {\n CivicNextAuthProvider as CivicAuthProvider,\n type NextCivicAuthProviderProps as AuthProviderProps,\n} from \"@/nextjs/providers/NextAuthProvider.js\";\n"]}
@@ -1,13 +1,9 @@
1
- /**
2
- * A very small context provider for the user object - it takes the user object from the cookie and provides it to the app.
3
- */
4
- import React from "react";
5
1
  import { type AuthConfigWithDefaults } from "../../nextjs/config.js";
6
2
  import type { AuthProviderProps } from "../../shared/providers/types.js";
7
3
  type NextCivicAuthProviderInternalProps = Omit<AuthProviderProps, "clientId"> & {
8
4
  resolvedConfig: AuthConfigWithDefaults;
9
5
  };
10
6
  type NextCivicAuthProviderProps = Omit<NextCivicAuthProviderInternalProps, "clientId" | "resolvedConfig" | "redirectUrl">;
11
- declare const CivicNextAuthProvider: ({ children, ...props }: NextCivicAuthProviderProps) => React.JSX.Element;
7
+ declare const CivicNextAuthProvider: ({ children, ...props }: NextCivicAuthProviderProps) => import("@emotion/react/jsx-runtime").JSX.Element;
12
8
  export { CivicNextAuthProvider, type NextCivicAuthProviderProps };
13
9
  //# sourceMappingURL=NextAuthProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"NextAuthProvider.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"AACA;;GAEG;AACH,OAAO,KAA2C,MAAM,OAAO,CAAC;AAChE,OAAO,EAEL,KAAK,sBAAsB,EAC5B,MAAM,oBAAoB,CAAC;AAe5B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAcrE,KAAK,kCAAkC,GAAG,IAAI,CAC5C,iBAAiB,EACjB,UAAU,CACX,GAAG;IACF,cAAc,EAAE,sBAAsB,CAAC;CACxC,CAAC;AACF,KAAK,0BAA0B,GAAG,IAAI,CACpC,kCAAkC,EAClC,UAAU,GAAG,gBAAgB,GAAG,aAAa,CAC9C,CAAC;AAoHF,QAAA,MAAM,qBAAqB,2BAGxB,0BAA0B,sBA0C5B,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,KAAK,0BAA0B,EAAE,CAAC"}
1
+ {"version":3,"file":"NextAuthProvider.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"AAKA,OAAO,EAEL,KAAK,sBAAsB,EAC5B,MAAM,oBAAoB,CAAC;AAe5B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAcrE,KAAK,kCAAkC,GAAG,IAAI,CAC5C,iBAAiB,EACjB,UAAU,CACX,GAAG;IACF,cAAc,EAAE,sBAAsB,CAAC;CACxC,CAAC;AACF,KAAK,0BAA0B,GAAG,IAAI,CACpC,kCAAkC,EAClC,UAAU,GAAG,gBAAgB,GAAG,aAAa,CAC9C,CAAC;AAoHF,QAAA,MAAM,qBAAqB,2BAGxB,0BAA0B,qDA0C5B,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,KAAK,0BAA0B,EAAE,CAAC"}