@civic/auth 0.0.1-beta.3 → 0.0.1-beta.31

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 (701) hide show
  1. package/.eslintignore +3 -0
  2. package/.eslintrc.json +10 -0
  3. package/.prettierignore +3 -0
  4. package/.prettierrc +1 -0
  5. package/.turbo/turbo-build.log +13 -0
  6. package/.turbo/turbo-lint$colon$fix.log +16 -0
  7. package/.turbo/turbo-test.log +1153 -0
  8. package/README.md +26 -4
  9. package/dist/cjs/src/browser/storage.d.ts +6 -0
  10. package/dist/cjs/src/browser/storage.d.ts.map +1 -0
  11. package/dist/cjs/src/browser/storage.js +13 -0
  12. package/dist/cjs/src/browser/storage.js.map +1 -0
  13. package/dist/cjs/src/config.d.ts +3 -0
  14. package/dist/cjs/src/config.d.ts.map +1 -0
  15. package/dist/cjs/src/config.js +8 -0
  16. package/dist/cjs/src/config.js.map +1 -0
  17. package/dist/cjs/src/constants.d.ts +9 -0
  18. package/dist/cjs/src/constants.d.ts.map +1 -0
  19. package/dist/cjs/src/constants.js +26 -0
  20. package/dist/cjs/src/constants.js.map +1 -0
  21. package/dist/cjs/src/index.d.ts +4 -0
  22. package/dist/cjs/src/index.d.ts.map +1 -0
  23. package/dist/cjs/src/index.js +3 -0
  24. package/dist/cjs/src/index.js.map +1 -0
  25. package/dist/cjs/src/lib/cookies.d.ts +7 -0
  26. package/dist/cjs/src/lib/cookies.d.ts.map +1 -0
  27. package/dist/cjs/src/lib/cookies.js +26 -0
  28. package/dist/cjs/src/lib/cookies.js.map +1 -0
  29. package/dist/cjs/src/lib/jwt.d.ts +3 -0
  30. package/dist/cjs/src/lib/jwt.d.ts.map +1 -0
  31. package/dist/cjs/src/lib/jwt.js +13 -0
  32. package/dist/cjs/src/lib/jwt.js.map +1 -0
  33. package/dist/cjs/src/lib/logger.d.ts +26 -0
  34. package/dist/cjs/src/lib/logger.d.ts.map +1 -0
  35. package/dist/cjs/src/lib/logger.js +62 -0
  36. package/dist/cjs/src/lib/logger.js.map +1 -0
  37. package/dist/cjs/src/lib/oauth.d.ts +19 -0
  38. package/dist/cjs/src/lib/oauth.d.ts.map +1 -0
  39. package/dist/cjs/src/lib/oauth.js +67 -0
  40. package/dist/cjs/src/lib/oauth.js.map +1 -0
  41. package/dist/cjs/src/lib/postMessage.d.ts +4 -0
  42. package/dist/cjs/src/lib/postMessage.d.ts.map +1 -0
  43. package/dist/cjs/src/lib/postMessage.js +18 -0
  44. package/dist/cjs/src/lib/postMessage.js.map +1 -0
  45. package/dist/cjs/src/lib/windowUtil.d.ts +4 -0
  46. package/dist/cjs/src/lib/windowUtil.d.ts.map +1 -0
  47. package/dist/cjs/src/lib/windowUtil.js +34 -0
  48. package/dist/cjs/src/lib/windowUtil.js.map +1 -0
  49. package/dist/cjs/src/nextjs/GetUser.d.ts +6 -0
  50. package/dist/cjs/src/nextjs/GetUser.d.ts.map +1 -0
  51. package/dist/cjs/src/nextjs/GetUser.js +22 -0
  52. package/dist/cjs/src/nextjs/GetUser.js.map +1 -0
  53. package/dist/cjs/src/nextjs/config.d.ts +178 -0
  54. package/dist/cjs/src/nextjs/config.d.ts.map +1 -0
  55. package/dist/cjs/src/nextjs/config.js +167 -0
  56. package/dist/cjs/src/nextjs/config.js.map +1 -0
  57. package/dist/cjs/src/nextjs/cookies.d.ts +30 -0
  58. package/dist/cjs/src/nextjs/cookies.d.ts.map +1 -0
  59. package/dist/cjs/src/nextjs/cookies.js +119 -0
  60. package/dist/cjs/src/nextjs/cookies.js.map +1 -0
  61. package/dist/cjs/src/nextjs/hooks/index.d.ts +2 -0
  62. package/dist/cjs/src/nextjs/hooks/index.d.ts.map +1 -0
  63. package/dist/cjs/src/nextjs/hooks/index.js +6 -0
  64. package/dist/cjs/src/nextjs/hooks/index.js.map +1 -0
  65. package/dist/cjs/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
  66. package/dist/cjs/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
  67. package/dist/cjs/src/nextjs/hooks/useTokenCookie.js +41 -0
  68. package/dist/cjs/src/nextjs/hooks/useTokenCookie.js.map +1 -0
  69. package/dist/cjs/src/nextjs/hooks/useUserCookie.d.ts +3 -0
  70. package/dist/cjs/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  71. package/dist/cjs/src/nextjs/hooks/useUserCookie.js +40 -0
  72. package/dist/cjs/src/nextjs/hooks/useUserCookie.js.map +1 -0
  73. package/dist/cjs/src/nextjs/index.d.ts +7 -0
  74. package/dist/cjs/src/nextjs/index.d.ts.map +1 -0
  75. package/dist/cjs/src/nextjs/index.js +18 -0
  76. package/dist/cjs/src/nextjs/index.js.map +1 -0
  77. package/dist/cjs/src/nextjs/middleware/index.d.ts +2 -0
  78. package/dist/cjs/src/nextjs/middleware/index.d.ts.map +1 -0
  79. package/dist/cjs/src/nextjs/middleware/index.js +8 -0
  80. package/dist/cjs/src/nextjs/middleware/index.js.map +1 -0
  81. package/dist/cjs/src/nextjs/middleware.d.ts +59 -0
  82. package/dist/cjs/src/nextjs/middleware.d.ts.map +1 -0
  83. package/dist/cjs/src/nextjs/middleware.js +116 -0
  84. package/dist/cjs/src/nextjs/middleware.js.map +1 -0
  85. package/dist/cjs/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
  86. package/dist/cjs/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  87. package/dist/cjs/src/nextjs/providers/NextAuthProvider.js +76 -0
  88. package/dist/cjs/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  89. package/dist/cjs/src/nextjs/routeHandler.d.ts +18 -0
  90. package/dist/cjs/src/nextjs/routeHandler.d.ts.map +1 -0
  91. package/dist/cjs/src/nextjs/routeHandler.js +217 -0
  92. package/dist/cjs/src/nextjs/routeHandler.js.map +1 -0
  93. package/dist/cjs/src/nextjs/utils.d.ts +3 -0
  94. package/dist/cjs/src/nextjs/utils.d.ts.map +1 -0
  95. package/dist/cjs/src/nextjs/utils.js +9 -0
  96. package/dist/cjs/src/nextjs/utils.js.map +1 -0
  97. package/dist/cjs/src/reactjs/components/SignInButton.d.ts +8 -0
  98. package/dist/cjs/src/reactjs/components/SignInButton.d.ts.map +1 -0
  99. package/dist/cjs/src/reactjs/components/SignInButton.js +20 -0
  100. package/dist/cjs/src/reactjs/components/SignInButton.js.map +1 -0
  101. package/dist/cjs/src/reactjs/components/SignOutButton.d.ts +6 -0
  102. package/dist/cjs/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  103. package/dist/cjs/src/reactjs/components/SignOutButton.js +20 -0
  104. package/dist/cjs/src/reactjs/components/SignOutButton.js.map +1 -0
  105. package/dist/cjs/src/reactjs/components/UserButton.d.ts +8 -0
  106. package/dist/cjs/src/reactjs/components/UserButton.d.ts.map +1 -0
  107. package/dist/cjs/src/reactjs/components/UserButton.js +136 -0
  108. package/dist/cjs/src/reactjs/components/UserButton.js.map +1 -0
  109. package/dist/cjs/src/reactjs/components/index.d.ts +6 -0
  110. package/dist/cjs/src/reactjs/components/index.d.ts.map +1 -0
  111. package/dist/cjs/src/reactjs/components/index.js +14 -0
  112. package/dist/cjs/src/reactjs/components/index.js.map +1 -0
  113. package/dist/cjs/src/reactjs/hooks/index.d.ts +7 -0
  114. package/dist/cjs/src/reactjs/hooks/index.d.ts.map +1 -0
  115. package/dist/cjs/src/reactjs/hooks/index.js +16 -0
  116. package/dist/cjs/src/reactjs/hooks/index.js.map +1 -0
  117. package/dist/cjs/src/reactjs/hooks/useAuth.d.ts +3 -0
  118. package/dist/cjs/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  119. package/dist/cjs/src/reactjs/hooks/useAuth.js +15 -0
  120. package/dist/cjs/src/reactjs/hooks/useAuth.js.map +1 -0
  121. package/dist/cjs/src/reactjs/hooks/useUser.d.ts +4 -0
  122. package/dist/cjs/src/reactjs/hooks/useUser.d.ts.map +1 -0
  123. package/dist/cjs/src/reactjs/hooks/useUser.js +15 -0
  124. package/dist/cjs/src/reactjs/hooks/useUser.js.map +1 -0
  125. package/dist/cjs/src/reactjs/index.d.ts +6 -0
  126. package/dist/cjs/src/reactjs/index.d.ts.map +1 -0
  127. package/dist/cjs/src/reactjs/index.js +30 -0
  128. package/dist/cjs/src/reactjs/index.js.map +1 -0
  129. package/dist/cjs/src/reactjs/providers/index.d.ts +8 -0
  130. package/dist/cjs/src/reactjs/providers/index.d.ts.map +1 -0
  131. package/dist/cjs/src/reactjs/providers/index.js +19 -0
  132. package/dist/cjs/src/reactjs/providers/index.js.map +1 -0
  133. package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts +18 -0
  134. package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  135. package/dist/cjs/src/server/ServerAuthenticationResolver.js +61 -0
  136. package/dist/cjs/src/server/ServerAuthenticationResolver.js.map +1 -0
  137. package/dist/cjs/src/server/config.d.ts +16 -0
  138. package/dist/cjs/src/server/config.d.ts.map +1 -0
  139. package/dist/cjs/src/server/config.js +3 -0
  140. package/dist/cjs/src/server/config.js.map +1 -0
  141. package/dist/cjs/src/server/index.d.ts +6 -0
  142. package/dist/cjs/src/server/index.d.ts.map +1 -0
  143. package/dist/cjs/src/server/index.js +14 -0
  144. package/dist/cjs/src/server/index.js.map +1 -0
  145. package/dist/cjs/src/server/login.d.ts +17 -0
  146. package/dist/cjs/src/server/login.d.ts.map +1 -0
  147. package/dist/cjs/src/server/login.js +42 -0
  148. package/dist/cjs/src/server/login.js.map +1 -0
  149. package/dist/cjs/src/server/refresh.d.ts +7 -0
  150. package/dist/cjs/src/server/refresh.d.ts.map +1 -0
  151. package/dist/cjs/src/server/refresh.js +16 -0
  152. package/dist/cjs/src/server/refresh.js.map +1 -0
  153. package/dist/cjs/src/services/AuthenticationService.d.ts +87 -0
  154. package/dist/cjs/src/services/AuthenticationService.d.ts.map +1 -0
  155. package/dist/cjs/src/services/AuthenticationService.js +218 -0
  156. package/dist/cjs/src/services/AuthenticationService.js.map +1 -0
  157. package/dist/cjs/src/services/PKCE.d.ts +20 -0
  158. package/dist/cjs/src/services/PKCE.d.ts.map +1 -0
  159. package/dist/cjs/src/services/PKCE.js +50 -0
  160. package/dist/cjs/src/services/PKCE.js.map +1 -0
  161. package/dist/cjs/src/services/types.d.ts +23 -0
  162. package/dist/cjs/src/services/types.d.ts.map +1 -0
  163. package/dist/cjs/src/services/types.js +11 -0
  164. package/dist/cjs/src/services/types.js.map +1 -0
  165. package/dist/cjs/src/shared/AuthProvider.d.ts +18 -0
  166. package/dist/cjs/src/shared/AuthProvider.d.ts.map +1 -0
  167. package/dist/cjs/src/shared/AuthProvider.js +246 -0
  168. package/dist/cjs/src/shared/AuthProvider.js.map +1 -0
  169. package/dist/cjs/src/shared/CivicAuthProvider.d.ts +6 -0
  170. package/dist/cjs/src/shared/CivicAuthProvider.d.ts.map +1 -0
  171. package/dist/cjs/src/shared/CivicAuthProvider.js +19 -0
  172. package/dist/cjs/src/shared/CivicAuthProvider.js.map +1 -0
  173. package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts +15 -0
  174. package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts.map +1 -0
  175. package/dist/cjs/src/shared/GenericAuthenticationRefresher.js +47 -0
  176. package/dist/cjs/src/shared/GenericAuthenticationRefresher.js.map +1 -0
  177. package/dist/cjs/src/shared/UserProvider.d.ts +17 -0
  178. package/dist/cjs/src/shared/UserProvider.d.ts.map +1 -0
  179. package/dist/cjs/src/shared/UserProvider.js +42 -0
  180. package/dist/cjs/src/shared/UserProvider.js.map +1 -0
  181. package/dist/cjs/src/shared/UserSession.d.ts +12 -0
  182. package/dist/cjs/src/shared/UserSession.d.ts.map +1 -0
  183. package/dist/cjs/src/shared/UserSession.js +24 -0
  184. package/dist/cjs/src/shared/UserSession.js.map +1 -0
  185. package/dist/cjs/src/shared/components/CivicAuthIframe.d.ts +8 -0
  186. package/dist/cjs/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  187. package/dist/cjs/src/shared/components/CivicAuthIframe.js +35 -0
  188. package/dist/cjs/src/shared/components/CivicAuthIframe.js.map +1 -0
  189. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.d.ts +9 -0
  190. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  191. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.js +154 -0
  192. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  193. package/dist/cjs/src/shared/components/CloseIcon.d.ts +4 -0
  194. package/dist/cjs/src/shared/components/CloseIcon.d.ts.map +1 -0
  195. package/dist/cjs/src/shared/components/CloseIcon.js +12 -0
  196. package/dist/cjs/src/shared/components/CloseIcon.js.map +1 -0
  197. package/dist/cjs/src/shared/components/LoadingIcon.d.ts +4 -0
  198. package/dist/cjs/src/shared/components/LoadingIcon.d.ts.map +1 -0
  199. package/dist/cjs/src/shared/components/LoadingIcon.js +36 -0
  200. package/dist/cjs/src/shared/components/LoadingIcon.js.map +1 -0
  201. package/dist/cjs/src/shared/hooks/index.d.ts +5 -0
  202. package/dist/cjs/src/shared/hooks/index.d.ts.map +1 -0
  203. package/dist/cjs/src/shared/hooks/index.js +12 -0
  204. package/dist/cjs/src/shared/hooks/index.js.map +1 -0
  205. package/dist/cjs/src/shared/hooks/useAuth.d.ts +3 -0
  206. package/dist/cjs/src/shared/hooks/useAuth.d.ts.map +1 -0
  207. package/dist/cjs/src/shared/hooks/useAuth.js +15 -0
  208. package/dist/cjs/src/shared/hooks/useAuth.js.map +1 -0
  209. package/dist/cjs/src/shared/hooks/useConfig.d.ts +3 -0
  210. package/dist/cjs/src/shared/hooks/useConfig.d.ts.map +1 -0
  211. package/dist/cjs/src/shared/hooks/useConfig.js +16 -0
  212. package/dist/cjs/src/shared/hooks/useConfig.js.map +1 -0
  213. package/dist/cjs/src/shared/hooks/useIframe.d.ts +3 -0
  214. package/dist/cjs/src/shared/hooks/useIframe.d.ts.map +1 -0
  215. package/dist/cjs/src/shared/hooks/useIframe.js +16 -0
  216. package/dist/cjs/src/shared/hooks/useIframe.js.map +1 -0
  217. package/dist/cjs/src/shared/hooks/useSession.d.ts +3 -0
  218. package/dist/cjs/src/shared/hooks/useSession.d.ts.map +1 -0
  219. package/dist/cjs/src/shared/hooks/useSession.js +16 -0
  220. package/dist/cjs/src/shared/hooks/useSession.js.map +1 -0
  221. package/dist/cjs/src/shared/hooks/useToken.d.ts +3 -0
  222. package/dist/cjs/src/shared/hooks/useToken.d.ts.map +1 -0
  223. package/dist/cjs/src/shared/hooks/useToken.js +15 -0
  224. package/dist/cjs/src/shared/hooks/useToken.js.map +1 -0
  225. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts +15 -0
  226. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  227. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js +43 -0
  228. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  229. package/dist/cjs/src/shared/lib/UserSession.d.ts +12 -0
  230. package/dist/cjs/src/shared/lib/UserSession.d.ts.map +1 -0
  231. package/dist/cjs/src/shared/lib/UserSession.js +24 -0
  232. package/dist/cjs/src/shared/lib/UserSession.js.map +1 -0
  233. package/dist/cjs/src/shared/lib/session.d.ts +3 -0
  234. package/dist/cjs/src/shared/lib/session.d.ts.map +1 -0
  235. package/dist/cjs/src/shared/lib/session.js +13 -0
  236. package/dist/cjs/src/shared/lib/session.js.map +1 -0
  237. package/dist/cjs/src/shared/lib/storage.d.ts +25 -0
  238. package/dist/cjs/src/shared/lib/storage.d.ts.map +1 -0
  239. package/dist/cjs/src/shared/lib/storage.js +21 -0
  240. package/dist/cjs/src/shared/lib/storage.js.map +1 -0
  241. package/dist/cjs/src/shared/lib/types.d.ts +22 -0
  242. package/dist/cjs/src/shared/lib/types.d.ts.map +1 -0
  243. package/dist/cjs/src/shared/lib/types.js +19 -0
  244. package/dist/cjs/src/shared/lib/types.js.map +1 -0
  245. package/dist/cjs/src/shared/lib/util.d.ts +33 -0
  246. package/dist/cjs/src/shared/lib/util.d.ts.map +1 -0
  247. package/dist/cjs/src/shared/lib/util.js +163 -0
  248. package/dist/cjs/src/shared/lib/util.js.map +1 -0
  249. package/dist/cjs/src/shared/providers/AuthContext.d.ts +10 -0
  250. package/dist/cjs/src/shared/providers/AuthContext.d.ts.map +1 -0
  251. package/dist/cjs/src/shared/providers/AuthContext.js +6 -0
  252. package/dist/cjs/src/shared/providers/AuthContext.js.map +1 -0
  253. package/dist/cjs/src/shared/providers/AuthProvider.d.ts +20 -0
  254. package/dist/cjs/src/shared/providers/AuthProvider.d.ts.map +1 -0
  255. package/dist/cjs/src/shared/providers/AuthProvider.js +289 -0
  256. package/dist/cjs/src/shared/providers/AuthProvider.js.map +1 -0
  257. package/dist/cjs/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  258. package/dist/cjs/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  259. package/dist/cjs/src/shared/providers/CivicAuthProvider.js +21 -0
  260. package/dist/cjs/src/shared/providers/CivicAuthProvider.js.map +1 -0
  261. package/dist/cjs/src/shared/providers/ConfigProvider.d.ts +21 -0
  262. package/dist/cjs/src/shared/providers/ConfigProvider.d.ts.map +1 -0
  263. package/dist/cjs/src/shared/providers/ConfigProvider.js +46 -0
  264. package/dist/cjs/src/shared/providers/ConfigProvider.js.map +1 -0
  265. package/dist/cjs/src/shared/providers/IframeProvider.d.ts +16 -0
  266. package/dist/cjs/src/shared/providers/IframeProvider.d.ts.map +1 -0
  267. package/dist/cjs/src/shared/providers/IframeProvider.js +38 -0
  268. package/dist/cjs/src/shared/providers/IframeProvider.js.map +1 -0
  269. package/dist/cjs/src/shared/providers/SessionProvider.d.ts +13 -0
  270. package/dist/cjs/src/shared/providers/SessionProvider.d.ts.map +1 -0
  271. package/dist/cjs/src/shared/providers/SessionProvider.js +40 -0
  272. package/dist/cjs/src/shared/providers/SessionProvider.js.map +1 -0
  273. package/dist/cjs/src/shared/providers/TokenProvider.d.ts +18 -0
  274. package/dist/cjs/src/shared/providers/TokenProvider.d.ts.map +1 -0
  275. package/dist/cjs/src/shared/providers/TokenProvider.js +80 -0
  276. package/dist/cjs/src/shared/providers/TokenProvider.js.map +1 -0
  277. package/dist/cjs/src/shared/providers/UserProvider.d.ts +18 -0
  278. package/dist/cjs/src/shared/providers/UserProvider.d.ts.map +1 -0
  279. package/dist/cjs/src/shared/providers/UserProvider.js +65 -0
  280. package/dist/cjs/src/shared/providers/UserProvider.js.map +1 -0
  281. package/dist/cjs/src/shared/session.d.ts +3 -0
  282. package/dist/cjs/src/shared/session.d.ts.map +1 -0
  283. package/dist/cjs/src/shared/session.js +13 -0
  284. package/dist/cjs/src/shared/session.js.map +1 -0
  285. package/dist/cjs/src/shared/util.d.ts +39 -0
  286. package/dist/cjs/src/shared/util.d.ts.map +1 -0
  287. package/dist/cjs/src/shared/util.js +162 -0
  288. package/dist/cjs/src/shared/util.js.map +1 -0
  289. package/dist/cjs/src/types.d.ts +146 -0
  290. package/dist/cjs/src/types.d.ts.map +1 -0
  291. package/dist/cjs/src/types.js +3 -0
  292. package/dist/cjs/src/types.js.map +1 -0
  293. package/dist/cjs/src/utils.d.ts +15 -0
  294. package/dist/cjs/src/utils.d.ts.map +1 -0
  295. package/dist/cjs/src/utils.js +47 -0
  296. package/dist/cjs/src/utils.js.map +1 -0
  297. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -0
  298. package/dist/esm/src/browser/storage.d.ts +6 -0
  299. package/dist/esm/src/browser/storage.d.ts.map +1 -0
  300. package/dist/esm/src/browser/storage.js +9 -0
  301. package/dist/esm/src/browser/storage.js.map +1 -0
  302. package/dist/esm/src/config.d.ts +3 -0
  303. package/dist/esm/src/config.d.ts.map +1 -0
  304. package/dist/esm/src/config.js +5 -0
  305. package/dist/esm/src/config.js.map +1 -0
  306. package/dist/esm/src/constants.d.ts +9 -0
  307. package/dist/esm/src/constants.d.ts.map +1 -0
  308. package/dist/esm/src/constants.js +17 -0
  309. package/dist/esm/src/constants.js.map +1 -0
  310. package/dist/esm/src/index.d.ts +4 -0
  311. package/dist/esm/src/index.d.ts.map +1 -0
  312. package/dist/esm/src/index.js +2 -0
  313. package/dist/esm/src/index.js.map +1 -0
  314. package/dist/esm/src/lib/cookies.d.ts +7 -0
  315. package/dist/esm/src/lib/cookies.d.ts.map +1 -0
  316. package/dist/esm/src/lib/cookies.js +23 -0
  317. package/dist/esm/src/lib/cookies.js.map +1 -0
  318. package/dist/esm/src/lib/jwt.d.ts +3 -0
  319. package/dist/esm/src/lib/jwt.d.ts.map +1 -0
  320. package/dist/esm/src/lib/jwt.js +9 -0
  321. package/dist/esm/src/lib/jwt.js.map +1 -0
  322. package/dist/esm/src/lib/logger.d.ts +26 -0
  323. package/dist/esm/src/lib/logger.d.ts.map +1 -0
  324. package/dist/esm/src/lib/logger.js +55 -0
  325. package/dist/esm/src/lib/logger.js.map +1 -0
  326. package/dist/esm/src/lib/oauth.d.ts +19 -0
  327. package/dist/esm/src/lib/oauth.d.ts.map +1 -0
  328. package/dist/esm/src/lib/oauth.js +60 -0
  329. package/dist/esm/src/lib/oauth.js.map +1 -0
  330. package/dist/esm/src/lib/postMessage.d.ts +4 -0
  331. package/dist/esm/src/lib/postMessage.d.ts.map +1 -0
  332. package/dist/esm/src/lib/postMessage.js +15 -0
  333. package/dist/esm/src/lib/postMessage.js.map +1 -0
  334. package/dist/esm/src/lib/windowUtil.d.ts +4 -0
  335. package/dist/esm/src/lib/windowUtil.d.ts.map +1 -0
  336. package/dist/esm/src/lib/windowUtil.js +30 -0
  337. package/dist/esm/src/lib/windowUtil.js.map +1 -0
  338. package/dist/esm/src/nextjs/GetUser.d.ts +6 -0
  339. package/dist/esm/src/nextjs/GetUser.d.ts.map +1 -0
  340. package/dist/esm/src/nextjs/GetUser.js +18 -0
  341. package/dist/esm/src/nextjs/GetUser.js.map +1 -0
  342. package/dist/esm/src/nextjs/config.d.ts +178 -0
  343. package/dist/esm/src/nextjs/config.d.ts.map +1 -0
  344. package/dist/esm/src/nextjs/config.js +162 -0
  345. package/dist/esm/src/nextjs/config.js.map +1 -0
  346. package/dist/esm/src/nextjs/cookies.d.ts +30 -0
  347. package/dist/esm/src/nextjs/cookies.d.ts.map +1 -0
  348. package/dist/esm/src/nextjs/cookies.js +112 -0
  349. package/dist/esm/src/nextjs/cookies.js.map +1 -0
  350. package/dist/esm/src/nextjs/hooks/index.d.ts +2 -0
  351. package/dist/esm/src/nextjs/hooks/index.d.ts.map +1 -0
  352. package/dist/esm/src/nextjs/hooks/index.js +2 -0
  353. package/dist/esm/src/nextjs/hooks/index.js.map +1 -0
  354. package/dist/esm/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
  355. package/dist/esm/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
  356. package/dist/esm/src/nextjs/hooks/useTokenCookie.js +37 -0
  357. package/dist/esm/src/nextjs/hooks/useTokenCookie.js.map +1 -0
  358. package/dist/esm/src/nextjs/hooks/useUserCookie.d.ts +3 -0
  359. package/dist/esm/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  360. package/dist/esm/src/nextjs/hooks/useUserCookie.js +36 -0
  361. package/dist/esm/src/nextjs/hooks/useUserCookie.js.map +1 -0
  362. package/dist/esm/src/nextjs/index.d.ts +7 -0
  363. package/dist/esm/src/nextjs/index.d.ts.map +1 -0
  364. package/dist/esm/src/nextjs/index.js +6 -0
  365. package/dist/esm/src/nextjs/index.js.map +1 -0
  366. package/dist/esm/src/nextjs/middleware/index.d.ts +2 -0
  367. package/dist/esm/src/nextjs/middleware/index.d.ts.map +1 -0
  368. package/dist/esm/src/nextjs/middleware/index.js +2 -0
  369. package/dist/esm/src/nextjs/middleware/index.js.map +1 -0
  370. package/dist/esm/src/nextjs/middleware.d.ts +59 -0
  371. package/dist/esm/src/nextjs/middleware.d.ts.map +1 -0
  372. package/dist/esm/src/nextjs/middleware.js +107 -0
  373. package/dist/esm/src/nextjs/middleware.js.map +1 -0
  374. package/dist/esm/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
  375. package/dist/esm/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  376. package/dist/esm/src/nextjs/providers/NextAuthProvider.js +50 -0
  377. package/dist/esm/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  378. package/dist/esm/src/nextjs/routeHandler.d.ts +18 -0
  379. package/dist/esm/src/nextjs/routeHandler.d.ts.map +1 -0
  380. package/dist/esm/src/nextjs/routeHandler.js +212 -0
  381. package/dist/esm/src/nextjs/routeHandler.js.map +1 -0
  382. package/dist/esm/src/nextjs/utils.d.ts +3 -0
  383. package/dist/esm/src/nextjs/utils.d.ts.map +1 -0
  384. package/dist/esm/src/nextjs/utils.js +5 -0
  385. package/dist/esm/src/nextjs/utils.js.map +1 -0
  386. package/dist/esm/src/reactjs/components/SignInButton.d.ts +8 -0
  387. package/dist/esm/src/reactjs/components/SignInButton.d.ts.map +1 -0
  388. package/dist/esm/src/reactjs/components/SignInButton.js +14 -0
  389. package/dist/esm/src/reactjs/components/SignInButton.js.map +1 -0
  390. package/dist/esm/src/reactjs/components/SignOutButton.d.ts +6 -0
  391. package/dist/esm/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  392. package/dist/esm/src/reactjs/components/SignOutButton.js +14 -0
  393. package/dist/esm/src/reactjs/components/SignOutButton.js.map +1 -0
  394. package/dist/esm/src/reactjs/components/UserButton.d.ts +8 -0
  395. package/dist/esm/src/reactjs/components/UserButton.d.ts.map +1 -0
  396. package/dist/esm/src/reactjs/components/UserButton.js +110 -0
  397. package/dist/esm/src/reactjs/components/UserButton.js.map +1 -0
  398. package/dist/esm/src/reactjs/components/index.d.ts +6 -0
  399. package/dist/esm/src/reactjs/components/index.d.ts.map +1 -0
  400. package/dist/esm/src/reactjs/components/index.js +6 -0
  401. package/dist/esm/src/reactjs/components/index.js.map +1 -0
  402. package/dist/esm/src/reactjs/hooks/index.d.ts +7 -0
  403. package/dist/esm/src/reactjs/hooks/index.d.ts.map +1 -0
  404. package/dist/esm/src/reactjs/hooks/index.js +7 -0
  405. package/dist/esm/src/reactjs/hooks/index.js.map +1 -0
  406. package/dist/esm/src/reactjs/hooks/useAuth.d.ts +3 -0
  407. package/dist/esm/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  408. package/dist/esm/src/reactjs/hooks/useAuth.js +12 -0
  409. package/dist/esm/src/reactjs/hooks/useAuth.js.map +1 -0
  410. package/dist/esm/src/reactjs/hooks/useUser.d.ts +4 -0
  411. package/dist/esm/src/reactjs/hooks/useUser.d.ts.map +1 -0
  412. package/dist/esm/src/reactjs/hooks/useUser.js +12 -0
  413. package/dist/esm/src/reactjs/hooks/useUser.js.map +1 -0
  414. package/dist/esm/src/reactjs/index.d.ts +6 -0
  415. package/dist/esm/src/reactjs/index.d.ts.map +1 -0
  416. package/dist/esm/src/reactjs/index.js +8 -0
  417. package/dist/esm/src/reactjs/index.js.map +1 -0
  418. package/dist/esm/src/reactjs/providers/index.d.ts +8 -0
  419. package/dist/esm/src/reactjs/providers/index.d.ts.map +1 -0
  420. package/dist/esm/src/reactjs/providers/index.js +7 -0
  421. package/dist/esm/src/reactjs/providers/index.js.map +1 -0
  422. package/dist/esm/src/server/ServerAuthenticationResolver.d.ts +18 -0
  423. package/dist/esm/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  424. package/dist/esm/src/server/ServerAuthenticationResolver.js +57 -0
  425. package/dist/esm/src/server/ServerAuthenticationResolver.js.map +1 -0
  426. package/dist/esm/src/server/config.d.ts +16 -0
  427. package/dist/esm/src/server/config.d.ts.map +1 -0
  428. package/dist/esm/src/server/config.js +2 -0
  429. package/dist/esm/src/server/config.js.map +1 -0
  430. package/dist/esm/src/server/index.d.ts +6 -0
  431. package/dist/esm/src/server/index.d.ts.map +1 -0
  432. package/dist/esm/src/server/index.js +5 -0
  433. package/dist/esm/src/server/index.js.map +1 -0
  434. package/dist/esm/src/server/login.d.ts +17 -0
  435. package/dist/esm/src/server/login.d.ts.map +1 -0
  436. package/dist/esm/src/server/login.js +37 -0
  437. package/dist/esm/src/server/login.js.map +1 -0
  438. package/dist/esm/src/server/refresh.d.ts +7 -0
  439. package/dist/esm/src/server/refresh.d.ts.map +1 -0
  440. package/dist/esm/src/server/refresh.js +13 -0
  441. package/dist/esm/src/server/refresh.js.map +1 -0
  442. package/dist/esm/src/services/AuthenticationService.d.ts +87 -0
  443. package/dist/esm/src/services/AuthenticationService.d.ts.map +1 -0
  444. package/dist/esm/src/services/AuthenticationService.js +212 -0
  445. package/dist/esm/src/services/AuthenticationService.js.map +1 -0
  446. package/dist/esm/src/services/PKCE.d.ts +20 -0
  447. package/dist/esm/src/services/PKCE.d.ts.map +1 -0
  448. package/dist/esm/src/services/PKCE.js +44 -0
  449. package/dist/esm/src/services/PKCE.js.map +1 -0
  450. package/dist/esm/src/services/types.d.ts +23 -0
  451. package/dist/esm/src/services/types.d.ts.map +1 -0
  452. package/dist/esm/src/services/types.js +7 -0
  453. package/dist/esm/src/services/types.js.map +1 -0
  454. package/dist/esm/src/shared/components/CivicAuthIframe.d.ts +8 -0
  455. package/dist/esm/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  456. package/dist/esm/src/shared/components/CivicAuthIframe.js +9 -0
  457. package/dist/esm/src/shared/components/CivicAuthIframe.js.map +1 -0
  458. package/dist/esm/src/shared/components/CivicAuthIframeContainer.d.ts +9 -0
  459. package/dist/esm/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  460. package/dist/esm/src/shared/components/CivicAuthIframeContainer.js +128 -0
  461. package/dist/esm/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  462. package/dist/esm/src/shared/components/CloseIcon.d.ts +4 -0
  463. package/dist/esm/src/shared/components/CloseIcon.d.ts.map +1 -0
  464. package/dist/esm/src/shared/components/CloseIcon.js +6 -0
  465. package/dist/esm/src/shared/components/CloseIcon.js.map +1 -0
  466. package/dist/esm/src/shared/components/LoadingIcon.d.ts +4 -0
  467. package/dist/esm/src/shared/components/LoadingIcon.d.ts.map +1 -0
  468. package/dist/esm/src/shared/components/LoadingIcon.js +30 -0
  469. package/dist/esm/src/shared/components/LoadingIcon.js.map +1 -0
  470. package/dist/esm/src/shared/hooks/index.d.ts +5 -0
  471. package/dist/esm/src/shared/hooks/index.d.ts.map +1 -0
  472. package/dist/esm/src/shared/hooks/index.js +5 -0
  473. package/dist/esm/src/shared/hooks/index.js.map +1 -0
  474. package/dist/esm/src/shared/hooks/useAuth.d.ts +3 -0
  475. package/dist/esm/src/shared/hooks/useAuth.d.ts.map +1 -0
  476. package/dist/esm/src/shared/hooks/useAuth.js +12 -0
  477. package/dist/esm/src/shared/hooks/useAuth.js.map +1 -0
  478. package/dist/esm/src/shared/hooks/useConfig.d.ts +3 -0
  479. package/dist/esm/src/shared/hooks/useConfig.d.ts.map +1 -0
  480. package/dist/esm/src/shared/hooks/useConfig.js +13 -0
  481. package/dist/esm/src/shared/hooks/useConfig.js.map +1 -0
  482. package/dist/esm/src/shared/hooks/useIframe.d.ts +3 -0
  483. package/dist/esm/src/shared/hooks/useIframe.d.ts.map +1 -0
  484. package/dist/esm/src/shared/hooks/useIframe.js +13 -0
  485. package/dist/esm/src/shared/hooks/useIframe.js.map +1 -0
  486. package/dist/esm/src/shared/hooks/useSession.d.ts +3 -0
  487. package/dist/esm/src/shared/hooks/useSession.d.ts.map +1 -0
  488. package/dist/esm/src/shared/hooks/useSession.js +13 -0
  489. package/dist/esm/src/shared/hooks/useSession.js.map +1 -0
  490. package/dist/esm/src/shared/hooks/useToken.d.ts +3 -0
  491. package/dist/esm/src/shared/hooks/useToken.d.ts.map +1 -0
  492. package/dist/esm/src/shared/hooks/useToken.js +12 -0
  493. package/dist/esm/src/shared/hooks/useToken.js.map +1 -0
  494. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts +15 -0
  495. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  496. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js +39 -0
  497. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  498. package/dist/esm/src/shared/lib/UserSession.d.ts +12 -0
  499. package/dist/esm/src/shared/lib/UserSession.d.ts.map +1 -0
  500. package/dist/esm/src/shared/lib/UserSession.js +20 -0
  501. package/dist/esm/src/shared/lib/UserSession.js.map +1 -0
  502. package/dist/esm/src/shared/lib/session.d.ts +3 -0
  503. package/dist/esm/src/shared/lib/session.d.ts.map +1 -0
  504. package/dist/esm/src/shared/lib/session.js +10 -0
  505. package/dist/esm/src/shared/lib/session.js.map +1 -0
  506. package/dist/esm/src/shared/lib/storage.d.ts +25 -0
  507. package/dist/esm/src/shared/lib/storage.d.ts.map +1 -0
  508. package/dist/esm/src/shared/lib/storage.js +17 -0
  509. package/dist/esm/src/shared/lib/storage.js.map +1 -0
  510. package/dist/esm/src/shared/lib/types.d.ts +22 -0
  511. package/dist/esm/src/shared/lib/types.d.ts.map +1 -0
  512. package/dist/esm/src/shared/lib/types.js +16 -0
  513. package/dist/esm/src/shared/lib/types.js.map +1 -0
  514. package/dist/esm/src/shared/lib/util.d.ts +33 -0
  515. package/dist/esm/src/shared/lib/util.d.ts.map +1 -0
  516. package/dist/esm/src/shared/lib/util.js +127 -0
  517. package/dist/esm/src/shared/lib/util.js.map +1 -0
  518. package/dist/esm/src/shared/providers/AuthContext.d.ts +10 -0
  519. package/dist/esm/src/shared/providers/AuthContext.d.ts.map +1 -0
  520. package/dist/esm/src/shared/providers/AuthContext.js +3 -0
  521. package/dist/esm/src/shared/providers/AuthContext.js.map +1 -0
  522. package/dist/esm/src/shared/providers/AuthProvider.d.ts +20 -0
  523. package/dist/esm/src/shared/providers/AuthProvider.d.ts.map +1 -0
  524. package/dist/esm/src/shared/providers/AuthProvider.js +263 -0
  525. package/dist/esm/src/shared/providers/AuthProvider.js.map +1 -0
  526. package/dist/esm/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  527. package/dist/esm/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  528. package/dist/esm/src/shared/providers/CivicAuthProvider.js +15 -0
  529. package/dist/esm/src/shared/providers/CivicAuthProvider.js.map +1 -0
  530. package/dist/esm/src/shared/providers/ConfigProvider.d.ts +21 -0
  531. package/dist/esm/src/shared/providers/ConfigProvider.d.ts.map +1 -0
  532. package/dist/esm/src/shared/providers/ConfigProvider.js +19 -0
  533. package/dist/esm/src/shared/providers/ConfigProvider.js.map +1 -0
  534. package/dist/esm/src/shared/providers/IframeProvider.d.ts +16 -0
  535. package/dist/esm/src/shared/providers/IframeProvider.d.ts.map +1 -0
  536. package/dist/esm/src/shared/providers/IframeProvider.js +11 -0
  537. package/dist/esm/src/shared/providers/IframeProvider.js.map +1 -0
  538. package/dist/esm/src/shared/providers/SessionProvider.d.ts +13 -0
  539. package/dist/esm/src/shared/providers/SessionProvider.d.ts.map +1 -0
  540. package/dist/esm/src/shared/providers/SessionProvider.js +13 -0
  541. package/dist/esm/src/shared/providers/SessionProvider.js.map +1 -0
  542. package/dist/esm/src/shared/providers/TokenProvider.d.ts +18 -0
  543. package/dist/esm/src/shared/providers/TokenProvider.d.ts.map +1 -0
  544. package/dist/esm/src/shared/providers/TokenProvider.js +53 -0
  545. package/dist/esm/src/shared/providers/TokenProvider.js.map +1 -0
  546. package/dist/esm/src/shared/providers/UserProvider.d.ts +18 -0
  547. package/dist/esm/src/shared/providers/UserProvider.d.ts.map +1 -0
  548. package/dist/esm/src/shared/providers/UserProvider.js +38 -0
  549. package/dist/esm/src/shared/providers/UserProvider.js.map +1 -0
  550. package/dist/esm/src/types.d.ts +146 -0
  551. package/dist/esm/src/types.d.ts.map +1 -0
  552. package/dist/esm/src/types.js +2 -0
  553. package/dist/esm/src/types.js.map +1 -0
  554. package/dist/esm/src/utils.d.ts +15 -0
  555. package/dist/esm/src/utils.d.ts.map +1 -0
  556. package/dist/esm/src/utils.js +43 -0
  557. package/dist/esm/src/utils.js.map +1 -0
  558. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -0
  559. package/dist/src/nextjs/cookies.d.ts.map +1 -0
  560. package/dist/src/nextjs/cookies.js +113 -0
  561. package/dist/src/nextjs/cookies.js.map +1 -0
  562. package/dist/tsconfig.tsbuildinfo +1 -0
  563. package/package.json +53 -43
  564. package/src/browser/storage.ts +11 -0
  565. package/src/config.ts +6 -0
  566. package/src/constants.ts +29 -0
  567. package/src/index.ts +16 -0
  568. package/src/lib/cookies.ts +28 -0
  569. package/src/lib/jwt.ts +15 -0
  570. package/src/lib/logger.ts +72 -0
  571. package/src/lib/oauth.ts +83 -0
  572. package/src/lib/postMessage.ts +22 -0
  573. package/src/lib/windowUtil.ts +29 -0
  574. package/src/nextjs/GetUser.ts +22 -0
  575. package/src/nextjs/config.ts +205 -0
  576. package/src/nextjs/cookies.ts +162 -0
  577. package/src/nextjs/hooks/index.ts +1 -0
  578. package/src/nextjs/hooks/useTokenCookie.ts +41 -0
  579. package/src/nextjs/hooks/useUserCookie.ts +41 -0
  580. package/src/nextjs/index.ts +20 -0
  581. package/src/nextjs/middleware/index.ts +1 -0
  582. package/src/nextjs/middleware.ts +155 -0
  583. package/src/nextjs/providers/NextAuthProvider.tsx +87 -0
  584. package/src/nextjs/routeHandler.ts +297 -0
  585. package/src/nextjs/utils.ts +9 -0
  586. package/src/reactjs/components/SignInButton.tsx +32 -0
  587. package/src/reactjs/components/SignOutButton.tsx +24 -0
  588. package/src/reactjs/components/UserButton.tsx +215 -0
  589. package/src/reactjs/components/index.ts +5 -0
  590. package/src/reactjs/hooks/index.ts +6 -0
  591. package/src/reactjs/hooks/useAuth.ts +15 -0
  592. package/src/reactjs/hooks/useUser.ts +20 -0
  593. package/src/reactjs/index.ts +19 -0
  594. package/src/reactjs/providers/index.ts +27 -0
  595. package/src/server/ServerAuthenticationResolver.ts +102 -0
  596. package/src/server/config.ts +17 -0
  597. package/src/server/index.ts +12 -0
  598. package/src/server/login.ts +59 -0
  599. package/src/server/refresh.ts +23 -0
  600. package/src/services/AuthenticationService.ts +324 -0
  601. package/src/services/PKCE.ts +45 -0
  602. package/src/services/types.ts +54 -0
  603. package/src/shared/components/CivicAuthIframe.tsx +26 -0
  604. package/src/shared/components/CivicAuthIframeContainer.tsx +190 -0
  605. package/src/shared/components/CloseIcon.tsx +21 -0
  606. package/src/shared/components/LoadingIcon.tsx +53 -0
  607. package/src/shared/hooks/index.ts +4 -0
  608. package/src/shared/hooks/useAuth.ts +15 -0
  609. package/src/shared/hooks/useConfig.ts +14 -0
  610. package/src/shared/hooks/useIframe.ts +14 -0
  611. package/src/shared/hooks/useSession.ts +14 -0
  612. package/src/shared/hooks/useToken.ts +15 -0
  613. package/src/shared/lib/GenericAuthenticationRefresher.ts +70 -0
  614. package/src/shared/lib/UserSession.ts +25 -0
  615. package/src/shared/lib/session.ts +11 -0
  616. package/src/shared/lib/storage.ts +40 -0
  617. package/src/shared/lib/types.ts +26 -0
  618. package/src/shared/lib/util.ts +217 -0
  619. package/src/shared/providers/AuthContext.tsx +11 -0
  620. package/src/shared/providers/AuthProvider.tsx +390 -0
  621. package/src/shared/providers/CivicAuthProvider.tsx +31 -0
  622. package/src/shared/providers/ConfigProvider.tsx +50 -0
  623. package/src/shared/providers/IframeProvider.tsx +34 -0
  624. package/src/shared/providers/SessionProvider.tsx +29 -0
  625. package/src/shared/providers/TokenProvider.tsx +78 -0
  626. package/src/shared/providers/UserProvider.tsx +80 -0
  627. package/src/types.ts +227 -0
  628. package/src/utils.ts +58 -0
  629. package/test/integration/sdk.test.tsx +266 -0
  630. package/test/support/fixtures.ts +56 -0
  631. package/test/support/tokens.json +26 -0
  632. package/test/unit/lib/oauth.test.ts +72 -0
  633. package/test/unit/logger.test.ts +175 -0
  634. package/test/unit/nextjs/NextAuthProvider.test.tsx +38 -0
  635. package/test/unit/nextjs/config.test.ts +218 -0
  636. package/test/unit/nextjs/getUser.test.ts +41 -0
  637. package/test/unit/nextjs/middleware.test.ts +138 -0
  638. package/test/unit/nextjs/routeHandler.test.ts.skipped +369 -0
  639. package/test/unit/nextjs/utils.test.ts +17 -0
  640. package/test/unit/publicApi/__snapshots__/apiSnapshot.test.ts.snap +17 -0
  641. package/test/unit/publicApi/apiSnapshot.test.ts +11 -0
  642. package/test/unit/react/components/SignInButton.test.tsx +50 -0
  643. package/test/unit/react/components/SignOutButton.test.tsx +49 -0
  644. package/test/unit/server/login.test.ts +181 -0
  645. package/test/unit/server/session.test.ts +51 -0
  646. package/test/unit/services/AuthenticationService.test.ts +152 -0
  647. package/test/unit/services/ServerAuthenticationResolver.test.ts +115 -0
  648. package/test/unit/shared/GenericAuthenticationRefresher.test.ts +89 -0
  649. package/test/unit/shared/UserSession.test.ts +42 -0
  650. package/test/unit/shared/components/CivicAuthIframeContainer.test.tsx +154 -0
  651. package/test/unit/shared/storage.test.ts +67 -0
  652. package/test/unit/utils.test.ts +48 -0
  653. package/tsconfig.build.json +5 -0
  654. package/tsconfig.cjs.json +8 -0
  655. package/tsconfig.esm.json +7 -0
  656. package/tsconfig.json +42 -0
  657. package/vitest.config.ts +41 -0
  658. package/dist/chunk-4GIHS7LB.js +0 -201
  659. package/dist/chunk-4GIHS7LB.js.map +0 -1
  660. package/dist/chunk-CRTRMMJ7.js +0 -59
  661. package/dist/chunk-CRTRMMJ7.js.map +0 -1
  662. package/dist/chunk-GNGLWGZJ.mjs +0 -238
  663. package/dist/chunk-GNGLWGZJ.mjs.map +0 -1
  664. package/dist/chunk-NQPMNXBL.mjs +0 -154
  665. package/dist/chunk-NQPMNXBL.mjs.map +0 -1
  666. package/dist/chunk-RGHW4PYM.mjs +0 -59
  667. package/dist/chunk-RGHW4PYM.mjs.map +0 -1
  668. package/dist/chunk-UV56GNIT.mjs +0 -201
  669. package/dist/chunk-UV56GNIT.mjs.map +0 -1
  670. package/dist/chunk-VXIWRZWU.js +0 -238
  671. package/dist/chunk-VXIWRZWU.js.map +0 -1
  672. package/dist/chunk-WPISYQG3.js +0 -154
  673. package/dist/chunk-WPISYQG3.js.map +0 -1
  674. package/dist/index-DoDoIY_K.d.mts +0 -79
  675. package/dist/index-DoDoIY_K.d.ts +0 -79
  676. package/dist/index.css +0 -342
  677. package/dist/index.css.map +0 -1
  678. package/dist/index.d.mts +0 -3
  679. package/dist/index.d.ts +0 -3
  680. package/dist/index.js +0 -2
  681. package/dist/index.js.map +0 -1
  682. package/dist/index.mjs +0 -2
  683. package/dist/index.mjs.map +0 -1
  684. package/dist/nextjs.d.mts +0 -225
  685. package/dist/nextjs.d.ts +0 -225
  686. package/dist/nextjs.js +0 -253
  687. package/dist/nextjs.js.map +0 -1
  688. package/dist/nextjs.mjs +0 -253
  689. package/dist/nextjs.mjs.map +0 -1
  690. package/dist/react.d.mts +0 -119
  691. package/dist/react.d.ts +0 -119
  692. package/dist/react.js +0 -1178
  693. package/dist/react.js.map +0 -1
  694. package/dist/react.mjs +0 -1178
  695. package/dist/react.mjs.map +0 -1
  696. package/dist/server.d.mts +0 -55
  697. package/dist/server.d.ts +0 -55
  698. package/dist/server.js +0 -17
  699. package/dist/server.js.map +0 -1
  700. package/dist/server.mjs +0 -17
  701. package/dist/server.mjs.map +0 -1
@@ -0,0 +1,48 @@
1
+ import { isPopupBlocked } from "@/utils.js";
2
+ import { vi } from "vitest";
3
+
4
+ describe("isPopupBlocked", () => {
5
+ afterEach(() => {
6
+ // Reset mocks after each test
7
+ vi.restoreAllMocks();
8
+ });
9
+
10
+ it("should return true if window.open returns null", () => {
11
+ // Mock window.open to return null (popup blocked)
12
+ vi.spyOn(window, "open").mockReturnValue(null);
13
+
14
+ const result = isPopupBlocked();
15
+ expect(result).toBe(true);
16
+ });
17
+
18
+ it("should return false if window.open returns a valid popup", () => {
19
+ // Mock a valid popup window object
20
+ const mockPopup = { closed: false, close: vi.fn() } as unknown as Window;
21
+
22
+ vi.spyOn(window, "open").mockReturnValue(mockPopup);
23
+
24
+ const result = isPopupBlocked();
25
+ expect(result).toBe(false);
26
+ expect(mockPopup.close).toHaveBeenCalled(); // Ensure the popup is closed
27
+ });
28
+
29
+ it("should return true if window.open throws an error accessing properties", () => {
30
+ // Mock a popup window object that throws an error when accessing properties
31
+ const mockPopup = {
32
+ get closed() {
33
+ throw new Error("Blocked");
34
+ },
35
+ close: vi.fn(),
36
+ } as unknown as Window;
37
+
38
+ vi.spyOn(window, "open").mockReturnValue(mockPopup);
39
+
40
+ const result = isPopupBlocked();
41
+ expect(result).toBe(true);
42
+ });
43
+ it("should return true if popup properties are not defined", () => {
44
+ const mockPopup = {} as unknown as Window;
45
+ vi.spyOn(window, "open").mockReturnValue(mockPopup);
46
+ expect(isPopupBlocked()).toBe(true);
47
+ });
48
+ });
@@ -0,0 +1,5 @@
1
+ {
2
+ "extends": "./tsconfig.json",
3
+ "include": ["src"],
4
+ "exclude": ["test"]
5
+ }
@@ -0,0 +1,8 @@
1
+ {
2
+ "extends": "./tsconfig.build.json",
3
+ "compilerOptions": {
4
+ "module": "CommonJS",
5
+ "verbatimModuleSyntax": false,
6
+ "outDir": "dist/cjs"
7
+ }
8
+ }
@@ -0,0 +1,7 @@
1
+ {
2
+ "extends": "./tsconfig.build.json",
3
+ "compilerOptions": {
4
+ "module": "NodeNext",
5
+ "outDir": "dist/esm"
6
+ }
7
+ }
package/tsconfig.json ADDED
@@ -0,0 +1,42 @@
1
+ {
2
+ "compilerOptions": {
3
+ "types": ["node"],
4
+ "baseUrl": ".",
5
+ "paths": {
6
+ "@/*": ["./src/*"]
7
+ },
8
+ /* Base Options: */
9
+ "esModuleInterop": true,
10
+ "skipLibCheck": true,
11
+ "target": "es2022",
12
+ "allowJs": true,
13
+ "resolveJsonModule": true,
14
+ "moduleDetection": "force",
15
+ "isolatedModules": true,
16
+ "verbatimModuleSyntax": true,
17
+
18
+ /* Strictness */
19
+ "strict": true,
20
+ "noUncheckedIndexedAccess": true,
21
+ "noImplicitOverride": true,
22
+
23
+ /* If transpiling with TypeScript: */
24
+ "module": "NodeNext",
25
+ "outDir": "dist",
26
+ "sourceMap": true,
27
+ "inlineSources": true,
28
+
29
+ /* AND if you're building for a library: */
30
+ "declaration": true,
31
+
32
+ /* AND if you're building for a library in a monorepo: */
33
+ "composite": true,
34
+ "declarationMap": true,
35
+
36
+ /* If your code runs in the DOM: */
37
+ "lib": ["es2022", "dom", "dom.iterable"],
38
+ "jsx": "react"
39
+ },
40
+ "include": ["src", "test", "test/support/*.json", "vitest.config.ts", "etc/scripts/**/*.ts"],
41
+ "exclude": ["node_modules"]
42
+ }
@@ -0,0 +1,41 @@
1
+ /// <reference types='vitest' />
2
+ import { defineConfig } from "vite";
3
+ import path from "path";
4
+
5
+ export default defineConfig({
6
+ resolve: {
7
+ alias: {
8
+ "@": path.resolve(__dirname, "./src"),
9
+ },
10
+ },
11
+
12
+ test: {
13
+ globals: true,
14
+ environment: "jsdom",
15
+ include: ["test/**/*.{test,spec}.{js,mjs,cjs,ts,mts,cts,jsx,tsx}"],
16
+ env: {
17
+ NODE_ENV: "development",
18
+ },
19
+ reporters: ["default"],
20
+ coverage: {
21
+ exclude: [
22
+ "**/node_modules/**",
23
+ "**/dist/**",
24
+ "**/build/**",
25
+ "postcss.config.cjs",
26
+ "tailwind.config.js",
27
+ ".eslintrc.js",
28
+ "tsup.config.ts",
29
+ "vitest.config.ts",
30
+ ],
31
+ reportsDirectory: "../../coverage/apps/civic-auth-client",
32
+ provider: "v8",
33
+ thresholds: {
34
+ lines: 80,
35
+ functions: 70,
36
+ branches: 85,
37
+ statements: 80,
38
+ },
39
+ },
40
+ },
41
+ });
@@ -1,201 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
- var _chunkVXIWRZWUjs = require('./chunk-VXIWRZWU.js');
12
-
13
-
14
-
15
-
16
- var _chunkCRTRMMJ7js = require('./chunk-CRTRMMJ7.js');
17
-
18
- // src/shared/storage.ts
19
- var DEFAULT_COOKIE_DURATION = 60 * 15;
20
- var CookieStorage = class {
21
- constructor(settings = {}) {
22
- var _a, _b, _c, _d, _e;
23
- this.settings = {
24
- httpOnly: (_a = settings.httpOnly) != null ? _a : true,
25
- secure: (_b = settings.secure) != null ? _b : true,
26
- // the callback request comes the auth server
27
- // 'lax' ensures the code_verifier cookie is sent with the request
28
- sameSite: (_c = settings.sameSite) != null ? _c : "lax",
29
- expires: (_d = settings.expires) != null ? _d : new Date(Date.now() + 1e3 * DEFAULT_COOKIE_DURATION),
30
- path: (_e = settings.path) != null ? _e : "/"
31
- };
32
- }
33
- };
34
-
35
- // src/services/PKCE.ts
36
- var _oauth2 = require('oslo/oauth2');
37
- var GenericPublicClientPKCEProducer = class {
38
- constructor(storage) {
39
- this.storage = storage;
40
- }
41
- // if there is already a verifier, return it,
42
- // If not, create a new one and store it
43
- getCodeChallenge() {
44
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
45
- const verifier = _oauth2.generateCodeVerifier.call(void 0, );
46
- this.storage.set("code_verifier", verifier);
47
- return _chunkVXIWRZWUjs.deriveCodeChallenge.call(void 0, verifier);
48
- });
49
- }
50
- // if there is already a verifier, return it,
51
- getCodeVerifier() {
52
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
53
- return this.storage.get("code_verifier");
54
- });
55
- }
56
- };
57
-
58
- // src/services/AuthenticationService.ts
59
-
60
- var GenericAuthenticationInitiator = class {
61
- constructor(config) {
62
- this.config = config;
63
- }
64
- // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url
65
- // and simply return the url
66
- signIn() {
67
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
68
- return _chunkVXIWRZWUjs.generateOauthLoginUrl.call(void 0, this.config);
69
- });
70
- }
71
- signOut() {
72
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
73
- return _chunkVXIWRZWUjs.generateOauthLogoutUrl.call(void 0, this.config);
74
- });
75
- }
76
- };
77
-
78
- // src/server/ServerAuthenticationResolver.ts
79
-
80
- var ServerAuthenticationResolver = class _ServerAuthenticationResolver {
81
- constructor(authConfig, storage, endpointOverrides) {
82
- this.authConfig = authConfig;
83
- this.storage = storage;
84
- this.endpointOverrides = endpointOverrides;
85
- this.pkceProducer = new GenericPublicClientPKCEProducer(storage);
86
- }
87
- init() {
88
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
89
- this.endpoints = yield _chunkVXIWRZWUjs.getEndpointsWithOverrides.call(void 0,
90
- this.authConfig.oauthServer,
91
- this.endpointOverrides
92
- );
93
- this.oauth2client = new (0, _oauth2.OAuth2Client)(
94
- this.authConfig.clientId,
95
- this.endpoints.auth,
96
- this.endpoints.token,
97
- {
98
- redirectURI: this.authConfig.redirectUrl
99
- }
100
- );
101
- return this;
102
- });
103
- }
104
- tokenExchange(code, state) {
105
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
106
- if (!this.oauth2client) yield this.init();
107
- const codeVerifier = yield this.pkceProducer.getCodeVerifier();
108
- if (!codeVerifier) throw new Error("Code verifier not found in storage");
109
- const tokens = yield _chunkVXIWRZWUjs.exchangeTokens.call(void 0,
110
- code,
111
- state,
112
- this.pkceProducer,
113
- this.oauth2client,
114
- // clean up types here to avoid the ! operator
115
- this.authConfig.oauthServer,
116
- this.endpoints
117
- // clean up types here to avoid the ! operator
118
- );
119
- _chunkVXIWRZWUjs.storeTokens.call(void 0, this.storage, tokens);
120
- return tokens;
121
- });
122
- }
123
- getSessionData() {
124
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
125
- const storageData = _chunkVXIWRZWUjs.retrieveTokens.call(void 0, this.storage);
126
- if (!storageData) return null;
127
- return {
128
- authenticated: !!storageData.id_token,
129
- idToken: storageData.id_token,
130
- accessToken: storageData.access_token,
131
- refreshToken: storageData.refresh_token
132
- };
133
- });
134
- }
135
- static build(authConfig, storage, endpointOverrides) {
136
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
137
- const resolver = new _ServerAuthenticationResolver(
138
- authConfig,
139
- storage,
140
- endpointOverrides
141
- );
142
- yield resolver.init();
143
- return resolver;
144
- });
145
- }
146
- };
147
-
148
- // src/server/login.ts
149
- function resolveOAuthAccessCode(code, state, storage, config) {
150
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
151
- var _a;
152
- const authSessionService = yield ServerAuthenticationResolver.build(
153
- _chunkCRTRMMJ7js.__spreadProps.call(void 0, _chunkCRTRMMJ7js.__spreadValues.call(void 0, {}, config), {
154
- oauthServer: (_a = config.oauthServer) != null ? _a : _chunkVXIWRZWUjs.AUTH_SERVER
155
- }),
156
- storage,
157
- config.endpointOverrides
158
- );
159
- return authSessionService.tokenExchange(code, state);
160
- });
161
- }
162
- function isLoggedIn(storage) {
163
- return !!storage.get("id_token");
164
- }
165
- function buildLoginUrl(config, storage) {
166
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
167
- var _a, _b, _c;
168
- const state = (_a = config.state) != null ? _a : Math.random().toString(36).substring(2);
169
- const scopes = (_b = config.scopes) != null ? _b : _chunkVXIWRZWUjs.DEFAULT_SCOPES;
170
- const pkceProducer = new GenericPublicClientPKCEProducer(storage);
171
- const authInitiator = new GenericAuthenticationInitiator(_chunkCRTRMMJ7js.__spreadProps.call(void 0, _chunkCRTRMMJ7js.__spreadValues.call(void 0, {}, config), {
172
- state,
173
- scopes,
174
- oauthServer: (_c = config.oauthServer) != null ? _c : _chunkVXIWRZWUjs.AUTH_SERVER,
175
- // When retrieving the PKCE challenge on the server-side, we produce it and store it in the session
176
- pkceConsumer: pkceProducer
177
- }));
178
- return authInitiator.signIn();
179
- });
180
- }
181
-
182
- // src/server/session.ts
183
- var _jwt = require('oslo/jwt');
184
- function getUser(storage) {
185
- return _chunkCRTRMMJ7js.__async.call(void 0, this, null, function* () {
186
- var _a, _b;
187
- const tokens = _chunkVXIWRZWUjs.retrieveTokens.call(void 0, storage);
188
- if (!tokens) return null;
189
- return (_b = (_a = _jwt.parseJWT.call(void 0, tokens.id_token)) == null ? void 0 : _a.payload) != null ? _b : null;
190
- });
191
- }
192
-
193
-
194
-
195
-
196
-
197
-
198
-
199
-
200
- exports.CookieStorage = CookieStorage; exports.GenericPublicClientPKCEProducer = GenericPublicClientPKCEProducer; exports.resolveOAuthAccessCode = resolveOAuthAccessCode; exports.isLoggedIn = isLoggedIn; exports.buildLoginUrl = buildLoginUrl; exports.getUser = getUser;
201
- //# sourceMappingURL=chunk-4GIHS7LB.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/lucas/dev/civic/civic-auth/packages/civic-auth-client/dist/chunk-4GIHS7LB.js","../src/shared/storage.ts","../src/services/PKCE.ts","../src/services/AuthenticationService.ts","../src/server/ServerAuthenticationResolver.ts","../src/server/login.ts","../src/server/session.ts"],"names":["OAuth2Client"],"mappings":"AAAA;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,sDAA4B;AAC5B;AACE;AACA;AACA;AACF,sDAA4B;AAC5B;AACA;ACQO,IAAM,wBAAA,EAA0B,GAAA,EAAK,EAAA;AAErC,IAAe,cAAA,EAAf,MAAoD;AAAA,EAE/C,WAAA,CAAY,SAAA,EAA2C,CAAC,CAAA,EAAG;AA7BvE,IAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AA8BI,IAAA,IAAA,CAAK,SAAA,EAAW;AAAA,MACd,QAAA,EAAA,CAAU,GAAA,EAAA,QAAA,CAAS,QAAA,EAAA,GAAT,KAAA,EAAA,GAAA,EAAqB,IAAA;AAAA,MAC/B,MAAA,EAAA,CAAQ,GAAA,EAAA,QAAA,CAAS,MAAA,EAAA,GAAT,KAAA,EAAA,GAAA,EAAmB,IAAA;AAAA;AAAA;AAAA,MAG3B,QAAA,EAAA,CAAU,GAAA,EAAA,QAAA,CAAS,QAAA,EAAA,GAAT,KAAA,EAAA,GAAA,EAAqB,KAAA;AAAA,MAC/B,OAAA,EAAA,CACE,GAAA,EAAA,QAAA,CAAS,OAAA,EAAA,GAAT,KAAA,EAAA,GAAA,EACA,IAAI,IAAA,CAAK,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,IAAA,EAAO,uBAAuB,CAAA;AAAA,MACtD,IAAA,EAAA,CAAM,GAAA,EAAA,QAAA,CAAS,IAAA,EAAA,GAAT,KAAA,EAAA,GAAA,EAAiB;AAAA,IACzB,CAAA;AAAA,EACF;AAGF,CAAA;ADXA;AACA;AEjCA,qCAAqC;AAgB9B,IAAM,gCAAA,EAAN,MAA8D;AAAA,EACnE,WAAA,CAAoB,OAAA,EAAsB;AAAtB,IAAA,IAAA,CAAA,QAAA,EAAA,OAAA;AAAA,EAAuB;AAAA;AAAA;AAAA,EAIrC,gBAAA,CAAA,EAAoC;AAAA,IAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAGxC,MAAA,MAAM,SAAA,EAAW,0CAAA,CAAqB;AACtC,MAAA,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,eAAA,EAAiB,QAAQ,CAAA;AAE1C,MAAA,OAAO,kDAAA,QAA4B,CAAA;AAAA,IACrC,CAAA,CAAA;AAAA,EAAA;AAAA;AAAA,EAEM,eAAA,CAAA,EAA0C;AAAA,IAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAC9C,MAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,eAAe,CAAA;AAAA,IACzC,CAAA,CAAA;AAAA,EAAA;AACF,CAAA;AFsBA;AACA;AGvCA;AAqEO,IAAM,+BAAA,EAAN,MAAwE;AAAA,EAa7E,WAAA,CAAY,MAAA,EAA4B;AACtC,IAAA,IAAA,CAAK,OAAA,EAAS,MAAA;AAAA,EAChB;AAAA;AAAA;AAAA,EAIM,MAAA,CAAA,EAAuB;AAAA,IAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAC3B,MAAA,OAAO,oDAAA,IAAsB,CAAK,MAAM,CAAA;AAAA,IAC1C,CAAA,CAAA;AAAA,EAAA;AAAA,EAEM,OAAA,CAAA,EAAwB;AAAA,IAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAC5B,MAAA,OAAO,qDAAA,IAAuB,CAAK,MAAM,CAAA;AAAA,IAC3C,CAAA,CAAA;AAAA,EAAA;AACF,CAAA;AHrCA;AACA;AI5EA;AAYO,IAAM,6BAAA,EAAN,MAAM,8BAA+D;AAAA,EAKlE,WAAA,CACG,UAAA,EACA,OAAA,EACA,iBAAA,EACT;AAHS,IAAA,IAAA,CAAA,WAAA,EAAA,UAAA;AACA,IAAA,IAAA,CAAA,QAAA,EAAA,OAAA;AACA,IAAA,IAAA,CAAA,kBAAA,EAAA,iBAAA;AAET,IAAA,IAAA,CAAK,aAAA,EAAe,IAAI,+BAAA,CAAgC,OAAO,CAAA;AAAA,EACjE;AAAA,EAEM,IAAA,CAAA,EAAsB;AAAA,IAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAE1B,MAAA,IAAA,CAAK,UAAA,EAAY,MAAM,wDAAA;AAAA,QACrB,IAAA,CAAK,UAAA,CAAW,WAAA;AAAA,QAChB,IAAA,CAAK;AAAA,MACP,CAAA;AACA,MAAA,IAAA,CAAK,aAAA,EAAe,IAAIA,yBAAAA;AAAA,QACtB,IAAA,CAAK,UAAA,CAAW,QAAA;AAAA,QAChB,IAAA,CAAK,SAAA,CAAU,IAAA;AAAA,QACf,IAAA,CAAK,SAAA,CAAU,KAAA;AAAA,QACf;AAAA,UACE,WAAA,EAAa,IAAA,CAAK,UAAA,CAAW;AAAA,QAC/B;AAAA,MACF,CAAA;AAEA,MAAA,OAAO,IAAA;AAAA,IACT,CAAA,CAAA;AAAA,EAAA;AAAA,EAEM,aAAA,CACJ,IAAA,EACA,KAAA,EACgC;AAAA,IAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAChC,MAAA,GAAA,CAAI,CAAC,IAAA,CAAK,YAAA,EAAc,MAAM,IAAA,CAAK,IAAA,CAAK,CAAA;AACxC,MAAA,MAAM,aAAA,EAAe,MAAM,IAAA,CAAK,YAAA,CAAa,eAAA,CAAgB,CAAA;AAC7D,MAAA,GAAA,CAAI,CAAC,YAAA,EAAc,MAAM,IAAI,KAAA,CAAM,oCAAoC,CAAA;AAGvE,MAAA,MAAM,OAAA,EAAS,MAAM,6CAAA;AAAA,QACnB,IAAA;AAAA,QACA,KAAA;AAAA,QACA,IAAA,CAAK,YAAA;AAAA,QACL,IAAA,CAAK,YAAA;AAAA;AAAA,QACL,IAAA,CAAK,UAAA,CAAW,WAAA;AAAA,QAChB,IAAA,CAAK;AAAA;AAAA,MACP,CAAA;AAEA,MAAA,0CAAA,IAAY,CAAK,OAAA,EAAS,MAAM,CAAA;AAEhC,MAAA,OAAO,MAAA;AAAA,IACT,CAAA,CAAA;AAAA,EAAA;AAAA,EAEM,cAAA,CAAA,EAA8C;AAAA,IAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAClD,MAAA,MAAM,YAAA,EAAc,6CAAA,IAAe,CAAK,OAAO,CAAA;AAE/C,MAAA,GAAA,CAAI,CAAC,WAAA,EAAa,OAAO,IAAA;AAEzB,MAAA,OAAO;AAAA,QACL,aAAA,EAAe,CAAC,CAAC,WAAA,CAAY,QAAA;AAAA,QAC7B,OAAA,EAAS,WAAA,CAAY,QAAA;AAAA,QACrB,WAAA,EAAa,WAAA,CAAY,YAAA;AAAA,QACzB,YAAA,EAAc,WAAA,CAAY;AAAA,MAC5B,CAAA;AAAA,IACF,CAAA,CAAA;AAAA,EAAA;AAAA,EAEA,OAAa,KAAA,CACX,UAAA,EACA,OAAA,EACA,iBAAA,EACiC;AAAA,IAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AACjC,MAAA,MAAM,SAAA,EAAW,IAAI,6BAAA;AAAA,QACnB,UAAA;AAAA,QACA,OAAA;AAAA,QACA;AAAA,MACF,CAAA;AACA,MAAA,MAAM,QAAA,CAAS,IAAA,CAAK,CAAA;AAEpB,MAAA,OAAO,QAAA;AAAA,IACT,CAAA,CAAA;AAAA,EAAA;AACF,CAAA;AJoDA;AACA;AK7HA,SAAsB,sBAAA,CACpB,IAAA,EACA,KAAA,EACA,OAAA,EACA,MAAA,EACgC;AAAA,EAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AA3BlC,IAAA,IAAA,EAAA;AA4BE,IAAA,MAAM,mBAAA,EAAqB,MAAM,4BAAA,CAA6B,KAAA;AAAA,MAC5D,4CAAA,6CAAA,CAAA,CAAA,EACK,MAAA,CAAA,EADL;AAAA,QAEE,WAAA,EAAA,CAAa,GAAA,EAAA,MAAA,CAAO,WAAA,EAAA,GAAP,KAAA,EAAA,GAAA,EAAsB;AAAA,MACrC,CAAA,CAAA;AAAA,MACA,OAAA;AAAA,MACA,MAAA,CAAO;AAAA,IACT,CAAA;AAEA,IAAA,OAAO,kBAAA,CAAmB,aAAA,CAAc,IAAA,EAAM,KAAK,CAAA;AAAA,EACrD,CAAA,CAAA;AAAA;AAEO,SAAS,UAAA,CAAW,OAAA,EAA+B;AACxD,EAAA,OAAO,CAAC,CAAC,OAAA,CAAQ,GAAA,CAAI,UAAU,CAAA;AACjC;AAEA,SAAsB,aAAA,CACpB,MAAA,EAKA,OAAA,EACc;AAAA,EAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAnDhB,IAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AAqDE,IAAA,MAAM,MAAA,EAAA,CAAQ,GAAA,EAAA,MAAA,CAAO,KAAA,EAAA,GAAP,KAAA,EAAA,GAAA,EAAgB,IAAA,CAAK,MAAA,CAAO,CAAA,CAAE,QAAA,CAAS,EAAE,CAAA,CAAE,SAAA,CAAU,CAAC,CAAA;AACpE,IAAA,MAAM,OAAA,EAAA,CAAS,GAAA,EAAA,MAAA,CAAO,MAAA,EAAA,GAAP,KAAA,EAAA,GAAA,EAAiB,+BAAA;AAChC,IAAA,MAAM,aAAA,EAAe,IAAI,+BAAA,CAAgC,OAAO,CAAA;AAChE,IAAA,MAAM,cAAA,EAAgB,IAAI,8BAAA,CAA+B,4CAAA,6CAAA,CAAA,CAAA,EACpD,MAAA,CAAA,EADoD;AAAA,MAEvD,KAAA;AAAA,MACA,MAAA;AAAA,MACA,WAAA,EAAA,CAAa,GAAA,EAAA,MAAA,CAAO,WAAA,EAAA,GAAP,KAAA,EAAA,GAAA,EAAsB,4BAAA;AAAA;AAAA,MAEnC,YAAA,EAAc;AAAA,IAChB,CAAA,CAAC,CAAA;AAED,IAAA,OAAO,aAAA,CAAc,MAAA,CAAO,CAAA;AAAA,EAC9B,CAAA,CAAA;AAAA;ALkHA;AACA;AMpLA,+BAAyB;AAIzB,SAAsB,OAAA,CAAQ,OAAA,EAA4C;AAAA,EAAA,OAAA,sCAAA,IAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,EAAA;AAL1E,IAAA,IAAA,EAAA,EAAA,EAAA;AAME,IAAA,MAAM,OAAA,EAAS,6CAAA,OAAsB,CAAA;AACrC,IAAA,GAAA,CAAI,CAAC,MAAA,EAAQ,OAAO,IAAA;AAGpB,IAAA,OAAA,CAAQ,GAAA,EAAA,CAAA,GAAA,EAAA,2BAAA,MAAS,CAAO,QAAQ,CAAA,EAAA,GAAxB,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAA2B,OAAA,EAAA,GAA3B,KAAA,EAAA,GAAA,EAA+C,IAAA;AAAA,EACzD,CAAA,CAAA;AAAA;ANoLA;AACA;AACE;AACA;AACA;AACA;AACA;AACA;AACF,6QAAC","file":"/Users/lucas/dev/civic/civic-auth/packages/civic-auth-client/dist/chunk-4GIHS7LB.js","sourcesContent":[null,"import { SessionData, UnknownObject, User } from \"@/types.js\";\n\ntype SameSiteOption = \"strict\" | \"lax\" | \"none\";\n\nexport interface SessionStorage {\n get(): SessionData;\n getUser(): User<UnknownObject> | null;\n set(data: Partial<SessionData>): void;\n setUser(data: User<UnknownObject> | null): void;\n clear(): void;\n}\n\nexport interface AuthStorage {\n get(key: string): string | null;\n set(key: string, value: string): void;\n}\n\nexport type CookieStorageSettings = {\n httpOnly: boolean;\n secure: boolean;\n sameSite: SameSiteOption;\n expires: Date;\n path: string;\n};\n\nexport const DEFAULT_COOKIE_DURATION = 60 * 15; // 15 minutes\n\nexport abstract class CookieStorage implements AuthStorage {\n protected settings: CookieStorageSettings;\n protected constructor(settings: Partial<CookieStorageSettings> = {}) {\n this.settings = {\n httpOnly: settings.httpOnly ?? true,\n secure: settings.secure ?? true,\n // the callback request comes the auth server\n // 'lax' ensures the code_verifier cookie is sent with the request\n sameSite: settings.sameSite ?? \"lax\",\n expires:\n settings.expires ??\n new Date(Date.now() + 1000 * DEFAULT_COOKIE_DURATION),\n path: settings.path ?? \"/\",\n };\n }\n abstract get(key: string): string | null;\n abstract set(key: string, value: string): void;\n}\n","import { deriveCodeChallenge } from \"@/shared/util.js\";\nimport { generateCodeVerifier } from \"oslo/oauth2\";\nimport { AuthStorage } from \"@/shared/storage.js\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport { PKCEConsumer, PKCEProducer } from \"@/services/types.ts\";\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(this.pkceChallengeEndpoint);\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(\"code_verifier\", 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(\"code_verifier\");\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","// Proposals for revised versions of the SessionService AKA AuthSessionService\n\nimport {\n DisplayMode,\n Endpoints,\n OIDCTokenResponseBody,\n SessionData,\n} from \"@/types.js\";\nimport { BrowserPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport {\n exchangeTokens,\n generateOauthLoginUrl,\n generateOauthLogoutUrl,\n getEndpointsWithOverrides,\n retrieveTokens,\n storeTokens,\n} from \"@/shared/util.js\";\nimport { generateState } from \"@/lib/oauth.js\";\nimport { OAuth2Client } from \"oslo/oauth2\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport {\n AuthenticationInitiator,\n AuthenticationResolver,\n PKCEConsumer,\n} from \"@/services/types.js\";\n\n/**\n * An authentication initiator that works on a browser. Since this is just triggering\n * login and logout, session data is not stored here.\n * An associated AuthenticationResolver would be needed to get the session data.\n * Storage is needed for the code verifier, this is the domain of the PKCEConsumer\n * The storage used by the PKCEConsumer should be available to the AuthenticationResolver.\n *\n * Example usage:\n *\n * 1) Client-only SPA -eg a react app with no server:\n * new BrowserAuthenticationInitiator({\n * pkceConsumer: new BrowserPublicClientPKCEProducer(), // generate and retrieve the challenge client-side\n * ... other config\n * })\n *\n * 2) Client-side of a client/server app - eg a react app with a backend:\n * new BrowserAuthenticationInitiator({\n * pkceConsumer: new ConfidentialClientPKCEConsumer(\"https://myserver.com/pkce\"), // get the challenge from the server\n * ... other config\n * })\n */\nexport class BrowserAuthenticationInitiator implements AuthenticationInitiator {\n protected config: {\n clientId: string;\n redirectUrl: string;\n state: string;\n scopes: string[];\n // determines whether to trigger the login/logout in an iframe, a new browser window, or redirect the current one.\n displayMode: DisplayMode;\n oauthServer: string;\n // the endpoints to use for the login (if not obtained from the auth server\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n };\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 then use the display mode to decide how to send the user there\n async signIn(): Promise<URL> {\n const url = await generateOauthLoginUrl(this.config);\n // TODO open the iframe or new tab etc\n\n return url;\n }\n\n async signOut(): Promise<URL> {\n const url = await generateOauthLogoutUrl(this.config);\n // TODO open the iframe or new tab etc\n\n return url;\n }\n}\n\n/** A general-purpose authentication initiator, that just generates urls, but lets\n * the caller decide how to use them. This is useful for server-side applications\n * that may serve this URL to their front-ends or just call them directly\n */\nexport class GenericAuthenticationInitiator implements AuthenticationInitiator {\n protected config: {\n clientId: string;\n redirectUrl: string;\n state: string;\n scopes: string[];\n oauthServer: string;\n // the endpoints to use for the login (if not obtained from the auth server)\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n };\n\n constructor(config: typeof this.config) {\n this.config = config;\n }\n\n // Use the config (Client ID, scopes OAuth Server, Endpoints, PKCEConsumer) to generate a new login url\n // and simply return the url\n async signIn(): Promise<URL> {\n return generateOauthLoginUrl(this.config);\n }\n\n async signOut(): Promise<URL> {\n return generateOauthLogoutUrl(this.config);\n }\n}\n\ntype BrowserAuthenticationConfig = {\n clientId: string;\n redirectUrl: string;\n scopes: string[];\n oauthServer: string;\n endpointOverrides?: Partial<Endpoints>;\n displayMode: DisplayMode;\n};\n\n/**\n * An authentication resolver that can run on the browser (i.e. a public client)\n * It uses PKCE for security. PKCE and Session data are stored in local storage\n */\nexport class BrowserAuthenticationService extends BrowserAuthenticationInitiator {\n private oauth2client: OAuth2Client | undefined;\n private endpoints: Endpoints | undefined;\n\n // TODO WIP - perhaps we want to keep resolver and initiator separate here\n constructor(\n config: BrowserAuthenticationConfig,\n // Since we are running fully on the client, we produce as well as consume the PKCE challenge\n protected pkceProducer = new BrowserPublicClientPKCEProducer(),\n ) {\n super({\n ...config,\n state: generateState(config.displayMode),\n // Store and retrieve the PKCE challenge in local storage\n pkceConsumer: pkceProducer,\n });\n }\n\n // TODO too much code duplication here between the browser and the server variant.\n // Suggestion for refactor: Standardise the config for AuthenticationResolvers and create a one-shot\n // function for generating an oauth2client from it\n async init(): Promise<this> {\n // resolve oauth config\n this.endpoints = await getEndpointsWithOverrides(\n this.config.oauthServer,\n this.config.endpointOverrides,\n );\n this.oauth2client = new OAuth2Client(\n this.config.clientId,\n this.endpoints.auth,\n this.endpoints.token,\n {\n redirectURI: this.config.redirectUrl,\n },\n );\n\n return this;\n }\n\n // Two responsibilities:\n // 1. resolve the auth code to get the tokens (should use library code)\n // 2. store the tokens in local storage\n async tokenExchange(\n code: string,\n state: string,\n ): Promise<OIDCTokenResponseBody> {\n if (!this.oauth2client) await this.init();\n const codeVerifier = await this.pkceProducer.getCodeVerifier();\n if (!codeVerifier) throw new Error(\"Code verifier not found in storage\");\n\n // exchange auth code for tokens\n const tokens = await exchangeTokens(\n code,\n state,\n this.pkceProducer,\n this.oauth2client!, // clean up types here to avoid the ! operator\n this.config.oauthServer,\n this.endpoints!, // clean up types here to avoid the ! operator\n );\n\n storeTokens(new LocalStorageAdapter(), tokens);\n\n return tokens;\n }\n\n // Get the session data from local storage\n async getSessionData(): Promise<SessionData | null> {\n const storageData = retrieveTokens(new LocalStorageAdapter());\n\n if (!storageData) return null;\n\n return {\n authenticated: !!storageData.id_token,\n idToken: storageData.id_token,\n accessToken: storageData.access_token,\n refreshToken: storageData.refresh_token,\n };\n }\n\n 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","import { GenericPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport { OAuth2Client } from \"oslo/oauth2\";\nimport { Endpoints, OIDCTokenResponseBody, SessionData } from \"@/types.js\";\nimport { AuthConfig } from \"@/server/config.js\";\nimport { AuthStorage } from \"@/shared/storage.js\";\nimport {\n exchangeTokens,\n getEndpointsWithOverrides,\n retrieveTokens,\n storeTokens,\n} from \"@/shared/util.js\";\nimport { AuthenticationResolver, PKCEProducer } from \"@/services/types.ts\";\n\nexport class ServerAuthenticationResolver implements AuthenticationResolver {\n private pkceProducer: PKCEProducer;\n private oauth2client: OAuth2Client | undefined;\n private endpoints: Endpoints | undefined;\n\n private constructor(\n readonly authConfig: AuthConfig,\n readonly storage: AuthStorage,\n readonly endpointOverrides?: Partial<Endpoints>,\n ) {\n this.pkceProducer = new GenericPublicClientPKCEProducer(storage);\n }\n\n async init(): Promise<this> {\n // resolve oauth config\n this.endpoints = await getEndpointsWithOverrides(\n this.authConfig.oauthServer,\n this.endpointOverrides,\n );\n this.oauth2client = new OAuth2Client(\n this.authConfig.clientId,\n this.endpoints.auth,\n this.endpoints.token,\n {\n redirectURI: this.authConfig.redirectUrl,\n },\n );\n\n return this;\n }\n\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.authConfig.oauthServer,\n this.endpoints!, // clean up types here to avoid the ! operator\n );\n\n storeTokens(this.storage, tokens);\n\n return tokens;\n }\n\n async getSessionData(): Promise<SessionData | null> {\n const storageData = retrieveTokens(this.storage);\n\n if (!storageData) return null;\n\n return {\n authenticated: !!storageData.id_token,\n idToken: storageData.id_token,\n accessToken: storageData.access_token,\n refreshToken: storageData.refresh_token,\n };\n }\n\n static async build(\n authConfig: AuthConfig,\n storage: AuthStorage,\n endpointOverrides?: Partial<Endpoints>,\n ): Promise<AuthenticationResolver> {\n const resolver = new ServerAuthenticationResolver(\n authConfig,\n storage,\n endpointOverrides,\n );\n await resolver.init();\n\n return resolver;\n }\n}\n","import { AuthStorage } from \"@/shared/storage.js\";\nimport { Endpoints, OIDCTokenResponseBody } from \"@/types.js\";\nimport { AUTH_SERVER, DEFAULT_SCOPES } from \"@/constants.js\";\nimport { GenericAuthenticationInitiator } from \"@/services/AuthenticationService.js\";\nimport { GenericPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport { ServerAuthenticationResolver } from \"@/server/ServerAuthenticationResolver.js\";\n\ntype Config = {\n clientId: string;\n redirectUrl: string;\n challengeUrl: string;\n oauthServer?: string;\n endpointOverrides?: Partial<Endpoints> | undefined;\n};\n\n/**\n * Resolve an OAuth access code to a set of OIDC tokens\n * @param code The access code, typically from a query parameter in the redirect url\n * @param state The oauth random state string, used to distinguish between requests. Typically also passed in the redirect url\n * @param storage The place that this server uses to store session data (e.g. a cookie store)\n * @param config Oauth Server configuration\n */\nexport async function resolveOAuthAccessCode(\n code: string,\n state: string,\n storage: AuthStorage,\n config: Config,\n): Promise<OIDCTokenResponseBody> {\n const authSessionService = await ServerAuthenticationResolver.build(\n {\n ...config,\n oauthServer: config.oauthServer ?? AUTH_SERVER,\n },\n storage,\n config.endpointOverrides,\n );\n\n return authSessionService.tokenExchange(code, state);\n}\n\nexport function isLoggedIn(storage: AuthStorage): boolean {\n return !!storage.get(\"id_token\");\n}\n\nexport async function buildLoginUrl(\n config: Omit<Config, \"challengeUrl\"> & {\n scopes?: string[];\n state?: string;\n nonce?: string;\n },\n storage: AuthStorage,\n): Promise<URL> {\n // generate a random state if not provided\n const state = config.state ?? Math.random().toString(36).substring(2);\n const scopes = config.scopes ?? DEFAULT_SCOPES;\n const pkceProducer = new GenericPublicClientPKCEProducer(storage);\n const authInitiator = new GenericAuthenticationInitiator({\n ...config,\n state,\n scopes,\n oauthServer: config.oauthServer ?? AUTH_SERVER,\n // When retrieving the PKCE challenge on the server-side, we produce it and store it in the session\n pkceConsumer: pkceProducer,\n });\n\n return authInitiator.signIn();\n}\n","import { retrieveTokens } from \"@/shared/util.js\";\nimport { parseJWT } from \"oslo/jwt\";\nimport { User } from \"@/types.js\";\nimport { AuthStorage } from \"@/shared/storage.js\";\n\nexport async function getUser(storage: AuthStorage): Promise<User | null> {\n const tokens = retrieveTokens(storage);\n if (!tokens) return null;\n\n // Assumes all information is in the ID token\n return (parseJWT(tokens.id_token)?.payload as User) ?? null;\n}\n"]}
@@ -1,59 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __objRest = (source, exclude) => {
21
- var target = {};
22
- for (var prop in source)
23
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
- target[prop] = source[prop];
25
- if (source != null && __getOwnPropSymbols)
26
- for (var prop of __getOwnPropSymbols(source)) {
27
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
- target[prop] = source[prop];
29
- }
30
- return target;
31
- };
32
- var __async = (__this, __arguments, generator) => {
33
- return new Promise((resolve, reject) => {
34
- var fulfilled = (value) => {
35
- try {
36
- step(generator.next(value));
37
- } catch (e) {
38
- reject(e);
39
- }
40
- };
41
- var rejected = (value) => {
42
- try {
43
- step(generator.throw(value));
44
- } catch (e) {
45
- reject(e);
46
- }
47
- };
48
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
49
- step((generator = generator.apply(__this, __arguments)).next());
50
- });
51
- };
52
-
53
-
54
-
55
-
56
-
57
-
58
- exports.__spreadValues = __spreadValues; exports.__spreadProps = __spreadProps; exports.__objRest = __objRest; exports.__async = __async;
59
- //# sourceMappingURL=chunk-CRTRMMJ7.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/lucas/dev/civic/civic-auth/packages/civic-auth-client/dist/chunk-CRTRMMJ7.js"],"names":[],"mappings":"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","file":"/Users/lucas/dev/civic/civic-auth/packages/civic-auth-client/dist/chunk-CRTRMMJ7.js"}