@civic/auth 0.4.3-alpha.0 → 0.4.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (808) hide show
  1. package/CHANGELOG.md +0 -7
  2. package/dist/shared/components/CivicAuthIframe.d.ts.map +1 -1
  3. package/dist/shared/components/CivicAuthIframe.js +20 -17
  4. package/dist/shared/components/CivicAuthIframe.js.map +1 -1
  5. package/dist/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  6. package/dist/shared/components/CivicAuthIframeContainer.js +4 -3
  7. package/dist/shared/components/CivicAuthIframeContainer.js.map +1 -1
  8. package/dist/shared/lib/iframeUtils.d.ts +5 -1
  9. package/dist/shared/lib/iframeUtils.d.ts.map +1 -1
  10. package/dist/shared/lib/iframeUtils.js +1 -3
  11. package/dist/shared/lib/iframeUtils.js.map +1 -1
  12. package/dist/shared/providers/IframeProvider.js +1 -1
  13. package/dist/shared/providers/IframeProvider.js.map +1 -1
  14. package/dist/shared/version.d.ts +1 -1
  15. package/dist/shared/version.d.ts.map +1 -1
  16. package/dist/shared/version.js +1 -1
  17. package/dist/shared/version.js.map +1 -1
  18. package/package.json +3 -3
  19. package/dist/cjs/browser/storage.d.ts +0 -10
  20. package/dist/cjs/browser/storage.d.ts.map +0 -1
  21. package/dist/cjs/browser/storage.js +0 -24
  22. package/dist/cjs/browser/storage.js.map +0 -1
  23. package/dist/cjs/config.d.ts +0 -3
  24. package/dist/cjs/config.d.ts.map +0 -1
  25. package/dist/cjs/config.js +0 -8
  26. package/dist/cjs/config.js.map +0 -1
  27. package/dist/cjs/constants.d.ts +0 -15
  28. package/dist/cjs/constants.d.ts.map +0 -1
  29. package/dist/cjs/constants.js +0 -44
  30. package/dist/cjs/constants.js.map +0 -1
  31. package/dist/cjs/index.d.ts +0 -8
  32. package/dist/cjs/index.d.ts.map +0 -1
  33. package/dist/cjs/index.js +0 -11
  34. package/dist/cjs/index.js.map +0 -1
  35. package/dist/cjs/lib/cookies.d.ts +0 -7
  36. package/dist/cjs/lib/cookies.d.ts.map +0 -1
  37. package/dist/cjs/lib/cookies.js +0 -29
  38. package/dist/cjs/lib/cookies.js.map +0 -1
  39. package/dist/cjs/lib/jwt.d.ts +0 -3
  40. package/dist/cjs/lib/jwt.d.ts.map +0 -1
  41. package/dist/cjs/lib/jwt.js +0 -13
  42. package/dist/cjs/lib/jwt.js.map +0 -1
  43. package/dist/cjs/lib/logger.d.ts +0 -26
  44. package/dist/cjs/lib/logger.d.ts.map +0 -1
  45. package/dist/cjs/lib/logger.js +0 -62
  46. package/dist/cjs/lib/logger.js.map +0 -1
  47. package/dist/cjs/lib/oauth.d.ts +0 -19
  48. package/dist/cjs/lib/oauth.d.ts.map +0 -1
  49. package/dist/cjs/lib/oauth.js +0 -74
  50. package/dist/cjs/lib/oauth.js.map +0 -1
  51. package/dist/cjs/lib/obj.d.ts +0 -3
  52. package/dist/cjs/lib/obj.d.ts.map +0 -1
  53. package/dist/cjs/lib/obj.js +0 -21
  54. package/dist/cjs/lib/obj.js.map +0 -1
  55. package/dist/cjs/lib/postMessage.d.ts +0 -4
  56. package/dist/cjs/lib/postMessage.d.ts.map +0 -1
  57. package/dist/cjs/lib/postMessage.js +0 -16
  58. package/dist/cjs/lib/postMessage.js.map +0 -1
  59. package/dist/cjs/lib/windowUtil.d.ts +0 -4
  60. package/dist/cjs/lib/windowUtil.d.ts.map +0 -1
  61. package/dist/cjs/lib/windowUtil.js +0 -35
  62. package/dist/cjs/lib/windowUtil.js.map +0 -1
  63. package/dist/cjs/nextjs/GetUser.d.ts +0 -6
  64. package/dist/cjs/nextjs/GetUser.d.ts.map +0 -1
  65. package/dist/cjs/nextjs/GetUser.js +0 -11
  66. package/dist/cjs/nextjs/GetUser.js.map +0 -1
  67. package/dist/cjs/nextjs/NextAuthenticationRefresherImpl.d.ts +0 -11
  68. package/dist/cjs/nextjs/NextAuthenticationRefresherImpl.d.ts.map +0 -1
  69. package/dist/cjs/nextjs/NextAuthenticationRefresherImpl.js +0 -21
  70. package/dist/cjs/nextjs/NextAuthenticationRefresherImpl.js.map +0 -1
  71. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.d.ts +0 -8
  72. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.d.ts.map +0 -1
  73. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js +0 -28
  74. package/dist/cjs/nextjs/NextClientAuthenticationRefresher.js.map +0 -1
  75. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.d.ts +0 -12
  76. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +0 -1
  77. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.js +0 -29
  78. package/dist/cjs/nextjs/NextServerAuthenticationRefresherImpl.js.map +0 -1
  79. package/dist/cjs/nextjs/config.d.ts +0 -209
  80. package/dist/cjs/nextjs/config.d.ts.map +0 -1
  81. package/dist/cjs/nextjs/config.js +0 -191
  82. package/dist/cjs/nextjs/config.js.map +0 -1
  83. package/dist/cjs/nextjs/cookies.d.ts +0 -16
  84. package/dist/cjs/nextjs/cookies.d.ts.map +0 -1
  85. package/dist/cjs/nextjs/cookies.js +0 -44
  86. package/dist/cjs/nextjs/cookies.js.map +0 -1
  87. package/dist/cjs/nextjs/hooks/index.d.ts +0 -2
  88. package/dist/cjs/nextjs/hooks/index.d.ts.map +0 -1
  89. package/dist/cjs/nextjs/hooks/index.js +0 -6
  90. package/dist/cjs/nextjs/hooks/index.js.map +0 -1
  91. package/dist/cjs/nextjs/hooks/usePrevious.d.ts +0 -2
  92. package/dist/cjs/nextjs/hooks/usePrevious.d.ts.map +0 -1
  93. package/dist/cjs/nextjs/hooks/usePrevious.js +0 -12
  94. package/dist/cjs/nextjs/hooks/usePrevious.js.map +0 -1
  95. package/dist/cjs/nextjs/hooks/useRefresh.d.ts +0 -6
  96. package/dist/cjs/nextjs/hooks/useRefresh.d.ts.map +0 -1
  97. package/dist/cjs/nextjs/hooks/useRefresh.js +0 -51
  98. package/dist/cjs/nextjs/hooks/useRefresh.js.map +0 -1
  99. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts +0 -8
  100. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +0 -1
  101. package/dist/cjs/nextjs/hooks/useUserCookie.js +0 -93
  102. package/dist/cjs/nextjs/hooks/useUserCookie.js.map +0 -1
  103. package/dist/cjs/nextjs/index.d.ts +0 -9
  104. package/dist/cjs/nextjs/index.d.ts.map +0 -1
  105. package/dist/cjs/nextjs/index.js +0 -27
  106. package/dist/cjs/nextjs/index.js.map +0 -1
  107. package/dist/cjs/nextjs/middleware/index.d.ts +0 -2
  108. package/dist/cjs/nextjs/middleware/index.d.ts.map +0 -1
  109. package/dist/cjs/nextjs/middleware/index.js +0 -10
  110. package/dist/cjs/nextjs/middleware/index.js.map +0 -1
  111. package/dist/cjs/nextjs/middleware.d.ts +0 -57
  112. package/dist/cjs/nextjs/middleware.d.ts.map +0 -1
  113. package/dist/cjs/nextjs/middleware.js +0 -110
  114. package/dist/cjs/nextjs/middleware.js.map +0 -1
  115. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +0 -9
  116. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
  117. package/dist/cjs/nextjs/providers/NextAuthProvider.js +0 -108
  118. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +0 -1
  119. package/dist/cjs/nextjs/routeHandler.d.ts +0 -19
  120. package/dist/cjs/nextjs/routeHandler.d.ts.map +0 -1
  121. package/dist/cjs/nextjs/routeHandler.js +0 -325
  122. package/dist/cjs/nextjs/routeHandler.js.map +0 -1
  123. package/dist/cjs/nextjs/utils.d.ts +0 -3
  124. package/dist/cjs/nextjs/utils.d.ts.map +0 -1
  125. package/dist/cjs/nextjs/utils.js +0 -9
  126. package/dist/cjs/nextjs/utils.js.map +0 -1
  127. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts +0 -17
  128. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts.map +0 -1
  129. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js +0 -40
  130. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js.map +0 -1
  131. package/dist/cjs/reactjs/components/LoadingSpinner.d.ts +0 -7
  132. package/dist/cjs/reactjs/components/LoadingSpinner.d.ts.map +0 -1
  133. package/dist/cjs/reactjs/components/LoadingSpinner.js +0 -33
  134. package/dist/cjs/reactjs/components/LoadingSpinner.js.map +0 -1
  135. package/dist/cjs/reactjs/components/SignInButton.d.ts +0 -9
  136. package/dist/cjs/reactjs/components/SignInButton.d.ts.map +0 -1
  137. package/dist/cjs/reactjs/components/SignInButton.js +0 -31
  138. package/dist/cjs/reactjs/components/SignInButton.js.map +0 -1
  139. package/dist/cjs/reactjs/components/SignOutButton.d.ts +0 -7
  140. package/dist/cjs/reactjs/components/SignOutButton.d.ts.map +0 -1
  141. package/dist/cjs/reactjs/components/SignOutButton.js +0 -27
  142. package/dist/cjs/reactjs/components/SignOutButton.js.map +0 -1
  143. package/dist/cjs/reactjs/components/UserButton.d.ts +0 -9
  144. package/dist/cjs/reactjs/components/UserButton.d.ts.map +0 -1
  145. package/dist/cjs/reactjs/components/UserButton.js +0 -145
  146. package/dist/cjs/reactjs/components/UserButton.js.map +0 -1
  147. package/dist/cjs/reactjs/components/index.d.ts +0 -6
  148. package/dist/cjs/reactjs/components/index.d.ts.map +0 -1
  149. package/dist/cjs/reactjs/components/index.js +0 -14
  150. package/dist/cjs/reactjs/components/index.js.map +0 -1
  151. package/dist/cjs/reactjs/components/utils.d.ts +0 -13
  152. package/dist/cjs/reactjs/components/utils.d.ts.map +0 -1
  153. package/dist/cjs/reactjs/components/utils.js +0 -31
  154. package/dist/cjs/reactjs/components/utils.js.map +0 -1
  155. package/dist/cjs/reactjs/hooks/index.d.ts +0 -3
  156. package/dist/cjs/reactjs/hooks/index.d.ts.map +0 -1
  157. package/dist/cjs/reactjs/hooks/index.js +0 -8
  158. package/dist/cjs/reactjs/hooks/index.js.map +0 -1
  159. package/dist/cjs/reactjs/hooks/useAuth.d.ts +0 -3
  160. package/dist/cjs/reactjs/hooks/useAuth.d.ts.map +0 -1
  161. package/dist/cjs/reactjs/hooks/useAuth.js +0 -15
  162. package/dist/cjs/reactjs/hooks/useAuth.js.map +0 -1
  163. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts +0 -3
  164. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  165. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js +0 -16
  166. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js.map +0 -1
  167. package/dist/cjs/reactjs/hooks/useSignIn.d.ts +0 -6
  168. package/dist/cjs/reactjs/hooks/useSignIn.d.ts.map +0 -1
  169. package/dist/cjs/reactjs/hooks/useSignIn.js +0 -38
  170. package/dist/cjs/reactjs/hooks/useSignIn.js.map +0 -1
  171. package/dist/cjs/reactjs/hooks/useUser.d.ts +0 -4
  172. package/dist/cjs/reactjs/hooks/useUser.d.ts.map +0 -1
  173. package/dist/cjs/reactjs/hooks/useUser.js +0 -15
  174. package/dist/cjs/reactjs/hooks/useUser.js.map +0 -1
  175. package/dist/cjs/reactjs/index.d.ts +0 -6
  176. package/dist/cjs/reactjs/index.d.ts.map +0 -1
  177. package/dist/cjs/reactjs/index.js +0 -32
  178. package/dist/cjs/reactjs/index.js.map +0 -1
  179. package/dist/cjs/reactjs/providers/AuthProvider.d.ts +0 -10
  180. package/dist/cjs/reactjs/providers/AuthProvider.d.ts.map +0 -1
  181. package/dist/cjs/reactjs/providers/AuthProvider.js +0 -99
  182. package/dist/cjs/reactjs/providers/AuthProvider.js.map +0 -1
  183. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts +0 -5
  184. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts.map +0 -1
  185. package/dist/cjs/reactjs/providers/CivicAuthProvider.js +0 -29
  186. package/dist/cjs/reactjs/providers/CivicAuthProvider.js.map +0 -1
  187. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
  188. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  189. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js +0 -146
  190. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  191. package/dist/cjs/reactjs/providers/index.d.ts +0 -8
  192. package/dist/cjs/reactjs/providers/index.d.ts.map +0 -1
  193. package/dist/cjs/reactjs/providers/index.js +0 -19
  194. package/dist/cjs/reactjs/providers/index.js.map +0 -1
  195. package/dist/cjs/server/ServerAuthenticationResolver.d.ts +0 -20
  196. package/dist/cjs/server/ServerAuthenticationResolver.d.ts.map +0 -1
  197. package/dist/cjs/server/ServerAuthenticationResolver.js +0 -71
  198. package/dist/cjs/server/ServerAuthenticationResolver.js.map +0 -1
  199. package/dist/cjs/server/config.d.ts +0 -11
  200. package/dist/cjs/server/config.d.ts.map +0 -1
  201. package/dist/cjs/server/config.js +0 -3
  202. package/dist/cjs/server/config.js.map +0 -1
  203. package/dist/cjs/server/index.d.ts +0 -9
  204. package/dist/cjs/server/index.d.ts.map +0 -1
  205. package/dist/cjs/server/index.js +0 -21
  206. package/dist/cjs/server/index.js.map +0 -1
  207. package/dist/cjs/server/login.d.ts +0 -17
  208. package/dist/cjs/server/login.d.ts.map +0 -1
  209. package/dist/cjs/server/login.js +0 -42
  210. package/dist/cjs/server/login.js.map +0 -1
  211. package/dist/cjs/server/logout.d.ts +0 -7
  212. package/dist/cjs/server/logout.d.ts.map +0 -1
  213. package/dist/cjs/server/logout.js +0 -26
  214. package/dist/cjs/server/logout.js.map +0 -1
  215. package/dist/cjs/server/refresh.d.ts +0 -7
  216. package/dist/cjs/server/refresh.d.ts.map +0 -1
  217. package/dist/cjs/server/refresh.js +0 -19
  218. package/dist/cjs/server/refresh.js.map +0 -1
  219. package/dist/cjs/services/AuthenticationService.d.ts +0 -93
  220. package/dist/cjs/services/AuthenticationService.d.ts.map +0 -1
  221. package/dist/cjs/services/AuthenticationService.js +0 -367
  222. package/dist/cjs/services/AuthenticationService.js.map +0 -1
  223. package/dist/cjs/services/PKCE.d.ts +0 -20
  224. package/dist/cjs/services/PKCE.d.ts.map +0 -1
  225. package/dist/cjs/services/PKCE.js +0 -50
  226. package/dist/cjs/services/PKCE.js.map +0 -1
  227. package/dist/cjs/services/types.d.ts +0 -24
  228. package/dist/cjs/services/types.d.ts.map +0 -1
  229. package/dist/cjs/services/types.js +0 -11
  230. package/dist/cjs/services/types.js.map +0 -1
  231. package/dist/cjs/shared/components/BlockDisplay.d.ts +0 -6
  232. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +0 -1
  233. package/dist/cjs/shared/components/BlockDisplay.js +0 -32
  234. package/dist/cjs/shared/components/BlockDisplay.js.map +0 -1
  235. package/dist/cjs/shared/components/CivicAuthIframe.d.ts +0 -9
  236. package/dist/cjs/shared/components/CivicAuthIframe.d.ts.map +0 -1
  237. package/dist/cjs/shared/components/CivicAuthIframe.js +0 -72
  238. package/dist/cjs/shared/components/CivicAuthIframe.js.map +0 -1
  239. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts +0 -14
  240. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
  241. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +0 -158
  242. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +0 -1
  243. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts +0 -6
  244. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +0 -1
  245. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js +0 -21
  246. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js.map +0 -1
  247. package/dist/cjs/shared/components/CloseIcon.d.ts +0 -3
  248. package/dist/cjs/shared/components/CloseIcon.d.ts.map +0 -1
  249. package/dist/cjs/shared/components/CloseIcon.js +0 -7
  250. package/dist/cjs/shared/components/CloseIcon.js.map +0 -1
  251. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +0 -7
  252. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +0 -1
  253. package/dist/cjs/shared/components/IFrameAndLoading.js +0 -39
  254. package/dist/cjs/shared/components/IFrameAndLoading.js.map +0 -1
  255. package/dist/cjs/shared/components/LoadingIcon.d.ts +0 -6
  256. package/dist/cjs/shared/components/LoadingIcon.d.ts.map +0 -1
  257. package/dist/cjs/shared/components/LoadingIcon.js +0 -28
  258. package/dist/cjs/shared/components/LoadingIcon.js.map +0 -1
  259. package/dist/cjs/shared/components/SVGLoading.d.ts +0 -4
  260. package/dist/cjs/shared/components/SVGLoading.d.ts.map +0 -1
  261. package/dist/cjs/shared/components/SVGLoading.js +0 -30
  262. package/dist/cjs/shared/components/SVGLoading.js.map +0 -1
  263. package/dist/cjs/shared/hooks/index.d.ts +0 -11
  264. package/dist/cjs/shared/hooks/index.d.ts.map +0 -1
  265. package/dist/cjs/shared/hooks/index.js +0 -24
  266. package/dist/cjs/shared/hooks/index.js.map +0 -1
  267. package/dist/cjs/shared/hooks/useAuth.d.ts +0 -3
  268. package/dist/cjs/shared/hooks/useAuth.d.ts.map +0 -1
  269. package/dist/cjs/shared/hooks/useAuth.js +0 -15
  270. package/dist/cjs/shared/hooks/useAuth.js.map +0 -1
  271. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +0 -3
  272. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +0 -1
  273. package/dist/cjs/shared/hooks/useCivicAuthConfig.js +0 -13
  274. package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +0 -1
  275. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +0 -3
  276. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  277. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +0 -16
  278. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +0 -1
  279. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts +0 -3
  280. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +0 -1
  281. package/dist/cjs/shared/hooks/useCurrentUrl.js +0 -27
  282. package/dist/cjs/shared/hooks/useCurrentUrl.js.map +0 -1
  283. package/dist/cjs/shared/hooks/useIframe.d.ts +0 -3
  284. package/dist/cjs/shared/hooks/useIframe.d.ts.map +0 -1
  285. package/dist/cjs/shared/hooks/useIframe.js +0 -16
  286. package/dist/cjs/shared/hooks/useIframe.js.map +0 -1
  287. package/dist/cjs/shared/hooks/useIsInIframe.d.ts +0 -3
  288. package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +0 -1
  289. package/dist/cjs/shared/hooks/useIsInIframe.js +0 -17
  290. package/dist/cjs/shared/hooks/useIsInIframe.js.map +0 -1
  291. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts +0 -4
  292. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +0 -1
  293. package/dist/cjs/shared/hooks/useOAuthEndpoints.js +0 -17
  294. package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +0 -1
  295. package/dist/cjs/shared/hooks/useRefresh.d.ts +0 -6
  296. package/dist/cjs/shared/hooks/useRefresh.d.ts.map +0 -1
  297. package/dist/cjs/shared/hooks/useRefresh.js +0 -49
  298. package/dist/cjs/shared/hooks/useRefresh.js.map +0 -1
  299. package/dist/cjs/shared/hooks/useSession.d.ts +0 -3
  300. package/dist/cjs/shared/hooks/useSession.d.ts.map +0 -1
  301. package/dist/cjs/shared/hooks/useSession.js +0 -16
  302. package/dist/cjs/shared/hooks/useSession.js.map +0 -1
  303. package/dist/cjs/shared/hooks/useSignIn.d.ts +0 -17
  304. package/dist/cjs/shared/hooks/useSignIn.d.ts.map +0 -1
  305. package/dist/cjs/shared/hooks/useSignIn.js +0 -171
  306. package/dist/cjs/shared/hooks/useSignIn.js.map +0 -1
  307. package/dist/cjs/shared/hooks/useToken.d.ts +0 -3
  308. package/dist/cjs/shared/hooks/useToken.d.ts.map +0 -1
  309. package/dist/cjs/shared/hooks/useToken.js +0 -15
  310. package/dist/cjs/shared/hooks/useToken.js.map +0 -1
  311. package/dist/cjs/shared/hooks/useWindowFocused.d.ts +0 -5
  312. package/dist/cjs/shared/hooks/useWindowFocused.d.ts.map +0 -1
  313. package/dist/cjs/shared/hooks/useWindowFocused.js +0 -24
  314. package/dist/cjs/shared/hooks/useWindowFocused.js.map +0 -1
  315. package/dist/cjs/shared/index.d.ts +0 -7
  316. package/dist/cjs/shared/index.d.ts.map +0 -1
  317. package/dist/cjs/shared/index.js +0 -25
  318. package/dist/cjs/shared/index.js.map +0 -1
  319. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts +0 -14
  320. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.d.ts.map +0 -1
  321. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js +0 -55
  322. package/dist/cjs/shared/lib/AuthenticationRefresherImpl.js.map +0 -1
  323. package/dist/cjs/shared/lib/BrowserAuthenticationRefresher.d.ts +0 -11
  324. package/dist/cjs/shared/lib/BrowserAuthenticationRefresher.d.ts.map +0 -1
  325. package/dist/cjs/shared/lib/BrowserAuthenticationRefresher.js +0 -63
  326. package/dist/cjs/shared/lib/BrowserAuthenticationRefresher.js.map +0 -1
  327. package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts +0 -9
  328. package/dist/cjs/shared/lib/BrowserCookieStorage.d.ts.map +0 -1
  329. package/dist/cjs/shared/lib/BrowserCookieStorage.js +0 -60
  330. package/dist/cjs/shared/lib/BrowserCookieStorage.js.map +0 -1
  331. package/dist/cjs/shared/lib/GenericAuthenticationRefresher copy.d.ts +0 -18
  332. package/dist/cjs/shared/lib/GenericAuthenticationRefresher copy.d.ts.map +0 -1
  333. package/dist/cjs/shared/lib/GenericAuthenticationRefresher copy.js +0 -85
  334. package/dist/cjs/shared/lib/GenericAuthenticationRefresher copy.js.map +0 -1
  335. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts +0 -14
  336. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
  337. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +0 -38
  338. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
  339. package/dist/cjs/shared/lib/UserSession.d.ts +0 -17
  340. package/dist/cjs/shared/lib/UserSession.d.ts.map +0 -1
  341. package/dist/cjs/shared/lib/UserSession.js +0 -27
  342. package/dist/cjs/shared/lib/UserSession.js.map +0 -1
  343. package/dist/cjs/shared/lib/iframeUtils.d.ts +0 -6
  344. package/dist/cjs/shared/lib/iframeUtils.d.ts.map +0 -1
  345. package/dist/cjs/shared/lib/iframeUtils.js +0 -11
  346. package/dist/cjs/shared/lib/iframeUtils.js.map +0 -1
  347. package/dist/cjs/shared/lib/session.d.ts +0 -4
  348. package/dist/cjs/shared/lib/session.d.ts.map +0 -1
  349. package/dist/cjs/shared/lib/session.js +0 -48
  350. package/dist/cjs/shared/lib/session.js.map +0 -1
  351. package/dist/cjs/shared/lib/storage.d.ts +0 -35
  352. package/dist/cjs/shared/lib/storage.d.ts.map +0 -1
  353. package/dist/cjs/shared/lib/storage.js +0 -21
  354. package/dist/cjs/shared/lib/storage.js.map +0 -1
  355. package/dist/cjs/shared/lib/types.d.ts +0 -39
  356. package/dist/cjs/shared/lib/types.d.ts.map +0 -1
  357. package/dist/cjs/shared/lib/types.js +0 -22
  358. package/dist/cjs/shared/lib/types.js.map +0 -1
  359. package/dist/cjs/shared/lib/util.d.ts +0 -40
  360. package/dist/cjs/shared/lib/util.d.ts.map +0 -1
  361. package/dist/cjs/shared/lib/util.js +0 -252
  362. package/dist/cjs/shared/lib/util.js.map +0 -1
  363. package/dist/cjs/shared/providers/AuthContext.d.ts +0 -12
  364. package/dist/cjs/shared/providers/AuthContext.d.ts.map +0 -1
  365. package/dist/cjs/shared/providers/AuthContext.js +0 -7
  366. package/dist/cjs/shared/providers/AuthContext.js.map +0 -1
  367. package/dist/cjs/shared/providers/AuthProvider.d.ts +0 -22
  368. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +0 -1
  369. package/dist/cjs/shared/providers/AuthProvider.js +0 -108
  370. package/dist/cjs/shared/providers/AuthProvider.js.map +0 -1
  371. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +0 -19
  372. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +0 -1
  373. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +0 -59
  374. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +0 -1
  375. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts +0 -6
  376. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +0 -1
  377. package/dist/cjs/shared/providers/CivicAuthProvider.js +0 -38
  378. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +0 -1
  379. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
  380. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  381. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +0 -168
  382. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  383. package/dist/cjs/shared/providers/IframeProvider.d.ts +0 -25
  384. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +0 -1
  385. package/dist/cjs/shared/providers/IframeProvider.js +0 -63
  386. package/dist/cjs/shared/providers/IframeProvider.js.map +0 -1
  387. package/dist/cjs/shared/providers/SessionProvider.d.ts +0 -19
  388. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +0 -1
  389. package/dist/cjs/shared/providers/SessionProvider.js +0 -28
  390. package/dist/cjs/shared/providers/SessionProvider.js.map +0 -1
  391. package/dist/cjs/shared/providers/TokenProvider.d.ts +0 -17
  392. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +0 -1
  393. package/dist/cjs/shared/providers/TokenProvider.js +0 -39
  394. package/dist/cjs/shared/providers/TokenProvider.js.map +0 -1
  395. package/dist/cjs/shared/providers/UserProvider.d.ts +0 -26
  396. package/dist/cjs/shared/providers/UserProvider.d.ts.map +0 -1
  397. package/dist/cjs/shared/providers/UserProvider.js +0 -69
  398. package/dist/cjs/shared/providers/UserProvider.js.map +0 -1
  399. package/dist/cjs/shared/providers/types.d.ts +0 -15
  400. package/dist/cjs/shared/providers/types.d.ts.map +0 -1
  401. package/dist/cjs/shared/providers/types.js +0 -3
  402. package/dist/cjs/shared/providers/types.js.map +0 -1
  403. package/dist/cjs/shared/version.d.ts +0 -2
  404. package/dist/cjs/shared/version.d.ts.map +0 -1
  405. package/dist/cjs/shared/version.js +0 -6
  406. package/dist/cjs/shared/version.js.map +0 -1
  407. package/dist/cjs/types.d.ts +0 -163
  408. package/dist/cjs/types.d.ts.map +0 -1
  409. package/dist/cjs/types.js +0 -20
  410. package/dist/cjs/types.js.map +0 -1
  411. package/dist/cjs/utils.d.ts +0 -15
  412. package/dist/cjs/utils.d.ts.map +0 -1
  413. package/dist/cjs/utils.js +0 -47
  414. package/dist/cjs/utils.js.map +0 -1
  415. package/dist/cjs/version.d.ts +0 -2
  416. package/dist/cjs/version.d.ts.map +0 -1
  417. package/dist/cjs/version.js +0 -6
  418. package/dist/cjs/version.js.map +0 -1
  419. package/dist/esm/browser/storage.d.ts +0 -10
  420. package/dist/esm/browser/storage.d.ts.map +0 -1
  421. package/dist/esm/browser/storage.js +0 -20
  422. package/dist/esm/browser/storage.js.map +0 -1
  423. package/dist/esm/config.d.ts +0 -3
  424. package/dist/esm/config.d.ts.map +0 -1
  425. package/dist/esm/config.js +0 -5
  426. package/dist/esm/config.js.map +0 -1
  427. package/dist/esm/constants.d.ts +0 -15
  428. package/dist/esm/constants.d.ts.map +0 -1
  429. package/dist/esm/constants.js +0 -29
  430. package/dist/esm/constants.js.map +0 -1
  431. package/dist/esm/index.d.ts +0 -8
  432. package/dist/esm/index.d.ts.map +0 -1
  433. package/dist/esm/index.js +0 -6
  434. package/dist/esm/index.js.map +0 -1
  435. package/dist/esm/lib/cookies.d.ts +0 -7
  436. package/dist/esm/lib/cookies.d.ts.map +0 -1
  437. package/dist/esm/lib/cookies.js +0 -26
  438. package/dist/esm/lib/cookies.js.map +0 -1
  439. package/dist/esm/lib/jwt.d.ts +0 -3
  440. package/dist/esm/lib/jwt.d.ts.map +0 -1
  441. package/dist/esm/lib/jwt.js +0 -9
  442. package/dist/esm/lib/jwt.js.map +0 -1
  443. package/dist/esm/lib/logger.d.ts +0 -26
  444. package/dist/esm/lib/logger.d.ts.map +0 -1
  445. package/dist/esm/lib/logger.js +0 -55
  446. package/dist/esm/lib/logger.js.map +0 -1
  447. package/dist/esm/lib/oauth.d.ts +0 -19
  448. package/dist/esm/lib/oauth.d.ts.map +0 -1
  449. package/dist/esm/lib/oauth.js +0 -67
  450. package/dist/esm/lib/oauth.js.map +0 -1
  451. package/dist/esm/lib/obj.d.ts +0 -3
  452. package/dist/esm/lib/obj.d.ts.map +0 -1
  453. package/dist/esm/lib/obj.js +0 -18
  454. package/dist/esm/lib/obj.js.map +0 -1
  455. package/dist/esm/lib/postMessage.d.ts +0 -4
  456. package/dist/esm/lib/postMessage.d.ts.map +0 -1
  457. package/dist/esm/lib/postMessage.js +0 -13
  458. package/dist/esm/lib/postMessage.js.map +0 -1
  459. package/dist/esm/lib/windowUtil.d.ts +0 -4
  460. package/dist/esm/lib/windowUtil.d.ts.map +0 -1
  461. package/dist/esm/lib/windowUtil.js +0 -31
  462. package/dist/esm/lib/windowUtil.js.map +0 -1
  463. package/dist/esm/nextjs/GetUser.d.ts +0 -6
  464. package/dist/esm/nextjs/GetUser.d.ts.map +0 -1
  465. package/dist/esm/nextjs/GetUser.js +0 -7
  466. package/dist/esm/nextjs/GetUser.js.map +0 -1
  467. package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts +0 -8
  468. package/dist/esm/nextjs/NextClientAuthenticationRefresher.d.ts.map +0 -1
  469. package/dist/esm/nextjs/NextClientAuthenticationRefresher.js +0 -24
  470. package/dist/esm/nextjs/NextClientAuthenticationRefresher.js.map +0 -1
  471. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.d.ts +0 -12
  472. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.d.ts.map +0 -1
  473. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.js +0 -25
  474. package/dist/esm/nextjs/NextServerAuthenticationRefresherImpl.js.map +0 -1
  475. package/dist/esm/nextjs/config.d.ts +0 -209
  476. package/dist/esm/nextjs/config.d.ts.map +0 -1
  477. package/dist/esm/nextjs/config.js +0 -186
  478. package/dist/esm/nextjs/config.js.map +0 -1
  479. package/dist/esm/nextjs/cookies.d.ts +0 -16
  480. package/dist/esm/nextjs/cookies.d.ts.map +0 -1
  481. package/dist/esm/nextjs/cookies.js +0 -41
  482. package/dist/esm/nextjs/cookies.js.map +0 -1
  483. package/dist/esm/nextjs/hooks/index.d.ts +0 -2
  484. package/dist/esm/nextjs/hooks/index.d.ts.map +0 -1
  485. package/dist/esm/nextjs/hooks/index.js +0 -2
  486. package/dist/esm/nextjs/hooks/index.js.map +0 -1
  487. package/dist/esm/nextjs/hooks/usePrevious.d.ts +0 -2
  488. package/dist/esm/nextjs/hooks/usePrevious.d.ts.map +0 -1
  489. package/dist/esm/nextjs/hooks/usePrevious.js +0 -9
  490. package/dist/esm/nextjs/hooks/usePrevious.js.map +0 -1
  491. package/dist/esm/nextjs/hooks/useRefresh.d.ts +0 -6
  492. package/dist/esm/nextjs/hooks/useRefresh.d.ts.map +0 -1
  493. package/dist/esm/nextjs/hooks/useRefresh.js +0 -48
  494. package/dist/esm/nextjs/hooks/useRefresh.js.map +0 -1
  495. package/dist/esm/nextjs/hooks/useUserCookie.d.ts +0 -8
  496. package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +0 -1
  497. package/dist/esm/nextjs/hooks/useUserCookie.js +0 -89
  498. package/dist/esm/nextjs/hooks/useUserCookie.js.map +0 -1
  499. package/dist/esm/nextjs/index.d.ts +0 -9
  500. package/dist/esm/nextjs/index.d.ts.map +0 -1
  501. package/dist/esm/nextjs/index.js +0 -17
  502. package/dist/esm/nextjs/index.js.map +0 -1
  503. package/dist/esm/nextjs/middleware/index.d.ts +0 -2
  504. package/dist/esm/nextjs/middleware/index.d.ts.map +0 -1
  505. package/dist/esm/nextjs/middleware/index.js +0 -4
  506. package/dist/esm/nextjs/middleware/index.js.map +0 -1
  507. package/dist/esm/nextjs/middleware.d.ts +0 -57
  508. package/dist/esm/nextjs/middleware.d.ts.map +0 -1
  509. package/dist/esm/nextjs/middleware.js +0 -101
  510. package/dist/esm/nextjs/middleware.js.map +0 -1
  511. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +0 -9
  512. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
  513. package/dist/esm/nextjs/providers/NextAuthProvider.js +0 -105
  514. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +0 -1
  515. package/dist/esm/nextjs/routeHandler.d.ts +0 -19
  516. package/dist/esm/nextjs/routeHandler.d.ts.map +0 -1
  517. package/dist/esm/nextjs/routeHandler.js +0 -319
  518. package/dist/esm/nextjs/routeHandler.js.map +0 -1
  519. package/dist/esm/nextjs/utils.d.ts +0 -3
  520. package/dist/esm/nextjs/utils.d.ts.map +0 -1
  521. package/dist/esm/nextjs/utils.js +0 -5
  522. package/dist/esm/nextjs/utils.js.map +0 -1
  523. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts +0 -17
  524. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts.map +0 -1
  525. package/dist/esm/reactjs/components/ButtonContentOrLoader.js +0 -37
  526. package/dist/esm/reactjs/components/ButtonContentOrLoader.js.map +0 -1
  527. package/dist/esm/reactjs/components/SignInButton.d.ts +0 -9
  528. package/dist/esm/reactjs/components/SignInButton.d.ts.map +0 -1
  529. package/dist/esm/reactjs/components/SignInButton.js +0 -28
  530. package/dist/esm/reactjs/components/SignInButton.js.map +0 -1
  531. package/dist/esm/reactjs/components/SignOutButton.d.ts +0 -7
  532. package/dist/esm/reactjs/components/SignOutButton.d.ts.map +0 -1
  533. package/dist/esm/reactjs/components/SignOutButton.js +0 -24
  534. package/dist/esm/reactjs/components/SignOutButton.js.map +0 -1
  535. package/dist/esm/reactjs/components/UserButton.d.ts +0 -9
  536. package/dist/esm/reactjs/components/UserButton.d.ts.map +0 -1
  537. package/dist/esm/reactjs/components/UserButton.js +0 -142
  538. package/dist/esm/reactjs/components/UserButton.js.map +0 -1
  539. package/dist/esm/reactjs/components/index.d.ts +0 -6
  540. package/dist/esm/reactjs/components/index.d.ts.map +0 -1
  541. package/dist/esm/reactjs/components/index.js +0 -6
  542. package/dist/esm/reactjs/components/index.js.map +0 -1
  543. package/dist/esm/reactjs/components/utils.d.ts +0 -13
  544. package/dist/esm/reactjs/components/utils.d.ts.map +0 -1
  545. package/dist/esm/reactjs/components/utils.js +0 -27
  546. package/dist/esm/reactjs/components/utils.js.map +0 -1
  547. package/dist/esm/reactjs/hooks/index.d.ts +0 -3
  548. package/dist/esm/reactjs/hooks/index.d.ts.map +0 -1
  549. package/dist/esm/reactjs/hooks/index.js +0 -3
  550. package/dist/esm/reactjs/hooks/index.js.map +0 -1
  551. package/dist/esm/reactjs/hooks/useAuth.d.ts +0 -3
  552. package/dist/esm/reactjs/hooks/useAuth.d.ts.map +0 -1
  553. package/dist/esm/reactjs/hooks/useAuth.js +0 -12
  554. package/dist/esm/reactjs/hooks/useAuth.js.map +0 -1
  555. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts +0 -3
  556. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  557. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js +0 -13
  558. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js.map +0 -1
  559. package/dist/esm/reactjs/hooks/useSignIn.d.ts +0 -6
  560. package/dist/esm/reactjs/hooks/useSignIn.d.ts.map +0 -1
  561. package/dist/esm/reactjs/hooks/useSignIn.js +0 -34
  562. package/dist/esm/reactjs/hooks/useSignIn.js.map +0 -1
  563. package/dist/esm/reactjs/hooks/useUser.d.ts +0 -4
  564. package/dist/esm/reactjs/hooks/useUser.d.ts.map +0 -1
  565. package/dist/esm/reactjs/hooks/useUser.js +0 -12
  566. package/dist/esm/reactjs/hooks/useUser.js.map +0 -1
  567. package/dist/esm/reactjs/index.d.ts +0 -6
  568. package/dist/esm/reactjs/index.d.ts.map +0 -1
  569. package/dist/esm/reactjs/index.js +0 -10
  570. package/dist/esm/reactjs/index.js.map +0 -1
  571. package/dist/esm/reactjs/providers/AuthProvider.d.ts +0 -10
  572. package/dist/esm/reactjs/providers/AuthProvider.d.ts.map +0 -1
  573. package/dist/esm/reactjs/providers/AuthProvider.js +0 -97
  574. package/dist/esm/reactjs/providers/AuthProvider.js.map +0 -1
  575. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts +0 -5
  576. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts.map +0 -1
  577. package/dist/esm/reactjs/providers/CivicAuthProvider.js +0 -27
  578. package/dist/esm/reactjs/providers/CivicAuthProvider.js.map +0 -1
  579. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
  580. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  581. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js +0 -142
  582. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  583. package/dist/esm/reactjs/providers/index.d.ts +0 -8
  584. package/dist/esm/reactjs/providers/index.d.ts.map +0 -1
  585. package/dist/esm/reactjs/providers/index.js +0 -7
  586. package/dist/esm/reactjs/providers/index.js.map +0 -1
  587. package/dist/esm/server/ServerAuthenticationResolver.d.ts +0 -20
  588. package/dist/esm/server/ServerAuthenticationResolver.d.ts.map +0 -1
  589. package/dist/esm/server/ServerAuthenticationResolver.js +0 -67
  590. package/dist/esm/server/ServerAuthenticationResolver.js.map +0 -1
  591. package/dist/esm/server/config.d.ts +0 -11
  592. package/dist/esm/server/config.d.ts.map +0 -1
  593. package/dist/esm/server/config.js +0 -2
  594. package/dist/esm/server/config.js.map +0 -1
  595. package/dist/esm/server/index.d.ts +0 -9
  596. package/dist/esm/server/index.d.ts.map +0 -1
  597. package/dist/esm/server/index.js +0 -9
  598. package/dist/esm/server/index.js.map +0 -1
  599. package/dist/esm/server/login.d.ts +0 -17
  600. package/dist/esm/server/login.d.ts.map +0 -1
  601. package/dist/esm/server/login.js +0 -37
  602. package/dist/esm/server/login.js.map +0 -1
  603. package/dist/esm/server/logout.d.ts +0 -7
  604. package/dist/esm/server/logout.d.ts.map +0 -1
  605. package/dist/esm/server/logout.js +0 -23
  606. package/dist/esm/server/logout.js.map +0 -1
  607. package/dist/esm/server/refresh.d.ts +0 -7
  608. package/dist/esm/server/refresh.d.ts.map +0 -1
  609. package/dist/esm/server/refresh.js +0 -16
  610. package/dist/esm/server/refresh.js.map +0 -1
  611. package/dist/esm/services/AuthenticationService.d.ts +0 -93
  612. package/dist/esm/services/AuthenticationService.d.ts.map +0 -1
  613. package/dist/esm/services/AuthenticationService.js +0 -361
  614. package/dist/esm/services/AuthenticationService.js.map +0 -1
  615. package/dist/esm/services/PKCE.d.ts +0 -20
  616. package/dist/esm/services/PKCE.d.ts.map +0 -1
  617. package/dist/esm/services/PKCE.js +0 -44
  618. package/dist/esm/services/PKCE.js.map +0 -1
  619. package/dist/esm/services/types.d.ts +0 -24
  620. package/dist/esm/services/types.d.ts.map +0 -1
  621. package/dist/esm/services/types.js +0 -7
  622. package/dist/esm/services/types.js.map +0 -1
  623. package/dist/esm/shared/components/BlockDisplay.d.ts +0 -6
  624. package/dist/esm/shared/components/BlockDisplay.d.ts.map +0 -1
  625. package/dist/esm/shared/components/BlockDisplay.js +0 -29
  626. package/dist/esm/shared/components/BlockDisplay.js.map +0 -1
  627. package/dist/esm/shared/components/CivicAuthIframe.d.ts +0 -9
  628. package/dist/esm/shared/components/CivicAuthIframe.d.ts.map +0 -1
  629. package/dist/esm/shared/components/CivicAuthIframe.js +0 -33
  630. package/dist/esm/shared/components/CivicAuthIframe.js.map +0 -1
  631. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts +0 -14
  632. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
  633. package/dist/esm/shared/components/CivicAuthIframeContainer.js +0 -154
  634. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +0 -1
  635. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts +0 -6
  636. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +0 -1
  637. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js +0 -19
  638. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js.map +0 -1
  639. package/dist/esm/shared/components/CloseIcon.d.ts +0 -3
  640. package/dist/esm/shared/components/CloseIcon.d.ts.map +0 -1
  641. package/dist/esm/shared/components/CloseIcon.js +0 -5
  642. package/dist/esm/shared/components/CloseIcon.js.map +0 -1
  643. package/dist/esm/shared/components/IFrameAndLoading.d.ts +0 -7
  644. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +0 -1
  645. package/dist/esm/shared/components/IFrameAndLoading.js +0 -36
  646. package/dist/esm/shared/components/IFrameAndLoading.js.map +0 -1
  647. package/dist/esm/shared/components/LoadingIcon.d.ts +0 -6
  648. package/dist/esm/shared/components/LoadingIcon.d.ts.map +0 -1
  649. package/dist/esm/shared/components/LoadingIcon.js +0 -26
  650. package/dist/esm/shared/components/LoadingIcon.js.map +0 -1
  651. package/dist/esm/shared/components/SVGLoading.d.ts +0 -4
  652. package/dist/esm/shared/components/SVGLoading.d.ts.map +0 -1
  653. package/dist/esm/shared/components/SVGLoading.js +0 -28
  654. package/dist/esm/shared/components/SVGLoading.js.map +0 -1
  655. package/dist/esm/shared/hooks/index.d.ts +0 -11
  656. package/dist/esm/shared/hooks/index.d.ts.map +0 -1
  657. package/dist/esm/shared/hooks/index.js +0 -11
  658. package/dist/esm/shared/hooks/index.js.map +0 -1
  659. package/dist/esm/shared/hooks/useAuth.d.ts +0 -3
  660. package/dist/esm/shared/hooks/useAuth.d.ts.map +0 -1
  661. package/dist/esm/shared/hooks/useAuth.js +0 -12
  662. package/dist/esm/shared/hooks/useAuth.js.map +0 -1
  663. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts +0 -3
  664. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +0 -1
  665. package/dist/esm/shared/hooks/useCivicAuthConfig.js +0 -10
  666. package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +0 -1
  667. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +0 -3
  668. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +0 -1
  669. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +0 -13
  670. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +0 -1
  671. package/dist/esm/shared/hooks/useCurrentUrl.d.ts +0 -3
  672. package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +0 -1
  673. package/dist/esm/shared/hooks/useCurrentUrl.js +0 -24
  674. package/dist/esm/shared/hooks/useCurrentUrl.js.map +0 -1
  675. package/dist/esm/shared/hooks/useIframe.d.ts +0 -3
  676. package/dist/esm/shared/hooks/useIframe.d.ts.map +0 -1
  677. package/dist/esm/shared/hooks/useIframe.js +0 -13
  678. package/dist/esm/shared/hooks/useIframe.js.map +0 -1
  679. package/dist/esm/shared/hooks/useIsInIframe.d.ts +0 -3
  680. package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +0 -1
  681. package/dist/esm/shared/hooks/useIsInIframe.js +0 -14
  682. package/dist/esm/shared/hooks/useIsInIframe.js.map +0 -1
  683. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +0 -4
  684. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +0 -1
  685. package/dist/esm/shared/hooks/useOAuthEndpoints.js +0 -14
  686. package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +0 -1
  687. package/dist/esm/shared/hooks/useRefresh.d.ts +0 -6
  688. package/dist/esm/shared/hooks/useRefresh.d.ts.map +0 -1
  689. package/dist/esm/shared/hooks/useRefresh.js +0 -46
  690. package/dist/esm/shared/hooks/useRefresh.js.map +0 -1
  691. package/dist/esm/shared/hooks/useSession.d.ts +0 -3
  692. package/dist/esm/shared/hooks/useSession.d.ts.map +0 -1
  693. package/dist/esm/shared/hooks/useSession.js +0 -13
  694. package/dist/esm/shared/hooks/useSession.js.map +0 -1
  695. package/dist/esm/shared/hooks/useSignIn.d.ts +0 -17
  696. package/dist/esm/shared/hooks/useSignIn.d.ts.map +0 -1
  697. package/dist/esm/shared/hooks/useSignIn.js +0 -168
  698. package/dist/esm/shared/hooks/useSignIn.js.map +0 -1
  699. package/dist/esm/shared/hooks/useToken.d.ts +0 -3
  700. package/dist/esm/shared/hooks/useToken.d.ts.map +0 -1
  701. package/dist/esm/shared/hooks/useToken.js +0 -12
  702. package/dist/esm/shared/hooks/useToken.js.map +0 -1
  703. package/dist/esm/shared/hooks/useWindowFocused.d.ts +0 -5
  704. package/dist/esm/shared/hooks/useWindowFocused.d.ts.map +0 -1
  705. package/dist/esm/shared/hooks/useWindowFocused.js +0 -21
  706. package/dist/esm/shared/hooks/useWindowFocused.js.map +0 -1
  707. package/dist/esm/shared/index.d.ts +0 -7
  708. package/dist/esm/shared/index.d.ts.map +0 -1
  709. package/dist/esm/shared/index.js +0 -18
  710. package/dist/esm/shared/index.js.map +0 -1
  711. package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts +0 -14
  712. package/dist/esm/shared/lib/AuthenticationRefresherImpl.d.ts.map +0 -1
  713. package/dist/esm/shared/lib/AuthenticationRefresherImpl.js +0 -51
  714. package/dist/esm/shared/lib/AuthenticationRefresherImpl.js.map +0 -1
  715. package/dist/esm/shared/lib/BrowserAuthenticationRefresher.d.ts +0 -11
  716. package/dist/esm/shared/lib/BrowserAuthenticationRefresher.d.ts.map +0 -1
  717. package/dist/esm/shared/lib/BrowserAuthenticationRefresher.js +0 -59
  718. package/dist/esm/shared/lib/BrowserAuthenticationRefresher.js.map +0 -1
  719. package/dist/esm/shared/lib/BrowserCookieStorage.d.ts +0 -9
  720. package/dist/esm/shared/lib/BrowserCookieStorage.d.ts.map +0 -1
  721. package/dist/esm/shared/lib/BrowserCookieStorage.js +0 -56
  722. package/dist/esm/shared/lib/BrowserCookieStorage.js.map +0 -1
  723. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +0 -14
  724. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
  725. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js +0 -34
  726. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
  727. package/dist/esm/shared/lib/UserSession.d.ts +0 -17
  728. package/dist/esm/shared/lib/UserSession.d.ts.map +0 -1
  729. package/dist/esm/shared/lib/UserSession.js +0 -23
  730. package/dist/esm/shared/lib/UserSession.js.map +0 -1
  731. package/dist/esm/shared/lib/iframeUtils.d.ts +0 -6
  732. package/dist/esm/shared/lib/iframeUtils.d.ts.map +0 -1
  733. package/dist/esm/shared/lib/iframeUtils.js +0 -7
  734. package/dist/esm/shared/lib/iframeUtils.js.map +0 -1
  735. package/dist/esm/shared/lib/session.d.ts +0 -4
  736. package/dist/esm/shared/lib/session.d.ts.map +0 -1
  737. package/dist/esm/shared/lib/session.js +0 -44
  738. package/dist/esm/shared/lib/session.js.map +0 -1
  739. package/dist/esm/shared/lib/storage.d.ts +0 -35
  740. package/dist/esm/shared/lib/storage.d.ts.map +0 -1
  741. package/dist/esm/shared/lib/storage.js +0 -17
  742. package/dist/esm/shared/lib/storage.js.map +0 -1
  743. package/dist/esm/shared/lib/types.d.ts +0 -39
  744. package/dist/esm/shared/lib/types.d.ts.map +0 -1
  745. package/dist/esm/shared/lib/types.js +0 -19
  746. package/dist/esm/shared/lib/types.js.map +0 -1
  747. package/dist/esm/shared/lib/util.d.ts +0 -40
  748. package/dist/esm/shared/lib/util.d.ts.map +0 -1
  749. package/dist/esm/shared/lib/util.js +0 -200
  750. package/dist/esm/shared/lib/util.js.map +0 -1
  751. package/dist/esm/shared/providers/AuthContext.d.ts +0 -12
  752. package/dist/esm/shared/providers/AuthContext.d.ts.map +0 -1
  753. package/dist/esm/shared/providers/AuthContext.js +0 -4
  754. package/dist/esm/shared/providers/AuthContext.js.map +0 -1
  755. package/dist/esm/shared/providers/AuthProvider.d.ts +0 -22
  756. package/dist/esm/shared/providers/AuthProvider.d.ts.map +0 -1
  757. package/dist/esm/shared/providers/AuthProvider.js +0 -72
  758. package/dist/esm/shared/providers/AuthProvider.js.map +0 -1
  759. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +0 -19
  760. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +0 -1
  761. package/dist/esm/shared/providers/CivicAuthConfigContext.js +0 -55
  762. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +0 -1
  763. package/dist/esm/shared/providers/CivicAuthProvider.d.ts +0 -6
  764. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +0 -1
  765. package/dist/esm/shared/providers/CivicAuthProvider.js +0 -32
  766. package/dist/esm/shared/providers/CivicAuthProvider.js.map +0 -1
  767. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +0 -17
  768. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +0 -1
  769. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +0 -131
  770. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +0 -1
  771. package/dist/esm/shared/providers/IframeProvider.d.ts +0 -25
  772. package/dist/esm/shared/providers/IframeProvider.d.ts.map +0 -1
  773. package/dist/esm/shared/providers/IframeProvider.js +0 -59
  774. package/dist/esm/shared/providers/IframeProvider.js.map +0 -1
  775. package/dist/esm/shared/providers/SessionProvider.d.ts +0 -19
  776. package/dist/esm/shared/providers/SessionProvider.d.ts.map +0 -1
  777. package/dist/esm/shared/providers/SessionProvider.js +0 -24
  778. package/dist/esm/shared/providers/SessionProvider.js.map +0 -1
  779. package/dist/esm/shared/providers/TokenProvider.d.ts +0 -17
  780. package/dist/esm/shared/providers/TokenProvider.d.ts.map +0 -1
  781. package/dist/esm/shared/providers/TokenProvider.js +0 -35
  782. package/dist/esm/shared/providers/TokenProvider.js.map +0 -1
  783. package/dist/esm/shared/providers/UserProvider.d.ts +0 -26
  784. package/dist/esm/shared/providers/UserProvider.d.ts.map +0 -1
  785. package/dist/esm/shared/providers/UserProvider.js +0 -65
  786. package/dist/esm/shared/providers/UserProvider.js.map +0 -1
  787. package/dist/esm/shared/providers/types.d.ts +0 -15
  788. package/dist/esm/shared/providers/types.d.ts.map +0 -1
  789. package/dist/esm/shared/providers/types.js +0 -2
  790. package/dist/esm/shared/providers/types.js.map +0 -1
  791. package/dist/esm/shared/version.d.ts +0 -2
  792. package/dist/esm/shared/version.d.ts.map +0 -1
  793. package/dist/esm/shared/version.js +0 -3
  794. package/dist/esm/shared/version.js.map +0 -1
  795. package/dist/esm/types.d.ts +0 -163
  796. package/dist/esm/types.d.ts.map +0 -1
  797. package/dist/esm/types.js +0 -17
  798. package/dist/esm/types.js.map +0 -1
  799. package/dist/esm/utils.d.ts +0 -15
  800. package/dist/esm/utils.d.ts.map +0 -1
  801. package/dist/esm/utils.js +0 -42
  802. package/dist/esm/utils.js.map +0 -1
  803. package/dist/esm/version.d.ts +0 -2
  804. package/dist/esm/version.d.ts.map +0 -1
  805. package/dist/esm/version.js +0 -3
  806. package/dist/esm/version.js.map +0 -1
  807. package/dist/tsconfig.cjs.tsbuildinfo +0 -1
  808. package/dist/tsconfig.esm.tsbuildinfo +0 -1
@@ -1 +0,0 @@
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 IframeAuthMessage,\n LoginAppDesignOptions,\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, LOGOUT_STATE } from \"@/constants.js\";\nimport { validateLoginAppPostMessage } from \"@/lib/postMessage.js\";\nimport { getUser } from \"@/shared/lib/session.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport { getIframeRef } from \"@/shared/lib/iframeUtils.js\";\n\nexport type GenericAuthenticationInitiatorConfig = {\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\nexport type BrowserAuthenticationInitiatorConfig = Omit<\n GenericAuthenticationInitiatorConfig,\n \"state\"\n> & {\n logoutUrl?: string;\n logoutRedirectUrl: 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};\n\nconst defaultSetDesignOptions = (value: LoginAppDesignOptions) => {\n localStorage.setItem(\"loginAppDesign\", JSON.stringify(value));\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: BrowserAuthenticationInitiatorConfig;\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(\n config: typeof this.config,\n readonly setDesignOptions = defaultSetDesignOptions,\n ) {\n this.config = 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 if (loginMessage.type === \"generatePopupFailed\") {\n this.handleLoginAppPopupFailed(\n (loginMessage.data as { url: string }).url,\n );\n return;\n }\n if (loginMessage.type === \"design\") {\n // TODO handle the design message\n this.handleLoginAppDesignUpdate(\n loginMessage.data as LoginAppDesignOptions,\n );\n return;\n }\n }\n };\n\n window.addEventListener(\"message\", this.postMessageHandler);\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 async handleLoginAppDesignUpdate(options: LoginAppDesignOptions) {\n this.setDesignOptions(options);\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 if (this.config.displayMode === \"iframe\") {\n const ref = getIframeRef(iframeRef);\n ref.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 // TODO handle the 'onclose' event to clean up and reset the authStatus\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 protected handleIframeUrlChange(\n iframe: HTMLIFrameElement,\n expectedUrl: string,\n ): Promise<void> {\n return new Promise((resolve, reject) => {\n let interval: NodeJS.Timeout | undefined = undefined;\n let timeout: NodeJS.Timeout | undefined = undefined;\n\n const messageHandler = (event: MessageEvent) => {\n if (event.source !== iframe.contentWindow) {\n // This message did not originate from the iframe. Ignore it.\n return;\n }\n\n const message = event.data as IframeAuthMessage;\n\n if (\n message.source === \"civicloginApp\" &&\n (message.type === \"auth_error\" ||\n message.type === \"auth_error_try_again\")\n ) {\n clearInterval(interval);\n clearTimeout(timeout);\n window.removeEventListener(\"message\", messageHandler);\n reject(new Error(message.data.error || \"Authentication failed\"));\n return;\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n // Keep the existing URL check logic for success case\n const checkIframe = () => {\n try {\n const currentUrl = iframe.contentWindow?.location.href;\n if (currentUrl?.includes(expectedUrl)) {\n clearInterval(interval);\n window.removeEventListener(\"message\", messageHandler);\n resolve();\n }\n } catch {\n // Ignore cross-origin errors\n }\n };\n\n interval = setInterval(checkIframe, 100);\n\n // Timeout after 10 seconds\n timeout = setTimeout(() => {\n clearInterval(interval);\n window.removeEventListener(\"message\", messageHandler);\n reject(new Error(\"Timeout waiting for iframe URL change\"));\n }, 10000);\n });\n }\n\n async signOut(\n idToken: string | undefined,\n iframeRef: HTMLIFrameElement | null,\n ): Promise<URL> {\n let url;\n\n const state = this.state;\n if (this.isServerTokenExchange) {\n if (!this.config.logoutUrl) {\n throw new Error(\"logoutUrl is required for server token exchange\");\n }\n url = new URL(this.config.logoutUrl, window.location.origin);\n url.searchParams.append(\"state\", state);\n } else {\n if (!idToken) {\n throw new Error(\"idToken is required for non-server token exchange\");\n }\n url = await generateOauthLogoutUrl({\n ...this.config,\n idToken,\n state,\n redirectUrl: this.config.logoutRedirectUrl,\n });\n }\n\n if (this.config.displayMode === \"iframe\") {\n const ref = getIframeRef(iframeRef);\n ref.setAttribute(\"src\", url.toString());\n\n try {\n await this.handleIframeUrlChange(ref, this.config.logoutRedirectUrl);\n } catch (error) {\n console.log(\"Failed to sign out\", error);\n // on logout error, trigger the logout-callback directly,\n // if it is a logout from the server, so the the session is cleared\n // and user can still sign out.\n if (this.isServerTokenExchange) {\n url = new URL(this.config.logoutRedirectUrl, window.location.origin);\n url.searchParams.append(\"state\", state);\n url.searchParams.append(\"appUrl\", window.location.origin);\n ref.setAttribute(\"src\", url.toString());\n }\n }\n }\n\n if (this.config.displayMode === \"redirect\") {\n const localStorage = new LocalStorageAdapter();\n localStorage.set(LOGOUT_STATE, state);\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 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: GenericAuthenticationInitiatorConfig;\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(idToken: string): Promise<URL> {\n return generateOauthLogoutUrl({\n ...this.config,\n idToken,\n });\n }\n}\n\ntype BrowserAuthenticationConfig = {\n clientId: string;\n redirectUrl: string;\n logoutUrl?: string;\n logoutRedirectUrl: 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 accessTokenExpiresAt: storageData.access_token_expires_at,\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 access_token_expires_at: sessionData.accessTokenExpiresAt,\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 async getEndSessionEndpoint(): Promise<string | null> {\n if (!this.endpoints) {\n return null;\n }\n return this.endpoints?.endsession;\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,20 +0,0 @@
1
- import type { PKCEConsumer, PKCEProducer } from "../services/types.js";
2
- import type { AuthStorage } from "../types.js";
3
- /** A PKCE consumer that retrieves the challenge from a server endpoint */
4
- export declare class ConfidentialClientPKCEConsumer implements PKCEConsumer {
5
- private pkceChallengeEndpoint;
6
- constructor(pkceChallengeEndpoint: string);
7
- getCodeChallenge(): Promise<string>;
8
- }
9
- /** A PKCE Producer that can generate and store a code verifier, but is agnostic as to the storage location */
10
- export declare class GenericPublicClientPKCEProducer implements PKCEProducer {
11
- private storage;
12
- constructor(storage: AuthStorage);
13
- getCodeChallenge(): Promise<string>;
14
- getCodeVerifier(): Promise<string | null>;
15
- }
16
- /** A PKCE Producer that is expected to run on a browser, and does not need a backend */
17
- export declare class BrowserPublicClientPKCEProducer extends GenericPublicClientPKCEProducer {
18
- constructor();
19
- }
20
- //# sourceMappingURL=PKCE.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"PKCE.d.ts","sourceRoot":"","sources":["../../../src/services/PKCE.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACtE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAG9C,0EAA0E;AAC1E,qBAAa,8BAA+B,YAAW,YAAY;IACrD,OAAO,CAAC,qBAAqB;gBAArB,qBAAqB,EAAE,MAAM;IAC3C,gBAAgB,IAAI,OAAO,CAAC,MAAM,CAAC;CAO1C;AAED,8GAA8G;AAC9G,qBAAa,+BAAgC,YAAW,YAAY;IACtD,OAAO,CAAC,OAAO;gBAAP,OAAO,EAAE,WAAW;IAIlC,gBAAgB,IAAI,OAAO,CAAC,MAAM,CAAC;IASnC,eAAe,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;CAGhD;AAED,wFAAwF;AACxF,qBAAa,+BAAgC,SAAQ,+BAA+B;;CAInF"}
@@ -1,50 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BrowserPublicClientPKCEProducer = exports.GenericPublicClientPKCEProducer = exports.ConfidentialClientPKCEConsumer = void 0;
4
- const util_js_1 = require("../shared/lib/util.js");
5
- const oauth2_1 = require("oslo/oauth2");
6
- const storage_js_1 = require("../browser/storage.js");
7
- const types_js_1 = require("../shared/lib/types.js");
8
- /** A PKCE consumer that retrieves the challenge from a server endpoint */
9
- class ConfidentialClientPKCEConsumer {
10
- pkceChallengeEndpoint;
11
- constructor(pkceChallengeEndpoint) {
12
- this.pkceChallengeEndpoint = pkceChallengeEndpoint;
13
- }
14
- async getCodeChallenge() {
15
- const response = await fetch(`${this.pkceChallengeEndpoint}?appUrl=${window.location.origin}`);
16
- const data = (await response.json());
17
- return data.challenge;
18
- }
19
- }
20
- exports.ConfidentialClientPKCEConsumer = ConfidentialClientPKCEConsumer;
21
- /** A PKCE Producer that can generate and store a code verifier, but is agnostic as to the storage location */
22
- class GenericPublicClientPKCEProducer {
23
- storage;
24
- constructor(storage) {
25
- this.storage = storage;
26
- }
27
- // if there is already a verifier, return it,
28
- // If not, create a new one and store it
29
- async getCodeChallenge() {
30
- // let verifier = await this.getCodeVerifier();
31
- // if (!verifier) {
32
- const verifier = (0, oauth2_1.generateCodeVerifier)();
33
- this.storage.set(types_js_1.CodeVerifier.COOKIE_NAME, verifier);
34
- // }
35
- return (0, util_js_1.deriveCodeChallenge)(verifier);
36
- }
37
- // if there is already a verifier, return it,
38
- async getCodeVerifier() {
39
- return this.storage.get(types_js_1.CodeVerifier.COOKIE_NAME);
40
- }
41
- }
42
- exports.GenericPublicClientPKCEProducer = GenericPublicClientPKCEProducer;
43
- /** A PKCE Producer that is expected to run on a browser, and does not need a backend */
44
- class BrowserPublicClientPKCEProducer extends GenericPublicClientPKCEProducer {
45
- constructor() {
46
- super(new storage_js_1.LocalStorageAdapter());
47
- }
48
- }
49
- exports.BrowserPublicClientPKCEProducer = BrowserPublicClientPKCEProducer;
50
- //# sourceMappingURL=PKCE.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"PKCE.js","sourceRoot":"","sources":["../../../src/services/PKCE.ts"],"names":[],"mappings":";;;AAAA,kDAA2D;AAC3D,wCAAmD;AACnD,qDAA2D;AAG3D,oDAAqD;AAErD,0EAA0E;AAC1E,MAAa,8BAA8B;IACrB;IAApB,YAAoB,qBAA6B;QAA7B,0BAAqB,GAArB,qBAAqB,CAAQ;IAAG,CAAC;IACrD,KAAK,CAAC,gBAAgB;QACpB,MAAM,QAAQ,GAAG,MAAM,KAAK,CAC1B,GAAG,IAAI,CAAC,qBAAqB,WAAW,MAAM,CAAC,QAAQ,CAAC,MAAM,EAAE,CACjE,CAAC;QACF,MAAM,IAAI,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAA0B,CAAC;QAC9D,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;CACF;AATD,wEASC;AAED,8GAA8G;AAC9G,MAAa,+BAA+B;IACtB;IAApB,YAAoB,OAAoB;QAApB,YAAO,GAAP,OAAO,CAAa;IAAG,CAAC;IAE5C,6CAA6C;IAC7C,wCAAwC;IACxC,KAAK,CAAC,gBAAgB;QACpB,+CAA+C;QAC/C,mBAAmB;QACnB,MAAM,QAAQ,GAAG,IAAA,6BAAoB,GAAE,CAAC;QACxC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,uBAAY,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QACrD,IAAI;QACJ,OAAO,IAAA,6BAAmB,EAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;IACD,6CAA6C;IAC7C,KAAK,CAAC,eAAe;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,uBAAY,CAAC,WAAW,CAAC,CAAC;IACpD,CAAC;CACF;AAjBD,0EAiBC;AAED,wFAAwF;AACxF,MAAa,+BAAgC,SAAQ,+BAA+B;IAClF;QACE,KAAK,CAAC,IAAI,gCAAmB,EAAE,CAAC,CAAC;IACnC,CAAC;CACF;AAJD,0EAIC","sourcesContent":["import { deriveCodeChallenge } from \"@/shared/lib/util.js\";\nimport { generateCodeVerifier } from \"oslo/oauth2\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport type { PKCEConsumer, PKCEProducer } from \"@/services/types.js\";\nimport type { AuthStorage } from \"@/types.js\";\nimport { CodeVerifier } from \"@/shared/lib/types.js\";\n\n/** A PKCE consumer that retrieves the challenge from a server endpoint */\nexport class ConfidentialClientPKCEConsumer implements PKCEConsumer {\n constructor(private pkceChallengeEndpoint: string) {}\n async getCodeChallenge(): Promise<string> {\n const response = await fetch(\n `${this.pkceChallengeEndpoint}?appUrl=${window.location.origin}`,\n );\n const data = (await response.json()) as { challenge: string };\n return data.challenge;\n }\n}\n\n/** A PKCE Producer that can generate and store a code verifier, but is agnostic as to the storage location */\nexport class GenericPublicClientPKCEProducer implements PKCEProducer {\n constructor(private storage: AuthStorage) {}\n\n // if there is already a verifier, return it,\n // If not, create a new one and store it\n async getCodeChallenge(): Promise<string> {\n // let verifier = await this.getCodeVerifier();\n // if (!verifier) {\n const verifier = generateCodeVerifier();\n this.storage.set(CodeVerifier.COOKIE_NAME, verifier);\n // }\n return deriveCodeChallenge(verifier);\n }\n // if there is already a verifier, return it,\n async getCodeVerifier(): Promise<string | null> {\n return this.storage.get(CodeVerifier.COOKIE_NAME);\n }\n}\n\n/** A PKCE Producer that is expected to run on a browser, and does not need a backend */\nexport class BrowserPublicClientPKCEProducer extends GenericPublicClientPKCEProducer {\n constructor() {\n super(new LocalStorageAdapter());\n }\n}\n"]}
@@ -1,24 +0,0 @@
1
- import type { OIDCTokenResponseBody, SessionData } from "../types.js";
2
- export interface PKCEConsumer {
3
- getCodeChallenge(): Promise<string>;
4
- }
5
- export interface PKCEProducer extends PKCEConsumer {
6
- getCodeVerifier(): Promise<string | null>;
7
- }
8
- export interface AuthenticationInitiator {
9
- signIn(iframeRef: HTMLIFrameElement | null): Promise<URL>;
10
- signOut(idToken: string, iframeRef: HTMLIFrameElement | null): Promise<URL>;
11
- }
12
- export interface AuthenticationResolver {
13
- tokenExchange(code: string, state: string): Promise<OIDCTokenResponseBody>;
14
- getSessionData(): Promise<SessionData | null>;
15
- getEndSessionEndpoint(): Promise<string | null>;
16
- validateExistingSession(): Promise<SessionData>;
17
- }
18
- export interface AuthenticationRefresher {
19
- refreshTokens: () => Promise<OIDCTokenResponseBody>;
20
- }
21
- export declare class PopupError extends Error {
22
- constructor(message: string);
23
- }
24
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/services/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AASrE,MAAM,WAAW,YAAY;IAE3B,gBAAgB,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;CACrC;AAGD,MAAM,WAAW,YAAa,SAAQ,YAAY;IAEhD,eAAe,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;CAC3C;AAGD,MAAM,WAAW,uBAAuB;IAEtC,MAAM,CAAC,SAAS,EAAE,iBAAiB,GAAG,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAG1D,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,iBAAiB,GAAG,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;CAC7E;AAGD,MAAM,WAAW,sBAAsB;IAKrC,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAG3E,cAAc,IAAI,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IAE9C,qBAAqB,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IAEhD,uBAAuB,IAAI,OAAO,CAAC,WAAW,CAAC,CAAC;CACjD;AAED,MAAM,WAAW,uBAAuB;IACtC,aAAa,EAAE,MAAM,OAAO,CAAC,qBAAqB,CAAC,CAAC;CACrD;AAED,qBAAa,UAAW,SAAQ,KAAK;gBACvB,OAAO,EAAE,MAAM;CAI5B"}
@@ -1,11 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.PopupError = void 0;
4
- class PopupError extends Error {
5
- constructor(message) {
6
- super(message);
7
- Object.setPrototypeOf(this, PopupError.prototype);
8
- }
9
- }
10
- exports.PopupError = PopupError;
11
- //# sourceMappingURL=types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/services/types.ts"],"names":[],"mappings":";;;AAiDA,MAAa,UAAW,SAAQ,KAAK;IACnC,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;CACF;AALD,gCAKC","sourcesContent":["import type { OIDCTokenResponseBody, SessionData } from \"@/types.js\";\n\n// A PKCEConsumer can get a code challenge to use in the login process\n// A PKCEProducer can also generate and store verifiers. The producer must also be a consumer in order to get the challenge from an existing flow\n// Examples:\n// - Client-only SPA: The SPA generates the code challenge and verifier, stores the verifier in state and returns the code challenge\n// Note - The SPA should use PKCEProducer instead to do both\n// - Client-side of a client/server app: The client calls the backend to get the challenge.\n// - Server-side: The server should generate a new stored verifier and derive the challenge from it.\nexport interface PKCEConsumer {\n // Retrieve a new PKCE challenge\n getCodeChallenge(): Promise<string>;\n}\n\n// All producers are consumers, because the producer can get its own challenge\nexport interface PKCEProducer extends PKCEConsumer {\n // Retrieve the PKCE challenge from the session if one exists\n getCodeVerifier(): Promise<string | null>;\n}\n\n// A service that can initiate requests to login or log out\nexport interface AuthenticationInitiator {\n // trigger a new login\n signIn(iframeRef: HTMLIFrameElement | null): Promise<URL>;\n\n // trigger a new logout\n signOut(idToken: string, iframeRef: HTMLIFrameElement | null): Promise<URL>;\n}\n\n// A service that can resolve an authentication request according to the OAuth Auth Code grant types\nexport interface AuthenticationResolver {\n // Given an auth code, get the tokens from the auth server and store them. works in PKCE and non-PKCE environments\n // Note, if we choose later to implement other grants, this method would move into a subinterface specifically\n // for the authorization code grant type.\n // The return type is just for convenience and can be ignored, as the same data would be provided by getSessionData\n tokenExchange(code: string, state: string): Promise<OIDCTokenResponseBody>;\n\n // If the tokens have already been retrieved, return them\n getSessionData(): Promise<SessionData | null>;\n\n getEndSessionEndpoint(): Promise<string | null>;\n // If an existing session is found, validate it and return the session data\n validateExistingSession(): Promise<SessionData>;\n}\n\nexport interface AuthenticationRefresher {\n refreshTokens: () => Promise<OIDCTokenResponseBody>;\n}\n\nexport class PopupError extends Error {\n constructor(message: string) {\n super(message);\n Object.setPrototypeOf(this, PopupError.prototype);\n }\n}\n"]}
@@ -1,6 +0,0 @@
1
- import type { ReactNode } from "react";
2
- declare const BlockDisplay: ({ children }: {
3
- children: ReactNode;
4
- }) => import("@emotion/react/jsx-runtime").JSX.Element;
5
- export { BlockDisplay };
6
- //# sourceMappingURL=BlockDisplay.d.ts.map
@@ -1 +0,0 @@
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;AAIvC,QAAA,MAAM,YAAY,iBAAkB;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,qDAmC1D,CAAC;AACF,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -1,32 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BlockDisplay = void 0;
4
- const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
5
- const useIframe_js_1 = require("../hooks/useIframe.js");
6
- const useIsInIframe_js_1 = require("../hooks/useIsInIframe.js");
7
- const BlockDisplay = ({ children }) => {
8
- const isInIframe = (0, useIsInIframe_js_1.useIsInIframe)();
9
- const { backgroundColor } = (0, useIframe_js_1.useIframe)();
10
- const useBackgroundColor = isInIframe ? backgroundColor : "white";
11
- return ((0, jsx_runtime_1.jsx)("div", { id: "iframe-block-display-wrapper", style: {
12
- position: "relative",
13
- left: 0,
14
- top: 0,
15
- zIndex: 50,
16
- display: "flex",
17
- height: "100vh",
18
- width: "100vw",
19
- alignItems: "center",
20
- justifyContent: "center",
21
- backgroundColor: useBackgroundColor,
22
- }, children: (0, jsx_runtime_1.jsx)("div", { id: "iframe-block-display", style: {
23
- position: "absolute",
24
- inset: 0,
25
- display: "flex",
26
- alignItems: "center",
27
- justifyContent: "center",
28
- backgroundColor: useBackgroundColor,
29
- }, children: children }) }));
30
- };
31
- exports.BlockDisplay = BlockDisplay;
32
- //# sourceMappingURL=BlockDisplay.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"BlockDisplay.js","sourceRoot":"","sources":["../../../../src/shared/components/BlockDisplay.tsx"],"names":[],"mappings":";;;;AACA,wDAAkD;AAClD,gEAA0D;AAE1D,MAAM,YAAY,GAAG,CAAC,EAAE,QAAQ,EAA2B,EAAE,EAAE;IAC7D,MAAM,UAAU,GAAG,IAAA,gCAAa,GAAE,CAAC;IACnC,MAAM,EAAE,eAAe,EAAE,GAAG,IAAA,wBAAS,GAAE,CAAC;IACxC,MAAM,kBAAkB,GAAG,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,OAAO,CAAC;IAClE,OAAO,CACL,gCACE,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,kBAAkB;SACpC,YAED,gCACE,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,kBAAkB;aACpC,YAEA,QAAQ,GACL,GACF,CACP,CAAC;AACJ,CAAC,CAAC;AACO,oCAAY","sourcesContent":["import type { ReactNode } from \"react\";\nimport { useIframe } from \"../hooks/useIframe.js\";\nimport { useIsInIframe } from \"../hooks/useIsInIframe.js\";\n\nconst BlockDisplay = ({ children }: { children: ReactNode }) => {\n const isInIframe = useIsInIframe();\n const { backgroundColor } = useIframe();\n const useBackgroundColor = isInIframe ? backgroundColor : \"white\";\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: useBackgroundColor,\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: useBackgroundColor,\n }}\n >\n {children}\n </div>\n </div>\n );\n};\nexport { BlockDisplay };\n"]}
@@ -1,9 +0,0 @@
1
- import React from "react";
2
- type CivicAuthIframeProps = {
3
- onLoad?: () => void;
4
- id: string;
5
- };
6
- declare const CivicAuthIframe: React.ForwardRefExoticComponent<CivicAuthIframeProps & React.RefAttributes<HTMLIFrameElement>>;
7
- export type { CivicAuthIframeProps };
8
- export { CivicAuthIframe };
9
- //# sourceMappingURL=CivicAuthIframe.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CivicAuthIframe.d.ts","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthIframe.tsx"],"names":[],"mappings":"AACA,OAAO,KAA0C,MAAM,OAAO,CAAC;AAK/D,KAAK,oBAAoB,GAAG;IAC1B,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,QAAA,MAAM,eAAe,gGAiDpB,CAAC;AAIF,YAAY,EAAE,oBAAoB,EAAE,CAAC;AAErC,OAAO,EAAE,eAAe,EAAE,CAAC"}
@@ -1,72 +0,0 @@
1
- "use strict";
2
- "use client";
3
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
- if (k2 === undefined) k2 = k;
5
- var desc = Object.getOwnPropertyDescriptor(m, k);
6
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
- desc = { enumerable: true, get: function() { return m[k]; } };
8
- }
9
- Object.defineProperty(o, k2, desc);
10
- }) : (function(o, m, k, k2) {
11
- if (k2 === undefined) k2 = k;
12
- o[k2] = m[k];
13
- }));
14
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
15
- Object.defineProperty(o, "default", { enumerable: true, value: v });
16
- }) : function(o, v) {
17
- o["default"] = v;
18
- });
19
- var __importStar = (this && this.__importStar) || (function () {
20
- var ownKeys = function(o) {
21
- ownKeys = Object.getOwnPropertyNames || function (o) {
22
- var ar = [];
23
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
24
- return ar;
25
- };
26
- return ownKeys(o);
27
- };
28
- return function (mod) {
29
- if (mod && mod.__esModule) return mod;
30
- var result = {};
31
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
32
- __setModuleDefault(result, mod);
33
- return result;
34
- };
35
- })();
36
- var __importDefault = (this && this.__importDefault) || function (mod) {
37
- return (mod && mod.__esModule) ? mod : { "default": mod };
38
- };
39
- Object.defineProperty(exports, "__esModule", { value: true });
40
- exports.CivicAuthIframe = void 0;
41
- const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
42
- const react_1 = __importStar(require("react"));
43
- const react_2 = __importDefault(require("@iframe-resizer/react"));
44
- const SVGLoading_js_1 = __importDefault(require("./SVGLoading.js"));
45
- const useIframe_js_1 = require("../hooks/useIframe.js");
46
- const CivicAuthIframe = (0, react_1.forwardRef)(({ onLoad, id }, ref) => {
47
- const [isLoaded, setIsLoaded] = react_1.default.useState(false);
48
- const { iframeMode, backgroundColor } = (0, useIframe_js_1.useIframe)();
49
- const [isClient, setIsClient] = (0, react_1.useState)(false);
50
- (0, react_1.useEffect)(() => {
51
- // only runs on client
52
- setIsClient(true);
53
- }, []);
54
- // don't render on the server as the appearance changes when the iframe is loaded from login-app post-messages
55
- return !isClient ? null : ((0, jsx_runtime_1.jsxs)("div", { children: [isLoaded ? null : ((0, jsx_runtime_1.jsx)("span", { "data-testid": "iframe-shimmer-loader", children: iframeMode !== "embedded" && ((0, jsx_runtime_1.jsx)(SVGLoading_js_1.default, { backgroundColor: backgroundColor })) })), (0, jsx_runtime_1.jsx)(react_2.default, { inPageLinks: true, license: "1jy4dww5qzv-s54r73oxcn-v59f4kfgfz", id: id, forwardRef: ref, "data-testid": "civic-auth-iframe-with-resizer", style: {
56
- // we don't want the letterbox effect in embedded mode
57
- height: iframeMode !== "embedded" ? "26px" : "24rem",
58
- width: "100%",
59
- border: "none",
60
- minWidth: "100%",
61
- backgroundColor,
62
- transition: "height 0.25s ease",
63
- pointerEvents: "auto",
64
- borderRadius: "24px",
65
- }, checkOrigin: false, onLoad: () => {
66
- setIsLoaded(true);
67
- onLoad?.();
68
- }, allow: "camera; screen-wake-lock", allowFullScreen: true, direction: "vertical", warningTimeout: 0 })] }));
69
- });
70
- exports.CivicAuthIframe = CivicAuthIframe;
71
- CivicAuthIframe.displayName = "CivicAuthIframe";
72
- //# sourceMappingURL=CivicAuthIframe.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CivicAuthIframe.js","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthIframe.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACb,+CAA+D;AAC/D,kEAAkD;AAClD,oEAAyC;AACzC,wDAAkD;AAOlD,MAAM,eAAe,GAAG,IAAA,kBAAU,EAChC,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE;IACtB,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,eAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACtD,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,GAAG,IAAA,wBAAS,GAAE,CAAC;IACpD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAC;IAChD,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,sBAAsB;QACtB,WAAW,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC,EAAE,EAAE,CAAC,CAAC;IACP,8GAA8G;IAC9G,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CACxB,4CACG,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CACjB,gDAAkB,uBAAuB,YACtC,UAAU,KAAK,UAAU,IAAI,CAC5B,uBAAC,uBAAU,IAAC,eAAe,EAAE,eAAe,GAAI,CACjD,GACI,CACR,EACD,uBAAC,eAAa,IACZ,WAAW,QACX,OAAO,EAAC,mCAAmC,EAC3C,EAAE,EAAE,EAAE,EACN,UAAU,EAAE,GAAG,iBACF,gCAAgC,EAC7C,KAAK,EAAE;oBACL,sDAAsD;oBACtD,MAAM,EAAE,UAAU,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO;oBACpD,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,MAAM;oBACd,QAAQ,EAAE,MAAM;oBAChB,eAAe;oBACf,UAAU,EAAE,mBAAmB;oBAC/B,aAAa,EAAE,MAAM;oBACrB,YAAY,EAAE,MAAM;iBACrB,EACD,WAAW,EAAE,KAAK,EAClB,MAAM,EAAE,GAAG,EAAE;oBACX,WAAW,CAAC,IAAI,CAAC,CAAC;oBAClB,MAAM,EAAE,EAAE,CAAC;gBACb,CAAC,EACD,KAAK,EAAC,0BAA0B,EAChC,eAAe,QACf,SAAS,EAAC,UAAU,EACpB,cAAc,EAAE,CAAC,GACjB,IACE,CACP,CAAC;AACJ,CAAC,CACF,CAAC;AAMO,0CAAe;AAJxB,eAAe,CAAC,WAAW,GAAG,iBAAiB,CAAC","sourcesContent":["\"use client\";\nimport React, { forwardRef, useEffect, useState } from \"react\";\nimport IframeResizer from \"@iframe-resizer/react\";\nimport SVGLoading from \"./SVGLoading.js\";\nimport { useIframe } from \"../hooks/useIframe.js\";\n\ntype CivicAuthIframeProps = {\n onLoad?: () => void;\n id: string;\n};\n\nconst CivicAuthIframe = forwardRef<HTMLIFrameElement, CivicAuthIframeProps>(\n ({ onLoad, id }, ref) => {\n const [isLoaded, setIsLoaded] = React.useState(false);\n const { iframeMode, backgroundColor } = useIframe();\n const [isClient, setIsClient] = useState(false);\n useEffect(() => {\n // only runs on client\n setIsClient(true);\n }, []);\n // don't render on the server as the appearance changes when the iframe is loaded from login-app post-messages\n return !isClient ? null : (\n <div>\n {isLoaded ? null : (\n <span data-testid=\"iframe-shimmer-loader\">\n {iframeMode !== \"embedded\" && (\n <SVGLoading backgroundColor={backgroundColor} />\n )}\n </span>\n )}\n <IframeResizer\n inPageLinks\n license=\"1jy4dww5qzv-s54r73oxcn-v59f4kfgfz\"\n id={id}\n forwardRef={ref}\n data-testid={\"civic-auth-iframe-with-resizer\"}\n style={{\n // we don't want the letterbox effect in embedded mode\n height: iframeMode !== \"embedded\" ? \"26px\" : \"24rem\",\n width: \"100%\",\n border: \"none\",\n minWidth: \"100%\",\n backgroundColor,\n transition: \"height 0.25s ease\",\n pointerEvents: \"auto\",\n borderRadius: \"24px\",\n }}\n checkOrigin={false}\n onLoad={() => {\n setIsLoaded(true);\n onLoad?.();\n }}\n allow=\"camera; screen-wake-lock\"\n allowFullScreen\n direction=\"vertical\"\n warningTimeout={0}\n />\n </div>\n );\n },\n);\n\nCivicAuthIframe.displayName = \"CivicAuthIframe\";\n\nexport type { CivicAuthIframeProps };\n\nexport { CivicAuthIframe };\n"]}
@@ -1,14 +0,0 @@
1
- import React from "react";
2
- type CivicAuthIframeContainerProps = {
3
- onClose?: () => void;
4
- closeOnRedirect?: boolean;
5
- };
6
- export declare function IframeChrome({ children, onClose, isFrameLoaded, }: {
7
- children: React.ReactNode;
8
- onClose?: () => void;
9
- isFrameLoaded: boolean;
10
- }): import("@emotion/react/jsx-runtime").JSX.Element;
11
- declare const CivicAuthIframeContainer: ({ onClose, closeOnRedirect, }: CivicAuthIframeContainerProps) => import("@emotion/react/jsx-runtime").JSX.Element;
12
- export type { CivicAuthIframeContainerProps };
13
- export { CivicAuthIframeContainer };
14
- //# sourceMappingURL=CivicAuthIframeContainer.d.ts.map
@@ -1 +0,0 @@
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;AAeF,wBAAgB,YAAY,CAAC,EAC3B,QAAQ,EACR,OAAO,EACP,aAAa,GACd,EAAE;IACD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,aAAa,EAAE,OAAO,CAAC;CACxB,oDAkFA;AAED,QAAA,MAAM,wBAAwB,kCAG3B,6BAA6B,qDA4G/B,CAAC;AAEF,YAAY,EAAE,6BAA6B,EAAE,CAAC;AAE9C,OAAO,EAAE,wBAAwB,EAAE,CAAC"}
@@ -1,158 +0,0 @@
1
- "use strict";
2
- "use client";
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.CivicAuthIframeContainer = void 0;
5
- exports.IframeChrome = IframeChrome;
6
- const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
7
- const react_1 = require("react");
8
- const LoadingIcon_js_1 = require("../../shared/components/LoadingIcon.js");
9
- const CloseIcon_js_1 = require("../../shared/components/CloseIcon.js");
10
- const CivicAuthIframe_js_1 = require("../../shared/components/CivicAuthIframe.js");
11
- const index_js_1 = require("../../shared/hooks/index.js");
12
- const constants_js_1 = require("../../constants.js");
13
- const index_js_2 = require("../../shared/hooks/index.js");
14
- const index_js_3 = require("../../shared/hooks/index.js");
15
- const iframeUtils_js_1 = require("../lib/iframeUtils.js");
16
- function NoChrome({ children, }) {
17
- return ((0, jsx_runtime_1.jsx)("div", { "data-testid": "civic-iframe-no-chrome", style: { position: "relative" }, children: children }));
18
- }
19
- function IframeChrome({ children, onClose, isFrameLoaded, }) {
20
- const { setIframeAborted, iframeMode, backgroundColor } = (0, index_js_1.useIframe)();
21
- const iframeContainerStyleOverrides = iframeMode === "embedded"
22
- ? {
23
- paddingTop: "1.5rem",
24
- borderRadius: "1.5rem",
25
- }
26
- : {
27
- ...(isFrameLoaded
28
- ? {
29
- paddingTop: "1.5rem",
30
- borderRadius: "1.5rem",
31
- }
32
- : { borderRadius: "0.5rem", paddingTop: "0" }),
33
- };
34
- return ((0, jsx_runtime_1.jsx)("div", { style: {
35
- position: "fixed", // Change to fixed to stay in viewport
36
- left: 0,
37
- top: 0,
38
- zIndex: 50,
39
- display: "flex",
40
- height: "100vh",
41
- width: "100vw",
42
- alignItems: "center",
43
- justifyContent: "center",
44
- backgroundColor: "rgba(17, 24, 39, 0.5)", // Semi-transparent dark background
45
- backdropFilter: "blur(4px)", // Optional: adds slight blur to background
46
- }, onClick: () => {
47
- setIframeAborted(true);
48
- onClose?.();
49
- }, children: (0, jsx_runtime_1.jsxs)("div", { "data-testid": "iframe-chrome", style: {
50
- position: "relative",
51
- overflow: "hidden",
52
- backgroundColor,
53
- paddingLeft: "0",
54
- paddingRight: "0",
55
- paddingBottom: "0",
56
- // paddingTop gets added in style overrides
57
- ...iframeContainerStyleOverrides,
58
- boxShadow: "0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)",
59
- minWidth: "20rem",
60
- }, onClick: (e) => e.stopPropagation(), children: [isFrameLoaded && ((0, jsx_runtime_1.jsx)("button", { style: {
61
- position: "absolute",
62
- right: "1rem",
63
- top: "1rem",
64
- display: "flex",
65
- cursor: "pointer",
66
- alignItems: "center",
67
- justifyContent: "center",
68
- border: "none",
69
- backgroundColor: "transparent",
70
- padding: "0.25rem",
71
- color: "#9ca3af",
72
- }, onClick: () => {
73
- setIframeAborted(true);
74
- onClose?.();
75
- }, children: (0, jsx_runtime_1.jsx)(CloseIcon_js_1.CloseIcon, {}) })), children] }) }));
76
- }
77
- const CivicAuthIframeContainer = ({ onClose, closeOnRedirect = true, }) => {
78
- const config = (0, index_js_2.useCivicAuthConfig)();
79
- const [tokenExchangeUrl, setTokenExchangeUrl] = (0, react_1.useState)(null);
80
- const { doTokenExchange } = (0, index_js_3.useClientTokenExchangeSession)();
81
- const { iframeRef, iframeMode, backgroundColor } = (0, index_js_1.useIframe)();
82
- (0, react_1.useEffect)(() => {
83
- if (tokenExchangeUrl) {
84
- doTokenExchange?.(tokenExchangeUrl);
85
- }
86
- }, [doTokenExchange, tokenExchangeUrl]);
87
- const processIframeUrl = (0, react_1.useCallback)(() => {
88
- if (!config)
89
- return;
90
- if (iframeRef && iframeRef.current) {
91
- const ref = (0, iframeUtils_js_1.getIframeRef)(iframeRef.current);
92
- if (ref.contentWindow) {
93
- try {
94
- const iframeUrl = ref.contentWindow.location.href;
95
- // we know that oauth has finished when the iframe redirects to our redirectUrl
96
- if (iframeUrl.startsWith(config.redirectUrl)) {
97
- const iframeBody = ref.contentWindow.document.body.innerHTML;
98
- // If we're doing a server token exchange, we need to call the server a second time
99
- // using a fetch so that we're on the same domain and cookies can be sent and read
100
- // The server will use the presence of the code_verifier cookie to determine whether to do a token exchange or not.
101
- // 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,
102
- // and we'll do the exchange request from here, which will include the cookies.
103
- if (iframeBody.includes(constants_js_1.TOKEN_EXCHANGE_TRIGGER_TEXT)) {
104
- const params = new URL(iframeUrl).searchParams;
105
- const appUrl = globalThis.window?.location?.origin;
106
- fetch(`${config.redirectUrl}?${params.toString()}&appUrl=${appUrl}`);
107
- }
108
- else {
109
- // if we're doing token-exchange in the client, we can just set the authResponseUrl
110
- // to be handled by the auth provider
111
- // iframeRef.current.setAttribute("src", "");
112
- setTokenExchangeUrl(iframeUrl);
113
- }
114
- if (closeOnRedirect)
115
- onClose?.();
116
- return true; // Successfully processed the URL
117
- }
118
- }
119
- catch {
120
- // ignore errors while waiting for redirect
121
- }
122
- }
123
- }
124
- return false; // Haven't processed the URL yet
125
- }, [closeOnRedirect, config, iframeRef, onClose]);
126
- const intervalId = (0, react_1.useRef)();
127
- const handleEscape = (0, react_1.useCallback)((event) => {
128
- if (event.key === "Escape") {
129
- onClose?.();
130
- }
131
- }, [onClose]);
132
- // handle Escape
133
- (0, react_1.useEffect)(() => {
134
- window.addEventListener("keydown", handleEscape);
135
- return () => window.removeEventListener("keydown", handleEscape);
136
- });
137
- const [isIframeContentLoaded, setIsIframeContentLoaded] = (0, react_1.useState)(false);
138
- const handleIframeLoad = (0, react_1.useCallback)(() => {
139
- setIsIframeContentLoaded(true);
140
- const iframeHasUrl = processIframeUrl();
141
- if (iframeHasUrl && intervalId.current) {
142
- clearInterval(intervalId.current);
143
- }
144
- }, [processIframeUrl, intervalId]);
145
- const WrapperComponent = iframeMode === "embedded" ? NoChrome : IframeChrome;
146
- const showLoadingIcon = !isIframeContentLoaded && iframeMode === "embedded";
147
- return ((0, jsx_runtime_1.jsxs)(WrapperComponent, { onClose: onClose, isFrameLoaded: isIframeContentLoaded, children: [showLoadingIcon ? ((0, jsx_runtime_1.jsx)("div", { id: "civic-auth-loading-icon-wrapper", style: {
148
- position: "absolute",
149
- inset: 0,
150
- display: "flex",
151
- alignItems: "center",
152
- justifyContent: "center",
153
- backgroundColor,
154
- borderRadius: "24px",
155
- }, children: (0, jsx_runtime_1.jsx)(LoadingIcon_js_1.LoadingIcon, {}) })) : null, (0, jsx_runtime_1.jsx)(CivicAuthIframe_js_1.CivicAuthIframe, { ref: iframeRef, id: "civic-auth-iframe", onLoad: handleIframeLoad })] }));
156
- };
157
- exports.CivicAuthIframeContainer = CivicAuthIframeContainer;
158
- //# sourceMappingURL=CivicAuthIframeContainer.js.map
@@ -1 +0,0 @@
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 { getIframeRef } from \"../lib/iframeUtils.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 (\n <div data-testid=\"civic-iframe-no-chrome\" style={{ position: \"relative\" }}>\n {children}\n </div>\n );\n}\n\nexport function IframeChrome({\n children,\n onClose,\n isFrameLoaded,\n}: {\n children: React.ReactNode;\n onClose?: () => void;\n isFrameLoaded: boolean;\n}) {\n const { setIframeAborted, iframeMode, backgroundColor } = useIframe();\n\n const iframeContainerStyleOverrides =\n iframeMode === \"embedded\"\n ? {\n paddingTop: \"1.5rem\",\n borderRadius: \"1.5rem\",\n }\n : {\n ...(isFrameLoaded\n ? {\n paddingTop: \"1.5rem\",\n borderRadius: \"1.5rem\",\n }\n : { borderRadius: \"0.5rem\", paddingTop: \"0\" }),\n };\n return (\n <div\n style={{\n position: \"fixed\", // Change to fixed to stay in viewport\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: \"rgba(17, 24, 39, 0.5)\", // Semi-transparent dark background\n backdropFilter: \"blur(4px)\", // Optional: adds slight blur to background\n }}\n onClick={() => {\n setIframeAborted(true);\n onClose?.();\n }}\n >\n <div\n data-testid=\"iframe-chrome\"\n style={{\n position: \"relative\",\n overflow: \"hidden\",\n backgroundColor,\n paddingLeft: \"0\",\n paddingRight: \"0\",\n paddingBottom: \"0\",\n // paddingTop gets added in style overrides\n ...iframeContainerStyleOverrides,\n boxShadow:\n \"0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)\",\n minWidth: \"20rem\",\n }}\n onClick={(e) => e.stopPropagation()}\n >\n {isFrameLoaded && (\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={() => {\n setIframeAborted(true);\n onClose?.();\n }}\n >\n <CloseIcon />\n </button>\n )}\n\n {children}\n </div>\n </div>\n );\n}\n\nconst CivicAuthIframeContainer = ({\n onClose,\n closeOnRedirect = true,\n}: CivicAuthIframeContainerProps) => {\n const config = useCivicAuthConfig();\n const [tokenExchangeUrl, setTokenExchangeUrl] = useState<string | null>(null);\n const { doTokenExchange } = useClientTokenExchangeSession();\n const { iframeRef, iframeMode, backgroundColor } = 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) {\n const ref = getIframeRef(iframeRef.current)!;\n if (ref.contentWindow) {\n try {\n const iframeUrl = ref.contentWindow.location.href;\n // we know that oauth has finished when the iframe redirects to our redirectUrl\n if (iframeUrl.startsWith(config.redirectUrl)) {\n const iframeBody = ref.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 // ignore errors while waiting for redirect\n }\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 [isIframeContentLoaded, setIsIframeContentLoaded] = useState(false);\n const handleIframeLoad = useCallback(() => {\n setIsIframeContentLoaded(true);\n\n const iframeHasUrl = processIframeUrl();\n if (iframeHasUrl && intervalId.current) {\n clearInterval(intervalId.current);\n }\n }, [processIframeUrl, intervalId]);\n\n const WrapperComponent = iframeMode === \"embedded\" ? NoChrome : IframeChrome;\n\n const showLoadingIcon = !isIframeContentLoaded && iframeMode === \"embedded\";\n return (\n <WrapperComponent onClose={onClose} isFrameLoaded={isIframeContentLoaded}>\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,\n borderRadius: \"24px\",\n }}\n >\n <LoadingIcon />\n </div>\n ) : null}\n <CivicAuthIframe\n ref={iframeRef}\n id={\"civic-auth-iframe\"}\n onLoad={handleIframeLoad}\n />\n </WrapperComponent>\n );\n};\n\nexport type { CivicAuthIframeContainerProps };\n\nexport { CivicAuthIframeContainer };\n"]}
@@ -1,6 +0,0 @@
1
- type CivicAuthLogoutIframeContainerProps = {
2
- isLoading?: boolean;
3
- };
4
- declare const CivicAuthLogoutIframeContainer: ({ isLoading, }: CivicAuthLogoutIframeContainerProps) => import("@emotion/react/jsx-runtime").JSX.Element;
5
- export { CivicAuthLogoutIframeContainer };
6
- //# sourceMappingURL=CivicAuthLogoutIframeContainer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CivicAuthLogoutIframeContainer.d.ts","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthLogoutIframeContainer.tsx"],"names":[],"mappings":"AAQA,KAAK,mCAAmC,GAAG;IACzC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,CAAC;AAEF,QAAA,MAAM,8BAA8B,mBAEjC,mCAAmC,qDA0BrC,CAAC;AAEF,OAAO,EAAE,8BAA8B,EAAE,CAAC"}
@@ -1,21 +0,0 @@
1
- "use strict";
2
- "use client";
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.CivicAuthLogoutIframeContainer = void 0;
5
- const jsx_runtime_1 = require("@emotion/react/jsx-runtime");
6
- const CivicAuthIframe_js_1 = require("../../shared/components/CivicAuthIframe.js");
7
- const index_js_1 = require("../../shared/hooks/index.js");
8
- const LoadingIcon_js_1 = require("./LoadingIcon.js");
9
- const CivicAuthIframeContainer_js_1 = require("./CivicAuthIframeContainer.js");
10
- const CivicAuthLogoutIframeContainer = ({ isLoading = false, }) => {
11
- const { logoutIframeRef } = (0, index_js_1.useIframe)();
12
- return ((0, jsx_runtime_1.jsxs)(CivicAuthIframeContainer_js_1.IframeChrome, { isFrameLoaded: true, children: [isLoading ? ((0, jsx_runtime_1.jsx)("div", { id: "civic-auth-loading-icon-wrapper", style: {
13
- position: "absolute",
14
- inset: 0,
15
- display: "flex",
16
- alignItems: "center",
17
- justifyContent: "center",
18
- }, children: (0, jsx_runtime_1.jsx)(LoadingIcon_js_1.LoadingIcon, {}) })) : null, (0, jsx_runtime_1.jsx)(CivicAuthIframe_js_1.CivicAuthIframe, { ref: logoutIframeRef, id: "civic-auth-logout-iframe", onLoad: () => { } })] }));
19
- };
20
- exports.CivicAuthLogoutIframeContainer = CivicAuthLogoutIframeContainer;
21
- //# sourceMappingURL=CivicAuthLogoutIframeContainer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CivicAuthLogoutIframeContainer.js","sourceRoot":"","sources":["../../../../src/shared/components/CivicAuthLogoutIframeContainer.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;AAGb,+EAAyE;AACzE,sDAAoD;AACpD,qDAA+C;AAC/C,+EAA6D;AAM7D,MAAM,8BAA8B,GAAG,CAAC,EACtC,SAAS,GAAG,KAAK,GACmB,EAAE,EAAE;IACxC,MAAM,EAAE,eAAe,EAAE,GAAG,IAAA,oBAAS,GAAE,CAAC;IAExC,OAAO,CACL,wBAAC,0CAAY,IAAC,aAAa,EAAE,IAAI,aAC9B,SAAS,CAAC,CAAC,CAAC,CACX,gCACE,EAAE,EAAC,iCAAiC,EACpC,KAAK,EAAE;oBACL,QAAQ,EAAE,UAAU;oBACpB,KAAK,EAAE,CAAC;oBACR,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;iBACzB,YAED,uBAAC,4BAAW,KAAG,GACX,CACP,CAAC,CAAC,CAAC,IAAI,EACR,uBAAC,oCAAe,IACd,GAAG,EAAE,eAAe,EACpB,EAAE,EAAE,0BAA0B,EAC9B,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC,GAChB,IACW,CAChB,CAAC;AACJ,CAAC,CAAC;AAEO,wEAA8B","sourcesContent":["\"use client\";\n\nimport React from \"react\";\nimport { CivicAuthIframe } from \"@/shared/components/CivicAuthIframe.js\";\nimport { useIframe } from \"@/shared/hooks/index.js\";\nimport { LoadingIcon } from \"./LoadingIcon.js\";\nimport { IframeChrome } from \"./CivicAuthIframeContainer.js\";\n\ntype CivicAuthLogoutIframeContainerProps = {\n isLoading?: boolean;\n};\n\nconst CivicAuthLogoutIframeContainer = ({\n isLoading = false,\n}: CivicAuthLogoutIframeContainerProps) => {\n const { logoutIframeRef } = useIframe();\n\n return (\n <IframeChrome isFrameLoaded={true}>\n {isLoading ? (\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 }}\n >\n <LoadingIcon />\n </div>\n ) : null}\n <CivicAuthIframe\n ref={logoutIframeRef}\n id={\"civic-auth-logout-iframe\"}\n onLoad={() => {}}\n />\n </IframeChrome>\n );\n};\n\nexport { CivicAuthLogoutIframeContainer };\n"]}
@@ -1,3 +0,0 @@
1
- declare const CloseIcon: () => import("@emotion/react/jsx-runtime").JSX.Element;
2
- export { CloseIcon };
3
- //# sourceMappingURL=CloseIcon.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CloseIcon.d.ts","sourceRoot":"","sources":["../../../../src/shared/components/CloseIcon.tsx"],"names":[],"mappings":"AAEA,QAAA,MAAM,SAAS,wDAgBd,CAAC;AAEF,OAAO,EAAE,SAAS,EAAE,CAAC"}