@civic/auth 0.3.2-beta.0 → 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 (522) hide show
  1. package/dist/cjs/constants.d.ts +1 -2
  2. package/dist/cjs/constants.d.ts.map +1 -1
  3. package/dist/cjs/constants.js +1 -9
  4. package/dist/cjs/constants.js.map +1 -1
  5. package/dist/cjs/nextjs/config.d.ts.map +1 -1
  6. package/dist/cjs/nextjs/config.js +1 -1
  7. package/dist/cjs/nextjs/config.js.map +1 -1
  8. package/dist/cjs/shared/lib/session.d.ts.map +1 -1
  9. package/dist/cjs/shared/lib/session.js +5 -7
  10. package/dist/cjs/shared/lib/session.js.map +1 -1
  11. package/dist/cjs/shared/lib/util.d.ts.map +1 -1
  12. package/dist/cjs/shared/lib/util.js +5 -5
  13. package/dist/cjs/shared/lib/util.js.map +1 -1
  14. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -1
  15. package/dist/cjs/shared/providers/TokenProvider.js +5 -2
  16. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -1
  17. package/dist/cjs/shared/providers/UserProvider.d.ts +2 -2
  18. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -1
  19. package/dist/cjs/shared/providers/UserProvider.js.map +1 -1
  20. package/dist/cjs/shared/version.d.ts +1 -1
  21. package/dist/cjs/shared/version.js +1 -1
  22. package/dist/cjs/shared/version.js.map +1 -1
  23. package/dist/cjs/types.d.ts +11 -3
  24. package/dist/cjs/types.d.ts.map +1 -1
  25. package/dist/cjs/types.js +3 -1
  26. package/dist/cjs/types.js.map +1 -1
  27. package/dist/esm/constants.d.ts +1 -2
  28. package/dist/esm/constants.d.ts.map +1 -1
  29. package/dist/esm/constants.js +1 -8
  30. package/dist/esm/constants.js.map +1 -1
  31. package/dist/esm/nextjs/config.d.ts.map +1 -1
  32. package/dist/esm/nextjs/config.js +1 -1
  33. package/dist/esm/nextjs/config.js.map +1 -1
  34. package/dist/esm/shared/lib/session.d.ts.map +1 -1
  35. package/dist/esm/shared/lib/session.js +6 -8
  36. package/dist/esm/shared/lib/session.js.map +1 -1
  37. package/dist/esm/shared/lib/util.d.ts.map +1 -1
  38. package/dist/esm/shared/lib/util.js +5 -5
  39. package/dist/esm/shared/lib/util.js.map +1 -1
  40. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -1
  41. package/dist/esm/shared/providers/TokenProvider.js +5 -2
  42. package/dist/esm/shared/providers/TokenProvider.js.map +1 -1
  43. package/dist/esm/shared/providers/UserProvider.d.ts +2 -2
  44. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -1
  45. package/dist/esm/shared/providers/UserProvider.js.map +1 -1
  46. package/dist/esm/shared/version.d.ts +1 -1
  47. package/dist/esm/shared/version.js +1 -1
  48. package/dist/esm/shared/version.js.map +1 -1
  49. package/dist/esm/types.d.ts +11 -3
  50. package/dist/esm/types.d.ts.map +1 -1
  51. package/dist/esm/types.js +2 -1
  52. package/dist/esm/types.js.map +1 -1
  53. package/dist/generateVersion.d.ts +2 -0
  54. package/dist/generateVersion.d.ts.map +1 -0
  55. package/dist/generateVersion.js +12 -0
  56. package/dist/generateVersion.js.map +1 -0
  57. package/dist/package.json +118 -0
  58. package/dist/src/browser/storage.d.ts +9 -0
  59. package/dist/src/browser/storage.d.ts.map +1 -0
  60. package/dist/src/browser/storage.js +17 -0
  61. package/dist/src/browser/storage.js.map +1 -0
  62. package/dist/src/config.d.ts +3 -0
  63. package/dist/src/config.d.ts.map +1 -0
  64. package/dist/src/config.js +5 -0
  65. package/dist/src/config.js.map +1 -0
  66. package/dist/src/constants.d.ts +8 -0
  67. package/dist/src/constants.d.ts.map +1 -0
  68. package/dist/src/constants.js +16 -0
  69. package/dist/src/constants.js.map +1 -0
  70. package/dist/src/index.d.ts +6 -0
  71. package/dist/src/index.d.ts.map +1 -0
  72. package/dist/src/index.js +4 -0
  73. package/dist/src/index.js.map +1 -0
  74. package/dist/src/lib/cookies.d.ts +7 -0
  75. package/dist/src/lib/cookies.d.ts.map +1 -0
  76. package/dist/src/lib/cookies.js +25 -0
  77. package/dist/src/lib/cookies.js.map +1 -0
  78. package/dist/src/lib/jwt.d.ts +3 -0
  79. package/dist/src/lib/jwt.d.ts.map +1 -0
  80. package/dist/src/lib/jwt.js +9 -0
  81. package/dist/src/lib/jwt.js.map +1 -0
  82. package/dist/src/lib/logger.d.ts +26 -0
  83. package/dist/src/lib/logger.d.ts.map +1 -0
  84. package/dist/src/lib/logger.js +55 -0
  85. package/dist/src/lib/logger.js.map +1 -0
  86. package/dist/src/lib/oauth.d.ts +19 -0
  87. package/dist/src/lib/oauth.d.ts.map +1 -0
  88. package/dist/src/lib/oauth.js +61 -0
  89. package/dist/src/lib/oauth.js.map +1 -0
  90. package/dist/src/lib/obj.d.ts +3 -0
  91. package/dist/src/lib/obj.d.ts.map +1 -0
  92. package/dist/src/lib/obj.js +18 -0
  93. package/dist/src/lib/obj.js.map +1 -0
  94. package/dist/src/lib/postMessage.d.ts +4 -0
  95. package/dist/src/lib/postMessage.d.ts.map +1 -0
  96. package/dist/src/lib/postMessage.js +15 -0
  97. package/dist/src/lib/postMessage.js.map +1 -0
  98. package/dist/src/lib/windowUtil.d.ts +4 -0
  99. package/dist/src/lib/windowUtil.d.ts.map +1 -0
  100. package/dist/src/lib/windowUtil.js +31 -0
  101. package/dist/src/lib/windowUtil.js.map +1 -0
  102. package/dist/src/nextjs/GetUser.d.ts +6 -0
  103. package/dist/src/nextjs/GetUser.d.ts.map +1 -0
  104. package/dist/src/nextjs/GetUser.js +7 -0
  105. package/dist/src/nextjs/GetUser.js.map +1 -0
  106. package/dist/src/nextjs/config.d.ts +181 -0
  107. package/dist/src/nextjs/config.d.ts.map +1 -0
  108. package/dist/src/nextjs/config.js +177 -0
  109. package/dist/src/nextjs/config.js.map +1 -0
  110. package/dist/src/nextjs/cookies.d.ts +30 -0
  111. package/dist/src/nextjs/cookies.d.ts.map +1 -0
  112. package/dist/src/nextjs/cookies.js +112 -0
  113. package/dist/src/nextjs/cookies.js.map +1 -0
  114. package/dist/src/nextjs/hooks/index.d.ts +2 -0
  115. package/dist/src/nextjs/hooks/index.d.ts.map +1 -0
  116. package/dist/src/nextjs/hooks/index.js +2 -0
  117. package/dist/src/nextjs/hooks/index.js.map +1 -0
  118. package/dist/src/nextjs/hooks/usePrevious.d.ts +2 -0
  119. package/dist/src/nextjs/hooks/usePrevious.d.ts.map +1 -0
  120. package/dist/src/nextjs/hooks/usePrevious.js +9 -0
  121. package/dist/src/nextjs/hooks/usePrevious.js.map +1 -0
  122. package/dist/src/nextjs/hooks/useUserCookie.d.ts +8 -0
  123. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  124. package/dist/src/nextjs/hooks/useUserCookie.js +88 -0
  125. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -0
  126. package/dist/src/nextjs/index.d.ts +7 -0
  127. package/dist/src/nextjs/index.d.ts.map +1 -0
  128. package/dist/src/nextjs/index.js +8 -0
  129. package/dist/src/nextjs/index.js.map +1 -0
  130. package/dist/src/nextjs/middleware/index.d.ts +2 -0
  131. package/dist/src/nextjs/middleware/index.d.ts.map +1 -0
  132. package/dist/src/nextjs/middleware/index.js +4 -0
  133. package/dist/src/nextjs/middleware/index.js.map +1 -0
  134. package/dist/src/nextjs/middleware.d.ts +59 -0
  135. package/dist/src/nextjs/middleware.d.ts.map +1 -0
  136. package/dist/src/nextjs/middleware.js +107 -0
  137. package/dist/src/nextjs/middleware.js.map +1 -0
  138. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +13 -0
  139. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  140. package/dist/src/nextjs/providers/NextAuthProvider.js +94 -0
  141. package/dist/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  142. package/dist/src/nextjs/routeHandler.d.ts +19 -0
  143. package/dist/src/nextjs/routeHandler.d.ts.map +1 -0
  144. package/dist/src/nextjs/routeHandler.js +309 -0
  145. package/dist/src/nextjs/routeHandler.js.map +1 -0
  146. package/dist/src/nextjs/utils.d.ts +3 -0
  147. package/dist/src/nextjs/utils.d.ts.map +1 -0
  148. package/dist/src/nextjs/utils.js +5 -0
  149. package/dist/src/nextjs/utils.js.map +1 -0
  150. package/dist/src/reactjs/components/SignInButton.d.ts +8 -0
  151. package/dist/src/reactjs/components/SignInButton.d.ts.map +1 -0
  152. package/dist/src/reactjs/components/SignInButton.js +14 -0
  153. package/dist/src/reactjs/components/SignInButton.js.map +1 -0
  154. package/dist/src/reactjs/components/SignOutButton.d.ts +6 -0
  155. package/dist/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  156. package/dist/src/reactjs/components/SignOutButton.js +14 -0
  157. package/dist/src/reactjs/components/SignOutButton.js.map +1 -0
  158. package/dist/src/reactjs/components/UserButton.d.ts +6 -0
  159. package/dist/src/reactjs/components/UserButton.d.ts.map +1 -0
  160. package/dist/src/reactjs/components/UserButton.js +118 -0
  161. package/dist/src/reactjs/components/UserButton.js.map +1 -0
  162. package/dist/src/reactjs/components/index.d.ts +6 -0
  163. package/dist/src/reactjs/components/index.d.ts.map +1 -0
  164. package/dist/src/reactjs/components/index.js +6 -0
  165. package/dist/src/reactjs/components/index.js.map +1 -0
  166. package/dist/src/reactjs/hooks/index.d.ts +6 -0
  167. package/dist/src/reactjs/hooks/index.d.ts.map +1 -0
  168. package/dist/src/reactjs/hooks/index.js +6 -0
  169. package/dist/src/reactjs/hooks/index.js.map +1 -0
  170. package/dist/src/reactjs/hooks/useAuth.d.ts +3 -0
  171. package/dist/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  172. package/dist/src/reactjs/hooks/useAuth.js +12 -0
  173. package/dist/src/reactjs/hooks/useAuth.js.map +1 -0
  174. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  175. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  176. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.js +13 -0
  177. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  178. package/dist/src/reactjs/hooks/useUser.d.ts +4 -0
  179. package/dist/src/reactjs/hooks/useUser.d.ts.map +1 -0
  180. package/dist/src/reactjs/hooks/useUser.js +12 -0
  181. package/dist/src/reactjs/hooks/useUser.js.map +1 -0
  182. package/dist/src/reactjs/index.d.ts +6 -0
  183. package/dist/src/reactjs/index.d.ts.map +1 -0
  184. package/dist/src/reactjs/index.js +10 -0
  185. package/dist/src/reactjs/index.js.map +1 -0
  186. package/dist/src/reactjs/providers/AuthProvider.d.ts +11 -0
  187. package/dist/src/reactjs/providers/AuthProvider.d.ts.map +1 -0
  188. package/dist/src/reactjs/providers/AuthProvider.js +76 -0
  189. package/dist/src/reactjs/providers/AuthProvider.js.map +1 -0
  190. package/dist/src/reactjs/providers/CivicAuthProvider.d.ts +6 -0
  191. package/dist/src/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  192. package/dist/src/reactjs/providers/CivicAuthProvider.js +32 -0
  193. package/dist/src/reactjs/providers/CivicAuthProvider.js.map +1 -0
  194. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  195. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  196. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.js +148 -0
  197. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  198. package/dist/src/reactjs/providers/index.d.ts +8 -0
  199. package/dist/src/reactjs/providers/index.d.ts.map +1 -0
  200. package/dist/src/reactjs/providers/index.js +7 -0
  201. package/dist/src/reactjs/providers/index.js.map +1 -0
  202. package/dist/src/server/ServerAuthenticationResolver.d.ts +20 -0
  203. package/dist/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  204. package/dist/src/server/ServerAuthenticationResolver.js +67 -0
  205. package/dist/src/server/ServerAuthenticationResolver.js.map +1 -0
  206. package/dist/src/server/config.d.ts +10 -0
  207. package/dist/src/server/config.d.ts.map +1 -0
  208. package/dist/src/server/config.js +2 -0
  209. package/dist/src/server/config.js.map +1 -0
  210. package/dist/src/server/index.d.ts +7 -0
  211. package/dist/src/server/index.d.ts.map +1 -0
  212. package/dist/src/server/index.js +7 -0
  213. package/dist/src/server/index.js.map +1 -0
  214. package/dist/src/server/login.d.ts +21 -0
  215. package/dist/src/server/login.d.ts.map +1 -0
  216. package/dist/src/server/login.js +56 -0
  217. package/dist/src/server/login.js.map +1 -0
  218. package/dist/src/server/refresh.d.ts +7 -0
  219. package/dist/src/server/refresh.d.ts.map +1 -0
  220. package/dist/src/server/refresh.js +13 -0
  221. package/dist/src/server/refresh.js.map +1 -0
  222. package/dist/src/services/AuthenticationService.d.ts +91 -0
  223. package/dist/src/services/AuthenticationService.d.ts.map +1 -0
  224. package/dist/src/services/AuthenticationService.js +322 -0
  225. package/dist/src/services/AuthenticationService.js.map +1 -0
  226. package/dist/src/services/PKCE.d.ts +20 -0
  227. package/dist/src/services/PKCE.d.ts.map +1 -0
  228. package/dist/src/services/PKCE.js +44 -0
  229. package/dist/src/services/PKCE.js.map +1 -0
  230. package/dist/src/services/types.d.ts +24 -0
  231. package/dist/src/services/types.d.ts.map +1 -0
  232. package/dist/src/services/types.js +7 -0
  233. package/dist/src/services/types.js.map +1 -0
  234. package/dist/src/shared/components/BlockDisplay.d.ts +7 -0
  235. package/dist/src/shared/components/BlockDisplay.d.ts.map +1 -0
  236. package/dist/src/shared/components/BlockDisplay.js +25 -0
  237. package/dist/src/shared/components/BlockDisplay.js.map +1 -0
  238. package/dist/src/shared/components/CivicAuthIframe.d.ts +9 -0
  239. package/dist/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  240. package/dist/src/shared/components/CivicAuthIframe.js +8 -0
  241. package/dist/src/shared/components/CivicAuthIframe.js.map +1 -0
  242. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts +13 -0
  243. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  244. package/dist/src/shared/components/CivicAuthIframeContainer.js +138 -0
  245. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  246. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.d.ts +7 -0
  247. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  248. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.js +22 -0
  249. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  250. package/dist/src/shared/components/CloseIcon.d.ts +4 -0
  251. package/dist/src/shared/components/CloseIcon.d.ts.map +1 -0
  252. package/dist/src/shared/components/CloseIcon.js +6 -0
  253. package/dist/src/shared/components/CloseIcon.js.map +1 -0
  254. package/dist/src/shared/components/IFrameAndLoading.d.ts +8 -0
  255. package/dist/src/shared/components/IFrameAndLoading.d.ts.map +1 -0
  256. package/dist/src/shared/components/IFrameAndLoading.js +27 -0
  257. package/dist/src/shared/components/IFrameAndLoading.js.map +1 -0
  258. package/dist/src/shared/components/LoadingIcon.d.ts +4 -0
  259. package/dist/src/shared/components/LoadingIcon.d.ts.map +1 -0
  260. package/dist/src/shared/components/LoadingIcon.js +30 -0
  261. package/dist/src/shared/components/LoadingIcon.js.map +1 -0
  262. package/dist/src/shared/hooks/index.d.ts +11 -0
  263. package/dist/src/shared/hooks/index.d.ts.map +1 -0
  264. package/dist/src/shared/hooks/index.js +11 -0
  265. package/dist/src/shared/hooks/index.js.map +1 -0
  266. package/dist/src/shared/hooks/useAuth.d.ts +3 -0
  267. package/dist/src/shared/hooks/useAuth.d.ts.map +1 -0
  268. package/dist/src/shared/hooks/useAuth.js +12 -0
  269. package/dist/src/shared/hooks/useAuth.js.map +1 -0
  270. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  271. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  272. package/dist/src/shared/hooks/useCivicAuthConfig.js +10 -0
  273. package/dist/src/shared/hooks/useCivicAuthConfig.js.map +1 -0
  274. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  275. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  276. package/dist/src/shared/hooks/useClientTokenExchangeSession.js +13 -0
  277. package/dist/src/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  278. package/dist/src/shared/hooks/useCurrentUrl.d.ts +3 -0
  279. package/dist/src/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  280. package/dist/src/shared/hooks/useCurrentUrl.js +24 -0
  281. package/dist/src/shared/hooks/useCurrentUrl.js.map +1 -0
  282. package/dist/src/shared/hooks/useIframe.d.ts +3 -0
  283. package/dist/src/shared/hooks/useIframe.d.ts.map +1 -0
  284. package/dist/src/shared/hooks/useIframe.js +13 -0
  285. package/dist/src/shared/hooks/useIframe.js.map +1 -0
  286. package/dist/src/shared/hooks/useIsInIframe.d.ts +3 -0
  287. package/dist/src/shared/hooks/useIsInIframe.d.ts.map +1 -0
  288. package/dist/src/shared/hooks/useIsInIframe.js +14 -0
  289. package/dist/src/shared/hooks/useIsInIframe.js.map +1 -0
  290. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  291. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  292. package/dist/src/shared/hooks/useOAuthEndpoints.js +14 -0
  293. package/dist/src/shared/hooks/useOAuthEndpoints.js.map +1 -0
  294. package/dist/src/shared/hooks/useRefresh.d.ts +4 -0
  295. package/dist/src/shared/hooks/useRefresh.d.ts.map +1 -0
  296. package/dist/src/shared/hooks/useRefresh.js +38 -0
  297. package/dist/src/shared/hooks/useRefresh.js.map +1 -0
  298. package/dist/src/shared/hooks/useSession.d.ts +3 -0
  299. package/dist/src/shared/hooks/useSession.d.ts.map +1 -0
  300. package/dist/src/shared/hooks/useSession.js +13 -0
  301. package/dist/src/shared/hooks/useSession.js.map +1 -0
  302. package/dist/src/shared/hooks/useSignIn.d.ts +15 -0
  303. package/dist/src/shared/hooks/useSignIn.d.ts.map +1 -0
  304. package/dist/src/shared/hooks/useSignIn.js +126 -0
  305. package/dist/src/shared/hooks/useSignIn.js.map +1 -0
  306. package/dist/src/shared/hooks/useToken.d.ts +3 -0
  307. package/dist/src/shared/hooks/useToken.d.ts.map +1 -0
  308. package/dist/src/shared/hooks/useToken.js +12 -0
  309. package/dist/src/shared/hooks/useToken.js.map +1 -0
  310. package/dist/src/shared/hooks/useWindowFocused.d.ts +5 -0
  311. package/dist/src/shared/hooks/useWindowFocused.d.ts.map +1 -0
  312. package/dist/src/shared/hooks/useWindowFocused.js +21 -0
  313. package/dist/src/shared/hooks/useWindowFocused.js.map +1 -0
  314. package/dist/src/shared/index.d.ts +5 -0
  315. package/dist/src/shared/index.d.ts.map +1 -0
  316. package/dist/src/shared/index.js +16 -0
  317. package/dist/src/shared/index.js.map +1 -0
  318. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +20 -0
  319. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  320. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +73 -0
  321. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  322. package/dist/src/shared/lib/UserSession.d.ts +12 -0
  323. package/dist/src/shared/lib/UserSession.d.ts.map +1 -0
  324. package/dist/src/shared/lib/UserSession.js +20 -0
  325. package/dist/src/shared/lib/UserSession.js.map +1 -0
  326. package/dist/src/shared/lib/session.d.ts +3 -0
  327. package/dist/src/shared/lib/session.d.ts.map +1 -0
  328. package/dist/src/shared/lib/session.js +21 -0
  329. package/dist/src/shared/lib/session.js.map +1 -0
  330. package/dist/src/shared/lib/storage.d.ts +25 -0
  331. package/dist/src/shared/lib/storage.d.ts.map +1 -0
  332. package/dist/src/shared/lib/storage.js +17 -0
  333. package/dist/src/shared/lib/storage.js.map +1 -0
  334. package/dist/src/shared/lib/types.d.ts +36 -0
  335. package/dist/src/shared/lib/types.d.ts.map +1 -0
  336. package/dist/src/shared/lib/types.js +18 -0
  337. package/dist/src/shared/lib/types.js.map +1 -0
  338. package/dist/src/shared/lib/util.d.ts +34 -0
  339. package/dist/src/shared/lib/util.d.ts.map +1 -0
  340. package/dist/src/shared/lib/util.js +137 -0
  341. package/dist/src/shared/lib/util.js.map +1 -0
  342. package/dist/src/shared/providers/AuthContext.d.ts +11 -0
  343. package/dist/src/shared/providers/AuthContext.d.ts.map +1 -0
  344. package/dist/src/shared/providers/AuthContext.js +3 -0
  345. package/dist/src/shared/providers/AuthContext.js.map +1 -0
  346. package/dist/src/shared/providers/AuthProvider.d.ts +22 -0
  347. package/dist/src/shared/providers/AuthProvider.d.ts.map +1 -0
  348. package/dist/src/shared/providers/AuthProvider.js +72 -0
  349. package/dist/src/shared/providers/AuthProvider.js.map +1 -0
  350. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts +18 -0
  351. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  352. package/dist/src/shared/providers/CivicAuthConfigContext.js +52 -0
  353. package/dist/src/shared/providers/CivicAuthConfigContext.js.map +1 -0
  354. package/dist/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  355. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  356. package/dist/src/shared/providers/CivicAuthProvider.js +32 -0
  357. package/dist/src/shared/providers/CivicAuthProvider.js.map +1 -0
  358. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  359. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  360. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js +131 -0
  361. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  362. package/dist/src/shared/providers/IframeProvider.d.ts +22 -0
  363. package/dist/src/shared/providers/IframeProvider.d.ts.map +1 -0
  364. package/dist/src/shared/providers/IframeProvider.js +35 -0
  365. package/dist/src/shared/providers/IframeProvider.js.map +1 -0
  366. package/dist/src/shared/providers/SessionProvider.d.ts +19 -0
  367. package/dist/src/shared/providers/SessionProvider.d.ts.map +1 -0
  368. package/dist/src/shared/providers/SessionProvider.js +23 -0
  369. package/dist/src/shared/providers/SessionProvider.js.map +1 -0
  370. package/dist/src/shared/providers/TokenProvider.d.ts +18 -0
  371. package/dist/src/shared/providers/TokenProvider.d.ts.map +1 -0
  372. package/dist/src/shared/providers/TokenProvider.js +42 -0
  373. package/dist/src/shared/providers/TokenProvider.js.map +1 -0
  374. package/dist/src/shared/providers/UserProvider.d.ts +24 -0
  375. package/dist/src/shared/providers/UserProvider.d.ts.map +1 -0
  376. package/dist/src/shared/providers/UserProvider.js +52 -0
  377. package/dist/src/shared/providers/UserProvider.js.map +1 -0
  378. package/dist/src/shared/providers/types.d.ts +15 -0
  379. package/dist/src/shared/providers/types.d.ts.map +1 -0
  380. package/dist/src/shared/providers/types.js +2 -0
  381. package/dist/src/shared/providers/types.js.map +1 -0
  382. package/dist/src/shared/version.d.ts +2 -0
  383. package/dist/src/shared/version.d.ts.map +1 -0
  384. package/dist/src/shared/version.js +3 -0
  385. package/dist/src/shared/version.js.map +1 -0
  386. package/dist/src/types.d.ts +148 -0
  387. package/dist/src/types.d.ts.map +1 -0
  388. package/dist/src/types.js +4 -0
  389. package/dist/src/types.js.map +1 -0
  390. package/dist/src/utils.d.ts +15 -0
  391. package/dist/src/utils.d.ts.map +1 -0
  392. package/dist/src/utils.js +43 -0
  393. package/dist/src/utils.js.map +1 -0
  394. package/dist/src/version.d.ts +2 -0
  395. package/dist/src/version.d.ts.map +1 -0
  396. package/dist/src/version.js +3 -0
  397. package/dist/src/version.js.map +1 -0
  398. package/dist/test/integration/sdk.test.d.ts +2 -0
  399. package/dist/test/integration/sdk.test.d.ts.map +1 -0
  400. package/dist/test/integration/sdk.test.js +237 -0
  401. package/dist/test/integration/sdk.test.js.map +1 -0
  402. package/dist/test/support/fixtures.d.ts +26 -0
  403. package/dist/test/support/fixtures.d.ts.map +1 -0
  404. package/dist/test/support/fixtures.js +55 -0
  405. package/dist/test/support/fixtures.js.map +1 -0
  406. package/dist/test/support/tokens.json +26 -0
  407. package/dist/test/unit/lib/oauth.test.d.ts +2 -0
  408. package/dist/test/unit/lib/oauth.test.d.ts.map +1 -0
  409. package/dist/test/unit/lib/oauth.test.js +56 -0
  410. package/dist/test/unit/lib/oauth.test.js.map +1 -0
  411. package/dist/test/unit/lib/obj.test.d.ts +2 -0
  412. package/dist/test/unit/lib/obj.test.d.ts.map +1 -0
  413. package/dist/test/unit/lib/obj.test.js +37 -0
  414. package/dist/test/unit/lib/obj.test.js.map +1 -0
  415. package/dist/test/unit/logger.test.d.ts +2 -0
  416. package/dist/test/unit/logger.test.d.ts.map +1 -0
  417. package/dist/test/unit/logger.test.js +141 -0
  418. package/dist/test/unit/logger.test.js.map +1 -0
  419. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +2 -0
  420. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts.map +1 -0
  421. package/dist/test/unit/nextjs/NextAuthProvider.test.js +31 -0
  422. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +1 -0
  423. package/dist/test/unit/nextjs/config.test.d.ts +2 -0
  424. package/dist/test/unit/nextjs/config.test.d.ts.map +1 -0
  425. package/dist/test/unit/nextjs/config.test.js +203 -0
  426. package/dist/test/unit/nextjs/config.test.js.map +1 -0
  427. package/dist/test/unit/nextjs/getUser.test.d.ts +2 -0
  428. package/dist/test/unit/nextjs/getUser.test.d.ts.map +1 -0
  429. package/dist/test/unit/nextjs/getUser.test.js +22 -0
  430. package/dist/test/unit/nextjs/getUser.test.js.map +1 -0
  431. package/dist/test/unit/nextjs/handler.test.d.ts +2 -0
  432. package/dist/test/unit/nextjs/handler.test.d.ts.map +1 -0
  433. package/dist/test/unit/nextjs/handler.test.js +207 -0
  434. package/dist/test/unit/nextjs/handler.test.js.map +1 -0
  435. package/dist/test/unit/nextjs/middleware.test.d.ts +2 -0
  436. package/dist/test/unit/nextjs/middleware.test.d.ts.map +1 -0
  437. package/dist/test/unit/nextjs/middleware.test.js +113 -0
  438. package/dist/test/unit/nextjs/middleware.test.js.map +1 -0
  439. package/dist/test/unit/nextjs/utils.test.d.ts +2 -0
  440. package/dist/test/unit/nextjs/utils.test.d.ts.map +1 -0
  441. package/dist/test/unit/nextjs/utils.test.js +13 -0
  442. package/dist/test/unit/nextjs/utils.test.js.map +1 -0
  443. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +2 -0
  444. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts.map +1 -0
  445. package/dist/test/unit/publicApi/apiSnapshot.test.js +10 -0
  446. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +1 -0
  447. package/dist/test/unit/react/components/SignInButton.test.d.ts +2 -0
  448. package/dist/test/unit/react/components/SignInButton.test.d.ts.map +1 -0
  449. package/dist/test/unit/react/components/SignInButton.test.js +31 -0
  450. package/dist/test/unit/react/components/SignInButton.test.js.map +1 -0
  451. package/dist/test/unit/react/components/SignOutButton.test.d.ts +2 -0
  452. package/dist/test/unit/react/components/SignOutButton.test.d.ts.map +1 -0
  453. package/dist/test/unit/react/components/SignOutButton.test.js +30 -0
  454. package/dist/test/unit/react/components/SignOutButton.test.js.map +1 -0
  455. package/dist/test/unit/server/login.test.d.ts +2 -0
  456. package/dist/test/unit/server/login.test.d.ts.map +1 -0
  457. package/dist/test/unit/server/login.test.js +184 -0
  458. package/dist/test/unit/server/login.test.js.map +1 -0
  459. package/dist/test/unit/server/refresh.test.d.ts +2 -0
  460. package/dist/test/unit/server/refresh.test.d.ts.map +1 -0
  461. package/dist/test/unit/server/refresh.test.js +55 -0
  462. package/dist/test/unit/server/refresh.test.js.map +1 -0
  463. package/dist/test/unit/server/session.test.d.ts +2 -0
  464. package/dist/test/unit/server/session.test.d.ts.map +1 -0
  465. package/dist/test/unit/server/session.test.js +41 -0
  466. package/dist/test/unit/server/session.test.js.map +1 -0
  467. package/dist/test/unit/services/AuthenticationService.test.d.ts +2 -0
  468. package/dist/test/unit/services/AuthenticationService.test.d.ts.map +1 -0
  469. package/dist/test/unit/services/AuthenticationService.test.js +301 -0
  470. package/dist/test/unit/services/AuthenticationService.test.js.map +1 -0
  471. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +2 -0
  472. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts.map +1 -0
  473. package/dist/test/unit/services/ServerAuthenticationResolver.test.js +75 -0
  474. package/dist/test/unit/services/ServerAuthenticationResolver.test.js.map +1 -0
  475. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +2 -0
  476. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts.map +1 -0
  477. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js +144 -0
  478. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js.map +1 -0
  479. package/dist/test/unit/shared/UserSession.test.d.ts +2 -0
  480. package/dist/test/unit/shared/UserSession.test.d.ts.map +1 -0
  481. package/dist/test/unit/shared/UserSession.test.js +37 -0
  482. package/dist/test/unit/shared/UserSession.test.js.map +1 -0
  483. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +2 -0
  484. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts.map +1 -0
  485. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +122 -0
  486. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +1 -0
  487. package/dist/test/unit/shared/printVersion.test.d.ts +2 -0
  488. package/dist/test/unit/shared/printVersion.test.d.ts.map +1 -0
  489. package/dist/test/unit/shared/printVersion.test.js +39 -0
  490. package/dist/test/unit/shared/printVersion.test.js.map +1 -0
  491. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.d.ts +2 -0
  492. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.d.ts.map +1 -0
  493. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.js +108 -0
  494. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.js.map +1 -0
  495. package/dist/test/unit/shared/storage.test.d.ts +2 -0
  496. package/dist/test/unit/shared/storage.test.d.ts.map +1 -0
  497. package/dist/test/unit/shared/storage.test.js +53 -0
  498. package/dist/test/unit/shared/storage.test.js.map +1 -0
  499. package/dist/test/unit/utils.test.d.ts +2 -0
  500. package/dist/test/unit/utils.test.d.ts.map +1 -0
  501. package/dist/test/unit/utils.test.js +40 -0
  502. package/dist/test/unit/utils.test.js.map +1 -0
  503. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  504. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  505. package/dist/tsconfig.tsbuildinfo +1 -0
  506. package/dist/vitest.config.d.ts +3 -0
  507. package/dist/vitest.config.d.ts.map +1 -0
  508. package/dist/vitest.config.js +44 -0
  509. package/dist/vitest.config.js.map +1 -0
  510. package/package.json +19 -18
  511. package/dist/cjs/reactjs/hooks/useSignIn.d.ts +0 -6
  512. package/dist/cjs/reactjs/hooks/useSignIn.d.ts.map +0 -1
  513. package/dist/cjs/reactjs/hooks/useSignIn.js +0 -38
  514. package/dist/cjs/reactjs/hooks/useSignIn.js.map +0 -1
  515. package/dist/cjs/services/UserinfoService.d.ts +0 -5
  516. package/dist/cjs/services/UserinfoService.d.ts.map +0 -1
  517. package/dist/cjs/services/UserinfoService.js +0 -15
  518. package/dist/cjs/services/UserinfoService.js.map +0 -1
  519. package/dist/esm/reactjs/hooks/useSignIn.d.ts +0 -6
  520. package/dist/esm/reactjs/hooks/useSignIn.d.ts.map +0 -1
  521. package/dist/esm/reactjs/hooks/useSignIn.js +0 -34
  522. package/dist/esm/reactjs/hooks/useSignIn.js.map +0 -1
@@ -0,0 +1,131 @@
1
+ "use client";
2
+ import React, { createContext, useCallback, useEffect, useMemo, useState, } from "react";
3
+ import { BrowserAuthenticationService } from "@/services/AuthenticationService.js";
4
+ import { isWindowInIframe } from "@/lib/windowUtil.js";
5
+ import { useCurrentUrl, useCivicAuthConfig, useWindowFocused, useRefresh, } from "@/shared/hooks/index.js";
6
+ import { LocalStorageAdapter } from "@/browser/storage.js";
7
+ const defaultSession = {
8
+ data: {
9
+ authenticated: false,
10
+ idToken: undefined,
11
+ accessToken: undefined,
12
+ displayMode: "iframe",
13
+ },
14
+ error: null,
15
+ isLoading: false,
16
+ doTokenExchange: null,
17
+ };
18
+ // Context for exposing session specifically to the TokenProvider
19
+ const ClientTokenExchangeSessionContext = createContext(defaultSession);
20
+ const ClientTokenExchangeSessionProvider = ({ children, }) => {
21
+ const authConfig = useCivicAuthConfig();
22
+ const [authService, setAuthService] = useState();
23
+ const [error, setError] = useState(null);
24
+ const [isLoading, setIsLoading] = useState(false);
25
+ const [session, setSession] = useState(null);
26
+ const { isWindowFocused } = useWindowFocused();
27
+ const currentUrl = useCurrentUrl();
28
+ useRefresh(session);
29
+ useEffect(() => {
30
+ if (!currentUrl || !authConfig)
31
+ return;
32
+ const { redirectUrl, clientId, oauthServer, scopes, logoutRedirectUrl, logoutUrl, } = authConfig;
33
+ BrowserAuthenticationService.build({
34
+ clientId,
35
+ redirectUrl,
36
+ logoutRedirectUrl,
37
+ logoutUrl,
38
+ oauthServer,
39
+ scopes,
40
+ displayMode: "iframe",
41
+ }).then(setAuthService);
42
+ }, [currentUrl, authConfig]);
43
+ const isInIframe = isWindowInIframe(globalThis.window);
44
+ const doTokenExchange = useCallback(async (inUrl) => {
45
+ if (!authService)
46
+ return;
47
+ const url = new URL(inUrl);
48
+ const code = url.searchParams.get("code");
49
+ const state = url.searchParams.get("state");
50
+ if (code && state) {
51
+ try {
52
+ setIsLoading(true);
53
+ await authService.tokenExchange(code, state);
54
+ }
55
+ catch (error) {
56
+ setError(error);
57
+ setSession({ authenticated: false });
58
+ }
59
+ setIsLoading(false);
60
+ }
61
+ }, [authService]);
62
+ const onSignIn = useCallback(async () => {
63
+ if (!authService)
64
+ return;
65
+ const session = await authService.getSessionData();
66
+ setSession(session);
67
+ }, [authService]);
68
+ const onSignOut = useCallback(() => {
69
+ setSession({ authenticated: false });
70
+ }, []);
71
+ useEffect(() => {
72
+ LocalStorageAdapter.emitter.on("signIn", onSignIn);
73
+ LocalStorageAdapter.emitter.on("signOut", onSignOut);
74
+ return () => {
75
+ LocalStorageAdapter.emitter.off("signIn", onSignIn);
76
+ LocalStorageAdapter.emitter.off("signOut", onSignOut);
77
+ };
78
+ }, [onSignIn, onSignOut]);
79
+ useEffect(() => {
80
+ if (!authConfig) {
81
+ setIsLoading(true);
82
+ }
83
+ else {
84
+ setIsLoading(false);
85
+ }
86
+ }, [authConfig]);
87
+ // Handle page load or refocus
88
+ useEffect(() => {
89
+ if (!authConfig || !authService || !currentUrl || isInIframe || isLoading) {
90
+ return;
91
+ }
92
+ const abortController = new AbortController();
93
+ const onPageLoad = async () => {
94
+ // if we have existing tokens, then validate them and return the session data
95
+ // otherwise check if we have a code in the url and exchange it for tokens
96
+ // if we have neither, return undefined
97
+ const existingSessionData = await authService.validateExistingSession();
98
+ if (existingSessionData.authenticated) {
99
+ setSession(existingSessionData);
100
+ return;
101
+ }
102
+ if (abortController.signal.aborted ||
103
+ !new URL(currentUrl).searchParams.get("code")) {
104
+ return;
105
+ }
106
+ await doTokenExchange(currentUrl);
107
+ };
108
+ onPageLoad();
109
+ return () => {
110
+ abortController.abort();
111
+ };
112
+ }, [
113
+ authConfig,
114
+ authService,
115
+ currentUrl,
116
+ doTokenExchange,
117
+ isInIframe,
118
+ isLoading,
119
+ isWindowFocused,
120
+ session?.authenticated,
121
+ ]);
122
+ const value = useMemo(() => ({
123
+ data: session,
124
+ error,
125
+ isLoading,
126
+ doTokenExchange: authService ? doTokenExchange : null,
127
+ }), [session, error, isLoading, authService, doTokenExchange]);
128
+ return (React.createElement(ClientTokenExchangeSessionContext.Provider, { value: value }, children));
129
+ };
130
+ export { ClientTokenExchangeSessionProvider, ClientTokenExchangeSessionContext, };
131
+ //# sourceMappingURL=ClientTokenExchangeSessionProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ClientTokenExchangeSessionProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/ClientTokenExchangeSessionProvider.tsx"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\nimport type { ReactNode } from \"react\";\nimport React, {\n createContext,\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport { BrowserAuthenticationService } from \"@/services/AuthenticationService.js\";\nimport type { AuthenticationResolver } from \"@/services/types.js\";\nimport { isWindowInIframe } from \"@/lib/windowUtil.js\";\nimport type { SessionData } from \"@/types.js\";\nimport {\n useCurrentUrl,\n useCivicAuthConfig,\n useWindowFocused,\n useRefresh,\n} from \"@/shared/hooks/index.js\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\n\nexport type ClientTokenExchangeSessionProviderOutput = {\n data: SessionData | null;\n error: Error | null;\n isLoading: boolean;\n doTokenExchange: null | ((url: string) => Promise<void>);\n};\nconst defaultSession: ClientTokenExchangeSessionProviderOutput = {\n data: {\n authenticated: false,\n idToken: undefined,\n accessToken: undefined,\n displayMode: \"iframe\",\n },\n error: null,\n isLoading: false,\n doTokenExchange: null,\n};\n\n// Context for exposing session specifically to the TokenProvider\nconst ClientTokenExchangeSessionContext =\n createContext<ClientTokenExchangeSessionProviderOutput>(defaultSession);\n\ntype ClientTokenExchangeSessionContextType = {\n children: ReactNode;\n};\n\nconst ClientTokenExchangeSessionProvider = ({\n children,\n}: ClientTokenExchangeSessionContextType) => {\n const authConfig = useCivicAuthConfig();\n const [authService, setAuthService] = useState<AuthenticationResolver>();\n const [error, setError] = useState<Error | null>(null);\n const [isLoading, setIsLoading] = useState(false);\n const [session, setSession] = useState<SessionData | null>(null);\n const { isWindowFocused } = useWindowFocused();\n const currentUrl = useCurrentUrl();\n\n useRefresh(session);\n\n useEffect(() => {\n if (!currentUrl || !authConfig) return;\n\n const {\n redirectUrl,\n clientId,\n oauthServer,\n scopes,\n logoutRedirectUrl,\n logoutUrl,\n } = authConfig;\n BrowserAuthenticationService.build({\n clientId,\n redirectUrl,\n logoutRedirectUrl,\n logoutUrl,\n oauthServer,\n scopes,\n displayMode: \"iframe\",\n }).then(setAuthService);\n }, [currentUrl, authConfig]);\n\n const isInIframe = isWindowInIframe(globalThis.window);\n\n const doTokenExchange = useCallback(\n async (inUrl: string) => {\n if (!authService) return;\n const url = new URL(inUrl);\n const code = url.searchParams.get(\"code\");\n const state = url.searchParams.get(\"state\");\n if (code && state) {\n try {\n setIsLoading(true);\n await authService.tokenExchange(code, state);\n } catch (error) {\n setError(error as Error);\n setSession({ authenticated: false });\n }\n setIsLoading(false);\n }\n },\n [authService],\n );\n\n const onSignIn = useCallback(async () => {\n if (!authService) return;\n const session = await authService.getSessionData();\n setSession(session);\n }, [authService]);\n\n const onSignOut = useCallback(() => {\n setSession({ authenticated: false });\n }, []);\n\n useEffect(() => {\n LocalStorageAdapter.emitter.on(\"signIn\", onSignIn);\n LocalStorageAdapter.emitter.on(\"signOut\", onSignOut);\n return () => {\n LocalStorageAdapter.emitter.off(\"signIn\", onSignIn);\n LocalStorageAdapter.emitter.off(\"signOut\", onSignOut);\n };\n }, [onSignIn, onSignOut]);\n\n useEffect(() => {\n if (!authConfig) {\n setIsLoading(true);\n } else {\n setIsLoading(false);\n }\n }, [authConfig]);\n // Handle page load or refocus\n useEffect(() => {\n if (!authConfig || !authService || !currentUrl || isInIframe || isLoading) {\n return;\n }\n const abortController = new AbortController();\n const onPageLoad = async () => {\n // if we have existing tokens, then validate them and return the session data\n // otherwise check if we have a code in the url and exchange it for tokens\n // if we have neither, return undefined\n const existingSessionData = await authService.validateExistingSession();\n if (existingSessionData.authenticated) {\n setSession(existingSessionData);\n return;\n }\n if (\n abortController.signal.aborted ||\n !new URL(currentUrl).searchParams.get(\"code\")\n ) {\n return;\n }\n await doTokenExchange(currentUrl);\n };\n onPageLoad();\n return () => {\n abortController.abort();\n };\n }, [\n authConfig,\n authService,\n currentUrl,\n doTokenExchange,\n isInIframe,\n isLoading,\n isWindowFocused,\n session?.authenticated,\n ]);\n\n const value = useMemo(\n () => ({\n data: session,\n error,\n isLoading,\n doTokenExchange: authService ? doTokenExchange : null,\n }),\n [session, error, isLoading, authService, doTokenExchange],\n );\n\n return (\n <ClientTokenExchangeSessionContext.Provider value={value}>\n {children}\n </ClientTokenExchangeSessionContext.Provider>\n );\n};\n\nexport type { ClientTokenExchangeSessionContextType as SessionContextType };\nexport {\n ClientTokenExchangeSessionProvider,\n ClientTokenExchangeSessionContext,\n};\n"]}
@@ -0,0 +1,22 @@
1
+ import type { Dispatch, ReactNode, RefObject, SetStateAction } from "react";
2
+ import React from "react";
3
+ import type { IframeMode } from "@/types.js";
4
+ export type IframeProviderOutput = {
5
+ iframeRef: RefObject<HTMLIFrameElement> | null;
6
+ logoutIframeRef: RefObject<HTMLIFrameElement> | null;
7
+ setIframeIsVisible: Dispatch<SetStateAction<boolean>>;
8
+ setLogoutIframeIsVisible: Dispatch<SetStateAction<boolean>>;
9
+ iframeIsVisible: boolean;
10
+ logoutIframeIsVisible: boolean;
11
+ iframeMode: IframeMode;
12
+ renderIframe: boolean;
13
+ };
14
+ declare const IframeContext: React.Context<IframeProviderOutput>;
15
+ type IframeContextType = {
16
+ children: ReactNode;
17
+ iframeMode?: IframeMode;
18
+ };
19
+ declare const IframeProvider: ({ children, iframeMode, }: IframeContextType) => React.JSX.Element;
20
+ export type { IframeContextType };
21
+ export { IframeProvider, IframeContext };
22
+ //# sourceMappingURL=IframeProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IframeProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/IframeProvider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAC5E,OAAO,KAA0C,MAAM,OAAO,CAAC;AAE/D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAE7C,MAAM,MAAM,oBAAoB,GAAG;IACjC,SAAS,EAAE,SAAS,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC;IAC/C,eAAe,EAAE,SAAS,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC;IACrD,kBAAkB,EAAE,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;IACtD,wBAAwB,EAAE,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;IAC5D,eAAe,EAAE,OAAO,CAAC;IACzB,qBAAqB,EAAE,OAAO,CAAC;IAC/B,UAAU,EAAE,UAAU,CAAC;IACvB,YAAY,EAAE,OAAO,CAAC;CACvB,CAAC;AAaF,QAAA,MAAM,aAAa,qCAAqD,CAAC;AAEzE,KAAK,iBAAiB,GAAG;IACvB,QAAQ,EAAE,SAAS,CAAC;IACpB,UAAU,CAAC,EAAE,UAAU,CAAC;CACzB,CAAC;AAEF,QAAA,MAAM,cAAc,8BAGjB,iBAAiB,sBAwBnB,CAAC;AAEF,YAAY,EAAE,iBAAiB,EAAE,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,CAAC"}
@@ -0,0 +1,35 @@
1
+ "use client";
2
+ import React, { createContext, useRef, useState } from "react";
3
+ import { useIsInIframe } from "@/shared/hooks/useIsInIframe.js";
4
+ const defaultIframe = {
5
+ iframeRef: null,
6
+ logoutIframeRef: null,
7
+ setIframeIsVisible: () => { },
8
+ setLogoutIframeIsVisible: () => { },
9
+ iframeIsVisible: false,
10
+ logoutIframeIsVisible: false,
11
+ iframeMode: "modal",
12
+ renderIframe: false,
13
+ };
14
+ // Context for exposing Iframe specifically to the TokenProvider
15
+ const IframeContext = createContext(defaultIframe);
16
+ const IframeProvider = ({ children, iframeMode = "modal", }) => {
17
+ const iframeRef = useRef(null);
18
+ const logoutIframeRef = useRef(null);
19
+ const isInIframe = useIsInIframe();
20
+ const [iframeIsVisible, setIframeIsVisible] = useState(false);
21
+ const [logoutIframeIsVisible, setLogoutIframeIsVisible] = useState(false);
22
+ const renderIframe = iframeMode === "modal" && !isInIframe;
23
+ return (React.createElement(IframeContext.Provider, { value: {
24
+ iframeRef,
25
+ logoutIframeRef,
26
+ setIframeIsVisible,
27
+ setLogoutIframeIsVisible,
28
+ iframeIsVisible,
29
+ logoutIframeIsVisible,
30
+ iframeMode,
31
+ renderIframe,
32
+ } }, children));
33
+ };
34
+ export { IframeProvider, IframeContext };
35
+ //# sourceMappingURL=IframeProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IframeProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/IframeProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAahE,MAAM,aAAa,GAAyB;IAC1C,SAAS,EAAE,IAAI;IACf,eAAe,EAAE,IAAI;IACrB,kBAAkB,EAAE,GAAG,EAAE,GAAE,CAAC;IAC5B,wBAAwB,EAAE,GAAG,EAAE,GAAE,CAAC;IAClC,eAAe,EAAE,KAAK;IACtB,qBAAqB,EAAE,KAAK;IAC5B,UAAU,EAAE,OAAO;IACnB,YAAY,EAAE,KAAK;CACpB,CAAC;AAEF,gEAAgE;AAChE,MAAM,aAAa,GAAG,aAAa,CAAuB,aAAa,CAAC,CAAC;AAOzE,MAAM,cAAc,GAAG,CAAC,EACtB,QAAQ,EACR,UAAU,GAAG,OAAO,GACF,EAAE,EAAE;IACtB,MAAM,SAAS,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAC;IAClD,MAAM,eAAe,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAC;IACxD,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9D,MAAM,CAAC,qBAAqB,EAAE,wBAAwB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE1E,MAAM,YAAY,GAAG,UAAU,KAAK,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3D,OAAO,CACL,oBAAC,aAAa,CAAC,QAAQ,IACrB,KAAK,EAAE;YACL,SAAS;YACT,eAAe;YACf,kBAAkB;YAClB,wBAAwB;YACxB,eAAe;YACf,qBAAqB;YACrB,UAAU;YACV,YAAY;SACb,IAEA,QAAQ,CACc,CAC1B,CAAC;AACJ,CAAC,CAAC;AAGF,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,CAAC","sourcesContent":["\"use client\";\nimport type { Dispatch, ReactNode, RefObject, SetStateAction } from \"react\";\nimport React, { createContext, useRef, useState } from \"react\";\nimport { useIsInIframe } from \"@/shared/hooks/useIsInIframe.js\";\nimport type { IframeMode } from \"@/types.js\";\n\nexport type IframeProviderOutput = {\n iframeRef: RefObject<HTMLIFrameElement> | null;\n logoutIframeRef: RefObject<HTMLIFrameElement> | null;\n setIframeIsVisible: Dispatch<SetStateAction<boolean>>;\n setLogoutIframeIsVisible: Dispatch<SetStateAction<boolean>>;\n iframeIsVisible: boolean;\n logoutIframeIsVisible: boolean;\n iframeMode: IframeMode;\n renderIframe: boolean;\n};\nconst defaultIframe: IframeProviderOutput = {\n iframeRef: null,\n logoutIframeRef: null,\n setIframeIsVisible: () => {},\n setLogoutIframeIsVisible: () => {},\n iframeIsVisible: false,\n logoutIframeIsVisible: false,\n iframeMode: \"modal\",\n renderIframe: false,\n};\n\n// Context for exposing Iframe specifically to the TokenProvider\nconst IframeContext = createContext<IframeProviderOutput>(defaultIframe);\n\ntype IframeContextType = {\n children: ReactNode;\n iframeMode?: IframeMode;\n};\n\nconst IframeProvider = ({\n children,\n iframeMode = \"modal\",\n}: IframeContextType) => {\n const iframeRef = useRef<HTMLIFrameElement>(null);\n const logoutIframeRef = useRef<HTMLIFrameElement>(null);\n const isInIframe = useIsInIframe();\n const [iframeIsVisible, setIframeIsVisible] = useState(false);\n const [logoutIframeIsVisible, setLogoutIframeIsVisible] = useState(false);\n\n const renderIframe = iframeMode === \"modal\" && !isInIframe;\n return (\n <IframeContext.Provider\n value={{\n iframeRef,\n logoutIframeRef,\n setIframeIsVisible,\n setLogoutIframeIsVisible,\n iframeIsVisible,\n logoutIframeIsVisible,\n iframeMode,\n renderIframe,\n }}\n >\n {children}\n </IframeContext.Provider>\n );\n};\n\nexport type { IframeContextType };\nexport { IframeProvider, IframeContext };\n"]}
@@ -0,0 +1,19 @@
1
+ import type { SessionData } from "@/types.js";
2
+ import type { ReactNode } from "react";
3
+ import React from "react";
4
+ export type SessionProviderOutput = {
5
+ data: SessionData | null;
6
+ error: Error | null;
7
+ isLoading: boolean;
8
+ };
9
+ declare const SessionContext: React.Context<SessionProviderOutput>;
10
+ type SessionContextType = {
11
+ children: ReactNode;
12
+ data?: SessionData | null;
13
+ error?: Error | null;
14
+ isLoading: boolean;
15
+ };
16
+ declare const SessionProvider: ({ children, ...props }: SessionContextType) => React.JSX.Element;
17
+ export type { SessionContextType };
18
+ export { SessionProvider, SessionContext };
19
+ //# sourceMappingURL=SessionProvider.d.ts.map
@@ -0,0 +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"}
@@ -0,0 +1,23 @@
1
+ "use client";
2
+ import React, { createContext } from "react";
3
+ const defaultSession = {
4
+ data: {
5
+ authenticated: false,
6
+ idToken: undefined,
7
+ accessToken: undefined,
8
+ displayMode: "iframe",
9
+ },
10
+ error: null,
11
+ isLoading: false,
12
+ };
13
+ // Context for exposing session specifically to the TokenProvider
14
+ const SessionContext = createContext(defaultSession);
15
+ const SessionProvider = ({ children, ...props }) => {
16
+ return (React.createElement(SessionContext.Provider, { value: {
17
+ ...props,
18
+ data: props.data || null,
19
+ error: props.error || null,
20
+ } }, children));
21
+ };
22
+ export { SessionProvider, SessionContext };
23
+ //# sourceMappingURL=SessionProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SessionProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/SessionProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAGb,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;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,aAAa,CAAwB,cAAc,CAAC,CAAC;AAS5E,MAAM,eAAe,GAAG,CAAC,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAsB,EAAE,EAAE;IACrE,OAAO,CACL,oBAAC,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;AAGF,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,CAAC","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"]}
@@ -0,0 +1,18 @@
1
+ import type { ReactNode } from "react";
2
+ import React from "react";
3
+ import type { ForwardedTokens } from "@/types.js";
4
+ type TokenContextType = {
5
+ accessToken: string | null;
6
+ idToken: string | null;
7
+ forwardedTokens: ForwardedTokens;
8
+ refreshToken: () => Promise<void>;
9
+ isLoading: boolean;
10
+ error: Error | null;
11
+ };
12
+ declare const TokenContext: React.Context<TokenContextType | undefined>;
13
+ declare const TokenProvider: ({ children }: {
14
+ children: ReactNode;
15
+ }) => React.JSX.Element;
16
+ export type { TokenContextType };
17
+ export { TokenProvider, TokenContext };
18
+ //# sourceMappingURL=TokenProvider.d.ts.map
@@ -0,0 +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,KAA8C,MAAM,OAAO,CAAC;AAEnE,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,YAAY,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAClC,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,sBA4C3D,CAAC;AAEF,YAAY,EAAE,gBAAgB,EAAE,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,42 @@
1
+ "use client";
2
+ import React, { createContext, useCallback, useMemo } from "react";
3
+ import { useSession } from "@/shared/hooks/useSession.js";
4
+ import { parseJWT } from "oslo/jwt";
5
+ import { convertForwardedTokenFormat } from "@/lib/jwt.js";
6
+ const TokenContext = createContext(undefined);
7
+ const TokenProvider = ({ children }) => {
8
+ const { isLoading, error: authError } = useSession();
9
+ const { data: session } = useSession();
10
+ const refreshToken = useCallback(async () => {
11
+ throw new Error("Not implemented");
12
+ }, []);
13
+ const decodeTokens = useMemo(() => {
14
+ if (!session?.idToken)
15
+ return null;
16
+ const parsedJWT = parseJWT(session.idToken);
17
+ if (!parsedJWT)
18
+ return null;
19
+ const { forwardedTokens } = parsedJWT.payload;
20
+ return forwardedTokens
21
+ ? convertForwardedTokenFormat(forwardedTokens)
22
+ : null;
23
+ }, [session?.idToken]);
24
+ const value = useMemo(() => ({
25
+ accessToken: session?.accessToken || null,
26
+ idToken: session?.idToken || null,
27
+ forwardedTokens: decodeTokens || {},
28
+ refreshToken,
29
+ isLoading,
30
+ error: authError,
31
+ }), [
32
+ session?.accessToken,
33
+ session?.idToken,
34
+ decodeTokens,
35
+ refreshToken,
36
+ isLoading,
37
+ authError,
38
+ ]);
39
+ return (React.createElement(TokenContext.Provider, { value: value }, children));
40
+ };
41
+ export { TokenProvider, TokenContext };
42
+ //# sourceMappingURL=TokenProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TokenProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/TokenProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,2BAA2B,EAAE,MAAM,cAAc,CAAC;AAW3D,MAAM,YAAY,GAAG,aAAa,CAA+B,SAAS,CAAC,CAAC;AAE5E,MAAM,aAAa,GAAG,CAAC,EAAE,QAAQ,EAA2B,EAAE,EAAE;IAC9D,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,UAAU,EAAE,CAAC;IACrD,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,CAAC;IAEvC,MAAM,YAAY,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QAC1C,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;IACrC,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,EAAE;QAChC,IAAI,CAAC,OAAO,EAAE,OAAO;YAAE,OAAO,IAAI,CAAC;QAEnC,MAAM,SAAS,GAAG,QAAQ,CAAC,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,2BAA2B,CAAC,eAAe,CAAC;YAC9C,CAAC,CAAC,IAAI,CAAC;IACX,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAEvB,MAAM,KAAK,GAAG,OAAO,CACnB,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,YAAY;QACZ,SAAS;QACT,KAAK,EAAE,SAAyB;KACjC,CAAC,EACF;QACE,OAAO,EAAE,WAAW;QACpB,OAAO,EAAE,OAAO;QAChB,YAAY;QACZ,YAAY;QACZ,SAAS;QACT,SAAS;KACV,CACF,CAAC;IAEF,OAAO,CACL,oBAAC,YAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,IAAG,QAAQ,CAAyB,CACxE,CAAC;AACJ,CAAC,CAAC;AAGF,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC","sourcesContent":["\"use client\";\nimport type { ReactNode } from \"react\";\nimport React, { createContext, useCallback, 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 refreshToken: () => Promise<void>;\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 refreshToken = useCallback(async () => {\n throw new Error(\"Not implemented\");\n }, []);\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 refreshToken,\n isLoading,\n error: authError as Error | null,\n }),\n [\n session?.accessToken,\n session?.idToken,\n decodeTokens,\n refreshToken,\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"]}
@@ -0,0 +1,24 @@
1
+ import React from "react";
2
+ import type { ReactNode } from "react";
3
+ import type { JWT } from "oslo/jwt";
4
+ import type { AuthStorage, DisplayMode, EmptyObject, ForwardedTokens, User } from "@/types.js";
5
+ import type { AuthContextType } from "@/shared/providers/AuthContext.js";
6
+ type UserContextType<T extends Record<string, unknown> & JWT["payload"] = Record<string, unknown> & JWT["payload"]> = {
7
+ user: User<T> | null;
8
+ } & {
9
+ accessToken?: string | null;
10
+ idToken?: string | null;
11
+ forwardedTokens?: ForwardedTokens;
12
+ } & Omit<AuthContextType, "isAuthenticated">;
13
+ declare const UserContext: React.Context<UserContextType<Record<string, unknown> & object> | null>;
14
+ declare const UserProvider: <T extends EmptyObject>({ children, storage, user: inputUser, signOut, signIn, displayMode, }: {
15
+ children: ReactNode;
16
+ storage: AuthStorage;
17
+ user?: User<T> | null;
18
+ signOut: () => Promise<void>;
19
+ signIn: (displayMode?: DisplayMode) => Promise<void>;
20
+ displayMode: DisplayMode;
21
+ }) => React.JSX.Element;
22
+ export type { UserContextType };
23
+ export { UserProvider, UserContext };
24
+ //# sourceMappingURL=UserProvider.d.ts.map
@@ -0,0 +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,WAAW,EACX,WAAW,EACX,WAAW,EACX,eAAe,EACf,IAAI,EACL,MAAM,YAAY,CAAC;AAEpB,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAIzE,KAAK,eAAe,CAClB,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,GAAG,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC1E,GAAG,CAAC,SAAS,CAAC,IACd;IACF,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,yEAA8C,CAAC;AAEhE,QAAA,MAAM,YAAY,GAAI,CAAC,SAAS,WAAW,yEAOxC;IACD,QAAQ,EAAE,SAAS,CAAC;IACpB,OAAO,EAAE,WAAW,CAAC;IACrB,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACtB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,MAAM,EAAE,CAAC,WAAW,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,WAAW,EAAE,WAAW,CAAC;CAC1B,sBAqDA,CAAC;AAEF,YAAY,EAAE,eAAe,EAAE,CAAC;AAEhC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC"}
@@ -0,0 +1,52 @@
1
+ "use client";
2
+ import React, { createContext, useCallback, useEffect, useState } from "react";
3
+ import { useSession } from "@/shared/hooks/useSession.js";
4
+ import { GenericUserSession } from "@/shared/lib/UserSession.js";
5
+ import { useToken } from "../hooks/useToken.js";
6
+ const UserContext = createContext(null);
7
+ const UserProvider = ({ children, storage, user: inputUser = null, signOut, signIn, displayMode, }) => {
8
+ const { error: authError, isLoading: authLoading } = useSession();
9
+ const { data: session } = useSession();
10
+ const tokens = useToken();
11
+ const [userLoading, setUserLoading] = useState(false);
12
+ const [userError, setUserError] = useState(null);
13
+ const [user, setUser] = useState(null);
14
+ const fetchUser = useCallback(async () => {
15
+ if (!session?.idToken) {
16
+ return null;
17
+ }
18
+ const userSession = new GenericUserSession(storage);
19
+ return userSession.get();
20
+ }, [session?.idToken, storage]);
21
+ useEffect(() => {
22
+ if (!session?.idToken) {
23
+ setUser(null);
24
+ return;
25
+ }
26
+ if (session?.idToken) {
27
+ setUserLoading(true);
28
+ fetchUser()
29
+ .then((user) => {
30
+ setUserLoading(false);
31
+ setUser(user);
32
+ })
33
+ .catch((error) => {
34
+ setUserLoading(false);
35
+ setUserError(error);
36
+ });
37
+ }
38
+ }, [fetchUser, session?.idToken]);
39
+ const isLoading = authLoading || userLoading;
40
+ const error = authError || userError;
41
+ return (React.createElement(UserContext.Provider, { value: {
42
+ ...tokens,
43
+ user: (inputUser || user) ?? null,
44
+ isLoading,
45
+ error,
46
+ signIn,
47
+ signOut,
48
+ displayMode: displayMode || "iframe",
49
+ } }, children));
50
+ };
51
+ export { UserProvider, UserContext };
52
+ //# sourceMappingURL=UserProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAU/E,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAahD,MAAM,WAAW,GAAG,aAAa,CAAyB,IAAI,CAAC,CAAC;AAEhE,MAAM,YAAY,GAAG,CAAwB,EAC3C,QAAQ,EACR,OAAO,EACP,IAAI,EAAE,SAAS,GAAG,IAAI,EACtB,OAAO,EACP,MAAM,EACN,WAAW,GAQZ,EAAE,EAAE;IACH,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,UAAU,EAAE,CAAC;IAClE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,CAAC;IACvC,MAAM,MAAM,GAAG,QAAQ,EAAE,CAAC;IAC1B,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IAC/D,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IAC/D,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAc,IAAI,CAAC,CAAC;IAEpD,MAAM,SAAS,GAAG,WAAW,CAAC,KAAK,IAA0B,EAAE;QAC7D,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,WAAW,GAAG,IAAI,kBAAkB,CAAC,OAAO,CAAC,CAAC;QACpD,OAAO,WAAW,CAAC,GAAG,EAAE,CAAC;IAC3B,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAEhC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YACtB,OAAO,CAAC,IAAI,CAAC,CAAC;YACd,OAAO;QACT,CAAC;QACD,IAAI,OAAO,EAAE,OAAO,EAAE,CAAC;YACrB,cAAc,CAAC,IAAI,CAAC,CAAC;YACrB,SAAS,EAAE;iBACR,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;gBACb,cAAc,CAAC,KAAK,CAAC,CAAC;gBACtB,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC,CAAC;iBACD,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;gBACf,cAAc,CAAC,KAAK,CAAC,CAAC;gBACtB,YAAY,CAAC,KAAK,CAAC,CAAC;YACtB,CAAC,CAAC,CAAC;QACP,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAElC,MAAM,SAAS,GAAG,WAAW,IAAI,WAAW,CAAC;IAC7C,MAAM,KAAK,GAAG,SAAS,IAAI,SAAS,CAAC;IAErC,OAAO,CACL,oBAAC,WAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,GAAG,MAAM;YACT,IAAI,EAAE,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,IAAI;YACjC,SAAS;YACT,KAAK;YACL,MAAM;YACN,OAAO;YACP,WAAW,EAAE,WAAW,IAAI,QAAQ;SACrC,IAEA,QAAQ,CACY,CACxB,CAAC;AACJ,CAAC,CAAC;AAIF,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC","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 AuthStorage,\n DisplayMode,\n EmptyObject,\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 UserContextType<\n T extends Record<string, unknown> & JWT[\"payload\"] = Record<string, unknown> &\n JWT[\"payload\"],\n> = {\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 EmptyObject>({\n children,\n storage,\n user: inputUser = null,\n signOut,\n signIn,\n displayMode,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user?: User<T> | null;\n signOut: () => Promise<void>;\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 | null>(null);\n\n const fetchUser = useCallback(async (): Promise<User | null> => {\n if (!session?.idToken) {\n return null;\n }\n const userSession = new GenericUserSession(storage);\n return userSession.get();\n }, [session?.idToken, storage]);\n\n useEffect(() => {\n if (!session?.idToken) {\n setUser(null);\n return;\n }\n if (session?.idToken) {\n setUserLoading(true);\n fetchUser()\n .then((user) => {\n setUserLoading(false);\n setUser(user);\n })\n .catch((error) => {\n setUserLoading(false);\n setUserError(error);\n });\n }\n }, [fetchUser, session?.idToken]);\n\n const isLoading = authLoading || userLoading;\n const error = authError || userError;\n\n return (\n <UserContext.Provider\n value={{\n ...tokens,\n user: (inputUser || user) ?? null,\n isLoading,\n error,\n signIn,\n signOut,\n displayMode: displayMode || \"iframe\",\n }}\n >\n {children}\n </UserContext.Provider>\n );\n};\n\nexport type { UserContextType };\n\nexport { UserProvider, UserContext };\n"]}
@@ -0,0 +1,15 @@
1
+ import type { Config, DisplayMode, IframeMode } from "@/types.js";
2
+ import type { ReactNode } from "react";
3
+ export type AuthProviderProps = {
4
+ children: ReactNode;
5
+ clientId: string;
6
+ nonce?: string;
7
+ onSignIn?: (error?: Error) => void;
8
+ onSignOut?: () => Promise<void>;
9
+ iframeMode?: IframeMode;
10
+ config?: Config;
11
+ redirectUrl?: string;
12
+ logoutRedirectUrl?: string;
13
+ displayMode?: DisplayMode;
14
+ };
15
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,MAAM,MAAM,iBAAiB,GAAG;IAC9B,QAAQ,EAAE,SAAS,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,KAAK,IAAI,CAAC;IACnC,SAAS,CAAC,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAChC,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/shared/providers/types.ts"],"names":[],"mappings":"","sourcesContent":["import type { Config, DisplayMode, IframeMode } from \"@/types.js\";\nimport type { ReactNode } from \"react\";\n\nexport type AuthProviderProps = {\n children: ReactNode;\n clientId: string;\n nonce?: string;\n onSignIn?: (error?: Error) => void;\n onSignOut?: () => Promise<void>;\n iframeMode?: IframeMode;\n config?: Config;\n redirectUrl?: string;\n logoutRedirectUrl?: string;\n displayMode?: DisplayMode;\n};\n"]}
@@ -0,0 +1,2 @@
1
+ export declare const VERSION = "@civic/auth:0.1.6-beta.0";
2
+ //# sourceMappingURL=version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,OAAO,6BAA6B,CAAC"}
@@ -0,0 +1,3 @@
1
+ // This is an auto-generated file. Do not edit.
2
+ export const VERSION = "@civic/auth:0.1.6-beta.0";
3
+ //# sourceMappingURL=version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAE/C,MAAM,CAAC,MAAM,OAAO,GAAG,0BAA0B,CAAC","sourcesContent":["// This is an auto-generated file. Do not edit.\n\nexport const VERSION = \"@civic/auth:0.1.6-beta.0\";\n"]}