@civic/auth 0.1.4-beta.1 → 0.1.4-beta.3

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 (275) hide show
  1. package/CHANGELOG.md +0 -1
  2. package/README.md +8 -11
  3. package/dist/cjs/index.d.ts.map +1 -1
  4. package/dist/cjs/index.js +5 -0
  5. package/dist/cjs/index.js.map +1 -1
  6. package/dist/cjs/nextjs/index.d.ts.map +1 -1
  7. package/dist/cjs/nextjs/index.js +2 -0
  8. package/dist/cjs/nextjs/index.js.map +1 -1
  9. package/dist/cjs/nextjs/providers/NextAuthProvider.js +2 -2
  10. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -1
  11. package/dist/cjs/reactjs/index.d.ts.map +1 -1
  12. package/dist/cjs/reactjs/index.js +2 -0
  13. package/dist/cjs/reactjs/index.js.map +1 -1
  14. package/dist/cjs/server/index.d.ts.map +1 -1
  15. package/dist/cjs/server/index.js +2 -0
  16. package/dist/cjs/server/index.js.map +1 -1
  17. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -1
  18. package/dist/cjs/shared/components/IFrameAndLoading.js +3 -3
  19. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -1
  20. package/dist/cjs/shared/providers/UserProvider.d.ts +6 -3
  21. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -1
  22. package/dist/cjs/shared/providers/UserProvider.js.map +1 -1
  23. package/dist/cjs/version.d.ts +2 -0
  24. package/dist/cjs/version.d.ts.map +1 -0
  25. package/dist/cjs/version.js +6 -0
  26. package/dist/cjs/version.js.map +1 -0
  27. package/dist/esm/index.d.ts.map +1 -1
  28. package/dist/esm/index.js +5 -1
  29. package/dist/esm/index.js.map +1 -1
  30. package/dist/esm/nextjs/index.d.ts.map +1 -1
  31. package/dist/esm/nextjs/index.js +2 -0
  32. package/dist/esm/nextjs/index.js.map +1 -1
  33. package/dist/esm/nextjs/providers/NextAuthProvider.js +1 -1
  34. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -1
  35. package/dist/esm/reactjs/index.d.ts.map +1 -1
  36. package/dist/esm/reactjs/index.js +2 -0
  37. package/dist/esm/reactjs/index.js.map +1 -1
  38. package/dist/esm/server/index.d.ts.map +1 -1
  39. package/dist/esm/server/index.js +2 -0
  40. package/dist/esm/server/index.js.map +1 -1
  41. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -1
  42. package/dist/esm/shared/components/IFrameAndLoading.js +3 -3
  43. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -1
  44. package/dist/esm/shared/providers/UserProvider.d.ts +6 -3
  45. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -1
  46. package/dist/esm/shared/providers/UserProvider.js.map +1 -1
  47. package/dist/esm/version.d.ts +2 -0
  48. package/dist/esm/version.d.ts.map +1 -0
  49. package/dist/esm/version.js +3 -0
  50. package/dist/esm/version.js.map +1 -0
  51. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  52. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  53. package/package.json +7 -4
  54. package/dist/src/browser/storage.d.ts +0 -9
  55. package/dist/src/browser/storage.d.ts.map +0 -1
  56. package/dist/src/browser/storage.js +0 -17
  57. package/dist/src/browser/storage.js.map +0 -1
  58. package/dist/src/config.d.ts.map +0 -1
  59. package/dist/src/index.d.ts.map +0 -1
  60. package/dist/src/lib/cookies.d.ts +0 -7
  61. package/dist/src/lib/cookies.d.ts.map +0 -1
  62. package/dist/src/lib/cookies.js +0 -25
  63. package/dist/src/lib/cookies.js.map +0 -1
  64. package/dist/src/lib/jwt.d.ts.map +0 -1
  65. package/dist/src/lib/oauth.d.ts.map +0 -1
  66. package/dist/src/lib/postMessage.d.ts.map +0 -1
  67. package/dist/src/lib/postMessage.js +0 -15
  68. package/dist/src/lib/postMessage.js.map +0 -1
  69. package/dist/src/lib/windowUtil.d.ts.map +0 -1
  70. package/dist/src/lib/windowUtil.js +0 -31
  71. package/dist/src/lib/windowUtil.js.map +0 -1
  72. package/dist/src/nextjs/GetUser.d.ts.map +0 -1
  73. package/dist/src/nextjs/GetUser.js +0 -7
  74. package/dist/src/nextjs/GetUser.js.map +0 -1
  75. package/dist/src/nextjs/config.d.ts.map +0 -1
  76. package/dist/src/nextjs/config.js +0 -173
  77. package/dist/src/nextjs/config.js.map +0 -1
  78. package/dist/src/nextjs/cookies.d.ts.map +0 -1
  79. package/dist/src/nextjs/hooks/index.d.ts +0 -2
  80. package/dist/src/nextjs/hooks/index.d.ts.map +0 -1
  81. package/dist/src/nextjs/hooks/index.js +0 -2
  82. package/dist/src/nextjs/hooks/index.js.map +0 -1
  83. package/dist/src/nextjs/hooks/useRefresh.d.ts +0 -4
  84. package/dist/src/nextjs/hooks/useRefresh.d.ts.map +0 -1
  85. package/dist/src/nextjs/hooks/useRefresh.js +0 -38
  86. package/dist/src/nextjs/hooks/useRefresh.js.map +0 -1
  87. package/dist/src/nextjs/hooks/useTokenCookie.d.ts +0 -3
  88. package/dist/src/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  89. package/dist/src/nextjs/hooks/useTokenCookie.js +0 -37
  90. package/dist/src/nextjs/hooks/useTokenCookie.js.map +0 -1
  91. package/dist/src/nextjs/hooks/useUserCookie.d.ts +0 -6
  92. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +0 -1
  93. package/dist/src/nextjs/hooks/useUserCookie.js +0 -64
  94. package/dist/src/nextjs/hooks/useUserCookie.js.map +0 -1
  95. package/dist/src/nextjs/index.d.ts.map +0 -1
  96. package/dist/src/nextjs/middleware/index.d.ts.map +0 -1
  97. package/dist/src/nextjs/middleware.d.ts.map +0 -1
  98. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +0 -13
  99. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
  100. package/dist/src/nextjs/providers/NextAuthProvider.js +0 -79
  101. package/dist/src/nextjs/providers/NextAuthProvider.js.map +0 -1
  102. package/dist/src/nextjs/routeHandler.d.ts.map +0 -1
  103. package/dist/src/nextjs/routeHandler.js +0 -212
  104. package/dist/src/nextjs/routeHandler.js.map +0 -1
  105. package/dist/src/nextjs/utils.d.ts.map +0 -1
  106. package/dist/src/reactjs/components/SignInButton.d.ts.map +0 -1
  107. package/dist/src/reactjs/components/SignOutButton.d.ts.map +0 -1
  108. package/dist/src/reactjs/components/UserButton.d.ts.map +0 -1
  109. package/dist/src/reactjs/components/UserButton.js +0 -118
  110. package/dist/src/reactjs/components/UserButton.js.map +0 -1
  111. package/dist/src/reactjs/components/index.d.ts.map +0 -1
  112. package/dist/src/reactjs/hooks/index.d.ts +0 -6
  113. package/dist/src/reactjs/hooks/index.d.ts.map +0 -1
  114. package/dist/src/reactjs/hooks/index.js +0 -6
  115. package/dist/src/reactjs/hooks/index.js.map +0 -1
  116. package/dist/src/reactjs/hooks/useAuth.d.ts.map +0 -1
  117. package/dist/src/reactjs/hooks/useRefresh.d.ts +0 -4
  118. package/dist/src/reactjs/hooks/useRefresh.d.ts.map +0 -1
  119. package/dist/src/reactjs/hooks/useRefresh.js +0 -28
  120. package/dist/src/reactjs/hooks/useRefresh.js.map +0 -1
  121. package/dist/src/reactjs/hooks/useUser.d.ts.map +0 -1
  122. package/dist/src/reactjs/index.d.ts.map +0 -1
  123. package/dist/src/reactjs/providers/index.d.ts.map +0 -1
  124. package/dist/src/server/ServerAuthenticationResolver.d.ts.map +0 -1
  125. package/dist/src/server/config.d.ts.map +0 -1
  126. package/dist/src/server/index.d.ts.map +0 -1
  127. package/dist/src/server/login.d.ts.map +0 -1
  128. package/dist/src/server/refresh.d.ts.map +0 -1
  129. package/dist/src/services/AuthenticationService.d.ts +0 -90
  130. package/dist/src/services/AuthenticationService.d.ts.map +0 -1
  131. package/dist/src/services/AuthenticationService.js +0 -243
  132. package/dist/src/services/AuthenticationService.js.map +0 -1
  133. package/dist/src/services/PKCE.d.ts.map +0 -1
  134. package/dist/src/services/types.d.ts.map +0 -1
  135. package/dist/src/shared/components/BlockDisplay.d.ts +0 -7
  136. package/dist/src/shared/components/BlockDisplay.d.ts.map +0 -1
  137. package/dist/src/shared/components/BlockDisplay.js +0 -25
  138. package/dist/src/shared/components/BlockDisplay.js.map +0 -1
  139. package/dist/src/shared/components/CivicAuthIframe.d.ts.map +0 -1
  140. package/dist/src/shared/components/CivicAuthIframe.js +0 -9
  141. package/dist/src/shared/components/CivicAuthIframe.js.map +0 -1
  142. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
  143. package/dist/src/shared/components/CivicAuthIframeContainer.js +0 -138
  144. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +0 -1
  145. package/dist/src/shared/components/IFrameAndLoading.d.ts +0 -7
  146. package/dist/src/shared/components/IFrameAndLoading.d.ts.map +0 -1
  147. package/dist/src/shared/components/IFrameAndLoading.js +0 -22
  148. package/dist/src/shared/components/IFrameAndLoading.js.map +0 -1
  149. package/dist/src/shared/hooks/index.d.ts +0 -9
  150. package/dist/src/shared/hooks/index.d.ts.map +0 -1
  151. package/dist/src/shared/hooks/index.js +0 -9
  152. package/dist/src/shared/hooks/index.js.map +0 -1
  153. package/dist/src/shared/hooks/useAuth.d.ts.map +0 -1
  154. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts +0 -3
  155. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts.map +0 -1
  156. package/dist/src/shared/hooks/useCivicAuthConfig.js +0 -10
  157. package/dist/src/shared/hooks/useCivicAuthConfig.js.map +0 -1
  158. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts +0 -3
  159. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  160. package/dist/src/shared/hooks/useClientTokenExchangeSession.js +0 -13
  161. package/dist/src/shared/hooks/useClientTokenExchangeSession.js.map +0 -1
  162. package/dist/src/shared/hooks/useConfig.d.ts +0 -3
  163. package/dist/src/shared/hooks/useConfig.d.ts.map +0 -1
  164. package/dist/src/shared/hooks/useConfig.js +0 -13
  165. package/dist/src/shared/hooks/useConfig.js.map +0 -1
  166. package/dist/src/shared/hooks/useCurrentUrl.d.ts +0 -3
  167. package/dist/src/shared/hooks/useCurrentUrl.d.ts.map +0 -1
  168. package/dist/src/shared/hooks/useCurrentUrl.js +0 -24
  169. package/dist/src/shared/hooks/useCurrentUrl.js.map +0 -1
  170. package/dist/src/shared/hooks/useIframe.d.ts.map +0 -1
  171. package/dist/src/shared/hooks/useIsInIframe.d.ts +0 -3
  172. package/dist/src/shared/hooks/useIsInIframe.d.ts.map +0 -1
  173. package/dist/src/shared/hooks/useIsInIframe.js +0 -14
  174. package/dist/src/shared/hooks/useIsInIframe.js.map +0 -1
  175. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts +0 -4
  176. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts.map +0 -1
  177. package/dist/src/shared/hooks/useOAuthEndpoints.js +0 -14
  178. package/dist/src/shared/hooks/useOAuthEndpoints.js.map +0 -1
  179. package/dist/src/shared/hooks/useRefresh.d.ts +0 -4
  180. package/dist/src/shared/hooks/useRefresh.d.ts.map +0 -1
  181. package/dist/src/shared/hooks/useRefresh.js +0 -38
  182. package/dist/src/shared/hooks/useRefresh.js.map +0 -1
  183. package/dist/src/shared/hooks/useSession.d.ts +0 -3
  184. package/dist/src/shared/hooks/useSession.d.ts.map +0 -1
  185. package/dist/src/shared/hooks/useSignIn.d.ts +0 -14
  186. package/dist/src/shared/hooks/useSignIn.d.ts.map +0 -1
  187. package/dist/src/shared/hooks/useSignIn.js +0 -71
  188. package/dist/src/shared/hooks/useSignIn.js.map +0 -1
  189. package/dist/src/shared/hooks/useToken.d.ts.map +0 -1
  190. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +0 -20
  191. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
  192. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +0 -73
  193. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
  194. package/dist/src/shared/lib/UserSession.d.ts.map +0 -1
  195. package/dist/src/shared/lib/session.d.ts +0 -3
  196. package/dist/src/shared/lib/session.d.ts.map +0 -1
  197. package/dist/src/shared/lib/session.js +0 -21
  198. package/dist/src/shared/lib/session.js.map +0 -1
  199. package/dist/src/shared/lib/storage.d.ts.map +0 -1
  200. package/dist/src/shared/lib/types.d.ts +0 -35
  201. package/dist/src/shared/lib/types.d.ts.map +0 -1
  202. package/dist/src/shared/lib/types.js +0 -18
  203. package/dist/src/shared/lib/types.js.map +0 -1
  204. package/dist/src/shared/lib/util.d.ts.map +0 -1
  205. package/dist/src/shared/lib/util.js +0 -133
  206. package/dist/src/shared/lib/util.js.map +0 -1
  207. package/dist/src/shared/providers/AuthContext.d.ts.map +0 -1
  208. package/dist/src/shared/providers/AuthProvider.d.ts +0 -21
  209. package/dist/src/shared/providers/AuthProvider.d.ts.map +0 -1
  210. package/dist/src/shared/providers/AuthProvider.js +0 -63
  211. package/dist/src/shared/providers/AuthProvider.js.map +0 -1
  212. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts +0 -16
  213. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts.map +0 -1
  214. package/dist/src/shared/providers/CivicAuthConfigContext.js +0 -43
  215. package/dist/src/shared/providers/CivicAuthConfigContext.js.map +0 -1
  216. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +0 -1
  217. package/dist/src/shared/providers/CivicAuthProvider.js +0 -32
  218. package/dist/src/shared/providers/CivicAuthProvider.js.map +0 -1
  219. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
  220. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  221. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js +0 -146
  222. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  223. package/dist/src/shared/providers/ConfigProvider.d.ts +0 -21
  224. package/dist/src/shared/providers/ConfigProvider.d.ts.map +0 -1
  225. package/dist/src/shared/providers/ConfigProvider.js +0 -19
  226. package/dist/src/shared/providers/ConfigProvider.js.map +0 -1
  227. package/dist/src/shared/providers/IframeProvider.d.ts +0 -19
  228. package/dist/src/shared/providers/IframeProvider.d.ts.map +0 -1
  229. package/dist/src/shared/providers/IframeProvider.js +0 -29
  230. package/dist/src/shared/providers/IframeProvider.js.map +0 -1
  231. package/dist/src/shared/providers/SessionProvider.d.ts +0 -19
  232. package/dist/src/shared/providers/SessionProvider.d.ts.map +0 -1
  233. package/dist/src/shared/providers/SessionProvider.js +0 -23
  234. package/dist/src/shared/providers/SessionProvider.js.map +0 -1
  235. package/dist/src/shared/providers/TokenProvider.d.ts.map +0 -1
  236. package/dist/src/shared/providers/TokenProvider.js +0 -42
  237. package/dist/src/shared/providers/TokenProvider.js.map +0 -1
  238. package/dist/src/shared/providers/UserProvider.d.ts +0 -20
  239. package/dist/src/shared/providers/UserProvider.d.ts.map +0 -1
  240. package/dist/src/shared/providers/UserProvider.js +0 -51
  241. package/dist/src/shared/providers/UserProvider.js.map +0 -1
  242. package/dist/src/types.d.ts +0 -146
  243. package/dist/src/types.d.ts.map +0 -1
  244. package/dist/src/types.js +0 -4
  245. package/dist/src/types.js.map +0 -1
  246. package/dist/test/integration/sdk.test.d.ts.map +0 -1
  247. package/dist/test/integration/sdk.test.js +0 -189
  248. package/dist/test/integration/sdk.test.js.map +0 -1
  249. package/dist/test/unit/lib/oauth.test.d.ts.map +0 -1
  250. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts.map +0 -1
  251. package/dist/test/unit/nextjs/NextAuthProvider.test.js +0 -31
  252. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +0 -1
  253. package/dist/test/unit/nextjs/config.test.d.ts.map +0 -1
  254. package/dist/test/unit/nextjs/getUser.test.d.ts.map +0 -1
  255. package/dist/test/unit/nextjs/getUser.test.js +0 -22
  256. package/dist/test/unit/nextjs/getUser.test.js.map +0 -1
  257. package/dist/test/unit/nextjs/middleware.test.d.ts.map +0 -1
  258. package/dist/test/unit/nextjs/utils.test.d.ts.map +0 -1
  259. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts.map +0 -1
  260. package/dist/test/unit/react/components/SignInButton.test.d.ts.map +0 -1
  261. package/dist/test/unit/react/components/SignOutButton.test.d.ts.map +0 -1
  262. package/dist/test/unit/server/login.test.d.ts.map +0 -1
  263. package/dist/test/unit/server/refresh.test.d.ts.map +0 -1
  264. package/dist/test/unit/server/session.test.d.ts.map +0 -1
  265. package/dist/test/unit/services/AuthenticationService.test.d.ts.map +0 -1
  266. package/dist/test/unit/services/AuthenticationService.test.js +0 -121
  267. package/dist/test/unit/services/AuthenticationService.test.js.map +0 -1
  268. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts.map +0 -1
  269. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts.map +0 -1
  270. package/dist/test/unit/shared/UserSession.test.d.ts.map +0 -1
  271. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts.map +0 -1
  272. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +0 -122
  273. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +0 -1
  274. package/dist/test/unit/shared/storage.test.d.ts.map +0 -1
  275. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"CivicAuthProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/CivicAuthProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EACL,YAAY,GAEb,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,+BAA+B,EAAE,MAAM,oBAAoB,CAAC;AACrE,OAAO,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,uBAAuB,EAAE,MAAM,8CAA8C,CAAC;AACvF,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AACtE,OAAO,EAAE,kCAAkC,EAAE,MAAM,0DAA0D,CAAC;AAC9G,OAAO,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AACxE,OAAO,EAAE,6BAA6B,EAAE,MAAM,iDAAiD,CAAC;AAChG,OAAO,EAAE,aAAa,EAAE,MAAM,qCAAqC,CAAC;AACpE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAIpD,MAAM,mBAAmB,GAAG,CAAC,EAAE,QAAQ,EAAiC,EAAE,EAAE;IAC1E,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,CAAC;IACtC,OAAO,CACL,oBAAC,YAAY,IACX,OAAO,EAAE,IAAI,mBAAmB,EAAE,EAClC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,OAAO,IAEf,QAAQ,CACI,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,MAAM,0BAA0B,GAAG,CAAC,EAClC,QAAQ,EACR,GAAG,KAAK,EACe,EAAE,EAAE;IAC3B,MAAM,WAAW,GAAG,6BAA6B,EAAE,CAAC;IACpD,OAAO,CACL,oBAAC,eAAe,OAAK,WAAW;QAC9B,oBAAC,cAAc,IAAC,UAAU,EAAE,KAAK,CAAC,UAAU;YAC1C,oBAAC,YAAY,OACP,KAAK,EACT,YAAY,EAAE,IAAI,+BAA+B,EAAE;gBAEnD,oBAAC,aAAa;oBACZ,oBAAC,mBAAmB,QAAE,QAAQ,CAAuB,CACvC,CACH,CACA,CACD,CACnB,CAAC;AACJ,CAAC,CAAC;AACF,MAAM,iBAAiB,GAAG,CAAC,EAAE,QAAQ,EAAE,GAAG,KAAK,EAA0B,EAAE,EAAE;IAC3E,OAAO,CACL,oBAAC,uBAAuB,IACtB,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EACvC,QAAQ,EAAE,KAAK,EAAE,QAAQ,EACzB,WAAW,EAAE,KAAK,EAAE,WAAW,EAC/B,KAAK,EAAE,KAAK,EAAE,KAAK;QAEnB,oBAAC,kCAAkC;YACjC,oBAAC,0BAA0B,OAAK,KAAK,IAClC,QAAQ,CACkB,CACM,CACb,CAC3B,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,iBAAiB,EAA+B,CAAC","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport {\n AuthProvider,\n type AuthProviderProps,\n} from \"@/shared/providers/AuthProvider.js\";\nimport { BrowserPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport { UserProvider } from \"@/shared/providers/UserProvider.js\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport { CivicAuthConfigProvider } from \"@/shared/providers/CivicAuthConfigContext.js\";\nimport { IframeProvider } from \"@/shared/providers/IframeProvider.js\";\nimport { ClientTokenExchangeSessionProvider } from \"@/shared/providers/ClientTokenExchangeSessionProvider.js\";\nimport { SessionProvider } from \"@/shared/providers/SessionProvider.js\";\nimport { useClientTokenExchangeSession } from \"@/shared/hooks/useClientTokenExchangeSession.js\";\nimport { TokenProvider } from \"@/shared/providers/TokenProvider.js\";\nimport { useAuth } from \"@/shared/hooks/useAuth.js\";\n\ntype CivicAuthProviderProps = Omit<AuthProviderProps, \"pkceConsumer\">;\n\nconst WrapperUserProvider = ({ children }: { children: React.ReactNode }) => {\n const { signIn, signOut } = useAuth();\n return (\n <UserProvider\n storage={new LocalStorageAdapter()}\n signIn={signIn}\n signOut={signOut}\n >\n {children}\n </UserProvider>\n );\n};\nconst WrapperSessionAuthProvider = ({\n children,\n ...props\n}: CivicAuthProviderProps) => {\n const sessionData = useClientTokenExchangeSession();\n return (\n <SessionProvider {...sessionData}>\n <IframeProvider iframeMode={props.iframeMode}>\n <AuthProvider\n {...props}\n pkceConsumer={new BrowserPublicClientPKCEProducer()}\n >\n <TokenProvider>\n <WrapperUserProvider>{children}</WrapperUserProvider>\n </TokenProvider>\n </AuthProvider>\n </IframeProvider>\n </SessionProvider>\n );\n};\nconst CivicAuthProvider = ({ children, ...props }: CivicAuthProviderProps) => {\n return (\n <CivicAuthConfigProvider\n oauthServer={props?.config?.oauthServer}\n clientId={props?.clientId}\n redirectUrl={props?.redirectUrl}\n nonce={props?.nonce}\n >\n <ClientTokenExchangeSessionProvider>\n <WrapperSessionAuthProvider {...props}>\n {children}\n </WrapperSessionAuthProvider>\n </ClientTokenExchangeSessionProvider>\n </CivicAuthConfigProvider>\n );\n};\n\nexport { CivicAuthProvider, type CivicAuthProviderProps };\n"]}
@@ -1,17 +0,0 @@
1
- import type { ReactNode } from "react";
2
- import React from "react";
3
- import type { SessionData } from "@/types.js";
4
- export type ClientTokenExchangeSessionProviderOutput = {
5
- data: SessionData | null;
6
- error: Error | null;
7
- isLoading: boolean;
8
- doTokenExchange: null | ((url: string) => Promise<void>);
9
- };
10
- declare const ClientTokenExchangeSessionContext: React.Context<ClientTokenExchangeSessionProviderOutput>;
11
- type ClientTokenExchangeSessionContextType = {
12
- children: ReactNode;
13
- };
14
- declare const ClientTokenExchangeSessionProvider: ({ children, }: ClientTokenExchangeSessionContextType) => React.JSX.Element;
15
- export type { ClientTokenExchangeSessionContextType as SessionContextType };
16
- export { ClientTokenExchangeSessionProvider, ClientTokenExchangeSessionContext, };
17
- //# sourceMappingURL=ClientTokenExchangeSessionProvider.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ClientTokenExchangeSessionProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/ClientTokenExchangeSessionProvider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAMN,MAAM,OAAO,CAAC;AAIf,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAM9C,MAAM,MAAM,wCAAwC,GAAG;IACrD,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC;IACzB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,eAAe,EAAE,IAAI,GAAG,CAAC,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;CAC1D,CAAC;AAcF,QAAA,MAAM,iCAAiC,yDACkC,CAAC;AAE1E,KAAK,qCAAqC,GAAG;IAC3C,QAAQ,EAAE,SAAS,CAAC;CACrB,CAAC;AAEF,QAAA,MAAM,kCAAkC,kBAErC,qCAAqC,sBA+IvC,CAAC;AAEF,YAAY,EAAE,qCAAqC,IAAI,kBAAkB,EAAE,CAAC;AAC5E,OAAO,EACL,kCAAkC,EAClC,iCAAiC,GAClC,CAAC"}
@@ -1,146 +0,0 @@
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 } from "@/shared/hooks/useCurrentUrl.js";
6
- import { useCivicAuthConfig } from "@/shared/hooks/useCivicAuthConfig.js";
7
- import { LocalStorageAdapter } from "@/browser/storage.js";
8
- import { useRefresh } from "../hooks/useRefresh.js";
9
- const defaultSession = {
10
- data: {
11
- authenticated: false,
12
- idToken: undefined,
13
- accessToken: undefined,
14
- displayMode: "iframe",
15
- },
16
- error: null,
17
- isLoading: false,
18
- doTokenExchange: null,
19
- };
20
- // Context for exposing session specifically to the TokenProvider
21
- const ClientTokenExchangeSessionContext = createContext(defaultSession);
22
- const ClientTokenExchangeSessionProvider = ({ children, }) => {
23
- const authConfig = useCivicAuthConfig();
24
- const [authService, setAuthService] = useState();
25
- const [error, setError] = useState(null);
26
- const [isLoading, setIsLoading] = useState(false);
27
- const [session, setSession] = useState(null);
28
- const [isWindowFocused, setIsWindowFocused] = useState(true);
29
- useRefresh(session);
30
- // handle the window refocusing after redirect
31
- useEffect(() => {
32
- const handleFocus = () => {
33
- setIsWindowFocused(true);
34
- };
35
- const handleBlur = () => {
36
- setIsWindowFocused(false);
37
- };
38
- window.addEventListener("focus", handleFocus);
39
- window.addEventListener("blur", handleBlur);
40
- return () => {
41
- window.removeEventListener("focus", handleFocus);
42
- window.removeEventListener("blur", handleBlur);
43
- };
44
- }, []);
45
- const currentUrl = useCurrentUrl();
46
- useEffect(() => {
47
- if (!currentUrl || !authConfig)
48
- return;
49
- const { redirectUrl, clientId, oauthServer, scopes } = authConfig;
50
- BrowserAuthenticationService.build({
51
- clientId,
52
- redirectUrl,
53
- oauthServer,
54
- scopes,
55
- displayMode: "iframe",
56
- }).then(setAuthService);
57
- }, [currentUrl, authConfig]);
58
- const isInIframe = isWindowInIframe(globalThis.window);
59
- const doTokenExchange = useCallback(async (inUrl) => {
60
- if (!authService)
61
- return;
62
- const url = new URL(inUrl);
63
- const code = url.searchParams.get("code");
64
- const state = url.searchParams.get("state");
65
- if (code && state) {
66
- try {
67
- setIsLoading(true);
68
- await authService.tokenExchange(code, state);
69
- }
70
- catch (error) {
71
- setError(error);
72
- setSession({ authenticated: false });
73
- }
74
- setIsLoading(false);
75
- }
76
- }, [authService]);
77
- const onSignIn = useCallback(async () => {
78
- if (!authService)
79
- return;
80
- const session = await authService.getSessionData();
81
- setSession(session);
82
- }, [authService]);
83
- const onSignOut = useCallback(() => {
84
- setSession({ authenticated: false });
85
- }, []);
86
- useEffect(() => {
87
- LocalStorageAdapter.emitter.on("signIn", onSignIn);
88
- LocalStorageAdapter.emitter.on("signOut", onSignOut);
89
- return () => {
90
- LocalStorageAdapter.emitter.off("signIn", onSignIn);
91
- LocalStorageAdapter.emitter.off("signOut", onSignOut);
92
- };
93
- }, [onSignIn, onSignOut]);
94
- useEffect(() => {
95
- if (!authConfig) {
96
- setIsLoading(true);
97
- }
98
- else {
99
- setIsLoading(false);
100
- }
101
- }, [authConfig]);
102
- // Handle page load or refocus
103
- useEffect(() => {
104
- if (!authConfig || !authService || !currentUrl || isInIframe || isLoading) {
105
- return;
106
- }
107
- const abortController = new AbortController();
108
- const onPageLoad = async () => {
109
- // if we have existing tokens, then validate them and return the session data
110
- // otherwise check if we have a code in the url and exchange it for tokens
111
- // if we have neither, return undefined
112
- const existingSessionData = await authService.validateExistingSession();
113
- if (existingSessionData.authenticated) {
114
- setSession(existingSessionData);
115
- return;
116
- }
117
- if (abortController.signal.aborted ||
118
- !new URL(currentUrl).searchParams.get("code")) {
119
- return;
120
- }
121
- await doTokenExchange(currentUrl);
122
- };
123
- onPageLoad();
124
- return () => {
125
- abortController.abort();
126
- };
127
- }, [
128
- authConfig,
129
- authService,
130
- currentUrl,
131
- doTokenExchange,
132
- isInIframe,
133
- isLoading,
134
- isWindowFocused,
135
- session?.authenticated,
136
- ]);
137
- const value = useMemo(() => ({
138
- data: session,
139
- error,
140
- isLoading,
141
- doTokenExchange,
142
- }), [session, error, isLoading, doTokenExchange]);
143
- return (React.createElement(ClientTokenExchangeSessionContext.Provider, { value: value }, children));
144
- };
145
- export { ClientTokenExchangeSessionProvider, ClientTokenExchangeSessionContext, };
146
- //# sourceMappingURL=ClientTokenExchangeSessionProvider.js.map
@@ -1 +0,0 @@
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 { useCurrentUrl } from \"@/shared/hooks/useCurrentUrl.js\";\nimport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport { useRefresh } from \"../hooks/useRefresh.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, setIsWindowFocused] = useState(true);\n\n useRefresh(session);\n // handle the window refocusing after redirect\n useEffect(() => {\n const handleFocus = () => {\n setIsWindowFocused(true);\n };\n\n const handleBlur = () => {\n setIsWindowFocused(false);\n };\n window.addEventListener(\"focus\", handleFocus);\n window.addEventListener(\"blur\", handleBlur);\n\n return () => {\n window.removeEventListener(\"focus\", handleFocus);\n window.removeEventListener(\"blur\", handleBlur);\n };\n }, []);\n\n const currentUrl = useCurrentUrl();\n\n useEffect(() => {\n if (!currentUrl || !authConfig) return;\n\n const { redirectUrl, clientId, oauthServer, scopes } = authConfig;\n BrowserAuthenticationService.build({\n clientId,\n redirectUrl,\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,\n }),\n [session, error, isLoading, 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"]}
@@ -1,21 +0,0 @@
1
- import type { Config } from "@/types.js";
2
- import type { ReactNode } from "react";
3
- import React from "react";
4
- export type ConfigProviderOutput = {
5
- config: Config;
6
- redirectUrl: string;
7
- modalIframe: boolean;
8
- serverTokenExchange: boolean;
9
- };
10
- declare const ConfigContext: React.Context<ConfigProviderOutput>;
11
- type ConfigContextType = {
12
- children: ReactNode;
13
- config: Config;
14
- redirectUrl: string;
15
- modalIframe?: boolean;
16
- serverTokenExchange: boolean;
17
- };
18
- declare const ConfigProvider: ({ children, config, redirectUrl, modalIframe, serverTokenExchange, }: ConfigContextType) => React.JSX.Element;
19
- export type { ConfigContextType };
20
- export { ConfigProvider, ConfigContext };
21
- //# sourceMappingURL=ConfigProvider.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ConfigProvider.d.ts","sourceRoot":"","sources":["../../../../src/shared/providers/ConfigProvider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAwB,MAAM,OAAO,CAAC;AAE7C,MAAM,MAAM,oBAAoB,GAAG;IACjC,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,OAAO,CAAC;IACrB,mBAAmB,EAAE,OAAO,CAAC;CAC9B,CAAC;AAQF,QAAA,MAAM,aAAa,qCAAqD,CAAC;AAEzE,KAAK,iBAAiB,GAAG;IACvB,QAAQ,EAAE,SAAS,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,mBAAmB,EAAE,OAAO,CAAC;CAC9B,CAAC;AAEF,QAAA,MAAM,cAAc,yEAMjB,iBAAiB,sBAWnB,CAAC;AAEF,YAAY,EAAE,iBAAiB,EAAE,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,CAAC"}
@@ -1,19 +0,0 @@
1
- "use client";
2
- import { authConfig } from "@/config.js";
3
- import React, { createContext } from "react";
4
- const defaultConfig = {
5
- config: authConfig,
6
- redirectUrl: "",
7
- modalIframe: true,
8
- serverTokenExchange: false,
9
- };
10
- // Context for exposing Config specifically to the TokenProvider
11
- const ConfigContext = createContext(defaultConfig);
12
- const ConfigProvider = ({ children, config, redirectUrl, modalIframe, serverTokenExchange, }) => (React.createElement(ConfigContext.Provider, { value: {
13
- config,
14
- redirectUrl,
15
- modalIframe: !!modalIframe,
16
- serverTokenExchange,
17
- } }, children));
18
- export { ConfigProvider, ConfigContext };
19
- //# sourceMappingURL=ConfigProvider.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ConfigProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/ConfigProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAGzC,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAQ7C,MAAM,aAAa,GAAyB;IAC1C,MAAM,EAAE,UAAU;IAClB,WAAW,EAAE,EAAE;IACf,WAAW,EAAE,IAAI;IACjB,mBAAmB,EAAE,KAAK;CAC3B,CAAC;AACF,gEAAgE;AAChE,MAAM,aAAa,GAAG,aAAa,CAAuB,aAAa,CAAC,CAAC;AAUzE,MAAM,cAAc,GAAG,CAAC,EACtB,QAAQ,EACR,MAAM,EACN,WAAW,EACX,WAAW,EACX,mBAAmB,GACD,EAAE,EAAE,CAAC,CACvB,oBAAC,aAAa,CAAC,QAAQ,IACrB,KAAK,EAAE;QACL,MAAM;QACN,WAAW;QACX,WAAW,EAAE,CAAC,CAAC,WAAW;QAC1B,mBAAmB;KACpB,IAEA,QAAQ,CACc,CAC1B,CAAC;AAGF,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,CAAC","sourcesContent":["\"use client\";\nimport { authConfig } from \"@/config.js\";\nimport type { Config } from \"@/types.js\";\nimport type { ReactNode } from \"react\";\nimport React, { createContext } from \"react\";\n\nexport type ConfigProviderOutput = {\n config: Config;\n redirectUrl: string;\n modalIframe: boolean;\n serverTokenExchange: boolean;\n};\nconst defaultConfig: ConfigProviderOutput = {\n config: authConfig,\n redirectUrl: \"\",\n modalIframe: true,\n serverTokenExchange: false,\n};\n// Context for exposing Config specifically to the TokenProvider\nconst ConfigContext = createContext<ConfigProviderOutput>(defaultConfig);\n\ntype ConfigContextType = {\n children: ReactNode;\n config: Config;\n redirectUrl: string;\n modalIframe?: boolean;\n serverTokenExchange: boolean;\n};\n\nconst ConfigProvider = ({\n children,\n config,\n redirectUrl,\n modalIframe,\n serverTokenExchange,\n}: ConfigContextType) => (\n <ConfigContext.Provider\n value={{\n config,\n redirectUrl,\n modalIframe: !!modalIframe,\n serverTokenExchange,\n }}\n >\n {children}\n </ConfigContext.Provider>\n);\n\nexport type { ConfigContextType };\nexport { ConfigProvider, ConfigContext };\n"]}
@@ -1,19 +0,0 @@
1
- import type { Dispatch, ReactNode, RefObject, SetStateAction } from "react";
2
- import React from "react";
3
- import type { IframeMode } from "@/shared/providers/AuthProvider.js";
4
- export type IframeProviderOutput = {
5
- iframeRef: RefObject<HTMLIFrameElement> | null;
6
- setIframeIsVisible: Dispatch<SetStateAction<boolean>>;
7
- iframeIsVisible: boolean;
8
- iframeMode: IframeMode;
9
- renderIframe: boolean;
10
- };
11
- declare const IframeContext: React.Context<IframeProviderOutput>;
12
- type IframeContextType = {
13
- children: ReactNode;
14
- iframeMode?: IframeMode;
15
- };
16
- declare const IframeProvider: ({ children, iframeMode, }: IframeContextType) => React.JSX.Element;
17
- export type { IframeContextType };
18
- export { IframeProvider, IframeContext };
19
- //# sourceMappingURL=IframeProvider.d.ts.map
@@ -1 +0,0 @@
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;AAG/D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAErE,MAAM,MAAM,oBAAoB,GAAG;IACjC,SAAS,EAAE,SAAS,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC;IAC/C,kBAAkB,EAAE,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;IACtD,eAAe,EAAE,OAAO,CAAC;IACzB,UAAU,EAAE,UAAU,CAAC;IACvB,YAAY,EAAE,OAAO,CAAC;CACvB,CAAC;AAUF,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,sBAqBnB,CAAC;AAEF,YAAY,EAAE,iBAAiB,EAAE,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,CAAC"}
@@ -1,29 +0,0 @@
1
- "use client";
2
- import React, { createContext, useRef, useState } from "react";
3
- import { useIsInIframe } from "@/shared/hooks/useIsInIframe.js";
4
- import { useSession } from "@/shared/hooks/useSession.js";
5
- const defaultIframe = {
6
- iframeRef: null,
7
- setIframeIsVisible: () => { },
8
- iframeIsVisible: false,
9
- iframeMode: "modal",
10
- renderIframe: false,
11
- };
12
- // Context for exposing Iframe specifically to the TokenProvider
13
- const IframeContext = createContext(defaultIframe);
14
- const IframeProvider = ({ children, iframeMode = "modal", }) => {
15
- const iframeRef = useRef(null);
16
- const isInIframe = useIsInIframe();
17
- const [iframeIsVisible, setIframeIsVisible] = useState(false);
18
- const { data: session } = useSession();
19
- const renderIframe = iframeMode === "modal" && !isInIframe && !session?.authenticated;
20
- return (React.createElement(IframeContext.Provider, { value: {
21
- iframeRef,
22
- setIframeIsVisible,
23
- iframeIsVisible,
24
- iframeMode,
25
- renderIframe,
26
- } }, children));
27
- };
28
- export { IframeProvider, IframeContext };
29
- //# sourceMappingURL=IframeProvider.js.map
@@ -1 +0,0 @@
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;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAU1D,MAAM,aAAa,GAAyB;IAC1C,SAAS,EAAE,IAAI;IACf,kBAAkB,EAAE,GAAG,EAAE,GAAE,CAAC;IAC5B,eAAe,EAAE,KAAK;IACtB,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,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9D,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,CAAC;IAEvC,MAAM,YAAY,GAChB,UAAU,KAAK,OAAO,IAAI,CAAC,UAAU,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC;IACnE,OAAO,CACL,oBAAC,aAAa,CAAC,QAAQ,IACrB,KAAK,EAAE;YACL,SAAS;YACT,kBAAkB;YAClB,eAAe;YACf,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 { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { IframeMode } from \"@/shared/providers/AuthProvider.js\";\n\nexport type IframeProviderOutput = {\n iframeRef: RefObject<HTMLIFrameElement> | null;\n setIframeIsVisible: Dispatch<SetStateAction<boolean>>;\n iframeIsVisible: boolean;\n iframeMode: IframeMode;\n renderIframe: boolean;\n};\nconst defaultIframe: IframeProviderOutput = {\n iframeRef: null,\n setIframeIsVisible: () => {},\n iframeIsVisible: 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 isInIframe = useIsInIframe();\n const [iframeIsVisible, setIframeIsVisible] = useState(false);\n const { data: session } = useSession();\n\n const renderIframe =\n iframeMode === \"modal\" && !isInIframe && !session?.authenticated;\n return (\n <IframeContext.Provider\n value={{\n iframeRef,\n setIframeIsVisible,\n iframeIsVisible,\n iframeMode,\n renderIframe,\n }}\n >\n {children}\n </IframeContext.Provider>\n );\n};\n\nexport type { IframeContextType };\nexport { IframeProvider, IframeContext };\n"]}
@@ -1,19 +0,0 @@
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
@@ -1 +0,0 @@
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,23 +0,0 @@
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
@@ -1 +0,0 @@
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"]}
@@ -1 +0,0 @@
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"}
@@ -1,42 +0,0 @@
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
@@ -1 +0,0 @@
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"]}
@@ -1,20 +0,0 @@
1
- import React from "react";
2
- import type { ReactNode } from "react";
3
- import type { JWT } from "oslo/jwt";
4
- import type { AuthStorage, DisplayMode, EmptyObject, User } from "@/types.js";
5
- import type { AuthContextType } from "@/shared/providers/AuthContext.js";
6
- import type { TokenContextType } from "./TokenProvider.js";
7
- type UserContextType<T extends Record<string, unknown> & JWT["payload"] = Record<string, unknown> & JWT["payload"]> = {
8
- user: User<T> | null;
9
- } & Omit<TokenContextType, "isLoading" | "error" | "refreshToken"> & Omit<AuthContextType, "isAuthenticated">;
10
- declare const UserContext: React.Context<UserContextType<Record<string, unknown> & object> | null>;
11
- declare const UserProvider: <T extends EmptyObject>({ children, storage, user: inputUser, signOut, signIn, }: {
12
- children: ReactNode;
13
- storage: AuthStorage;
14
- user?: User<T> | null;
15
- signOut: () => Promise<void>;
16
- signIn: (displayMode?: DisplayMode) => Promise<void>;
17
- }) => React.JSX.Element;
18
- export type { UserContextType };
19
- export { UserProvider, UserContext };
20
- //# sourceMappingURL=UserProvider.d.ts.map
@@ -1 +0,0 @@
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,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAE9E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAEzE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAG3D,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,IAAI,CAAC,gBAAgB,EAAE,WAAW,GAAG,OAAO,GAAG,cAAc,CAAC,GAChE,IAAI,CAAC,eAAe,EAAE,iBAAiB,CAAC,CAAC;AAE3C,QAAA,MAAM,WAAW,yEAA8C,CAAC;AAEhE,QAAA,MAAM,YAAY,GAAI,CAAC,SAAS,WAAW,4DAMxC;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;CACtD,sBAoDA,CAAC;AAEF,YAAY,EAAE,eAAe,EAAE,CAAC;AAEhC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC"}
@@ -1,51 +0,0 @@
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, }) => {
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
- } }, children));
49
- };
50
- export { UserProvider, UserContext };
51
- //# sourceMappingURL=UserProvider.js.map
@@ -1 +0,0 @@
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;AAI/E,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAEjE,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAUhD,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,GAOP,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;SACR,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 { AuthStorage, DisplayMode, EmptyObject, User } from \"@/types.js\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { AuthContextType } from \"@/shared/providers/AuthContext.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport type { TokenContextType } from \"./TokenProvider.js\";\nimport { useToken } from \"../hooks/useToken.js\";\n\ntype UserContextType<\n T extends Record<string, unknown> & JWT[\"payload\"] = Record<string, unknown> &\n JWT[\"payload\"],\n> = {\n user: User<T> | null;\n} & Omit<TokenContextType, \"isLoading\" | \"error\" | \"refreshToken\"> &\n Omit<AuthContextType, \"isAuthenticated\">;\n\nconst UserContext = createContext<UserContextType | null>(null);\n\nconst UserProvider = <T extends EmptyObject>({\n children,\n storage,\n user: inputUser = null,\n signOut,\n signIn,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user?: User<T> | null;\n signOut: () => Promise<void>;\n signIn: (displayMode?: DisplayMode) => Promise<void>;\n}) => {\n const { error: authError, isLoading: authLoading } = useSession();\n const { data: session } = useSession();\n const tokens = useToken();\n const [userLoading, setUserLoading] = useState<boolean>(false);\n const [userError, setUserError] = useState<Error | null>(null);\n const [user, setUser] = useState<User | null>(null);\n\n const fetchUser = useCallback(async (): Promise<User | null> => {\n if (!session?.idToken) {\n return null;\n }\n const userSession = new GenericUserSession(storage);\n return userSession.get();\n }, [session?.idToken, storage]);\n\n useEffect(() => {\n if (!session?.idToken) {\n setUser(null);\n return;\n }\n if (session?.idToken) {\n setUserLoading(true);\n fetchUser()\n .then((user) => {\n setUserLoading(false);\n setUser(user);\n })\n .catch((error) => {\n setUserLoading(false);\n setUserError(error);\n });\n }\n }, [fetchUser, session?.idToken]);\n\n const isLoading = authLoading || userLoading;\n const error = authError || userError;\n\n return (\n <UserContext.Provider\n value={{\n ...tokens,\n user: (inputUser || user) ?? null,\n isLoading,\n error,\n signIn,\n signOut,\n }}\n >\n {children}\n </UserContext.Provider>\n );\n};\n\nexport type { UserContextType };\n\nexport { UserProvider, UserContext };\n"]}