@civic/auth 0.1.3 → 0.1.4-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (752) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/README.md +13 -10
  3. package/dist/cjs/browser/storage.d.ts +3 -0
  4. package/dist/cjs/browser/storage.d.ts.map +1 -1
  5. package/dist/cjs/browser/storage.js +8 -0
  6. package/dist/cjs/browser/storage.js.map +1 -1
  7. package/dist/cjs/lib/cookies.d.ts +2 -2
  8. package/dist/cjs/lib/cookies.d.ts.map +1 -1
  9. package/dist/cjs/lib/cookies.js +7 -5
  10. package/dist/cjs/lib/cookies.js.map +1 -1
  11. package/dist/cjs/lib/postMessage.js +1 -1
  12. package/dist/cjs/lib/postMessage.js.map +1 -1
  13. package/dist/cjs/lib/windowUtil.d.ts.map +1 -1
  14. package/dist/cjs/lib/windowUtil.js +1 -0
  15. package/dist/cjs/lib/windowUtil.js.map +1 -1
  16. package/dist/cjs/nextjs/GetUser.d.ts.map +1 -1
  17. package/dist/cjs/nextjs/GetUser.js +2 -13
  18. package/dist/cjs/nextjs/GetUser.js.map +1 -1
  19. package/dist/cjs/nextjs/config.d.ts.map +1 -1
  20. package/dist/cjs/nextjs/config.js +12 -0
  21. package/dist/cjs/nextjs/config.js.map +1 -1
  22. package/dist/cjs/nextjs/hooks/index.d.ts +1 -1
  23. package/dist/cjs/nextjs/hooks/index.d.ts.map +1 -1
  24. package/dist/cjs/nextjs/hooks/index.js +3 -3
  25. package/dist/cjs/nextjs/hooks/index.js.map +1 -1
  26. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts +4 -1
  27. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  28. package/dist/cjs/nextjs/hooks/useUserCookie.js +43 -15
  29. package/dist/cjs/nextjs/hooks/useUserCookie.js.map +1 -1
  30. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +5 -1
  31. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  32. package/dist/cjs/nextjs/providers/NextAuthProvider.js +74 -35
  33. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -1
  34. package/dist/cjs/nextjs/routeHandler.js +2 -2
  35. package/dist/cjs/nextjs/routeHandler.js.map +1 -1
  36. package/dist/cjs/reactjs/components/UserButton.js +20 -10
  37. package/dist/cjs/reactjs/components/UserButton.js.map +1 -1
  38. package/dist/cjs/reactjs/hooks/index.d.ts +0 -1
  39. package/dist/cjs/reactjs/hooks/index.d.ts.map +1 -1
  40. package/dist/cjs/reactjs/hooks/index.js +1 -3
  41. package/dist/cjs/reactjs/hooks/index.js.map +1 -1
  42. package/dist/cjs/services/AuthenticationService.d.ts +4 -1
  43. package/dist/cjs/services/AuthenticationService.d.ts.map +1 -1
  44. package/dist/cjs/services/AuthenticationService.js +38 -7
  45. package/dist/cjs/services/AuthenticationService.js.map +1 -1
  46. package/dist/cjs/shared/components/BlockDisplay.d.ts +7 -0
  47. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +1 -0
  48. package/dist/cjs/shared/components/BlockDisplay.js +31 -0
  49. package/dist/cjs/shared/components/BlockDisplay.js.map +1 -0
  50. package/dist/cjs/shared/components/CivicAuthIframe.js +18 -8
  51. package/dist/cjs/shared/components/CivicAuthIframe.js.map +1 -1
  52. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  53. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +39 -20
  54. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +1 -1
  55. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +7 -0
  56. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -0
  57. package/dist/cjs/shared/components/IFrameAndLoading.js +28 -0
  58. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -0
  59. package/dist/cjs/shared/hooks/index.d.ts +5 -1
  60. package/dist/cjs/shared/hooks/index.d.ts.map +1 -1
  61. package/dist/cjs/shared/hooks/index.js +11 -3
  62. package/dist/cjs/shared/hooks/index.js.map +1 -1
  63. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  64. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  65. package/dist/cjs/shared/hooks/useCivicAuthConfig.js +13 -0
  66. package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +1 -0
  67. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  68. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  69. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +16 -0
  70. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  71. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts +3 -0
  72. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  73. package/dist/cjs/shared/hooks/useCurrentUrl.js +27 -0
  74. package/dist/cjs/shared/hooks/useCurrentUrl.js.map +1 -0
  75. package/dist/cjs/shared/hooks/useIsInIframe.d.ts +3 -0
  76. package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +1 -0
  77. package/dist/cjs/shared/hooks/useIsInIframe.js +17 -0
  78. package/dist/cjs/shared/hooks/useIsInIframe.js.map +1 -0
  79. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  80. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  81. package/dist/cjs/shared/hooks/useOAuthEndpoints.js +17 -0
  82. package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +1 -0
  83. package/dist/cjs/shared/hooks/useRefresh.d.ts +4 -0
  84. package/dist/cjs/shared/hooks/useRefresh.d.ts.map +1 -0
  85. package/dist/cjs/shared/hooks/useRefresh.js +41 -0
  86. package/dist/cjs/shared/hooks/useRefresh.js.map +1 -0
  87. package/dist/cjs/shared/hooks/useSession.d.ts +1 -1
  88. package/dist/cjs/shared/hooks/useSession.d.ts.map +1 -1
  89. package/dist/cjs/shared/hooks/useSignIn.d.ts +14 -0
  90. package/dist/cjs/shared/hooks/useSignIn.d.ts.map +1 -0
  91. package/dist/cjs/shared/hooks/useSignIn.js +74 -0
  92. package/dist/cjs/shared/hooks/useSignIn.js.map +1 -0
  93. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  94. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  95. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +30 -0
  96. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  97. package/dist/cjs/shared/lib/session.d.ts +1 -1
  98. package/dist/cjs/shared/lib/session.d.ts.map +1 -1
  99. package/dist/cjs/shared/lib/session.js +12 -1
  100. package/dist/cjs/shared/lib/session.js.map +1 -1
  101. package/dist/cjs/shared/lib/types.d.ts +14 -1
  102. package/dist/cjs/shared/lib/types.d.ts.map +1 -1
  103. package/dist/cjs/shared/lib/types.js +2 -0
  104. package/dist/cjs/shared/lib/types.js.map +1 -1
  105. package/dist/cjs/shared/lib/util.d.ts.map +1 -1
  106. package/dist/cjs/shared/lib/util.js +28 -9
  107. package/dist/cjs/shared/lib/util.js.map +1 -1
  108. package/dist/cjs/shared/providers/AuthProvider.d.ts +3 -2
  109. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +1 -1
  110. package/dist/cjs/shared/providers/AuthProvider.js +53 -244
  111. package/dist/cjs/shared/providers/AuthProvider.js.map +1 -1
  112. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  113. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  114. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +80 -0
  115. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +1 -0
  116. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  117. package/dist/cjs/shared/providers/CivicAuthProvider.js +23 -6
  118. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +1 -1
  119. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  120. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  121. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +183 -0
  122. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  123. package/dist/cjs/shared/providers/IframeProvider.d.ts +7 -4
  124. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +1 -1
  125. package/dist/cjs/shared/providers/IframeProvider.js +37 -9
  126. package/dist/cjs/shared/providers/IframeProvider.js.map +1 -1
  127. package/dist/cjs/shared/providers/SessionProvider.d.ts +10 -4
  128. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +1 -1
  129. package/dist/cjs/shared/providers/SessionProvider.js +32 -12
  130. package/dist/cjs/shared/providers/SessionProvider.js.map +1 -1
  131. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -1
  132. package/dist/cjs/shared/providers/TokenProvider.js +29 -30
  133. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -1
  134. package/dist/cjs/shared/providers/UserProvider.d.ts +6 -4
  135. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -1
  136. package/dist/cjs/shared/providers/UserProvider.js +49 -26
  137. package/dist/cjs/shared/providers/UserProvider.js.map +1 -1
  138. package/dist/cjs/types.d.ts +5 -5
  139. package/dist/cjs/types.d.ts.map +1 -1
  140. package/dist/cjs/types.js +4 -0
  141. package/dist/cjs/types.js.map +1 -1
  142. package/dist/cjs/utils.d.ts.map +1 -1
  143. package/dist/esm/browser/storage.d.ts +3 -0
  144. package/dist/esm/browser/storage.d.ts.map +1 -1
  145. package/dist/esm/browser/storage.js +8 -0
  146. package/dist/esm/browser/storage.js.map +1 -1
  147. package/dist/esm/lib/cookies.d.ts +2 -2
  148. package/dist/esm/lib/cookies.d.ts.map +1 -1
  149. package/dist/esm/lib/cookies.js +7 -5
  150. package/dist/esm/lib/cookies.js.map +1 -1
  151. package/dist/esm/lib/postMessage.js +1 -1
  152. package/dist/esm/lib/postMessage.js.map +1 -1
  153. package/dist/esm/lib/windowUtil.d.ts.map +1 -1
  154. package/dist/esm/lib/windowUtil.js +1 -0
  155. package/dist/esm/lib/windowUtil.js.map +1 -1
  156. package/dist/esm/nextjs/GetUser.d.ts.map +1 -1
  157. package/dist/esm/nextjs/GetUser.js +2 -13
  158. package/dist/esm/nextjs/GetUser.js.map +1 -1
  159. package/dist/esm/nextjs/config.d.ts.map +1 -1
  160. package/dist/esm/nextjs/config.js +12 -0
  161. package/dist/esm/nextjs/config.js.map +1 -1
  162. package/dist/esm/nextjs/hooks/index.d.ts +1 -1
  163. package/dist/esm/nextjs/hooks/index.d.ts.map +1 -1
  164. package/dist/esm/nextjs/hooks/index.js +1 -1
  165. package/dist/esm/nextjs/hooks/index.js.map +1 -1
  166. package/dist/esm/nextjs/hooks/useUserCookie.d.ts +4 -1
  167. package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  168. package/dist/esm/nextjs/hooks/useUserCookie.js +45 -17
  169. package/dist/esm/nextjs/hooks/useUserCookie.js.map +1 -1
  170. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +5 -1
  171. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  172. package/dist/esm/nextjs/providers/NextAuthProvider.js +59 -30
  173. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -1
  174. package/dist/esm/nextjs/routeHandler.js +2 -2
  175. package/dist/esm/nextjs/routeHandler.js.map +1 -1
  176. package/dist/esm/reactjs/components/UserButton.js +3 -3
  177. package/dist/esm/reactjs/components/UserButton.js.map +1 -1
  178. package/dist/esm/reactjs/hooks/index.d.ts +0 -1
  179. package/dist/esm/reactjs/hooks/index.d.ts.map +1 -1
  180. package/dist/esm/reactjs/hooks/index.js +0 -1
  181. package/dist/esm/reactjs/hooks/index.js.map +1 -1
  182. package/dist/esm/services/AuthenticationService.d.ts +4 -1
  183. package/dist/esm/services/AuthenticationService.d.ts.map +1 -1
  184. package/dist/esm/services/AuthenticationService.js +39 -8
  185. package/dist/esm/services/AuthenticationService.js.map +1 -1
  186. package/dist/esm/shared/components/BlockDisplay.d.ts +7 -0
  187. package/dist/esm/shared/components/BlockDisplay.d.ts.map +1 -0
  188. package/dist/esm/shared/components/BlockDisplay.js +25 -0
  189. package/dist/esm/shared/components/BlockDisplay.js.map +1 -0
  190. package/dist/esm/shared/components/CivicAuthIframe.js +1 -1
  191. package/dist/esm/shared/components/CivicAuthIframe.js.map +1 -1
  192. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  193. package/dist/esm/shared/components/CivicAuthIframeContainer.js +23 -14
  194. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +1 -1
  195. package/dist/esm/shared/components/IFrameAndLoading.d.ts +7 -0
  196. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -0
  197. package/dist/esm/shared/components/IFrameAndLoading.js +22 -0
  198. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -0
  199. package/dist/esm/shared/hooks/index.d.ts +5 -1
  200. package/dist/esm/shared/hooks/index.d.ts.map +1 -1
  201. package/dist/esm/shared/hooks/index.js +5 -1
  202. package/dist/esm/shared/hooks/index.js.map +1 -1
  203. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  204. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  205. package/dist/esm/shared/hooks/useCivicAuthConfig.js +10 -0
  206. package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +1 -0
  207. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  208. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  209. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +13 -0
  210. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  211. package/dist/esm/shared/hooks/useCurrentUrl.d.ts +3 -0
  212. package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  213. package/dist/esm/shared/hooks/useCurrentUrl.js +24 -0
  214. package/dist/esm/shared/hooks/useCurrentUrl.js.map +1 -0
  215. package/dist/esm/shared/hooks/useIsInIframe.d.ts +3 -0
  216. package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +1 -0
  217. package/dist/esm/shared/hooks/useIsInIframe.js +14 -0
  218. package/dist/esm/shared/hooks/useIsInIframe.js.map +1 -0
  219. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  220. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  221. package/dist/esm/shared/hooks/useOAuthEndpoints.js +14 -0
  222. package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +1 -0
  223. package/dist/esm/shared/hooks/useRefresh.d.ts +4 -0
  224. package/dist/esm/shared/hooks/useRefresh.d.ts.map +1 -0
  225. package/dist/esm/shared/hooks/useRefresh.js +38 -0
  226. package/dist/esm/shared/hooks/useRefresh.js.map +1 -0
  227. package/dist/esm/shared/hooks/useSession.d.ts +1 -1
  228. package/dist/esm/shared/hooks/useSession.d.ts.map +1 -1
  229. package/dist/esm/shared/hooks/useSignIn.d.ts +14 -0
  230. package/dist/esm/shared/hooks/useSignIn.d.ts.map +1 -0
  231. package/dist/esm/shared/hooks/useSignIn.js +71 -0
  232. package/dist/esm/shared/hooks/useSignIn.js.map +1 -0
  233. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  234. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  235. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js +30 -0
  236. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  237. package/dist/esm/shared/lib/session.d.ts +1 -1
  238. package/dist/esm/shared/lib/session.d.ts.map +1 -1
  239. package/dist/esm/shared/lib/session.js +12 -1
  240. package/dist/esm/shared/lib/session.js.map +1 -1
  241. package/dist/esm/shared/lib/types.d.ts +14 -1
  242. package/dist/esm/shared/lib/types.d.ts.map +1 -1
  243. package/dist/esm/shared/lib/types.js +2 -0
  244. package/dist/esm/shared/lib/types.js.map +1 -1
  245. package/dist/esm/shared/lib/util.d.ts.map +1 -1
  246. package/dist/esm/shared/lib/util.js +11 -2
  247. package/dist/esm/shared/lib/util.js.map +1 -1
  248. package/dist/esm/shared/providers/AuthProvider.d.ts +3 -2
  249. package/dist/esm/shared/providers/AuthProvider.d.ts.map +1 -1
  250. package/dist/esm/shared/providers/AuthProvider.js +37 -238
  251. package/dist/esm/shared/providers/AuthProvider.js.map +1 -1
  252. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  253. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  254. package/dist/esm/shared/providers/CivicAuthConfigContext.js +43 -0
  255. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +1 -0
  256. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  257. package/dist/esm/shared/providers/CivicAuthProvider.js +23 -6
  258. package/dist/esm/shared/providers/CivicAuthProvider.js.map +1 -1
  259. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  260. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  261. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +146 -0
  262. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  263. package/dist/esm/shared/providers/IframeProvider.d.ts +7 -4
  264. package/dist/esm/shared/providers/IframeProvider.d.ts.map +1 -1
  265. package/dist/esm/shared/providers/IframeProvider.js +21 -3
  266. package/dist/esm/shared/providers/IframeProvider.js.map +1 -1
  267. package/dist/esm/shared/providers/SessionProvider.d.ts +10 -4
  268. package/dist/esm/shared/providers/SessionProvider.d.ts.map +1 -1
  269. package/dist/esm/shared/providers/SessionProvider.js +15 -5
  270. package/dist/esm/shared/providers/SessionProvider.js.map +1 -1
  271. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -1
  272. package/dist/esm/shared/providers/TokenProvider.js +13 -24
  273. package/dist/esm/shared/providers/TokenProvider.js.map +1 -1
  274. package/dist/esm/shared/providers/UserProvider.d.ts +6 -4
  275. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -1
  276. package/dist/esm/shared/providers/UserProvider.js +33 -20
  277. package/dist/esm/shared/providers/UserProvider.js.map +1 -1
  278. package/dist/esm/types.d.ts +5 -5
  279. package/dist/esm/types.d.ts.map +1 -1
  280. package/dist/esm/types.js +3 -1
  281. package/dist/esm/types.js.map +1 -1
  282. package/dist/esm/utils.d.ts.map +1 -1
  283. package/dist/src/browser/storage.d.ts +3 -0
  284. package/dist/src/browser/storage.d.ts.map +1 -1
  285. package/dist/src/browser/storage.js +8 -0
  286. package/dist/src/browser/storage.js.map +1 -1
  287. package/dist/src/lib/cookies.d.ts +2 -2
  288. package/dist/src/lib/cookies.d.ts.map +1 -1
  289. package/dist/src/lib/cookies.js +7 -5
  290. package/dist/src/lib/cookies.js.map +1 -1
  291. package/dist/src/lib/postMessage.js +1 -1
  292. package/dist/src/lib/postMessage.js.map +1 -1
  293. package/dist/src/lib/windowUtil.d.ts.map +1 -1
  294. package/dist/src/lib/windowUtil.js +1 -0
  295. package/dist/src/lib/windowUtil.js.map +1 -1
  296. package/dist/src/nextjs/GetUser.d.ts.map +1 -1
  297. package/dist/src/nextjs/GetUser.js +2 -13
  298. package/dist/src/nextjs/GetUser.js.map +1 -1
  299. package/dist/src/nextjs/config.d.ts.map +1 -1
  300. package/dist/src/nextjs/config.js +12 -0
  301. package/dist/src/nextjs/config.js.map +1 -1
  302. package/dist/src/nextjs/hooks/index.d.ts +1 -1
  303. package/dist/src/nextjs/hooks/index.d.ts.map +1 -1
  304. package/dist/src/nextjs/hooks/index.js +1 -1
  305. package/dist/src/nextjs/hooks/index.js.map +1 -1
  306. package/dist/src/nextjs/hooks/useRefresh.d.ts +4 -0
  307. package/dist/src/nextjs/hooks/useRefresh.d.ts.map +1 -0
  308. package/dist/src/nextjs/hooks/useRefresh.js +38 -0
  309. package/dist/src/nextjs/hooks/useRefresh.js.map +1 -0
  310. package/dist/src/nextjs/hooks/useUserCookie.d.ts +4 -1
  311. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  312. package/dist/src/nextjs/hooks/useUserCookie.js +45 -17
  313. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -1
  314. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +5 -1
  315. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  316. package/dist/src/nextjs/providers/NextAuthProvider.js +59 -30
  317. package/dist/src/nextjs/providers/NextAuthProvider.js.map +1 -1
  318. package/dist/src/nextjs/routeHandler.js +2 -2
  319. package/dist/src/nextjs/routeHandler.js.map +1 -1
  320. package/dist/src/reactjs/components/UserButton.js +3 -3
  321. package/dist/src/reactjs/components/UserButton.js.map +1 -1
  322. package/dist/src/reactjs/hooks/index.d.ts +0 -1
  323. package/dist/src/reactjs/hooks/index.d.ts.map +1 -1
  324. package/dist/src/reactjs/hooks/index.js +0 -1
  325. package/dist/src/reactjs/hooks/index.js.map +1 -1
  326. package/dist/src/reactjs/hooks/useRefresh.d.ts +4 -0
  327. package/dist/src/reactjs/hooks/useRefresh.d.ts.map +1 -0
  328. package/dist/src/reactjs/hooks/useRefresh.js +28 -0
  329. package/dist/src/reactjs/hooks/useRefresh.js.map +1 -0
  330. package/dist/src/services/AuthenticationService.d.ts +4 -1
  331. package/dist/src/services/AuthenticationService.d.ts.map +1 -1
  332. package/dist/src/services/AuthenticationService.js +39 -8
  333. package/dist/src/services/AuthenticationService.js.map +1 -1
  334. package/dist/src/shared/components/BlockDisplay.d.ts +7 -0
  335. package/dist/src/shared/components/BlockDisplay.d.ts.map +1 -0
  336. package/dist/src/shared/components/BlockDisplay.js +25 -0
  337. package/dist/src/shared/components/BlockDisplay.js.map +1 -0
  338. package/dist/src/shared/components/CivicAuthIframe.js +1 -1
  339. package/dist/src/shared/components/CivicAuthIframe.js.map +1 -1
  340. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  341. package/dist/src/shared/components/CivicAuthIframeContainer.js +23 -14
  342. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +1 -1
  343. package/dist/src/shared/components/IFrameAndLoading.d.ts +7 -0
  344. package/dist/src/shared/components/IFrameAndLoading.d.ts.map +1 -0
  345. package/dist/src/shared/components/IFrameAndLoading.js +22 -0
  346. package/dist/src/shared/components/IFrameAndLoading.js.map +1 -0
  347. package/dist/src/shared/hooks/index.d.ts +5 -1
  348. package/dist/src/shared/hooks/index.d.ts.map +1 -1
  349. package/dist/src/shared/hooks/index.js +5 -1
  350. package/dist/src/shared/hooks/index.js.map +1 -1
  351. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  352. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  353. package/dist/src/shared/hooks/useCivicAuthConfig.js +10 -0
  354. package/dist/src/shared/hooks/useCivicAuthConfig.js.map +1 -0
  355. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  356. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  357. package/dist/src/shared/hooks/useClientTokenExchangeSession.js +13 -0
  358. package/dist/src/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  359. package/dist/src/shared/hooks/useCurrentUrl.d.ts +3 -0
  360. package/dist/src/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  361. package/dist/src/shared/hooks/useCurrentUrl.js +24 -0
  362. package/dist/src/shared/hooks/useCurrentUrl.js.map +1 -0
  363. package/dist/src/shared/hooks/useIsInIframe.d.ts +3 -0
  364. package/dist/src/shared/hooks/useIsInIframe.d.ts.map +1 -0
  365. package/dist/src/shared/hooks/useIsInIframe.js +14 -0
  366. package/dist/src/shared/hooks/useIsInIframe.js.map +1 -0
  367. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  368. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  369. package/dist/src/shared/hooks/useOAuthEndpoints.js +14 -0
  370. package/dist/src/shared/hooks/useOAuthEndpoints.js.map +1 -0
  371. package/dist/src/shared/hooks/useRefresh.d.ts +4 -0
  372. package/dist/src/shared/hooks/useRefresh.d.ts.map +1 -0
  373. package/dist/src/shared/hooks/useRefresh.js +38 -0
  374. package/dist/src/shared/hooks/useRefresh.js.map +1 -0
  375. package/dist/src/shared/hooks/useSession.d.ts +1 -1
  376. package/dist/src/shared/hooks/useSession.d.ts.map +1 -1
  377. package/dist/src/shared/hooks/useSignIn.d.ts +14 -0
  378. package/dist/src/shared/hooks/useSignIn.d.ts.map +1 -0
  379. package/dist/src/shared/hooks/useSignIn.js +71 -0
  380. package/dist/src/shared/hooks/useSignIn.js.map +1 -0
  381. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  382. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  383. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +30 -0
  384. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  385. package/dist/src/shared/lib/session.d.ts +1 -1
  386. package/dist/src/shared/lib/session.d.ts.map +1 -1
  387. package/dist/src/shared/lib/session.js +12 -1
  388. package/dist/src/shared/lib/session.js.map +1 -1
  389. package/dist/src/shared/lib/types.d.ts +14 -1
  390. package/dist/src/shared/lib/types.d.ts.map +1 -1
  391. package/dist/src/shared/lib/types.js +2 -0
  392. package/dist/src/shared/lib/types.js.map +1 -1
  393. package/dist/src/shared/lib/util.d.ts.map +1 -1
  394. package/dist/src/shared/lib/util.js +11 -2
  395. package/dist/src/shared/lib/util.js.map +1 -1
  396. package/dist/src/shared/providers/AuthProvider.d.ts +3 -2
  397. package/dist/src/shared/providers/AuthProvider.d.ts.map +1 -1
  398. package/dist/src/shared/providers/AuthProvider.js +37 -238
  399. package/dist/src/shared/providers/AuthProvider.js.map +1 -1
  400. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  401. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  402. package/dist/src/shared/providers/CivicAuthConfigContext.js +43 -0
  403. package/dist/src/shared/providers/CivicAuthConfigContext.js.map +1 -0
  404. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  405. package/dist/src/shared/providers/CivicAuthProvider.js +23 -6
  406. package/dist/src/shared/providers/CivicAuthProvider.js.map +1 -1
  407. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  408. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  409. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js +146 -0
  410. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  411. package/dist/src/shared/providers/IframeProvider.d.ts +7 -4
  412. package/dist/src/shared/providers/IframeProvider.d.ts.map +1 -1
  413. package/dist/src/shared/providers/IframeProvider.js +21 -3
  414. package/dist/src/shared/providers/IframeProvider.js.map +1 -1
  415. package/dist/src/shared/providers/SessionProvider.d.ts +10 -4
  416. package/dist/src/shared/providers/SessionProvider.d.ts.map +1 -1
  417. package/dist/src/shared/providers/SessionProvider.js +15 -5
  418. package/dist/src/shared/providers/SessionProvider.js.map +1 -1
  419. package/dist/src/shared/providers/TokenProvider.d.ts.map +1 -1
  420. package/dist/src/shared/providers/TokenProvider.js +13 -24
  421. package/dist/src/shared/providers/TokenProvider.js.map +1 -1
  422. package/dist/src/shared/providers/UserProvider.d.ts +6 -4
  423. package/dist/src/shared/providers/UserProvider.d.ts.map +1 -1
  424. package/dist/src/shared/providers/UserProvider.js +33 -20
  425. package/dist/src/shared/providers/UserProvider.js.map +1 -1
  426. package/dist/src/types.d.ts +5 -5
  427. package/dist/src/types.d.ts.map +1 -1
  428. package/dist/src/types.js +3 -1
  429. package/dist/src/types.js.map +1 -1
  430. package/dist/test/integration/sdk.test.d.ts.map +1 -1
  431. package/dist/test/integration/sdk.test.js +39 -33
  432. package/dist/test/integration/sdk.test.js.map +1 -1
  433. package/dist/test/unit/nextjs/NextAuthProvider.test.js +8 -6
  434. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +1 -1
  435. package/dist/test/unit/nextjs/getUser.test.js +2 -16
  436. package/dist/test/unit/nextjs/getUser.test.js.map +1 -1
  437. package/dist/test/unit/server/refresh.test.d.ts.map +1 -0
  438. package/dist/test/unit/services/AuthenticationService.test.js +18 -1
  439. package/dist/test/unit/services/AuthenticationService.test.js.map +1 -1
  440. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +12 -10
  441. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +1 -1
  442. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  443. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  444. package/dist/tsconfig.tsbuildinfo +1 -1
  445. package/package.json +7 -1
  446. package/.eslintignore +0 -3
  447. package/.eslintrc.json +0 -10
  448. package/.prettierignore +0 -3
  449. package/.prettierrc +0 -1
  450. package/.turbo/turbo-build.log +0 -13
  451. package/.turbo/turbo-lint$colon$fix.log +0 -10
  452. package/.turbo/turbo-test.log +0 -1153
  453. package/dist/cjs/nextjs/hooks/useTokenCookie.d.ts +0 -3
  454. package/dist/cjs/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  455. package/dist/cjs/nextjs/hooks/useTokenCookie.js +0 -41
  456. package/dist/cjs/nextjs/hooks/useTokenCookie.js.map +0 -1
  457. package/dist/cjs/shared/hooks/useConfig.d.ts +0 -3
  458. package/dist/cjs/shared/hooks/useConfig.d.ts.map +0 -1
  459. package/dist/cjs/shared/hooks/useConfig.js +0 -16
  460. package/dist/cjs/shared/hooks/useConfig.js.map +0 -1
  461. package/dist/cjs/shared/providers/ConfigProvider.d.ts +0 -21
  462. package/dist/cjs/shared/providers/ConfigProvider.d.ts.map +0 -1
  463. package/dist/cjs/shared/providers/ConfigProvider.js +0 -46
  464. package/dist/cjs/shared/providers/ConfigProvider.js.map +0 -1
  465. package/dist/esm/nextjs/hooks/useTokenCookie.d.ts +0 -3
  466. package/dist/esm/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  467. package/dist/esm/nextjs/hooks/useTokenCookie.js +0 -37
  468. package/dist/esm/nextjs/hooks/useTokenCookie.js.map +0 -1
  469. package/dist/esm/shared/hooks/useConfig.d.ts +0 -3
  470. package/dist/esm/shared/hooks/useConfig.d.ts.map +0 -1
  471. package/dist/esm/shared/hooks/useConfig.js +0 -13
  472. package/dist/esm/shared/hooks/useConfig.js.map +0 -1
  473. package/dist/esm/shared/providers/ConfigProvider.d.ts +0 -21
  474. package/dist/esm/shared/providers/ConfigProvider.d.ts.map +0 -1
  475. package/dist/esm/shared/providers/ConfigProvider.js +0 -19
  476. package/dist/esm/shared/providers/ConfigProvider.js.map +0 -1
  477. package/dist/src/config.d.ts +0 -3
  478. package/dist/src/config.js +0 -5
  479. package/dist/src/config.js.map +0 -1
  480. package/dist/src/constants.d.ts +0 -9
  481. package/dist/src/constants.d.ts.map +0 -1
  482. package/dist/src/constants.js +0 -17
  483. package/dist/src/constants.js.map +0 -1
  484. package/dist/src/index.d.ts +0 -4
  485. package/dist/src/index.js +0 -2
  486. package/dist/src/index.js.map +0 -1
  487. package/dist/src/lib/jwt.d.ts +0 -3
  488. package/dist/src/lib/jwt.js +0 -9
  489. package/dist/src/lib/jwt.js.map +0 -1
  490. package/dist/src/lib/logger.d.ts +0 -26
  491. package/dist/src/lib/logger.d.ts.map +0 -1
  492. package/dist/src/lib/logger.js +0 -55
  493. package/dist/src/lib/logger.js.map +0 -1
  494. package/dist/src/lib/oauth.d.ts +0 -19
  495. package/dist/src/lib/oauth.js +0 -60
  496. package/dist/src/lib/oauth.js.map +0 -1
  497. package/dist/src/lib/postMessage.d.ts +0 -4
  498. package/dist/src/lib/windowUtil.d.ts +0 -4
  499. package/dist/src/nextjs/GetUser.d.ts +0 -6
  500. package/dist/src/nextjs/config.d.ts +0 -178
  501. package/dist/src/nextjs/cookies.d.ts +0 -30
  502. package/dist/src/nextjs/cookies.js +0 -112
  503. package/dist/src/nextjs/cookies.js.map +0 -1
  504. package/dist/src/nextjs/index.d.ts +0 -7
  505. package/dist/src/nextjs/index.js +0 -6
  506. package/dist/src/nextjs/index.js.map +0 -1
  507. package/dist/src/nextjs/middleware/index.d.ts +0 -2
  508. package/dist/src/nextjs/middleware/index.js +0 -2
  509. package/dist/src/nextjs/middleware/index.js.map +0 -1
  510. package/dist/src/nextjs/middleware.d.ts +0 -59
  511. package/dist/src/nextjs/middleware.js +0 -107
  512. package/dist/src/nextjs/middleware.js.map +0 -1
  513. package/dist/src/nextjs/routeHandler.d.ts +0 -18
  514. package/dist/src/nextjs/utils.d.ts +0 -3
  515. package/dist/src/nextjs/utils.js +0 -5
  516. package/dist/src/nextjs/utils.js.map +0 -1
  517. package/dist/src/reactjs/components/SignInButton.d.ts +0 -8
  518. package/dist/src/reactjs/components/SignInButton.js +0 -14
  519. package/dist/src/reactjs/components/SignInButton.js.map +0 -1
  520. package/dist/src/reactjs/components/SignOutButton.d.ts +0 -6
  521. package/dist/src/reactjs/components/SignOutButton.js +0 -14
  522. package/dist/src/reactjs/components/SignOutButton.js.map +0 -1
  523. package/dist/src/reactjs/components/UserButton.d.ts +0 -8
  524. package/dist/src/reactjs/components/index.d.ts +0 -6
  525. package/dist/src/reactjs/components/index.js +0 -6
  526. package/dist/src/reactjs/components/index.js.map +0 -1
  527. package/dist/src/reactjs/hooks/useAuth.d.ts +0 -3
  528. package/dist/src/reactjs/hooks/useAuth.js +0 -12
  529. package/dist/src/reactjs/hooks/useAuth.js.map +0 -1
  530. package/dist/src/reactjs/hooks/useUser.d.ts +0 -4
  531. package/dist/src/reactjs/hooks/useUser.js +0 -12
  532. package/dist/src/reactjs/hooks/useUser.js.map +0 -1
  533. package/dist/src/reactjs/index.d.ts +0 -6
  534. package/dist/src/reactjs/index.js +0 -8
  535. package/dist/src/reactjs/index.js.map +0 -1
  536. package/dist/src/reactjs/providers/index.d.ts +0 -8
  537. package/dist/src/reactjs/providers/index.js +0 -7
  538. package/dist/src/reactjs/providers/index.js.map +0 -1
  539. package/dist/src/server/ServerAuthenticationResolver.d.ts +0 -19
  540. package/dist/src/server/ServerAuthenticationResolver.js +0 -61
  541. package/dist/src/server/ServerAuthenticationResolver.js.map +0 -1
  542. package/dist/src/server/config.d.ts +0 -9
  543. package/dist/src/server/config.js +0 -2
  544. package/dist/src/server/config.js.map +0 -1
  545. package/dist/src/server/index.d.ts +0 -7
  546. package/dist/src/server/index.js +0 -5
  547. package/dist/src/server/index.js.map +0 -1
  548. package/dist/src/server/login.d.ts +0 -17
  549. package/dist/src/server/login.js +0 -37
  550. package/dist/src/server/login.js.map +0 -1
  551. package/dist/src/server/refresh.d.ts +0 -7
  552. package/dist/src/server/refresh.js +0 -13
  553. package/dist/src/server/refresh.js.map +0 -1
  554. package/dist/src/services/PKCE.d.ts +0 -20
  555. package/dist/src/services/PKCE.js +0 -44
  556. package/dist/src/services/PKCE.js.map +0 -1
  557. package/dist/src/services/types.d.ts +0 -23
  558. package/dist/src/services/types.js +0 -7
  559. package/dist/src/services/types.js.map +0 -1
  560. package/dist/src/shared/components/CivicAuthIframe.d.ts +0 -8
  561. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts +0 -9
  562. package/dist/src/shared/components/CloseIcon.d.ts +0 -4
  563. package/dist/src/shared/components/CloseIcon.d.ts.map +0 -1
  564. package/dist/src/shared/components/CloseIcon.js +0 -6
  565. package/dist/src/shared/components/CloseIcon.js.map +0 -1
  566. package/dist/src/shared/components/LoadingIcon.d.ts +0 -4
  567. package/dist/src/shared/components/LoadingIcon.d.ts.map +0 -1
  568. package/dist/src/shared/components/LoadingIcon.js +0 -30
  569. package/dist/src/shared/components/LoadingIcon.js.map +0 -1
  570. package/dist/src/shared/hooks/useAuth.d.ts +0 -3
  571. package/dist/src/shared/hooks/useAuth.js +0 -12
  572. package/dist/src/shared/hooks/useAuth.js.map +0 -1
  573. package/dist/src/shared/hooks/useIframe.d.ts +0 -3
  574. package/dist/src/shared/hooks/useIframe.js +0 -13
  575. package/dist/src/shared/hooks/useIframe.js.map +0 -1
  576. package/dist/src/shared/hooks/useSession.js +0 -13
  577. package/dist/src/shared/hooks/useSession.js.map +0 -1
  578. package/dist/src/shared/hooks/useToken.d.ts +0 -3
  579. package/dist/src/shared/hooks/useToken.js +0 -12
  580. package/dist/src/shared/hooks/useToken.js.map +0 -1
  581. package/dist/src/shared/lib/UserSession.d.ts +0 -12
  582. package/dist/src/shared/lib/UserSession.js +0 -20
  583. package/dist/src/shared/lib/UserSession.js.map +0 -1
  584. package/dist/src/shared/lib/storage.d.ts +0 -25
  585. package/dist/src/shared/lib/storage.js +0 -17
  586. package/dist/src/shared/lib/storage.js.map +0 -1
  587. package/dist/src/shared/lib/util.d.ts +0 -33
  588. package/dist/src/shared/providers/AuthContext.d.ts +0 -10
  589. package/dist/src/shared/providers/AuthContext.js +0 -3
  590. package/dist/src/shared/providers/AuthContext.js.map +0 -1
  591. package/dist/src/shared/providers/CivicAuthProvider.d.ts +0 -6
  592. package/dist/src/shared/providers/TokenProvider.d.ts +0 -18
  593. package/dist/src/utils.d.ts +0 -15
  594. package/dist/src/utils.d.ts.map +0 -1
  595. package/dist/src/utils.js +0 -43
  596. package/dist/src/utils.js.map +0 -1
  597. package/dist/test/integration/sdk.test.d.ts +0 -2
  598. package/dist/test/support/fixtures.d.ts +0 -26
  599. package/dist/test/support/fixtures.d.ts.map +0 -1
  600. package/dist/test/support/fixtures.js +0 -55
  601. package/dist/test/support/fixtures.js.map +0 -1
  602. package/dist/test/support/tokens.json +0 -26
  603. package/dist/test/unit/lib/oauth.test.d.ts +0 -2
  604. package/dist/test/unit/lib/oauth.test.js +0 -55
  605. package/dist/test/unit/lib/oauth.test.js.map +0 -1
  606. package/dist/test/unit/logger.test.d.ts +0 -2
  607. package/dist/test/unit/logger.test.d.ts.map +0 -1
  608. package/dist/test/unit/logger.test.js +0 -141
  609. package/dist/test/unit/logger.test.js.map +0 -1
  610. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +0 -2
  611. package/dist/test/unit/nextjs/config.test.d.ts +0 -2
  612. package/dist/test/unit/nextjs/config.test.js +0 -189
  613. package/dist/test/unit/nextjs/config.test.js.map +0 -1
  614. package/dist/test/unit/nextjs/getUser.test.d.ts +0 -2
  615. package/dist/test/unit/nextjs/middleware.test.d.ts +0 -2
  616. package/dist/test/unit/nextjs/middleware.test.js +0 -113
  617. package/dist/test/unit/nextjs/middleware.test.js.map +0 -1
  618. package/dist/test/unit/nextjs/utils.test.d.ts +0 -2
  619. package/dist/test/unit/nextjs/utils.test.js +0 -13
  620. package/dist/test/unit/nextjs/utils.test.js.map +0 -1
  621. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +0 -2
  622. package/dist/test/unit/publicApi/apiSnapshot.test.js +0 -10
  623. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +0 -1
  624. package/dist/test/unit/react/components/SignInButton.test.d.ts +0 -2
  625. package/dist/test/unit/react/components/SignInButton.test.js +0 -31
  626. package/dist/test/unit/react/components/SignInButton.test.js.map +0 -1
  627. package/dist/test/unit/react/components/SignOutButton.test.d.ts +0 -2
  628. package/dist/test/unit/react/components/SignOutButton.test.js +0 -30
  629. package/dist/test/unit/react/components/SignOutButton.test.js.map +0 -1
  630. package/dist/test/unit/server/login.test.d.ts +0 -2
  631. package/dist/test/unit/server/login.test.js +0 -127
  632. package/dist/test/unit/server/login.test.js.map +0 -1
  633. package/dist/test/unit/server/session.test.d.ts +0 -2
  634. package/dist/test/unit/server/session.test.js +0 -41
  635. package/dist/test/unit/server/session.test.js.map +0 -1
  636. package/dist/test/unit/services/AuthenticationService.test.d.ts +0 -2
  637. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +0 -2
  638. package/dist/test/unit/services/ServerAuthenticationResolver.test.js +0 -74
  639. package/dist/test/unit/services/ServerAuthenticationResolver.test.js.map +0 -1
  640. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +0 -2
  641. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js +0 -61
  642. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js.map +0 -1
  643. package/dist/test/unit/shared/UserSession.test.d.ts +0 -2
  644. package/dist/test/unit/shared/UserSession.test.js +0 -37
  645. package/dist/test/unit/shared/UserSession.test.js.map +0 -1
  646. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +0 -2
  647. package/dist/test/unit/shared/storage.test.d.ts +0 -2
  648. package/dist/test/unit/shared/storage.test.js +0 -53
  649. package/dist/test/unit/shared/storage.test.js.map +0 -1
  650. package/dist/test/unit/utils.test.d.ts +0 -2
  651. package/dist/test/unit/utils.test.d.ts.map +0 -1
  652. package/dist/test/unit/utils.test.js +0 -40
  653. package/dist/test/unit/utils.test.js.map +0 -1
  654. package/dist/vitest.config.d.ts +0 -3
  655. package/dist/vitest.config.d.ts.map +0 -1
  656. package/dist/vitest.config.js +0 -40
  657. package/dist/vitest.config.js.map +0 -1
  658. package/src/browser/storage.ts +0 -11
  659. package/src/config.ts +0 -6
  660. package/src/constants.ts +0 -29
  661. package/src/index.ts +0 -16
  662. package/src/lib/cookies.ts +0 -28
  663. package/src/lib/jwt.ts +0 -15
  664. package/src/lib/logger.ts +0 -72
  665. package/src/lib/oauth.ts +0 -83
  666. package/src/lib/postMessage.ts +0 -22
  667. package/src/lib/windowUtil.ts +0 -29
  668. package/src/nextjs/GetUser.ts +0 -22
  669. package/src/nextjs/config.ts +0 -203
  670. package/src/nextjs/cookies.ts +0 -162
  671. package/src/nextjs/hooks/index.ts +0 -1
  672. package/src/nextjs/hooks/useTokenCookie.ts +0 -41
  673. package/src/nextjs/hooks/useUserCookie.ts +0 -41
  674. package/src/nextjs/index.ts +0 -20
  675. package/src/nextjs/middleware/index.ts +0 -1
  676. package/src/nextjs/middleware.ts +0 -155
  677. package/src/nextjs/providers/NextAuthProvider.tsx +0 -87
  678. package/src/nextjs/routeHandler.ts +0 -297
  679. package/src/nextjs/utils.ts +0 -9
  680. package/src/reactjs/components/SignInButton.tsx +0 -32
  681. package/src/reactjs/components/SignOutButton.tsx +0 -24
  682. package/src/reactjs/components/UserButton.tsx +0 -239
  683. package/src/reactjs/components/index.ts +0 -5
  684. package/src/reactjs/hooks/index.ts +0 -6
  685. package/src/reactjs/hooks/useAuth.ts +0 -15
  686. package/src/reactjs/hooks/useUser.ts +0 -20
  687. package/src/reactjs/index.ts +0 -19
  688. package/src/reactjs/providers/index.ts +0 -27
  689. package/src/server/ServerAuthenticationResolver.ts +0 -107
  690. package/src/server/config.ts +0 -9
  691. package/src/server/index.ts +0 -13
  692. package/src/server/login.ts +0 -59
  693. package/src/server/refresh.ts +0 -23
  694. package/src/services/AuthenticationService.ts +0 -329
  695. package/src/services/PKCE.ts +0 -45
  696. package/src/services/types.ts +0 -54
  697. package/src/shared/components/CivicAuthIframe.tsx +0 -26
  698. package/src/shared/components/CivicAuthIframeContainer.tsx +0 -195
  699. package/src/shared/components/CloseIcon.tsx +0 -21
  700. package/src/shared/components/LoadingIcon.tsx +0 -53
  701. package/src/shared/hooks/index.ts +0 -4
  702. package/src/shared/hooks/useAuth.ts +0 -15
  703. package/src/shared/hooks/useConfig.ts +0 -14
  704. package/src/shared/hooks/useIframe.ts +0 -14
  705. package/src/shared/hooks/useSession.ts +0 -14
  706. package/src/shared/hooks/useToken.ts +0 -15
  707. package/src/shared/lib/GenericAuthenticationRefresher.ts +0 -75
  708. package/src/shared/lib/UserSession.ts +0 -25
  709. package/src/shared/lib/session.ts +0 -11
  710. package/src/shared/lib/storage.ts +0 -40
  711. package/src/shared/lib/types.ts +0 -26
  712. package/src/shared/lib/util.ts +0 -212
  713. package/src/shared/providers/AuthContext.tsx +0 -11
  714. package/src/shared/providers/AuthProvider.tsx +0 -397
  715. package/src/shared/providers/CivicAuthProvider.tsx +0 -31
  716. package/src/shared/providers/ConfigProvider.tsx +0 -50
  717. package/src/shared/providers/IframeProvider.tsx +0 -34
  718. package/src/shared/providers/SessionProvider.tsx +0 -29
  719. package/src/shared/providers/TokenProvider.tsx +0 -78
  720. package/src/shared/providers/UserProvider.tsx +0 -80
  721. package/src/types.ts +0 -227
  722. package/src/utils.ts +0 -58
  723. package/test/integration/sdk.test.tsx +0 -266
  724. package/test/support/fixtures.ts +0 -56
  725. package/test/support/tokens.json +0 -26
  726. package/test/unit/lib/oauth.test.ts +0 -72
  727. package/test/unit/logger.test.ts +0 -175
  728. package/test/unit/nextjs/NextAuthProvider.test.tsx +0 -38
  729. package/test/unit/nextjs/config.test.ts +0 -218
  730. package/test/unit/nextjs/getUser.test.ts +0 -41
  731. package/test/unit/nextjs/middleware.test.ts +0 -138
  732. package/test/unit/nextjs/routeHandler.test.ts.skipped +0 -369
  733. package/test/unit/nextjs/utils.test.ts +0 -17
  734. package/test/unit/publicApi/__snapshots__/apiSnapshot.test.ts.snap +0 -17
  735. package/test/unit/publicApi/apiSnapshot.test.ts +0 -11
  736. package/test/unit/react/components/SignInButton.test.tsx +0 -50
  737. package/test/unit/react/components/SignOutButton.test.tsx +0 -49
  738. package/test/unit/server/login.test.ts +0 -181
  739. package/test/unit/server/session.test.ts +0 -51
  740. package/test/unit/services/AuthenticationService.test.ts +0 -152
  741. package/test/unit/services/ServerAuthenticationResolver.test.ts +0 -115
  742. package/test/unit/shared/GenericAuthenticationRefresher.test.ts +0 -89
  743. package/test/unit/shared/UserSession.test.ts +0 -42
  744. package/test/unit/shared/components/CivicAuthIframeContainer.test.tsx +0 -154
  745. package/test/unit/shared/storage.test.ts +0 -67
  746. package/test/unit/utils.test.ts +0 -48
  747. package/tsconfig.build.json +0 -9
  748. package/tsconfig.cjs.json +0 -8
  749. package/tsconfig.esm.json +0 -7
  750. package/tsconfig.json +0 -42
  751. package/tsconfig.tsbuildinfo +0 -1
  752. package/vitest.config.ts +0 -41
@@ -1,5 +1,5 @@
1
1
  // Proposals for revised versions of the SessionService AKA AuthSessionService
2
- import { BrowserPublicClientPKCEProducer } from "../services/PKCE.js";
2
+ import { BrowserPublicClientPKCEProducer, ConfidentialClientPKCEConsumer, } from "../services/PKCE.js";
3
3
  import { clearTokens, clearUser, exchangeTokens, generateOauthLoginUrl, generateOauthLogoutUrl, getEndpointsWithOverrides, retrieveTokens, storeTokens, validateOauth2Tokens, } from "../shared/lib/util.js";
4
4
  import { displayModeFromState, generateState } from "../lib/oauth.js";
5
5
  import { OAuth2Client } from "oslo/oauth2";
@@ -8,6 +8,8 @@ import { PopupError } from "../services/types.js";
8
8
  import { removeParamsWithoutReload } from "../lib/windowUtil.js";
9
9
  import { DEFAULT_OAUTH_GET_PARAMS } from "../constants.js";
10
10
  import { validateLoginAppPostMessage } from "../lib/postMessage.js";
11
+ import { getUser } from "../shared/lib/session.js";
12
+ import { GenericUserSession } from "../shared/lib/UserSession.js";
11
13
  /**
12
14
  * An authentication initiator that works on a browser. Since this is just triggering
13
15
  * login and logout, session data is not stored here.
@@ -32,6 +34,18 @@ import { validateLoginAppPostMessage } from "../lib/postMessage.js";
32
34
  export class BrowserAuthenticationInitiator {
33
35
  postMessageHandler = null;
34
36
  config;
37
+ setDisplayMode(displayMode) {
38
+ this.config.displayMode = displayMode;
39
+ }
40
+ get displayMode() {
41
+ return this.config.displayMode;
42
+ }
43
+ get isServerTokenExchange() {
44
+ return this.config.pkceConsumer instanceof ConfidentialClientPKCEConsumer;
45
+ }
46
+ get state() {
47
+ return generateState(this.config.displayMode, this.isServerTokenExchange);
48
+ }
35
49
  constructor(config) {
36
50
  this.config = config;
37
51
  }
@@ -42,7 +56,10 @@ export class BrowserAuthenticationInitiator {
42
56
  // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url
43
57
  // and then use the display mode to decide how to send the user there
44
58
  async signIn(iframeRef) {
45
- const url = await generateOauthLoginUrl(this.config);
59
+ const url = await generateOauthLoginUrl({
60
+ ...this.config,
61
+ state: this.state,
62
+ });
46
63
  this.postMessageHandler = (event) => {
47
64
  const thisURL = new URL(window.location.href);
48
65
  if (event.origin.endsWith("civic.com") ||
@@ -78,9 +95,13 @@ export class BrowserAuthenticationInitiator {
78
95
  return url;
79
96
  }
80
97
  async signOut() {
81
- const localStorage = new LocalStorageAdapter();
82
- await clearTokens(localStorage);
83
- await clearUser(localStorage);
98
+ // we only use local storage for the client-side token exchange
99
+ if (!this.isServerTokenExchange) {
100
+ const localStorage = new LocalStorageAdapter();
101
+ await clearTokens(localStorage);
102
+ await clearUser(localStorage);
103
+ LocalStorageAdapter.emitter.emit("signOut");
104
+ }
84
105
  // TODO open the iframe or new tab etc: the logout URL is not currently
85
106
  // supported by on the oauth, so just clear state until then
86
107
  const url = await generateOauthLogoutUrl(this.config);
@@ -124,7 +145,6 @@ export class BrowserAuthenticationService extends BrowserAuthenticationInitiator
124
145
  pkceProducer = new BrowserPublicClientPKCEProducer()) {
125
146
  super({
126
147
  ...config,
127
- state: generateState(config.displayMode),
128
148
  // Store and retrieve the PKCE challenge in local storage
129
149
  pkceConsumer: pkceProducer,
130
150
  });
@@ -153,11 +173,22 @@ export class BrowserAuthenticationService extends BrowserAuthenticationInitiator
153
173
  // exchange auth code for tokens
154
174
  const tokens = await exchangeTokens(code, state, this.pkceProducer, this.oauth2client, // clean up types here to avoid the ! operator
155
175
  this.config.oauthServer, this.endpoints);
156
- await storeTokens(new LocalStorageAdapter(), tokens);
176
+ const clientStorage = new LocalStorageAdapter();
177
+ await storeTokens(clientStorage, tokens);
178
+ const user = await getUser(clientStorage);
179
+ if (!user) {
180
+ throw new Error("Failed to get user info");
181
+ }
182
+ const userSession = new GenericUserSession(clientStorage);
183
+ await userSession.set(user);
184
+ LocalStorageAdapter.emitter.emit("signIn");
157
185
  // cleanup the browser window if needed
158
186
  const parsedDisplayMode = displayModeFromState(state, this.config.displayMode);
159
187
  if (parsedDisplayMode === "new_tab") {
160
188
  // Close the popup window
189
+ window.addEventListener("beforeunload", () => {
190
+ window?.opener?.focus();
191
+ });
161
192
  window.close();
162
193
  }
163
194
  // these are the default oAuth params that get added to the URL in redirect which we want to remove if present
@@ -181,7 +212,7 @@ export class BrowserAuthenticationService extends BrowserAuthenticationInitiator
181
212
  const sessionData = await this.getSessionData();
182
213
  if (!sessionData?.idToken || !sessionData.accessToken) {
183
214
  const unAuthenticatedSession = { ...sessionData, authenticated: false };
184
- await clearTokens(new LocalStorageAdapter());
215
+ // await clearTokens(new LocalStorageAdapter());
185
216
  return unAuthenticatedSession;
186
217
  }
187
218
  if (!this.endpoints || !this.oauth2client)
@@ -1 +1 @@
1
- {"version":3,"file":"AuthenticationService.js","sourceRoot":"","sources":["../../../src/services/AuthenticationService.ts"],"names":[],"mappings":"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","sourcesContent":["// Proposals for revised versions of the SessionService AKA AuthSessionService\n\nimport type {\n DisplayMode,\n Endpoints,\n LoginPostMessage,\n OIDCTokenResponseBody,\n SessionData,\n} from \"@/types.js\";\nimport { BrowserPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport {\n clearTokens,\n clearUser,\n exchangeTokens,\n generateOauthLoginUrl,\n generateOauthLogoutUrl,\n getEndpointsWithOverrides,\n retrieveTokens,\n storeTokens,\n validateOauth2Tokens,\n} from \"@/shared/lib/util.js\";\nimport { displayModeFromState, generateState } from \"@/lib/oauth.js\";\nimport { OAuth2Client } from \"oslo/oauth2\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport type {\n AuthenticationInitiator,\n AuthenticationResolver,\n PKCEConsumer,\n} from \"@/services/types.js\";\nimport { PopupError } from \"@/services/types.js\";\nimport { removeParamsWithoutReload } from \"@/lib/windowUtil.js\";\nimport { DEFAULT_OAUTH_GET_PARAMS } from \"@/constants.js\";\nimport { validateLoginAppPostMessage } from \"@/lib/postMessage.js\";\n\n/**\n * An authentication initiator that works on a browser. Since this is just triggering\n * login and logout, session data is not stored here.\n * An associated AuthenticationResolver would be needed to get the session data.\n * Storage is needed for the code verifier, this is the domain of the PKCEConsumer\n * The storage used by the PKCEConsumer should be available to the AuthenticationResolver.\n *\n * Example usage:\n *\n * 1) Client-only SPA -eg a react app with no server:\n * new BrowserAuthenticationInitiator({\n * pkceConsumer: new BrowserPublicClientPKCEProducer(), // generate and retrieve the challenge client-side\n * ... other config\n * })\n *\n * 2) Client-side of a client/server app - eg a react app with a backend:\n * new BrowserAuthenticationInitiator({\n * pkceConsumer: new ConfidentialClientPKCEConsumer(\"https://myserver.com/pkce\"), // get the challenge from the server\n * ... other config\n * })\n */\nexport class BrowserAuthenticationInitiator implements AuthenticationInitiator {\n private postMessageHandler: null | ((event: MessageEvent) => void) = null;\n\n protected config: {\n clientId: string;\n redirectUrl: string;\n state: string;\n scopes: string[];\n // determines whether to trigger the login/logout in an iframe, a new browser window, or redirect the current one.\n displayMode: DisplayMode;\n oauthServer: string;\n // the endpoints to use for the login (if not obtained from the auth server\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n // the nonce to use for the login\n nonce?: string;\n };\n\n constructor(config: typeof this.config) {\n this.config = config;\n }\n\n async handleLoginAppPopupFailed(redirectUrl: string) {\n console.warn(\n \"Login app popup failed open a popup, using redirect mode instead...\",\n redirectUrl,\n );\n window.location.href = redirectUrl;\n }\n\n // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url\n // and then use the display mode to decide how to send the user there\n async signIn(iframeRef: HTMLIFrameElement | null): Promise<URL> {\n const url = await generateOauthLoginUrl(this.config);\n\n this.postMessageHandler = (event: MessageEvent) => {\n const thisURL = new URL(window.location.href);\n if (\n event.origin.endsWith(\"civic.com\") ||\n thisURL.hostname === \"localhost\"\n ) {\n if (!validateLoginAppPostMessage(event.data, this.config.clientId)) {\n return;\n }\n const loginMessage = event.data as LoginPostMessage;\n this.handleLoginAppPopupFailed(loginMessage.data.url);\n }\n };\n\n window.addEventListener(\"message\", this.postMessageHandler);\n\n if (this.config.displayMode === \"iframe\") {\n if (!iframeRef)\n throw new Error(\"iframeRef is required for displayMode 'iframe'\");\n iframeRef.setAttribute(\"src\", url.toString());\n }\n\n if (this.config.displayMode === \"redirect\") {\n window.location.href = url.toString();\n }\n\n if (this.config.displayMode === \"new_tab\") {\n try {\n const popupWindow = window.open(url.toString(), \"_blank\");\n if (!popupWindow) {\n throw new PopupError(\"Failed to open popup window\");\n }\n } catch (error) {\n console.error(\"popupWindow\", error);\n throw new PopupError(\n \"window.open has thrown: Failed to open popup window\",\n );\n }\n }\n\n return url;\n }\n\n async signOut(): Promise<URL> {\n const localStorage = new LocalStorageAdapter();\n await clearTokens(localStorage);\n await clearUser(localStorage);\n // TODO open the iframe or new tab etc: the logout URL is not currently\n // supported by on the oauth, so just clear state until then\n const url = await generateOauthLogoutUrl(this.config);\n return url;\n }\n\n cleanup() {\n if (this.postMessageHandler) {\n window.removeEventListener(\"message\", this.postMessageHandler);\n }\n }\n}\n\n/** A general-purpose authentication initiator, that just generates urls, but lets\n * the caller decide how to use them. This is useful for server-side applications\n * that may serve this URL to their front-ends or just call them directly\n */\nexport class GenericAuthenticationInitiator implements AuthenticationInitiator {\n protected config: {\n clientId: string;\n redirectUrl: string;\n state: string;\n scopes: string[];\n oauthServer: string;\n nonce?: string;\n // the endpoints to use for the login (if not obtained from the auth server)\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n };\n\n constructor(config: typeof this.config) {\n this.config = config;\n }\n\n // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url\n // and simply return the url\n async signIn(): Promise<URL> {\n return generateOauthLoginUrl(this.config);\n }\n\n async signOut(): Promise<URL> {\n return generateOauthLogoutUrl(this.config);\n }\n}\n\ntype BrowserAuthenticationConfig = {\n clientId: string;\n redirectUrl: string;\n scopes: string[];\n oauthServer: string;\n endpointOverrides?: Partial<Endpoints>;\n displayMode: DisplayMode;\n};\n\n/**\n * An authentication resolver that can run on the browser (i.e. a public client)\n * It uses PKCE for security. PKCE and Session data are stored in local storage\n */\nexport class BrowserAuthenticationService extends BrowserAuthenticationInitiator {\n private oauth2client: OAuth2Client | undefined;\n private endpoints: Endpoints | undefined;\n\n // TODO WIP - perhaps we want to keep resolver and initiator separate here\n constructor(\n config: BrowserAuthenticationConfig,\n // Since we are running fully on the client, we produce as well as consume the PKCE challenge\n protected pkceProducer = new BrowserPublicClientPKCEProducer(),\n ) {\n super({\n ...config,\n state: generateState(config.displayMode),\n // Store and retrieve the PKCE challenge in local storage\n pkceConsumer: pkceProducer,\n });\n }\n\n // TODO too much code duplication here between the browser and the server variant.\n // Suggestion for refactor: Standardise the config for AuthenticationResolvers and create a one-shot\n // function for generating an oauth2client from it\n async init(): Promise<this> {\n // resolve oauth config\n this.endpoints = await getEndpointsWithOverrides(\n this.config.oauthServer,\n this.config.endpointOverrides,\n );\n this.oauth2client = new OAuth2Client(\n this.config.clientId,\n this.endpoints.auth,\n this.endpoints.token,\n {\n redirectURI: this.config.redirectUrl,\n },\n );\n\n return this;\n }\n\n // Two responsibilities:\n // 1. resolve the auth code to get the tokens (should use library code)\n // 2. store the tokens in local storage\n async tokenExchange(\n code: string,\n state: string,\n ): Promise<OIDCTokenResponseBody> {\n if (!this.oauth2client) await this.init();\n const codeVerifier = await this.pkceProducer.getCodeVerifier();\n if (!codeVerifier) throw new Error(\"Code verifier not found in storage\");\n\n // exchange auth code for tokens\n const tokens = await exchangeTokens(\n code,\n state,\n this.pkceProducer,\n this.oauth2client!, // clean up types here to avoid the ! operator\n this.config.oauthServer,\n this.endpoints!, // clean up types here to avoid the ! operator\n );\n\n await storeTokens(new LocalStorageAdapter(), tokens);\n\n // cleanup the browser window if needed\n const parsedDisplayMode = displayModeFromState(\n state,\n this.config.displayMode,\n );\n\n if (parsedDisplayMode === \"new_tab\") {\n // Close the popup window\n window.close();\n }\n // these are the default oAuth params that get added to the URL in redirect which we want to remove if present\n removeParamsWithoutReload(DEFAULT_OAUTH_GET_PARAMS);\n return tokens;\n }\n\n // Get the session data from local storage\n async getSessionData(): Promise<SessionData | null> {\n const storageData = await retrieveTokens(new LocalStorageAdapter());\n\n if (!storageData) return null;\n\n return {\n authenticated: !!storageData.id_token,\n idToken: storageData.id_token,\n accessToken: storageData.access_token,\n refreshToken: storageData.refresh_token,\n };\n }\n\n async validateExistingSession(): Promise<SessionData> {\n try {\n const sessionData = await this.getSessionData();\n if (!sessionData?.idToken || !sessionData.accessToken) {\n const unAuthenticatedSession = { ...sessionData, authenticated: false };\n await clearTokens(new LocalStorageAdapter());\n return unAuthenticatedSession;\n }\n if (!this.endpoints || !this.oauth2client) await this.init();\n\n // this function will throw if any of the tokens are invalid\n await validateOauth2Tokens(\n {\n access_token: sessionData.accessToken,\n id_token: sessionData.idToken,\n refresh_token: sessionData.refreshToken,\n },\n this.endpoints!,\n this.oauth2client!,\n this.config.oauthServer,\n );\n return sessionData;\n } catch (error) {\n console.warn(\"Failed to validate existing tokens\", error);\n const unAuthenticatedSession = {\n authenticated: false,\n };\n await clearTokens(new LocalStorageAdapter());\n return unAuthenticatedSession;\n }\n }\n\n static async build(\n config: BrowserAuthenticationConfig,\n ): Promise<AuthenticationResolver> {\n const resolver = new BrowserAuthenticationService(config);\n await resolver.init();\n\n return resolver;\n }\n}\n"]}
1
+ {"version":3,"file":"AuthenticationService.js","sourceRoot":"","sources":["../../../src/services/AuthenticationService.ts"],"names":[],"mappings":"AAAA,8EAA8E;AAS9E,OAAO,EACL,+BAA+B,EAC/B,8BAA8B,GAC/B,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,WAAW,EACX,SAAS,EACT,cAAc,EACd,qBAAqB,EACrB,sBAAsB,EACtB,yBAAyB,EACzB,cAAc,EACd,WAAW,EACX,oBAAoB,GACrB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,oBAAoB,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAM3D,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AAChE,OAAO,EAAE,wBAAwB,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,2BAA2B,EAAE,MAAM,sBAAsB,CAAC;AACnE,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAEjE;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,OAAO,8BAA8B;IACjC,kBAAkB,GAA2C,IAAI,CAAC;IAEhE,MAAM,CAad;IAEK,cAAc,CAAC,WAAwB;QAC5C,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,WAAW,CAAC;IACxC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;IACjC,CAAC;IAED,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,YAAY,8BAA8B,CAAC;IAC5E,CAAC;IACD,IAAI,KAAK;QACP,OAAO,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;IAC5E,CAAC;IACD,YAAY,MAA0B;QACpC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,yBAAyB,CAAC,WAAmB;QACjD,OAAO,CAAC,IAAI,CACV,qEAAqE,EACrE,WAAW,CACZ,CAAC;QACF,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,WAAW,CAAC;IACrC,CAAC;IAED,uGAAuG;IACvG,qEAAqE;IACrE,KAAK,CAAC,MAAM,CAAC,SAAmC;QAC9C,MAAM,GAAG,GAAG,MAAM,qBAAqB,CAAC;YACtC,GAAG,IAAI,CAAC,MAAM;YACd,KAAK,EAAE,IAAI,CAAC,KAAK;SAClB,CAAC,CAAC;QAEH,IAAI,CAAC,kBAAkB,GAAG,CAAC,KAAmB,EAAE,EAAE;YAChD,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC9C,IACE,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC;gBAClC,OAAO,CAAC,QAAQ,KAAK,WAAW,EAChC,CAAC;gBACD,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACnE,OAAO;gBACT,CAAC;gBACD,MAAM,YAAY,GAAG,KAAK,CAAC,IAAwB,CAAC;gBACpD,IAAI,CAAC,yBAAyB,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACxD,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAE5D,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,KAAK,QAAQ,EAAE,CAAC;YACzC,IAAI,CAAC,SAAS;gBACZ,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;YACpE,SAAS,CAAC,YAAY,CAAC,KAAK,EAAE,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;QAChD,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,KAAK,UAAU,EAAE,CAAC;YAC3C,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,GAAG,CAAC,QAAQ,EAAE,CAAC;QACxC,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;YAC1C,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,QAAQ,CAAC,CAAC;gBAC1D,IAAI,CAAC,WAAW,EAAE,CAAC;oBACjB,MAAM,IAAI,UAAU,CAAC,6BAA6B,CAAC,CAAC;gBACtD,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;gBACpC,MAAM,IAAI,UAAU,CAClB,qDAAqD,CACtD,CAAC;YACJ,CAAC;QACH,CAAC;QAED,OAAO,GAAG,CAAC;IACb,CAAC;IAED,KAAK,CAAC,OAAO;QACX,+DAA+D;QAC/D,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAChC,MAAM,YAAY,GAAG,IAAI,mBAAmB,EAAE,CAAC;YAC/C,MAAM,WAAW,CAAC,YAAY,CAAC,CAAC;YAChC,MAAM,SAAS,CAAC,YAAY,CAAC,CAAC;YAC9B,mBAAmB,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9C,CAAC;QACD,uEAAuE;QACvE,4DAA4D;QAC5D,MAAM,GAAG,GAAG,MAAM,sBAAsB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEtD,OAAO,GAAG,CAAC;IACb,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACjE,CAAC;IACH,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,OAAO,8BAA8B;IAC/B,MAAM,CAWd;IAEF,YAAY,MAA0B;QACpC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,uGAAuG;IACvG,4BAA4B;IAC5B,KAAK,CAAC,MAAM;QACV,OAAO,qBAAqB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,OAAO;QACX,OAAO,sBAAsB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7C,CAAC;CACF;AAWD;;;GAGG;AACH,MAAM,OAAO,4BAA6B,SAAQ,8BAA8B;IAQlE;IAPJ,YAAY,CAA2B;IACvC,SAAS,CAAwB;IAEzC,0EAA0E;IAC1E,YACE,MAAmC;IACnC,6FAA6F;IACnF,eAAe,IAAI,+BAA+B,EAAE;QAE9D,KAAK,CAAC;YACJ,GAAG,MAAM;YACT,yDAAyD;YACzD,YAAY,EAAE,YAAY;SAC3B,CAAC,CAAC;QANO,iBAAY,GAAZ,YAAY,CAAwC;IAOhE,CAAC;IAED,kFAAkF;IAClF,oGAAoG;IACpG,kDAAkD;IAClD,KAAK,CAAC,IAAI;QACR,uBAAuB;QACvB,IAAI,CAAC,SAAS,GAAG,MAAM,yBAAyB,CAC9C,IAAI,CAAC,MAAM,CAAC,WAAW,EACvB,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAC9B,CAAC;QACF,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAClC,IAAI,CAAC,MAAM,CAAC,QAAQ,EACpB,IAAI,CAAC,SAAS,CAAC,IAAI,EACnB,IAAI,CAAC,SAAS,CAAC,KAAK,EACpB;YACE,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW;SACrC,CACF,CAAC;QAEF,OAAO,IAAI,CAAC;IACd,CAAC;IAED,wBAAwB;IACxB,uEAAuE;IACvE,uCAAuC;IACvC,KAAK,CAAC,aAAa,CACjB,IAAY,EACZ,KAAa;QAEb,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;QAC1C,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC;QAC/D,IAAI,CAAC,YAAY;YAAE,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;QAEzE,gCAAgC;QAChC,MAAM,MAAM,GAAG,MAAM,cAAc,CACjC,IAAI,EACJ,KAAK,EACL,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,YAAa,EAAE,8CAA8C;QAClE,IAAI,CAAC,MAAM,CAAC,WAAW,EACvB,IAAI,CAAC,SAAU,CAChB,CAAC;QACF,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;QAChD,MAAM,WAAW,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;QACzC,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,aAAa,CAAC,CAAC;QAC1C,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC7C,CAAC;QACD,MAAM,WAAW,GAAG,IAAI,kBAAkB,CAAC,aAAa,CAAC,CAAC;QAC1D,MAAM,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC5B,mBAAmB,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC3C,uCAAuC;QACvC,MAAM,iBAAiB,GAAG,oBAAoB,CAC5C,KAAK,EACL,IAAI,CAAC,MAAM,CAAC,WAAW,CACxB,CAAC;QAEF,IAAI,iBAAiB,KAAK,SAAS,EAAE,CAAC;YACpC,yBAAyB;YACzB,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE,GAAG,EAAE;gBAC3C,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;YAC1B,CAAC,CAAC,CAAC;YACH,MAAM,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC;QACD,8GAA8G;QAC9G,yBAAyB,CAAC,wBAAwB,CAAC,CAAC;QACpD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,0CAA0C;IAC1C,KAAK,CAAC,cAAc;QAClB,MAAM,WAAW,GAAG,MAAM,cAAc,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC;QAEpE,IAAI,CAAC,WAAW;YAAE,OAAO,IAAI,CAAC;QAE9B,OAAO;YACL,aAAa,EAAE,CAAC,CAAC,WAAW,CAAC,QAAQ;YACrC,OAAO,EAAE,WAAW,CAAC,QAAQ;YAC7B,WAAW,EAAE,WAAW,CAAC,YAAY;YACrC,YAAY,EAAE,WAAW,CAAC,aAAa;SACxC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,uBAAuB;QAC3B,IAAI,CAAC;YACH,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;YAChD,IAAI,CAAC,WAAW,EAAE,OAAO,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;gBACtD,MAAM,sBAAsB,GAAG,EAAE,GAAG,WAAW,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;gBACxE,gDAAgD;gBAChD,OAAO,sBAAsB,CAAC;YAChC,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,YAAY;gBAAE,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YAE7D,4DAA4D;YAC5D,MAAM,oBAAoB,CACxB;gBACE,YAAY,EAAE,WAAW,CAAC,WAAW;gBACrC,QAAQ,EAAE,WAAW,CAAC,OAAO;gBAC7B,aAAa,EAAE,WAAW,CAAC,YAAY;aACxC,EACD,IAAI,CAAC,SAAU,EACf,IAAI,CAAC,YAAa,EAClB,IAAI,CAAC,MAAM,CAAC,WAAW,CACxB,CAAC;YACF,OAAO,WAAW,CAAC;QACrB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAC;YAC1D,MAAM,sBAAsB,GAAG;gBAC7B,aAAa,EAAE,KAAK;aACrB,CAAC;YACF,MAAM,WAAW,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC;YAC7C,OAAO,sBAAsB,CAAC;QAChC,CAAC;IACH,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,KAAK,CAChB,MAAmC;QAEnC,MAAM,QAAQ,GAAG,IAAI,4BAA4B,CAAC,MAAM,CAAC,CAAC;QAC1D,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAEtB,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF","sourcesContent":["// Proposals for revised versions of the SessionService AKA AuthSessionService\n\nimport type {\n DisplayMode,\n Endpoints,\n LoginPostMessage,\n OIDCTokenResponseBody,\n SessionData,\n} from \"@/types.js\";\nimport {\n BrowserPublicClientPKCEProducer,\n ConfidentialClientPKCEConsumer,\n} from \"@/services/PKCE.js\";\nimport {\n clearTokens,\n clearUser,\n exchangeTokens,\n generateOauthLoginUrl,\n generateOauthLogoutUrl,\n getEndpointsWithOverrides,\n retrieveTokens,\n storeTokens,\n validateOauth2Tokens,\n} from \"@/shared/lib/util.js\";\nimport { displayModeFromState, generateState } from \"@/lib/oauth.js\";\nimport { OAuth2Client } from \"oslo/oauth2\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport type {\n AuthenticationInitiator,\n AuthenticationResolver,\n PKCEConsumer,\n} from \"@/services/types.js\";\nimport { PopupError } from \"@/services/types.js\";\nimport { removeParamsWithoutReload } from \"@/lib/windowUtil.js\";\nimport { DEFAULT_OAUTH_GET_PARAMS } from \"@/constants.js\";\nimport { validateLoginAppPostMessage } from \"@/lib/postMessage.js\";\nimport { getUser } from \"@/shared/lib/session.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\n\n/**\n * An authentication initiator that works on a browser. Since this is just triggering\n * login and logout, session data is not stored here.\n * An associated AuthenticationResolver would be needed to get the session data.\n * Storage is needed for the code verifier, this is the domain of the PKCEConsumer\n * The storage used by the PKCEConsumer should be available to the AuthenticationResolver.\n *\n * Example usage:\n *\n * 1) Client-only SPA -eg a react app with no server:\n * new BrowserAuthenticationInitiator({\n * pkceConsumer: new BrowserPublicClientPKCEProducer(), // generate and retrieve the challenge client-side\n * ... other config\n * })\n *\n * 2) Client-side of a client/server app - eg a react app with a backend:\n * new BrowserAuthenticationInitiator({\n * pkceConsumer: new ConfidentialClientPKCEConsumer(\"https://myserver.com/pkce\"), // get the challenge from the server\n * ... other config\n * })\n */\nexport class BrowserAuthenticationInitiator implements AuthenticationInitiator {\n private postMessageHandler: null | ((event: MessageEvent) => void) = null;\n\n protected config: {\n clientId: string;\n redirectUrl: string;\n scopes: string[];\n // determines whether to trigger the login/logout in an iframe, a new browser window, or redirect the current one.\n displayMode: DisplayMode;\n oauthServer: string;\n // the endpoints to use for the login (if not obtained from the auth server\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n // the nonce to use for the login\n nonce?: string;\n };\n\n public setDisplayMode(displayMode: DisplayMode) {\n this.config.displayMode = displayMode;\n }\n\n get displayMode() {\n return this.config.displayMode;\n }\n\n get isServerTokenExchange() {\n return this.config.pkceConsumer instanceof ConfidentialClientPKCEConsumer;\n }\n get state() {\n return generateState(this.config.displayMode, this.isServerTokenExchange);\n }\n constructor(config: typeof this.config) {\n this.config = config;\n }\n\n async handleLoginAppPopupFailed(redirectUrl: string) {\n console.warn(\n \"Login app popup failed open a popup, using redirect mode instead...\",\n redirectUrl,\n );\n window.location.href = redirectUrl;\n }\n\n // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url\n // and then use the display mode to decide how to send the user there\n async signIn(iframeRef: HTMLIFrameElement | null): Promise<URL> {\n const url = await generateOauthLoginUrl({\n ...this.config,\n state: this.state,\n });\n\n this.postMessageHandler = (event: MessageEvent) => {\n const thisURL = new URL(window.location.href);\n if (\n event.origin.endsWith(\"civic.com\") ||\n thisURL.hostname === \"localhost\"\n ) {\n if (!validateLoginAppPostMessage(event.data, this.config.clientId)) {\n return;\n }\n const loginMessage = event.data as LoginPostMessage;\n this.handleLoginAppPopupFailed(loginMessage.data.url);\n }\n };\n\n window.addEventListener(\"message\", this.postMessageHandler);\n\n if (this.config.displayMode === \"iframe\") {\n if (!iframeRef)\n throw new Error(\"iframeRef is required for displayMode 'iframe'\");\n iframeRef.setAttribute(\"src\", url.toString());\n }\n\n if (this.config.displayMode === \"redirect\") {\n window.location.href = url.toString();\n }\n\n if (this.config.displayMode === \"new_tab\") {\n try {\n const popupWindow = window.open(url.toString(), \"_blank\");\n if (!popupWindow) {\n throw new PopupError(\"Failed to open popup window\");\n }\n } catch (error) {\n console.error(\"popupWindow\", error);\n throw new PopupError(\n \"window.open has thrown: Failed to open popup window\",\n );\n }\n }\n\n return url;\n }\n\n async signOut(): Promise<URL> {\n // we only use local storage for the client-side token exchange\n if (!this.isServerTokenExchange) {\n const localStorage = new LocalStorageAdapter();\n await clearTokens(localStorage);\n await clearUser(localStorage);\n LocalStorageAdapter.emitter.emit(\"signOut\");\n }\n // TODO open the iframe or new tab etc: the logout URL is not currently\n // supported by on the oauth, so just clear state until then\n const url = await generateOauthLogoutUrl(this.config);\n\n return url;\n }\n\n cleanup() {\n if (this.postMessageHandler) {\n window.removeEventListener(\"message\", this.postMessageHandler);\n }\n }\n}\n\n/** A general-purpose authentication initiator, that just generates urls, but lets\n * the caller decide how to use them. This is useful for server-side applications\n * that may serve this URL to their front-ends or just call them directly\n */\nexport class GenericAuthenticationInitiator implements AuthenticationInitiator {\n protected config: {\n clientId: string;\n redirectUrl: string;\n state: string;\n scopes: string[];\n oauthServer: string;\n nonce?: string;\n // the endpoints to use for the login (if not obtained from the auth server)\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n };\n\n constructor(config: typeof this.config) {\n this.config = config;\n }\n\n // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url\n // and simply return the url\n async signIn(): Promise<URL> {\n return generateOauthLoginUrl(this.config);\n }\n\n async signOut(): Promise<URL> {\n return generateOauthLogoutUrl(this.config);\n }\n}\n\ntype BrowserAuthenticationConfig = {\n clientId: string;\n redirectUrl: string;\n scopes: string[];\n oauthServer: string;\n endpointOverrides?: Partial<Endpoints>;\n displayMode: DisplayMode;\n};\n\n/**\n * An authentication resolver that can run on the browser (i.e. a public client)\n * It uses PKCE for security. PKCE and Session data are stored in local storage\n */\nexport class BrowserAuthenticationService extends BrowserAuthenticationInitiator {\n private oauth2client: OAuth2Client | undefined;\n private endpoints: Endpoints | undefined;\n\n // TODO WIP - perhaps we want to keep resolver and initiator separate here\n constructor(\n config: BrowserAuthenticationConfig,\n // Since we are running fully on the client, we produce as well as consume the PKCE challenge\n protected pkceProducer = new BrowserPublicClientPKCEProducer(),\n ) {\n super({\n ...config,\n // Store and retrieve the PKCE challenge in local storage\n pkceConsumer: pkceProducer,\n });\n }\n\n // TODO too much code duplication here between the browser and the server variant.\n // Suggestion for refactor: Standardise the config for AuthenticationResolvers and create a one-shot\n // function for generating an oauth2client from it\n async init(): Promise<this> {\n // resolve oauth config\n this.endpoints = await getEndpointsWithOverrides(\n this.config.oauthServer,\n this.config.endpointOverrides,\n );\n this.oauth2client = new OAuth2Client(\n this.config.clientId,\n this.endpoints.auth,\n this.endpoints.token,\n {\n redirectURI: this.config.redirectUrl,\n },\n );\n\n return this;\n }\n\n // Two responsibilities:\n // 1. resolve the auth code to get the tokens (should use library code)\n // 2. store the tokens in local storage\n async tokenExchange(\n code: string,\n state: string,\n ): Promise<OIDCTokenResponseBody> {\n if (!this.oauth2client) await this.init();\n const codeVerifier = await this.pkceProducer.getCodeVerifier();\n if (!codeVerifier) throw new Error(\"Code verifier not found in storage\");\n\n // exchange auth code for tokens\n const tokens = await exchangeTokens(\n code,\n state,\n this.pkceProducer,\n this.oauth2client!, // clean up types here to avoid the ! operator\n this.config.oauthServer,\n this.endpoints!, // clean up types here to avoid the ! operator\n );\n const clientStorage = new LocalStorageAdapter();\n await storeTokens(clientStorage, tokens);\n const user = await getUser(clientStorage);\n if (!user) {\n throw new Error(\"Failed to get user info\");\n }\n const userSession = new GenericUserSession(clientStorage);\n await userSession.set(user);\n LocalStorageAdapter.emitter.emit(\"signIn\");\n // cleanup the browser window if needed\n const parsedDisplayMode = displayModeFromState(\n state,\n this.config.displayMode,\n );\n\n if (parsedDisplayMode === \"new_tab\") {\n // Close the popup window\n window.addEventListener(\"beforeunload\", () => {\n window?.opener?.focus();\n });\n window.close();\n }\n // these are the default oAuth params that get added to the URL in redirect which we want to remove if present\n removeParamsWithoutReload(DEFAULT_OAUTH_GET_PARAMS);\n return tokens;\n }\n\n // Get the session data from local storage\n async getSessionData(): Promise<SessionData | null> {\n const storageData = await retrieveTokens(new LocalStorageAdapter());\n\n if (!storageData) return null;\n\n return {\n authenticated: !!storageData.id_token,\n idToken: storageData.id_token,\n accessToken: storageData.access_token,\n refreshToken: storageData.refresh_token,\n };\n }\n\n async validateExistingSession(): Promise<SessionData> {\n try {\n const sessionData = await this.getSessionData();\n if (!sessionData?.idToken || !sessionData.accessToken) {\n const unAuthenticatedSession = { ...sessionData, authenticated: false };\n // await clearTokens(new LocalStorageAdapter());\n return unAuthenticatedSession;\n }\n if (!this.endpoints || !this.oauth2client) await this.init();\n\n // this function will throw if any of the tokens are invalid\n await validateOauth2Tokens(\n {\n access_token: sessionData.accessToken,\n id_token: sessionData.idToken,\n refresh_token: sessionData.refreshToken,\n },\n this.endpoints!,\n this.oauth2client!,\n this.config.oauthServer,\n );\n return sessionData;\n } catch (error) {\n console.warn(\"Failed to validate existing tokens\", error);\n const unAuthenticatedSession = {\n authenticated: false,\n };\n await clearTokens(new LocalStorageAdapter());\n return unAuthenticatedSession;\n }\n }\n\n static async build(\n config: BrowserAuthenticationConfig,\n ): Promise<AuthenticationResolver> {\n const resolver = new BrowserAuthenticationService(config);\n await resolver.init();\n\n return resolver;\n }\n}\n"]}
@@ -0,0 +1,7 @@
1
+ import type { ReactNode } from "react";
2
+ import React from "react";
3
+ declare const BlockDisplay: ({ children }: {
4
+ children: ReactNode;
5
+ }) => React.JSX.Element;
6
+ export { BlockDisplay };
7
+ //# sourceMappingURL=BlockDisplay.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BlockDisplay.d.ts","sourceRoot":"","sources":["../../../../src/shared/components/BlockDisplay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,QAAA,MAAM,YAAY,iBAAkB;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,sBAgC1D,CAAC;AACF,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,25 @@
1
+ import React from "react";
2
+ const BlockDisplay = ({ children }) => {
3
+ return (React.createElement("div", { id: "iframe-block-display-wrapper", style: {
4
+ position: "relative",
5
+ left: 0,
6
+ top: 0,
7
+ zIndex: 50,
8
+ display: "flex",
9
+ height: "100vh",
10
+ width: "100vw",
11
+ alignItems: "center",
12
+ justifyContent: "center",
13
+ backgroundColor: "white",
14
+ } },
15
+ React.createElement("div", { id: "iframe-block-display", style: {
16
+ position: "absolute",
17
+ inset: 0,
18
+ display: "flex",
19
+ alignItems: "center",
20
+ justifyContent: "center",
21
+ backgroundColor: "white",
22
+ } }, children)));
23
+ };
24
+ export { BlockDisplay };
25
+ //# sourceMappingURL=BlockDisplay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BlockDisplay.js","sourceRoot":"","sources":["../../../../src/shared/components/BlockDisplay.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,YAAY,GAAG,CAAC,EAAE,QAAQ,EAA2B,EAAE,EAAE;IAC7D,OAAO,CACL,6BACE,EAAE,EAAC,8BAA8B,EACjC,KAAK,EAAE;YACL,QAAQ,EAAE,UAAU;YACpB,IAAI,EAAE,CAAC;YACP,GAAG,EAAE,CAAC;YACN,MAAM,EAAE,EAAE;YACV,OAAO,EAAE,MAAM;YACf,MAAM,EAAE,OAAO;YACf,KAAK,EAAE,OAAO;YACd,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;YACxB,eAAe,EAAE,OAAO;SACzB;QAED,6BACE,EAAE,EAAC,sBAAsB,EACzB,KAAK,EAAE;gBACL,QAAQ,EAAE,UAAU;gBACpB,KAAK,EAAE,CAAC;gBACR,OAAO,EAAE,MAAM;gBACf,UAAU,EAAE,QAAQ;gBACpB,cAAc,EAAE,QAAQ;gBACxB,eAAe,EAAE,OAAO;aACzB,IAEA,QAAQ,CACL,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AACF,OAAO,EAAE,YAAY,EAAE,CAAC","sourcesContent":["import type { ReactNode } from \"react\";\nimport React from \"react\";\n\nconst BlockDisplay = ({ children }: { children: ReactNode }) => {\n return (\n <div\n id=\"iframe-block-display-wrapper\"\n style={{\n position: \"relative\",\n left: 0,\n top: 0,\n zIndex: 50,\n display: \"flex\",\n height: \"100vh\",\n width: \"100vw\",\n alignItems: \"center\",\n justifyContent: \"center\",\n backgroundColor: \"white\",\n }}\n >\n <div\n id=\"iframe-block-display\"\n style={{\n position: \"absolute\",\n inset: 0,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n backgroundColor: \"white\",\n }}\n >\n {children}\n </div>\n </div>\n );\n};\nexport { BlockDisplay };\n"]}
@@ -2,7 +2,7 @@
2
2
  import { IFRAME_ID } from "../../constants.js";
3
3
  import React, { forwardRef } from "react";
4
4
  const CivicAuthIframe = forwardRef(({ onLoad }, ref) => {
5
- return (React.createElement("iframe", { id: IFRAME_ID, ref: ref, style: { height: "26rem", width: "100%", border: "none" }, onLoad: onLoad }));
5
+ return (React.createElement("iframe", { id: IFRAME_ID, ref: ref, style: { height: "28rem", width: "100%", border: "none" }, onLoad: onLoad }));
6
6
  });
7
7
  CivicAuthIframe.displayName = "CivicAuthIframe";
8
8
  export { CivicAuthIframe };
@@ -1 +1 @@
1
- {"version":3,"file":"CivicAuthIframe.js","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthIframe.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAM1C,MAAM,eAAe,GAAG,UAAU,CAChC,CAAC,EAAE,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE;IAClB,OAAO,CACL,gCACE,EAAE,EAAE,SAAS,EACb,GAAG,EAAE,GAAG,EACR,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,EACzD,MAAM,EAAE,MAAM,GACd,CACH,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,eAAe,CAAC,WAAW,GAAG,iBAAiB,CAAC;AAIhD,OAAO,EAAE,eAAe,EAAE,CAAC","sourcesContent":["\"use client\";\nimport { IFRAME_ID } from \"@/constants.js\";\nimport React, { forwardRef } from \"react\";\n\ntype CivicAuthIframeProps = {\n onLoad?: () => void;\n};\n\nconst CivicAuthIframe = forwardRef<HTMLIFrameElement, CivicAuthIframeProps>(\n ({ onLoad }, ref) => {\n return (\n <iframe\n id={IFRAME_ID}\n ref={ref}\n style={{ height: \"26rem\", width: \"100%\", border: \"none\" }}\n onLoad={onLoad}\n />\n );\n },\n);\n\nCivicAuthIframe.displayName = \"CivicAuthIframe\";\n\nexport type { CivicAuthIframeProps };\n\nexport { CivicAuthIframe };\n"]}
1
+ {"version":3,"file":"CivicAuthIframe.js","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthIframe.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAM1C,MAAM,eAAe,GAAG,UAAU,CAChC,CAAC,EAAE,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE;IAClB,OAAO,CACL,gCACE,EAAE,EAAE,SAAS,EACb,GAAG,EAAE,GAAG,EACR,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,EACzD,MAAM,EAAE,MAAM,GACd,CACH,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,eAAe,CAAC,WAAW,GAAG,iBAAiB,CAAC;AAIhD,OAAO,EAAE,eAAe,EAAE,CAAC","sourcesContent":["\"use client\";\nimport { IFRAME_ID } from \"@/constants.js\";\nimport React, { forwardRef } from \"react\";\n\ntype CivicAuthIframeProps = {\n onLoad?: () => void;\n};\n\nconst CivicAuthIframe = forwardRef<HTMLIFrameElement, CivicAuthIframeProps>(\n ({ onLoad }, ref) => {\n return (\n <iframe\n id={IFRAME_ID}\n ref={ref}\n style={{ height: \"28rem\", width: \"100%\", border: \"none\" }}\n onLoad={onLoad}\n />\n );\n },\n);\n\nCivicAuthIframe.displayName = \"CivicAuthIframe\";\n\nexport type { CivicAuthIframeProps };\n\nexport { CivicAuthIframe };\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"CivicAuthIframeContainer.d.ts","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthIframeContainer.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmD,MAAM,OAAO,CAAC;AAOxE,KAAK,6BAA6B,GAAG;IACnC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B,CAAC;AAuEF,QAAA,MAAM,wBAAwB,kCAG3B,6BAA6B,sBAwG/B,CAAC;AAEF,YAAY,EAAE,6BAA6B,EAAE,CAAC;AAE9C,OAAO,EAAE,wBAAwB,EAAE,CAAC"}
1
+ {"version":3,"file":"CivicAuthIframeContainer.d.ts","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthIframeContainer.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmD,MAAM,OAAO,CAAC;AAUxE,KAAK,6BAA6B,GAAG;IACnC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B,CAAC;AAuEF,QAAA,MAAM,wBAAwB,kCAG3B,6BAA6B,sBA8G/B,CAAC;AAEF,YAAY,EAAE,6BAA6B,EAAE,CAAC;AAE9C,OAAO,EAAE,wBAAwB,EAAE,CAAC"}
@@ -3,8 +3,11 @@ import React, { useCallback, useEffect, useRef, useState } from "react";
3
3
  import { LoadingIcon } from "../../shared/components/LoadingIcon.js";
4
4
  import { CloseIcon } from "../../shared/components/CloseIcon.js";
5
5
  import { CivicAuthIframe } from "../../shared/components/CivicAuthIframe.js";
6
- import { useAuth, useConfig, useIframe } from "../../shared/hooks/index.js";
6
+ import { useIframe } from "../../shared/hooks/index.js";
7
7
  import { TOKEN_EXCHANGE_TRIGGER_TEXT } from "../../constants.js";
8
+ import { useCivicAuthConfig } from "../../shared/hooks/index.js";
9
+ import { useClientTokenExchangeSession } from "../../shared/hooks/index.js";
10
+ import { useSession } from "../../shared/hooks/index.js";
8
11
  function NoChrome({ children, }) {
9
12
  return React.createElement("div", { style: { position: "relative" } }, children);
10
13
  }
@@ -48,10 +51,19 @@ function IframeChrome({ children, onClose, }) {
48
51
  }
49
52
  const CivicAuthIframeContainer = ({ onClose, closeOnRedirect = true, }) => {
50
53
  const [isLoading, setIsLoading] = useState(true);
51
- const { isLoading: isAuthLoading } = useAuth();
52
- const config = useConfig();
53
- const { setAuthResponseUrl, iframeRef } = useIframe();
54
+ const { isLoading: isAuthLoading, data: session } = useSession();
55
+ const config = useCivicAuthConfig();
56
+ const [tokenExchangeUrl, setTokenExchangeUrl] = useState(null);
57
+ const { doTokenExchange } = useClientTokenExchangeSession();
58
+ const { iframeRef, iframeMode } = useIframe();
59
+ useEffect(() => {
60
+ if (tokenExchangeUrl) {
61
+ doTokenExchange?.(tokenExchangeUrl);
62
+ }
63
+ }, [doTokenExchange, tokenExchangeUrl]);
54
64
  const processIframeUrl = useCallback(() => {
65
+ if (!config)
66
+ return;
55
67
  if (iframeRef && iframeRef.current && iframeRef.current.contentWindow) {
56
68
  try {
57
69
  const iframeUrl = iframeRef.current.contentWindow.location.href;
@@ -73,7 +85,8 @@ const CivicAuthIframeContainer = ({ onClose, closeOnRedirect = true, }) => {
73
85
  else {
74
86
  // if we're doing token-exchange in the client, we can just set the authResponseUrl
75
87
  // to be handled by the auth provider
76
- setAuthResponseUrl(iframeUrl);
88
+ // iframeRef.current.setAttribute("src", "");
89
+ setTokenExchangeUrl(iframeUrl);
77
90
  }
78
91
  if (closeOnRedirect)
79
92
  onClose?.();
@@ -86,13 +99,7 @@ const CivicAuthIframeContainer = ({ onClose, closeOnRedirect = true, }) => {
86
99
  }
87
100
  }
88
101
  return false; // Haven't processed the URL yet
89
- }, [
90
- closeOnRedirect,
91
- config.redirectUrl,
92
- iframeRef,
93
- onClose,
94
- setAuthResponseUrl,
95
- ]);
102
+ }, [closeOnRedirect, config, iframeRef, onClose]);
96
103
  const intervalId = useRef();
97
104
  const handleEscape = useCallback((event) => {
98
105
  if (event.key === "Escape") {
@@ -111,8 +118,10 @@ const CivicAuthIframeContainer = ({ onClose, closeOnRedirect = true, }) => {
111
118
  clearInterval(intervalId.current);
112
119
  }
113
120
  }, [processIframeUrl, setIsLoading, intervalId]);
114
- const showLoadingIcon = isLoading || isAuthLoading;
115
- const WrapperComponent = config.modalIframe ? IframeChrome : NoChrome;
121
+ // if we're already authenticated then we're waiting either for the iframe to be closed
122
+ // or the page to redirect, so we want to show the loading icon
123
+ const showLoadingIcon = session?.authenticated || isLoading || isAuthLoading;
124
+ const WrapperComponent = iframeMode === "embedded" ? NoChrome : IframeChrome;
116
125
  return (React.createElement(WrapperComponent, { onClose: onClose },
117
126
  showLoadingIcon ? (React.createElement("div", { id: "civic-auth-loading-icon-wrapper", style: {
118
127
  position: "absolute",
@@ -1 +1 @@
1
- {"version":3,"file":"CivicAuthIframeContainer.js","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthIframeContainer.tsx"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\n\nimport React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { LoadingIcon } from \"@/shared/components/LoadingIcon.js\";\nimport { CloseIcon } from \"@/shared/components/CloseIcon.js\";\nimport { CivicAuthIframe } from \"@/shared/components/CivicAuthIframe.js\";\nimport { useAuth, useConfig, useIframe } from \"@/shared/hooks/index.js\";\nimport { TOKEN_EXCHANGE_TRIGGER_TEXT } from \"@/constants.js\";\n\ntype CivicAuthIframeContainerProps = {\n onClose?: () => void;\n closeOnRedirect?: boolean;\n};\n\nfunction NoChrome({\n children,\n}: {\n children: React.ReactNode;\n onClose?: () => void;\n}) {\n return <div style={{ position: \"relative\" }}>{children}</div>;\n}\n\nfunction IframeChrome({\n children,\n onClose,\n}: {\n children: React.ReactNode;\n onClose?: () => void;\n}) {\n return (\n <div\n style={{\n position: \"absolute\",\n left: 0,\n top: 0,\n zIndex: 50,\n display: \"flex\",\n height: \"100vh\",\n width: \"100vw\",\n minWidth: \"18rem\",\n alignItems: \"center\",\n justifyContent: \"center\",\n backgroundColor: \"rgba(17, 24, 39, 0.5)\",\n }}\n onClick={onClose}\n >\n <div\n style={{\n position: \"relative\",\n overflow: \"hidden\",\n borderRadius: \"1.5rem\",\n backgroundColor: \"white\",\n padding: \"1.5rem\",\n boxShadow:\n \"0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)\",\n }}\n onClick={(e) => e.stopPropagation()}\n >\n <button\n style={{\n position: \"absolute\",\n right: \"1rem\",\n top: \"1rem\",\n display: \"flex\",\n cursor: \"pointer\",\n alignItems: \"center\",\n justifyContent: \"center\",\n border: \"none\",\n backgroundColor: \"transparent\",\n padding: \"0.25rem\",\n color: \"#9ca3af\",\n }}\n onClick={onClose}\n >\n <CloseIcon />\n </button>\n\n {children}\n </div>\n </div>\n );\n}\nconst CivicAuthIframeContainer = ({\n onClose,\n closeOnRedirect = true,\n}: CivicAuthIframeContainerProps) => {\n const [isLoading, setIsLoading] = useState(true);\n const { isLoading: isAuthLoading } = useAuth();\n const config = useConfig();\n const { setAuthResponseUrl, iframeRef } = useIframe();\n\n const processIframeUrl = useCallback(() => {\n if (iframeRef && iframeRef.current && iframeRef.current.contentWindow) {\n try {\n const iframeUrl = iframeRef.current.contentWindow.location.href;\n // we know that oauth has finished when the iframe redirects to our redirectUrl\n if (iframeUrl.startsWith(config.redirectUrl)) {\n // we still want to show the spinner during redirect\n setIsLoading(true);\n const iframeBody =\n iframeRef.current.contentWindow.document.body.innerHTML;\n\n // If we're doing a server token exchange, we need to call the server a second time\n // using a fetch so that we're on the same domain and cookies can be sent and read\n // The server will use the presence of the code_verifier cookie to determine whether to do a token exchange or not.\n // On the initial (3rd party) redirect from the auth server, the cookie won't be sent, so the server-side callback route will just render a blank page,\n // and we'll do the exchange request from here, which will include the cookies.\n if (iframeBody.includes(TOKEN_EXCHANGE_TRIGGER_TEXT)) {\n const params = new URL(iframeUrl).searchParams;\n const appUrl = globalThis.window?.location?.origin;\n fetch(\n `${config.redirectUrl}?${params.toString()}&appUrl=${appUrl}`,\n );\n } else {\n // if we're doing token-exchange in the client, we can just set the authResponseUrl\n // to be handled by the auth provider\n setAuthResponseUrl(iframeUrl);\n }\n\n if (closeOnRedirect) onClose?.();\n return true; // Successfully processed the URL\n }\n } catch {\n // If we get here, the iframe hasn't redirected to our origin yet\n console.log(\"Waiting for redirect...\");\n }\n }\n return false; // Haven't processed the URL yet\n }, [\n closeOnRedirect,\n config.redirectUrl,\n iframeRef,\n onClose,\n setAuthResponseUrl,\n ]);\n\n const intervalId = useRef<NodeJS.Timeout>();\n\n const handleEscape = useCallback(\n (event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n onClose?.();\n }\n },\n [onClose],\n );\n\n // handle Escape\n useEffect(() => {\n window.addEventListener(\"keydown\", handleEscape);\n\n return () => window.removeEventListener(\"keydown\", handleEscape);\n });\n\n const handleIframeLoad = useCallback(() => {\n setIsLoading(false);\n\n const iframeHasUrl = processIframeUrl();\n\n if (iframeHasUrl && intervalId.current) {\n clearInterval(intervalId.current);\n }\n }, [processIframeUrl, setIsLoading, intervalId]);\n\n const showLoadingIcon = isLoading || isAuthLoading;\n\n const WrapperComponent = config.modalIframe ? IframeChrome : NoChrome;\n\n return (\n <WrapperComponent onClose={onClose}>\n {showLoadingIcon ? (\n <div\n id=\"civic-auth-loading-icon-wrapper\"\n style={{\n position: \"absolute\",\n inset: 0,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n backgroundColor: \"white\",\n }}\n >\n <LoadingIcon />\n </div>\n ) : null}\n\n <CivicAuthIframe ref={iframeRef} onLoad={handleIframeLoad} />\n </WrapperComponent>\n );\n};\n\nexport type { CivicAuthIframeContainerProps };\n\nexport { CivicAuthIframeContainer };\n"]}
1
+ {"version":3,"file":"CivicAuthIframeContainer.js","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthIframeContainer.tsx"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\n\nimport React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { LoadingIcon } from \"@/shared/components/LoadingIcon.js\";\nimport { CloseIcon } from \"@/shared/components/CloseIcon.js\";\nimport { CivicAuthIframe } from \"@/shared/components/CivicAuthIframe.js\";\nimport { useIframe } from \"@/shared/hooks/index.js\";\nimport { TOKEN_EXCHANGE_TRIGGER_TEXT } from \"@/constants.js\";\nimport { useCivicAuthConfig } from \"@/shared/hooks/index.js\";\nimport { useClientTokenExchangeSession } from \"@/shared/hooks/index.js\";\nimport { useSession } from \"@/shared/hooks/index.js\";\n\ntype CivicAuthIframeContainerProps = {\n onClose?: () => void;\n closeOnRedirect?: boolean;\n};\n\nfunction NoChrome({\n children,\n}: {\n children: React.ReactNode;\n onClose?: () => void;\n}) {\n return <div style={{ position: \"relative\" }}>{children}</div>;\n}\n\nfunction IframeChrome({\n children,\n onClose,\n}: {\n children: React.ReactNode;\n onClose?: () => void;\n}) {\n return (\n <div\n style={{\n position: \"absolute\",\n left: 0,\n top: 0,\n zIndex: 50,\n display: \"flex\",\n height: \"100vh\",\n width: \"100vw\",\n minWidth: \"18rem\",\n alignItems: \"center\",\n justifyContent: \"center\",\n backgroundColor: \"rgba(17, 24, 39, 0.5)\",\n }}\n onClick={onClose}\n >\n <div\n style={{\n position: \"relative\",\n overflow: \"hidden\",\n borderRadius: \"1.5rem\",\n backgroundColor: \"white\",\n padding: \"1.5rem\",\n boxShadow:\n \"0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)\",\n }}\n onClick={(e) => e.stopPropagation()}\n >\n <button\n style={{\n position: \"absolute\",\n right: \"1rem\",\n top: \"1rem\",\n display: \"flex\",\n cursor: \"pointer\",\n alignItems: \"center\",\n justifyContent: \"center\",\n border: \"none\",\n backgroundColor: \"transparent\",\n padding: \"0.25rem\",\n color: \"#9ca3af\",\n }}\n onClick={onClose}\n >\n <CloseIcon />\n </button>\n\n {children}\n </div>\n </div>\n );\n}\nconst CivicAuthIframeContainer = ({\n onClose,\n closeOnRedirect = true,\n}: CivicAuthIframeContainerProps) => {\n const [isLoading, setIsLoading] = useState(true);\n const { isLoading: isAuthLoading, data: session } = useSession();\n const config = useCivicAuthConfig();\n const [tokenExchangeUrl, setTokenExchangeUrl] = useState<string | null>(null);\n const { doTokenExchange } = useClientTokenExchangeSession();\n const { iframeRef, iframeMode } = useIframe();\n\n useEffect(() => {\n if (tokenExchangeUrl) {\n doTokenExchange?.(tokenExchangeUrl);\n }\n }, [doTokenExchange, tokenExchangeUrl]);\n\n const processIframeUrl = useCallback(() => {\n if (!config) return;\n if (iframeRef && iframeRef.current && iframeRef.current.contentWindow) {\n try {\n const iframeUrl = iframeRef.current.contentWindow.location.href;\n // we know that oauth has finished when the iframe redirects to our redirectUrl\n if (iframeUrl.startsWith(config.redirectUrl)) {\n // we still want to show the spinner during redirect\n setIsLoading(true);\n const iframeBody =\n iframeRef.current.contentWindow.document.body.innerHTML;\n\n // If we're doing a server token exchange, we need to call the server a second time\n // using a fetch so that we're on the same domain and cookies can be sent and read\n // The server will use the presence of the code_verifier cookie to determine whether to do a token exchange or not.\n // On the initial (3rd party) redirect from the auth server, the cookie won't be sent, so the server-side callback route will just render a blank page,\n // and we'll do the exchange request from here, which will include the cookies.\n if (iframeBody.includes(TOKEN_EXCHANGE_TRIGGER_TEXT)) {\n const params = new URL(iframeUrl).searchParams;\n const appUrl = globalThis.window?.location?.origin;\n fetch(\n `${config.redirectUrl}?${params.toString()}&appUrl=${appUrl}`,\n );\n } else {\n // if we're doing token-exchange in the client, we can just set the authResponseUrl\n // to be handled by the auth provider\n // iframeRef.current.setAttribute(\"src\", \"\");\n setTokenExchangeUrl(iframeUrl);\n }\n\n if (closeOnRedirect) onClose?.();\n return true; // Successfully processed the URL\n }\n } catch {\n // If we get here, the iframe hasn't redirected to our origin yet\n console.log(\"Waiting for redirect...\");\n }\n }\n return false; // Haven't processed the URL yet\n }, [closeOnRedirect, config, iframeRef, onClose]);\n\n const intervalId = useRef<NodeJS.Timeout>();\n\n const handleEscape = useCallback(\n (event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n onClose?.();\n }\n },\n [onClose],\n );\n\n // handle Escape\n useEffect(() => {\n window.addEventListener(\"keydown\", handleEscape);\n\n return () => window.removeEventListener(\"keydown\", handleEscape);\n });\n\n const handleIframeLoad = useCallback(() => {\n setIsLoading(false);\n\n const iframeHasUrl = processIframeUrl();\n\n if (iframeHasUrl && intervalId.current) {\n clearInterval(intervalId.current);\n }\n }, [processIframeUrl, setIsLoading, intervalId]);\n\n // if we're already authenticated then we're waiting either for the iframe to be closed\n // or the page to redirect, so we want to show the loading icon\n const showLoadingIcon = session?.authenticated || isLoading || isAuthLoading;\n\n const WrapperComponent = iframeMode === \"embedded\" ? NoChrome : IframeChrome;\n\n return (\n <WrapperComponent onClose={onClose}>\n {showLoadingIcon ? (\n <div\n id=\"civic-auth-loading-icon-wrapper\"\n style={{\n position: \"absolute\",\n inset: 0,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n backgroundColor: \"white\",\n }}\n >\n <LoadingIcon />\n </div>\n ) : null}\n\n <CivicAuthIframe ref={iframeRef} onLoad={handleIframeLoad} />\n </WrapperComponent>\n );\n};\n\nexport type { CivicAuthIframeContainerProps };\n\nexport { CivicAuthIframeContainer };\n"]}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ declare const IFrameAndLoading: ({ error, isLoading, }: {
3
+ error: Error | null;
4
+ isLoading: boolean;
5
+ }) => React.JSX.Element;
6
+ export { IFrameAndLoading };
7
+ //# sourceMappingURL=IFrameAndLoading.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IFrameAndLoading.d.ts","sourceRoot":"","sources":["../../../../src/shared/components/IFrameAndLoading.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B,QAAA,MAAM,gBAAgB,0BAGnB;IACD,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;CACpB,sBA8BA,CAAC;AACF,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
@@ -0,0 +1,22 @@
1
+ import React from "react";
2
+ import { useIframe } from "../hooks/useIframe.js";
3
+ import { useIsInIframe } from "../hooks/useIsInIframe.js";
4
+ import { CivicAuthIframeContainer } from "./CivicAuthIframeContainer.js";
5
+ import { BlockDisplay } from "./BlockDisplay.js";
6
+ import { LoadingIcon } from "./LoadingIcon.js";
7
+ const IFrameAndLoading = ({ error, isLoading, }) => {
8
+ const isInIframe = useIsInIframe();
9
+ const { renderIframe, iframeIsVisible, setIframeIsVisible, iframeMode } = useIframe();
10
+ const showIframeLoadingOverlay = iframeMode === "modal" && (isInIframe || isLoading);
11
+ return (React.createElement(React.Fragment, null,
12
+ renderIframe && (React.createElement("div", { style: iframeIsVisible ? { display: "block" } : { display: "none" } },
13
+ React.createElement(CivicAuthIframeContainer, { onClose: () => setIframeIsVisible(false) }))),
14
+ error && (React.createElement(BlockDisplay, null,
15
+ React.createElement("div", null,
16
+ "Error: ",
17
+ error?.message))),
18
+ showIframeLoadingOverlay && !error && (React.createElement(BlockDisplay, null,
19
+ React.createElement(LoadingIcon, null)))));
20
+ };
21
+ export { IFrameAndLoading };
22
+ //# sourceMappingURL=IFrameAndLoading.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IFrameAndLoading.js","sourceRoot":"","sources":["../../../../src/shared/components/IFrameAndLoading.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,MAAM,gBAAgB,GAAG,CAAC,EACxB,KAAK,EACL,SAAS,GAIV,EAAE,EAAE;IACH,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,EAAE,YAAY,EAAE,eAAe,EAAE,kBAAkB,EAAE,UAAU,EAAE,GACrE,SAAS,EAAE,CAAC;IACd,MAAM,wBAAwB,GAC5B,UAAU,KAAK,OAAO,IAAI,CAAC,UAAU,IAAI,SAAS,CAAC,CAAC;IAEtD,OAAO,CACL;QACG,YAAY,IAAI,CACf,6BACE,KAAK,EAAE,eAAe,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE;YAEnE,oBAAC,wBAAwB,IAAC,OAAO,EAAE,GAAG,EAAE,CAAC,kBAAkB,CAAC,KAAK,CAAC,GAAI,CAClE,CACP;QAEA,KAAK,IAAI,CACR,oBAAC,YAAY;YACX;;gBAAa,KAAK,EAAE,OAAO,CAAO,CACrB,CAChB;QAEA,wBAAwB,IAAI,CAAC,KAAK,IAAI,CACrC,oBAAC,YAAY;YACX,oBAAC,WAAW,OAAG,CACF,CAChB,CACA,CACJ,CAAC;AACJ,CAAC,CAAC;AACF,OAAO,EAAE,gBAAgB,EAAE,CAAC","sourcesContent":["import React from \"react\";\nimport { useIframe } from \"../hooks/useIframe.js\";\nimport { useIsInIframe } from \"../hooks/useIsInIframe.js\";\nimport { CivicAuthIframeContainer } from \"./CivicAuthIframeContainer.js\";\nimport { BlockDisplay } from \"./BlockDisplay.js\";\nimport { LoadingIcon } from \"./LoadingIcon.js\";\n\nconst IFrameAndLoading = ({\n error,\n isLoading,\n}: {\n error: Error | null;\n isLoading: boolean;\n}) => {\n const isInIframe = useIsInIframe();\n const { renderIframe, iframeIsVisible, setIframeIsVisible, iframeMode } =\n useIframe();\n const showIframeLoadingOverlay =\n iframeMode === \"modal\" && (isInIframe || isLoading);\n\n return (\n <>\n {renderIframe && (\n <div\n style={iframeIsVisible ? { display: \"block\" } : { display: \"none\" }}\n >\n <CivicAuthIframeContainer onClose={() => setIframeIsVisible(false)} />\n </div>\n )}\n\n {error && (\n <BlockDisplay>\n <div>Error: {error?.message}</div>\n </BlockDisplay>\n )}\n\n {showIframeLoadingOverlay && !error && (\n <BlockDisplay>\n <LoadingIcon />\n </BlockDisplay>\n )}\n </>\n );\n};\nexport { IFrameAndLoading };\n"]}
@@ -1,5 +1,9 @@
1
1
  export { useToken } from "../../shared/hooks/useToken.js";
2
2
  export { useAuth } from "../../shared/hooks/useAuth.js";
3
- export { useConfig } from "../../shared/hooks/useConfig.js";
4
3
  export { useIframe } from "../../shared/hooks/useIframe.js";
4
+ export { useSession } from "../../shared/hooks/useSession.js";
5
+ export { useCivicAuthConfig } from "../../shared/hooks/useCivicAuthConfig.js";
6
+ export { useOAuthEndpoints } from "../../shared/hooks/useOAuthEndpoints.js";
7
+ export { useCurrentUrl } from "../../shared/hooks/useCurrentUrl.js";
8
+ export { useClientTokenExchangeSession } from "../../shared/hooks/useClientTokenExchangeSession.js";
5
9
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,6BAA6B,EAAE,MAAM,iDAAiD,CAAC"}
@@ -1,5 +1,9 @@
1
1
  export { useToken } from "../../shared/hooks/useToken.js";
2
2
  export { useAuth } from "../../shared/hooks/useAuth.js";
3
- export { useConfig } from "../../shared/hooks/useConfig.js";
4
3
  export { useIframe } from "../../shared/hooks/useIframe.js";
4
+ export { useSession } from "../../shared/hooks/useSession.js";
5
+ export { useCivicAuthConfig } from "../../shared/hooks/useCivicAuthConfig.js";
6
+ export { useOAuthEndpoints } from "../../shared/hooks/useOAuthEndpoints.js";
7
+ export { useCurrentUrl } from "../../shared/hooks/useCurrentUrl.js";
8
+ export { useClientTokenExchangeSession } from "../../shared/hooks/useClientTokenExchangeSession.js";
5
9
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/shared/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC","sourcesContent":["export { useToken } from \"@/shared/hooks/useToken.js\";\nexport { useAuth } from \"@/shared/hooks/useAuth.js\";\nexport { useConfig } from \"@/shared/hooks/useConfig.js\";\nexport { useIframe } from \"@/shared/hooks/useIframe.js\";\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/shared/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,6BAA6B,EAAE,MAAM,iDAAiD,CAAC","sourcesContent":["export { useToken } from \"@/shared/hooks/useToken.js\";\nexport { useAuth } from \"@/shared/hooks/useAuth.js\";\nexport { useIframe } from \"@/shared/hooks/useIframe.js\";\nexport { useSession } from \"@/shared/hooks/useSession.js\";\nexport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nexport { useOAuthEndpoints } from \"@/shared/hooks/useOAuthEndpoints.js\";\nexport { useCurrentUrl } from \"@/shared/hooks/useCurrentUrl.js\";\nexport { useClientTokenExchangeSession } from \"@/shared/hooks/useClientTokenExchangeSession.js\";\n"]}
@@ -0,0 +1,3 @@
1
+ declare const useCivicAuthConfig: () => import("../lib/types.js").CivicAuthConfig;
2
+ export { useCivicAuthConfig };
3
+ //# sourceMappingURL=useCivicAuthConfig.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCivicAuthConfig.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/useCivicAuthConfig.ts"],"names":[],"mappings":"AAKA,QAAA,MAAM,kBAAkB,iDAGvB,CAAC;AAEF,OAAO,EAAE,kBAAkB,EAAE,CAAC"}
@@ -0,0 +1,10 @@
1
+ "use client";
2
+ import { useContext } from "react";
3
+ import { CivicAuthConfigContext } from "../../shared/providers/CivicAuthConfigContext.js";
4
+ // TokenProvider will use this internal context to access Config
5
+ const useCivicAuthConfig = () => {
6
+ const context = useContext(CivicAuthConfigContext);
7
+ return context;
8
+ };
9
+ export { useCivicAuthConfig };
10
+ //# sourceMappingURL=useCivicAuthConfig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCivicAuthConfig.js","sourceRoot":"","sources":["../../../../src/shared/hooks/useCivicAuthConfig.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACnC,OAAO,EAAE,sBAAsB,EAAE,MAAM,8CAA8C,CAAC;AAEtF,gEAAgE;AAChE,MAAM,kBAAkB,GAAG,GAAG,EAAE;IAC9B,MAAM,OAAO,GAAG,UAAU,CAAC,sBAAsB,CAAC,CAAC;IACnD,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,OAAO,EAAE,kBAAkB,EAAE,CAAC","sourcesContent":["\"use client\";\nimport { useContext } from \"react\";\nimport { CivicAuthConfigContext } from \"@/shared/providers/CivicAuthConfigContext.js\";\n\n// TokenProvider will use this internal context to access Config\nconst useCivicAuthConfig = () => {\n const context = useContext(CivicAuthConfigContext);\n return context;\n};\n\nexport { useCivicAuthConfig };\n"]}
@@ -0,0 +1,3 @@
1
+ declare const useClientTokenExchangeSession: () => import("../../shared/providers/ClientTokenExchangeSessionProvider.js").ClientTokenExchangeSessionProviderOutput;
2
+ export { useClientTokenExchangeSession };
3
+ //# sourceMappingURL=useClientTokenExchangeSession.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useClientTokenExchangeSession.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/useClientTokenExchangeSession.ts"],"names":[],"mappings":"AAKA,QAAA,MAAM,6BAA6B,mHAMlC,CAAC;AAEF,OAAO,EAAE,6BAA6B,EAAE,CAAC"}
@@ -0,0 +1,13 @@
1
+ "use client";
2
+ import { useContext } from "react";
3
+ import { ClientTokenExchangeSessionContext } from "../../shared/providers/ClientTokenExchangeSessionProvider.js";
4
+ // TokenProvider will use this internal context to access session
5
+ const useClientTokenExchangeSession = () => {
6
+ const context = useContext(ClientTokenExchangeSessionContext);
7
+ if (!context) {
8
+ throw new Error("useSession must be used within an SessionProvider");
9
+ }
10
+ return context;
11
+ };
12
+ export { useClientTokenExchangeSession };
13
+ //# sourceMappingURL=useClientTokenExchangeSession.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useClientTokenExchangeSession.js","sourceRoot":"","sources":["../../../../src/shared/hooks/useClientTokenExchangeSession.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACnC,OAAO,EAAE,iCAAiC,EAAE,MAAM,0DAA0D,CAAC;AAE7G,iEAAiE;AACjE,MAAM,6BAA6B,GAAG,GAAG,EAAE;IACzC,MAAM,OAAO,GAAG,UAAU,CAAC,iCAAiC,CAAC,CAAC;IAC9D,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;IACvE,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,OAAO,EAAE,6BAA6B,EAAE,CAAC","sourcesContent":["\"use client\";\nimport { useContext } from \"react\";\nimport { ClientTokenExchangeSessionContext } from \"@/shared/providers/ClientTokenExchangeSessionProvider.js\";\n\n// TokenProvider will use this internal context to access session\nconst useClientTokenExchangeSession = () => {\n const context = useContext(ClientTokenExchangeSessionContext);\n if (!context) {\n throw new Error(\"useSession must be used within an SessionProvider\");\n }\n return context;\n};\n\nexport { useClientTokenExchangeSession };\n"]}
@@ -0,0 +1,3 @@
1
+ declare const useCurrentUrl: () => string | undefined;
2
+ export { useCurrentUrl };
3
+ //# sourceMappingURL=useCurrentUrl.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCurrentUrl.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/useCurrentUrl.ts"],"names":[],"mappings":"AAEA,QAAA,MAAM,aAAa,0BAuBlB,CAAC;AACF,OAAO,EAAE,aAAa,EAAE,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { useEffect, useState } from "react";
2
+ const useCurrentUrl = () => {
3
+ const [currentUrl, setCurrentUrl] = useState();
4
+ // update the current url when the url changes
5
+ useEffect(() => {
6
+ const handleUrlChange = () => {
7
+ setCurrentUrl(window.location.href);
8
+ };
9
+ window.addEventListener("popstate", handleUrlChange);
10
+ window.addEventListener("pushstate", handleUrlChange);
11
+ window.addEventListener("replacestate", handleUrlChange);
12
+ handleUrlChange();
13
+ return () => {
14
+ if (typeof window !== "undefined") {
15
+ window.removeEventListener("popstate", handleUrlChange);
16
+ window.removeEventListener("pushstate", handleUrlChange);
17
+ window.removeEventListener("replacestate", handleUrlChange);
18
+ }
19
+ };
20
+ }, []);
21
+ return currentUrl;
22
+ };
23
+ export { useCurrentUrl };
24
+ //# sourceMappingURL=useCurrentUrl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCurrentUrl.js","sourceRoot":"","sources":["../../../../src/shared/hooks/useCurrentUrl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAE5C,MAAM,aAAa,GAAG,GAAG,EAAE;IACzB,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,EAAsB,CAAC;IACnE,8CAA8C;IAC9C,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,eAAe,GAAG,GAAG,EAAE;YAC3B,aAAa,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACtC,CAAC,CAAC;QACF,MAAM,CAAC,gBAAgB,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;QACrD,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;QACtD,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;QAEzD,eAAe,EAAE,CAAC;QAElB,OAAO,GAAG,EAAE;YACV,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;gBAClC,MAAM,CAAC,mBAAmB,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;gBACxD,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;gBACzD,MAAM,CAAC,mBAAmB,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;YAC9D,CAAC;QACH,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,UAAU,CAAC;AACpB,CAAC,CAAC;AACF,OAAO,EAAE,aAAa,EAAE,CAAC","sourcesContent":["import { useEffect, useState } from \"react\";\n\nconst useCurrentUrl = () => {\n const [currentUrl, setCurrentUrl] = useState<string | undefined>();\n // update the current url when the url changes\n useEffect(() => {\n const handleUrlChange = () => {\n setCurrentUrl(window.location.href);\n };\n window.addEventListener(\"popstate\", handleUrlChange);\n window.addEventListener(\"pushstate\", handleUrlChange);\n window.addEventListener(\"replacestate\", handleUrlChange);\n\n handleUrlChange();\n\n return () => {\n if (typeof window !== \"undefined\") {\n window.removeEventListener(\"popstate\", handleUrlChange);\n window.removeEventListener(\"pushstate\", handleUrlChange);\n window.removeEventListener(\"replacestate\", handleUrlChange);\n }\n };\n }, []);\n\n return currentUrl;\n};\nexport { useCurrentUrl };\n"]}
@@ -0,0 +1,3 @@
1
+ declare const useIsInIframe: () => boolean;
2
+ export { useIsInIframe };
3
+ //# sourceMappingURL=useIsInIframe.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIsInIframe.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/useIsInIframe.ts"],"names":[],"mappings":"AAGA,QAAA,MAAM,aAAa,eASlB,CAAC;AACF,OAAO,EAAE,aAAa,EAAE,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { isWindowInIframe } from "../../lib/windowUtil.js";
2
+ import { useEffect, useState } from "react";
3
+ const useIsInIframe = () => {
4
+ const [isInIframe, setIsInIframe] = useState(true);
5
+ useEffect(() => {
6
+ if (typeof globalThis.window !== "undefined") {
7
+ const isInIframeVal = isWindowInIframe(globalThis.window);
8
+ setIsInIframe(isInIframeVal);
9
+ }
10
+ }, []);
11
+ return isInIframe;
12
+ };
13
+ export { useIsInIframe };
14
+ //# sourceMappingURL=useIsInIframe.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIsInIframe.js","sourceRoot":"","sources":["../../../../src/shared/hooks/useIsInIframe.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAE5C,MAAM,aAAa,GAAG,GAAG,EAAE;IACzB,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IACnD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,UAAU,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;YAC7C,MAAM,aAAa,GAAG,gBAAgB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YAC1D,aAAa,CAAC,aAAa,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC,EAAE,EAAE,CAAC,CAAC;IACP,OAAO,UAAU,CAAC;AACpB,CAAC,CAAC;AACF,OAAO,EAAE,aAAa,EAAE,CAAC","sourcesContent":["import { isWindowInIframe } from \"@/lib/windowUtil.js\";\nimport { useEffect, useState } from \"react\";\n\nconst useIsInIframe = () => {\n const [isInIframe, setIsInIframe] = useState(true);\n useEffect(() => {\n if (typeof globalThis.window !== \"undefined\") {\n const isInIframeVal = isWindowInIframe(globalThis.window);\n setIsInIframe(isInIframeVal);\n }\n }, []);\n return isInIframe;\n};\nexport { useIsInIframe };\n"]}