@civic/auth 0.1.1-beta.0 → 0.1.2-beta.0

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 (342) hide show
  1. package/.turbo/turbo-build.log +3 -3
  2. package/CHANGELOG.md +5 -0
  3. package/dist/cjs/src/reactjs/components/UserButton.js +1 -1
  4. package/dist/cjs/src/reactjs/components/UserButton.js.map +1 -1
  5. package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts +1 -0
  6. package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts.map +1 -1
  7. package/dist/cjs/src/server/ServerAuthenticationResolver.js +6 -2
  8. package/dist/cjs/src/server/ServerAuthenticationResolver.js.map +1 -1
  9. package/dist/cjs/src/server/config.d.ts +1 -8
  10. package/dist/cjs/src/server/config.d.ts.map +1 -1
  11. package/dist/cjs/src/server/config.js.map +1 -1
  12. package/dist/cjs/src/server/index.d.ts +1 -0
  13. package/dist/cjs/src/server/index.d.ts.map +1 -1
  14. package/dist/cjs/src/server/index.js.map +1 -1
  15. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts +1 -0
  16. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  17. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js +5 -1
  18. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  19. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
  20. package/dist/esm/src/reactjs/components/UserButton.js +1 -1
  21. package/dist/esm/src/reactjs/components/UserButton.js.map +1 -1
  22. package/dist/esm/src/server/ServerAuthenticationResolver.d.ts +1 -0
  23. package/dist/esm/src/server/ServerAuthenticationResolver.d.ts.map +1 -1
  24. package/dist/esm/src/server/ServerAuthenticationResolver.js +6 -2
  25. package/dist/esm/src/server/ServerAuthenticationResolver.js.map +1 -1
  26. package/dist/esm/src/server/config.d.ts +1 -8
  27. package/dist/esm/src/server/config.d.ts.map +1 -1
  28. package/dist/esm/src/server/config.js.map +1 -1
  29. package/dist/esm/src/server/index.d.ts +1 -0
  30. package/dist/esm/src/server/index.d.ts.map +1 -1
  31. package/dist/esm/src/server/index.js.map +1 -1
  32. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts +1 -0
  33. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  34. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js +5 -1
  35. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  36. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  37. package/dist/src/browser/storage.d.ts +6 -0
  38. package/dist/src/browser/storage.d.ts.map +1 -0
  39. package/dist/src/browser/storage.js +9 -0
  40. package/dist/src/browser/storage.js.map +1 -0
  41. package/dist/src/config.d.ts +3 -0
  42. package/dist/src/config.d.ts.map +1 -0
  43. package/dist/src/config.js +5 -0
  44. package/dist/src/config.js.map +1 -0
  45. package/dist/src/constants.d.ts +9 -0
  46. package/dist/src/constants.d.ts.map +1 -0
  47. package/dist/src/constants.js +17 -0
  48. package/dist/src/constants.js.map +1 -0
  49. package/dist/src/index.d.ts +4 -0
  50. package/dist/src/index.d.ts.map +1 -0
  51. package/dist/src/index.js +2 -0
  52. package/dist/src/index.js.map +1 -0
  53. package/dist/src/lib/cookies.d.ts +7 -0
  54. package/dist/src/lib/cookies.d.ts.map +1 -0
  55. package/dist/src/lib/cookies.js +23 -0
  56. package/dist/src/lib/cookies.js.map +1 -0
  57. package/dist/src/lib/jwt.d.ts +3 -0
  58. package/dist/src/lib/jwt.d.ts.map +1 -0
  59. package/dist/src/lib/jwt.js +9 -0
  60. package/dist/src/lib/jwt.js.map +1 -0
  61. package/dist/src/lib/logger.d.ts +26 -0
  62. package/dist/src/lib/logger.d.ts.map +1 -0
  63. package/dist/src/lib/logger.js +55 -0
  64. package/dist/src/lib/logger.js.map +1 -0
  65. package/dist/src/lib/oauth.d.ts +19 -0
  66. package/dist/src/lib/oauth.d.ts.map +1 -0
  67. package/dist/src/lib/oauth.js +60 -0
  68. package/dist/src/lib/oauth.js.map +1 -0
  69. package/dist/src/lib/postMessage.d.ts +4 -0
  70. package/dist/src/lib/postMessage.d.ts.map +1 -0
  71. package/dist/src/lib/postMessage.js +15 -0
  72. package/dist/src/lib/postMessage.js.map +1 -0
  73. package/dist/src/lib/windowUtil.d.ts +4 -0
  74. package/dist/src/lib/windowUtil.d.ts.map +1 -0
  75. package/dist/src/lib/windowUtil.js +30 -0
  76. package/dist/src/lib/windowUtil.js.map +1 -0
  77. package/dist/src/nextjs/GetUser.d.ts +6 -0
  78. package/dist/src/nextjs/GetUser.js +18 -0
  79. package/dist/src/nextjs/GetUser.js.map +1 -0
  80. package/dist/src/nextjs/config.d.ts +178 -0
  81. package/dist/src/nextjs/cookies.d.ts +30 -0
  82. package/dist/src/nextjs/hooks/index.d.ts +2 -0
  83. package/dist/src/nextjs/hooks/index.d.ts.map +1 -0
  84. package/dist/src/nextjs/hooks/index.js +2 -0
  85. package/dist/src/nextjs/hooks/index.js.map +1 -0
  86. package/dist/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
  87. package/dist/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
  88. package/dist/src/nextjs/hooks/useTokenCookie.js +37 -0
  89. package/dist/src/nextjs/hooks/useTokenCookie.js.map +1 -0
  90. package/dist/src/nextjs/hooks/useUserCookie.d.ts +3 -0
  91. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  92. package/dist/src/nextjs/hooks/useUserCookie.js +36 -0
  93. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -0
  94. package/dist/src/nextjs/index.d.ts +7 -0
  95. package/dist/src/nextjs/index.js +6 -0
  96. package/dist/src/nextjs/index.js.map +1 -0
  97. package/dist/src/nextjs/middleware/index.d.ts +2 -0
  98. package/dist/src/nextjs/middleware/index.d.ts.map +1 -0
  99. package/dist/src/nextjs/middleware/index.js +2 -0
  100. package/dist/src/nextjs/middleware/index.js.map +1 -0
  101. package/dist/src/nextjs/middleware.d.ts +59 -0
  102. package/dist/src/nextjs/middleware.d.ts.map +1 -0
  103. package/dist/src/nextjs/middleware.js +107 -0
  104. package/dist/src/nextjs/middleware.js.map +1 -0
  105. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
  106. package/dist/src/nextjs/providers/NextAuthProvider.js +50 -0
  107. package/dist/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  108. package/dist/src/nextjs/routeHandler.d.ts +18 -0
  109. package/dist/src/nextjs/utils.d.ts +3 -0
  110. package/dist/src/nextjs/utils.d.ts.map +1 -0
  111. package/dist/src/nextjs/utils.js +5 -0
  112. package/dist/src/nextjs/utils.js.map +1 -0
  113. package/dist/src/reactjs/components/SignInButton.d.ts +8 -0
  114. package/dist/src/reactjs/components/SignInButton.d.ts.map +1 -0
  115. package/dist/src/reactjs/components/SignInButton.js +14 -0
  116. package/dist/src/reactjs/components/SignInButton.js.map +1 -0
  117. package/dist/src/reactjs/components/SignOutButton.d.ts +6 -0
  118. package/dist/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  119. package/dist/src/reactjs/components/SignOutButton.js +14 -0
  120. package/dist/src/reactjs/components/SignOutButton.js.map +1 -0
  121. package/dist/src/reactjs/components/UserButton.d.ts +8 -0
  122. package/dist/src/reactjs/components/UserButton.js +110 -0
  123. package/dist/src/reactjs/components/UserButton.js.map +1 -0
  124. package/dist/src/reactjs/components/index.d.ts +6 -0
  125. package/dist/src/reactjs/components/index.js +6 -0
  126. package/dist/src/reactjs/components/index.js.map +1 -0
  127. package/dist/src/reactjs/hooks/useAuth.d.ts +3 -0
  128. package/dist/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  129. package/dist/src/reactjs/hooks/useAuth.js +12 -0
  130. package/dist/src/reactjs/hooks/useAuth.js.map +1 -0
  131. package/dist/src/reactjs/hooks/useUser.d.ts +4 -0
  132. package/dist/src/reactjs/hooks/useUser.d.ts.map +1 -0
  133. package/dist/src/reactjs/hooks/useUser.js +12 -0
  134. package/dist/src/reactjs/hooks/useUser.js.map +1 -0
  135. package/dist/src/reactjs/index.d.ts +6 -0
  136. package/dist/src/reactjs/index.js +8 -0
  137. package/dist/src/reactjs/index.js.map +1 -0
  138. package/dist/src/reactjs/providers/index.d.ts +8 -0
  139. package/dist/src/reactjs/providers/index.js +7 -0
  140. package/dist/src/reactjs/providers/index.js.map +1 -0
  141. package/dist/src/server/ServerAuthenticationResolver.d.ts +19 -0
  142. package/dist/src/server/ServerAuthenticationResolver.d.ts.map +1 -1
  143. package/dist/src/server/ServerAuthenticationResolver.js +6 -2
  144. package/dist/src/server/ServerAuthenticationResolver.js.map +1 -1
  145. package/dist/src/server/config.d.ts +9 -0
  146. package/dist/src/server/config.d.ts.map +1 -0
  147. package/dist/src/server/config.js +2 -0
  148. package/dist/src/server/config.js.map +1 -0
  149. package/dist/src/server/index.d.ts +7 -0
  150. package/dist/src/server/index.d.ts.map +1 -1
  151. package/dist/src/server/index.js +5 -0
  152. package/dist/src/server/index.js.map +1 -0
  153. package/dist/src/server/refresh.d.ts +7 -0
  154. package/dist/src/server/refresh.js +13 -0
  155. package/dist/src/server/refresh.js.map +1 -0
  156. package/dist/src/services/PKCE.d.ts +20 -0
  157. package/dist/src/services/types.d.ts +23 -0
  158. package/dist/src/services/types.d.ts.map +1 -0
  159. package/dist/src/services/types.js +7 -0
  160. package/dist/src/services/types.js.map +1 -0
  161. package/dist/src/shared/components/CivicAuthIframe.d.ts +8 -0
  162. package/dist/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  163. package/dist/src/shared/components/CivicAuthIframe.js +9 -0
  164. package/dist/src/shared/components/CivicAuthIframe.js.map +1 -0
  165. package/dist/src/shared/components/CloseIcon.d.ts +4 -0
  166. package/dist/src/shared/components/CloseIcon.d.ts.map +1 -0
  167. package/dist/src/shared/components/CloseIcon.js +6 -0
  168. package/dist/src/shared/components/CloseIcon.js.map +1 -0
  169. package/dist/src/shared/components/LoadingIcon.d.ts +4 -0
  170. package/dist/src/shared/hooks/index.d.ts +5 -0
  171. package/dist/src/shared/hooks/index.d.ts.map +1 -0
  172. package/dist/src/shared/hooks/index.js +5 -0
  173. package/dist/src/shared/hooks/index.js.map +1 -0
  174. package/dist/src/shared/hooks/useAuth.d.ts +3 -0
  175. package/dist/src/shared/hooks/useAuth.d.ts.map +1 -0
  176. package/dist/src/shared/hooks/useAuth.js +12 -0
  177. package/dist/src/shared/hooks/useAuth.js.map +1 -0
  178. package/dist/src/shared/hooks/useConfig.d.ts +3 -0
  179. package/dist/src/shared/hooks/useConfig.d.ts.map +1 -0
  180. package/dist/src/shared/hooks/useConfig.js +13 -0
  181. package/dist/src/shared/hooks/useConfig.js.map +1 -0
  182. package/dist/src/shared/hooks/useIframe.d.ts +3 -0
  183. package/dist/src/shared/hooks/useIframe.d.ts.map +1 -0
  184. package/dist/src/shared/hooks/useIframe.js +13 -0
  185. package/dist/src/shared/hooks/useIframe.js.map +1 -0
  186. package/dist/src/shared/hooks/useSession.d.ts +3 -0
  187. package/dist/src/shared/hooks/useSession.d.ts.map +1 -0
  188. package/dist/src/shared/hooks/useSession.js +13 -0
  189. package/dist/src/shared/hooks/useSession.js.map +1 -0
  190. package/dist/src/shared/hooks/useToken.d.ts +3 -0
  191. package/dist/src/shared/hooks/useToken.d.ts.map +1 -0
  192. package/dist/src/shared/hooks/useToken.js +12 -0
  193. package/dist/src/shared/hooks/useToken.js.map +1 -0
  194. package/dist/{cjs/src/shared → src/shared/lib}/GenericAuthenticationRefresher.d.ts +5 -4
  195. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  196. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +5 -1
  197. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  198. package/dist/{cjs/src/shared → src/shared/lib}/UserSession.d.ts +1 -1
  199. package/dist/src/shared/lib/session.d.ts +3 -0
  200. package/dist/src/shared/lib/session.js +10 -0
  201. package/dist/src/shared/lib/session.js.map +1 -0
  202. package/dist/src/shared/lib/storage.d.ts +25 -0
  203. package/dist/src/shared/lib/storage.d.ts.map +1 -0
  204. package/dist/src/shared/lib/storage.js +17 -0
  205. package/dist/src/shared/lib/storage.js.map +1 -0
  206. package/dist/src/shared/lib/types.d.ts +22 -0
  207. package/dist/src/shared/lib/types.d.ts.map +1 -0
  208. package/dist/src/shared/lib/types.js +16 -0
  209. package/dist/src/shared/lib/types.js.map +1 -0
  210. package/dist/src/shared/providers/AuthContext.d.ts +10 -0
  211. package/dist/src/shared/providers/AuthContext.d.ts.map +1 -0
  212. package/dist/src/shared/providers/AuthContext.js +3 -0
  213. package/dist/src/shared/providers/AuthContext.js.map +1 -0
  214. package/dist/{cjs/src/shared → src/shared/providers}/CivicAuthProvider.d.ts +3 -3
  215. package/dist/src/shared/providers/CivicAuthProvider.js +15 -0
  216. package/dist/src/shared/providers/CivicAuthProvider.js.map +1 -0
  217. package/dist/src/shared/providers/ConfigProvider.d.ts +21 -0
  218. package/dist/src/shared/providers/ConfigProvider.d.ts.map +1 -0
  219. package/dist/src/shared/providers/ConfigProvider.js +19 -0
  220. package/dist/src/shared/providers/ConfigProvider.js.map +1 -0
  221. package/dist/src/shared/providers/IframeProvider.d.ts +16 -0
  222. package/dist/src/shared/providers/IframeProvider.d.ts.map +1 -0
  223. package/dist/src/shared/providers/IframeProvider.js +11 -0
  224. package/dist/src/shared/providers/IframeProvider.js.map +1 -0
  225. package/dist/src/shared/providers/SessionProvider.d.ts +13 -0
  226. package/dist/src/shared/providers/SessionProvider.d.ts.map +1 -0
  227. package/dist/src/shared/providers/SessionProvider.js +13 -0
  228. package/dist/src/shared/providers/SessionProvider.js.map +1 -0
  229. package/dist/src/shared/providers/TokenProvider.d.ts +18 -0
  230. package/dist/src/shared/providers/TokenProvider.d.ts.map +1 -0
  231. package/dist/src/shared/providers/TokenProvider.js +53 -0
  232. package/dist/src/shared/providers/TokenProvider.js.map +1 -0
  233. package/dist/{cjs/src/shared → src/shared/providers}/UserProvider.d.ts +7 -6
  234. package/dist/src/shared/providers/UserProvider.d.ts.map +1 -0
  235. package/dist/src/shared/providers/UserProvider.js +38 -0
  236. package/dist/src/shared/providers/UserProvider.js.map +1 -0
  237. package/dist/src/types.d.ts +146 -0
  238. package/dist/src/types.d.ts.map +1 -0
  239. package/dist/src/types.js +2 -0
  240. package/dist/src/types.js.map +1 -0
  241. package/dist/src/utils.d.ts +15 -0
  242. package/dist/src/utils.d.ts.map +1 -0
  243. package/dist/src/utils.js +43 -0
  244. package/dist/src/utils.js.map +1 -0
  245. package/dist/test/integration/sdk.test.d.ts +2 -0
  246. package/dist/test/integration/sdk.test.js +183 -0
  247. package/dist/test/integration/sdk.test.js.map +1 -0
  248. package/dist/test/support/fixtures.d.ts +26 -0
  249. package/dist/test/support/fixtures.d.ts.map +1 -0
  250. package/dist/test/support/fixtures.js +55 -0
  251. package/dist/test/support/fixtures.js.map +1 -0
  252. package/dist/test/support/tokens.json +26 -0
  253. package/dist/test/unit/lib/oauth.test.d.ts +2 -0
  254. package/dist/test/unit/lib/oauth.test.d.ts.map +1 -0
  255. package/dist/test/unit/lib/oauth.test.js +55 -0
  256. package/dist/test/unit/lib/oauth.test.js.map +1 -0
  257. package/dist/test/unit/logger.test.d.ts +2 -0
  258. package/dist/test/unit/logger.test.d.ts.map +1 -0
  259. package/dist/test/unit/logger.test.js +141 -0
  260. package/dist/test/unit/logger.test.js.map +1 -0
  261. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +2 -0
  262. package/dist/test/unit/nextjs/NextAuthProvider.test.js +29 -0
  263. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +1 -0
  264. package/dist/test/unit/nextjs/config.test.d.ts +2 -0
  265. package/dist/test/unit/nextjs/config.test.d.ts.map +1 -0
  266. package/dist/test/unit/nextjs/config.test.js +189 -0
  267. package/dist/test/unit/nextjs/config.test.js.map +1 -0
  268. package/dist/test/unit/nextjs/getUser.test.d.ts +2 -0
  269. package/dist/test/unit/nextjs/getUser.test.js +36 -0
  270. package/dist/test/unit/nextjs/getUser.test.js.map +1 -0
  271. package/dist/test/unit/nextjs/middleware.test.d.ts +2 -0
  272. package/dist/test/unit/nextjs/middleware.test.d.ts.map +1 -0
  273. package/dist/test/unit/nextjs/middleware.test.js +113 -0
  274. package/dist/test/unit/nextjs/middleware.test.js.map +1 -0
  275. package/dist/test/unit/nextjs/utils.test.d.ts +2 -0
  276. package/dist/test/unit/nextjs/utils.test.d.ts.map +1 -0
  277. package/dist/test/unit/nextjs/utils.test.js +13 -0
  278. package/dist/test/unit/nextjs/utils.test.js.map +1 -0
  279. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +2 -0
  280. package/dist/test/unit/publicApi/apiSnapshot.test.js +10 -0
  281. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +1 -0
  282. package/dist/test/unit/react/components/SignInButton.test.d.ts +2 -0
  283. package/dist/test/unit/react/components/SignInButton.test.js +31 -0
  284. package/dist/test/unit/react/components/SignInButton.test.js.map +1 -0
  285. package/dist/test/unit/react/components/SignOutButton.test.d.ts +2 -0
  286. package/dist/test/unit/react/components/SignOutButton.test.js +30 -0
  287. package/dist/test/unit/react/components/SignOutButton.test.js.map +1 -0
  288. package/dist/test/unit/server/login.test.d.ts +2 -0
  289. package/dist/test/unit/server/session.test.d.ts +2 -0
  290. package/dist/test/unit/services/AuthenticationService.test.d.ts +2 -0
  291. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +2 -0
  292. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +2 -0
  293. package/dist/test/unit/shared/UserSession.test.d.ts +2 -0
  294. package/dist/test/unit/shared/UserSession.test.d.ts.map +1 -0
  295. package/dist/test/unit/shared/UserSession.test.js +37 -0
  296. package/dist/test/unit/shared/UserSession.test.js.map +1 -0
  297. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +2 -0
  298. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +120 -0
  299. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +1 -0
  300. package/dist/test/unit/shared/storage.test.d.ts +2 -0
  301. package/dist/test/unit/shared/storage.test.d.ts.map +1 -0
  302. package/dist/test/unit/shared/storage.test.js +53 -0
  303. package/dist/test/unit/shared/storage.test.js.map +1 -0
  304. package/dist/test/unit/utils.test.d.ts +2 -0
  305. package/dist/test/unit/utils.test.d.ts.map +1 -0
  306. package/dist/test/unit/utils.test.js +40 -0
  307. package/dist/test/unit/utils.test.js.map +1 -0
  308. package/dist/tsconfig.tsbuildinfo +1 -1
  309. package/dist/vitest.config.d.ts +3 -0
  310. package/dist/vitest.config.d.ts.map +1 -0
  311. package/dist/vitest.config.js +40 -0
  312. package/dist/vitest.config.js.map +1 -0
  313. package/package.json +2 -2
  314. package/src/reactjs/components/UserButton.tsx +1 -1
  315. package/src/server/ServerAuthenticationResolver.ts +7 -2
  316. package/src/server/config.ts +1 -9
  317. package/src/server/index.ts +1 -0
  318. package/src/shared/lib/GenericAuthenticationRefresher.ts +6 -1
  319. package/dist/cjs/src/shared/AuthProvider.d.ts +0 -18
  320. package/dist/cjs/src/shared/AuthProvider.d.ts.map +0 -1
  321. package/dist/cjs/src/shared/AuthProvider.js +0 -246
  322. package/dist/cjs/src/shared/AuthProvider.js.map +0 -1
  323. package/dist/cjs/src/shared/CivicAuthProvider.d.ts.map +0 -1
  324. package/dist/cjs/src/shared/CivicAuthProvider.js +0 -19
  325. package/dist/cjs/src/shared/CivicAuthProvider.js.map +0 -1
  326. package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts.map +0 -1
  327. package/dist/cjs/src/shared/GenericAuthenticationRefresher.js +0 -47
  328. package/dist/cjs/src/shared/GenericAuthenticationRefresher.js.map +0 -1
  329. package/dist/cjs/src/shared/UserProvider.d.ts.map +0 -1
  330. package/dist/cjs/src/shared/UserProvider.js +0 -42
  331. package/dist/cjs/src/shared/UserProvider.js.map +0 -1
  332. package/dist/cjs/src/shared/UserSession.d.ts.map +0 -1
  333. package/dist/cjs/src/shared/UserSession.js +0 -24
  334. package/dist/cjs/src/shared/UserSession.js.map +0 -1
  335. package/dist/cjs/src/shared/session.d.ts +0 -3
  336. package/dist/cjs/src/shared/session.d.ts.map +0 -1
  337. package/dist/cjs/src/shared/session.js +0 -13
  338. package/dist/cjs/src/shared/session.js.map +0 -1
  339. package/dist/cjs/src/shared/util.d.ts +0 -39
  340. package/dist/cjs/src/shared/util.d.ts.map +0 -1
  341. package/dist/cjs/src/shared/util.js +0 -162
  342. package/dist/cjs/src/shared/util.js.map +0 -1
@@ -0,0 +1,6 @@
1
+ import type { AuthStorage } from "@/types.js";
2
+ export declare class LocalStorageAdapter implements AuthStorage {
3
+ get(key: string): Promise<string>;
4
+ set(key: string, value: string): Promise<void>;
5
+ }
6
+ //# sourceMappingURL=storage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../src/browser/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,qBAAa,mBAAoB,YAAW,WAAW;IAC/C,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAIjC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGrD"}
@@ -0,0 +1,9 @@
1
+ export class LocalStorageAdapter {
2
+ async get(key) {
3
+ return Promise.resolve(localStorage.getItem(key) || "");
4
+ }
5
+ async set(key, value) {
6
+ localStorage.setItem(key, value);
7
+ }
8
+ }
9
+ //# sourceMappingURL=storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"storage.js","sourceRoot":"","sources":["../../../src/browser/storage.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,mBAAmB;IAC9B,KAAK,CAAC,GAAG,CAAC,GAAW;QACnB,OAAO,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,GAAW,EAAE,KAAa;QAClC,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACnC,CAAC;CACF","sourcesContent":["import type { AuthStorage } from \"@/types.js\";\n\nexport class LocalStorageAdapter implements AuthStorage {\n async get(key: string): Promise<string> {\n return Promise.resolve(localStorage.getItem(key) || \"\");\n }\n\n async set(key: string, value: string): Promise<void> {\n localStorage.setItem(key, value);\n }\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import type { Config } from "@/types.js";
2
+ export declare const authConfig: Config;
3
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAGzC,eAAO,MAAM,UAAU,EAAE,MAExB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { DEFAULT_AUTH_SERVER } from "./constants.js";
2
+ export const authConfig = {
3
+ oauthServer: DEFAULT_AUTH_SERVER,
4
+ };
5
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAErD,MAAM,CAAC,MAAM,UAAU,GAAW;IAChC,WAAW,EAAE,mBAAmB;CACjC,CAAC","sourcesContent":["import type { Config } from \"@/types.js\";\nimport { DEFAULT_AUTH_SERVER } from \"./constants.js\";\n\nexport const authConfig: Config = {\n oauthServer: DEFAULT_AUTH_SERVER,\n};\n"]}
@@ -0,0 +1,9 @@
1
+ declare const DEFAULT_SCOPES: string[];
2
+ declare const IFRAME_ID = "civic-auth-iframe";
3
+ declare const DEFAULT_AUTH_SERVER = "https://auth.civic.com/oauth";
4
+ declare const DEFAULT_OAUTH_GET_PARAMS: string[];
5
+ declare const TOKEN_EXCHANGE_TRIGGER_TEXT = "sameDomainCodeExchangeRequired";
6
+ declare const TOKEN_EXCHANGE_SUCCESS_TEXT = "serverSideTokenExchangeSuccess";
7
+ declare const DEFAULT_DISPLAY_MODE = "iframe";
8
+ export { DEFAULT_SCOPES, DEFAULT_OAUTH_GET_PARAMS, DEFAULT_DISPLAY_MODE, IFRAME_ID, DEFAULT_AUTH_SERVER, TOKEN_EXCHANGE_TRIGGER_TEXT, TOKEN_EXCHANGE_SUCCESS_TEXT, };
9
+ //# sourceMappingURL=constants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,cAAc,UAMnB,CAAC;AACF,QAAA,MAAM,SAAS,sBAAsB,CAAC;AAEtC,QAAA,MAAM,mBAAmB,iCAAiC,CAAC;AAE3D,QAAA,MAAM,wBAAwB,UAA2B,CAAC;AAI1D,QAAA,MAAM,2BAA2B,mCAAmC,CAAC;AAErE,QAAA,MAAM,2BAA2B,mCAAmC,CAAC;AAErE,QAAA,MAAM,oBAAoB,WAAW,CAAC;AACtC,OAAO,EACL,cAAc,EACd,wBAAwB,EACxB,oBAAoB,EACpB,SAAS,EACT,mBAAmB,EACnB,2BAA2B,EAC3B,2BAA2B,GAC5B,CAAC"}
@@ -0,0 +1,17 @@
1
+ const DEFAULT_SCOPES = [
2
+ "openid",
3
+ "profile",
4
+ "email",
5
+ "forwardedTokens",
6
+ "offline_access",
7
+ ];
8
+ const IFRAME_ID = "civic-auth-iframe";
9
+ const DEFAULT_AUTH_SERVER = "https://auth.civic.com/oauth";
10
+ const DEFAULT_OAUTH_GET_PARAMS = ["code", "state", "iss"];
11
+ // The server's callback handler renders this text if it needs the front-end to make an additional token exchange call,
12
+ // for the iframe case where cookies are not sent along with the initial redirect.
13
+ const TOKEN_EXCHANGE_TRIGGER_TEXT = "sameDomainCodeExchangeRequired";
14
+ const TOKEN_EXCHANGE_SUCCESS_TEXT = "serverSideTokenExchangeSuccess";
15
+ const DEFAULT_DISPLAY_MODE = "iframe";
16
+ export { DEFAULT_SCOPES, DEFAULT_OAUTH_GET_PARAMS, DEFAULT_DISPLAY_MODE, IFRAME_ID, DEFAULT_AUTH_SERVER, TOKEN_EXCHANGE_TRIGGER_TEXT, TOKEN_EXCHANGE_SUCCESS_TEXT, };
17
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"AAAA,MAAM,cAAc,GAAG;IACrB,QAAQ;IACR,SAAS;IACT,OAAO;IACP,iBAAiB;IACjB,gBAAgB;CACjB,CAAC;AACF,MAAM,SAAS,GAAG,mBAAmB,CAAC;AAEtC,MAAM,mBAAmB,GAAG,8BAA8B,CAAC;AAE3D,MAAM,wBAAwB,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;AAE1D,uHAAuH;AACvH,kFAAkF;AAClF,MAAM,2BAA2B,GAAG,gCAAgC,CAAC;AAErE,MAAM,2BAA2B,GAAG,gCAAgC,CAAC;AAErE,MAAM,oBAAoB,GAAG,QAAQ,CAAC;AACtC,OAAO,EACL,cAAc,EACd,wBAAwB,EACxB,oBAAoB,EACpB,SAAS,EACT,mBAAmB,EACnB,2BAA2B,EAC3B,2BAA2B,GAC5B,CAAC","sourcesContent":["const DEFAULT_SCOPES = [\n \"openid\",\n \"profile\",\n \"email\",\n \"forwardedTokens\",\n \"offline_access\",\n];\nconst IFRAME_ID = \"civic-auth-iframe\";\n\nconst DEFAULT_AUTH_SERVER = \"https://auth.civic.com/oauth\";\n\nconst DEFAULT_OAUTH_GET_PARAMS = [\"code\", \"state\", \"iss\"];\n\n// The server's callback handler renders this text if it needs the front-end to make an additional token exchange call,\n// for the iframe case where cookies are not sent along with the initial redirect.\nconst TOKEN_EXCHANGE_TRIGGER_TEXT = \"sameDomainCodeExchangeRequired\";\n\nconst TOKEN_EXCHANGE_SUCCESS_TEXT = \"serverSideTokenExchangeSuccess\";\n\nconst DEFAULT_DISPLAY_MODE = \"iframe\";\nexport {\n DEFAULT_SCOPES,\n DEFAULT_OAUTH_GET_PARAMS,\n DEFAULT_DISPLAY_MODE,\n IFRAME_ID,\n DEFAULT_AUTH_SERVER,\n TOKEN_EXCHANGE_TRIGGER_TEXT,\n TOKEN_EXCHANGE_SUCCESS_TEXT,\n};\n"]}
@@ -0,0 +1,4 @@
1
+ export type { Tokens, Endpoints, Config, User, DisplayMode, ForwardedTokens, AuthStorage, } from "@/types.js";
2
+ export type * from "@/shared/lib/types.js";
3
+ export type { UserContextType } from "@/shared/providers/UserProvider.js";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAGA,YAAY,EACV,MAAM,EACN,SAAS,EACT,MAAM,EACN,IAAI,EACJ,WAAW,EACX,eAAe,EACf,WAAW,GACZ,MAAM,YAAY,CAAC;AAEpB,mBAAmB,uBAAuB,CAAC;AAE3C,YAAY,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"","sourcesContent":["// These are the default exports of the project.\n// They are limited by design to ensure that the public API does not expose any internal implementation details.\n// Do not change this without thinking carefully about the impact on the client-facing public API.\nexport type {\n Tokens,\n Endpoints,\n Config,\n User,\n DisplayMode,\n ForwardedTokens,\n AuthStorage,\n} from \"@/types.js\";\n\nexport type * from \"@/shared/lib/types.js\";\n\nexport type { UserContextType } from \"@/shared/providers/UserProvider.js\";\n"]}
@@ -0,0 +1,7 @@
1
+ declare const getWindowCookieValue: ({ key, window, parseJson, }: {
2
+ key: string;
3
+ window: Window;
4
+ parseJson?: boolean;
5
+ }) => any;
6
+ export { getWindowCookieValue };
7
+ //# sourceMappingURL=cookies.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cookies.d.ts","sourceRoot":"","sources":["../../../src/lib/cookies.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,oBAAoB,gCAIvB;IACD,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,QAkBA,CAAC;AACF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
@@ -0,0 +1,23 @@
1
+ const getWindowCookieValue = ({ key, window, parseJson = false, }) => {
2
+ const cookie = window.document.cookie;
3
+ if (!cookie)
4
+ return null;
5
+ const cookies = cookie.split(";");
6
+ for (const c of cookies) {
7
+ const [name, value] = c.trim().split("=");
8
+ if (value && name === key) {
9
+ try {
10
+ const decodeURIComponentValue = decodeURIComponent(value);
11
+ return parseJson
12
+ ? JSON.parse(decodeURIComponentValue)
13
+ : decodeURIComponentValue;
14
+ }
15
+ catch {
16
+ return value;
17
+ }
18
+ }
19
+ }
20
+ return null;
21
+ };
22
+ export { getWindowCookieValue };
23
+ //# sourceMappingURL=cookies.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cookies.js","sourceRoot":"","sources":["../../../src/lib/cookies.ts"],"names":[],"mappings":"AAAA,MAAM,oBAAoB,GAAG,CAAC,EAC5B,GAAG,EACH,MAAM,EACN,SAAS,GAAG,KAAK,GAKlB,EAAE,EAAE;IACH,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;IACtC,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IACzB,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAClC,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE,CAAC;QACxB,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC1C,IAAI,KAAK,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC;YAC1B,IAAI,CAAC;gBACH,MAAM,uBAAuB,GAAG,kBAAkB,CAAC,KAAK,CAAC,CAAC;gBAC1D,OAAO,SAAS;oBACd,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,uBAAuB,CAAC;oBACrC,CAAC,CAAC,uBAAuB,CAAC;YAC9B,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AACF,OAAO,EAAE,oBAAoB,EAAE,CAAC","sourcesContent":["const getWindowCookieValue = ({\n key,\n window,\n parseJson = false,\n}: {\n key: string;\n window: Window;\n parseJson?: boolean;\n}) => {\n const cookie = window.document.cookie;\n if (!cookie) return null;\n const cookies = cookie.split(\";\");\n for (const c of cookies) {\n const [name, value] = c.trim().split(\"=\");\n if (value && name === key) {\n try {\n const decodeURIComponentValue = decodeURIComponent(value);\n return parseJson\n ? JSON.parse(decodeURIComponentValue)\n : decodeURIComponentValue;\n } catch {\n return value;\n }\n }\n }\n return null;\n};\nexport { getWindowCookieValue };\n"]}
@@ -0,0 +1,3 @@
1
+ import type { ForwardedTokens, ForwardedTokensJWT } from "@/types.js";
2
+ export declare const convertForwardedTokenFormat: (inputTokens: ForwardedTokensJWT) => ForwardedTokens;
3
+ //# sourceMappingURL=jwt.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jwt.d.ts","sourceRoot":"","sources":["../../../src/lib/jwt.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAEtE,eAAO,MAAM,2BAA2B,gBACzB,kBAAkB,KAC9B,eAUA,CAAC"}
@@ -0,0 +1,9 @@
1
+ export const convertForwardedTokenFormat = (inputTokens) => Object.fromEntries(Object.entries(inputTokens).map(([source, tokens]) => [
2
+ source,
3
+ {
4
+ idToken: tokens?.id_token,
5
+ accessToken: tokens?.access_token,
6
+ refreshToken: tokens?.refresh_token,
7
+ },
8
+ ]));
9
+ //# sourceMappingURL=jwt.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jwt.js","sourceRoot":"","sources":["../../../src/lib/jwt.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,2BAA2B,GAAG,CACzC,WAA+B,EACd,EAAE,CACnB,MAAM,CAAC,WAAW,CAChB,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC;IACpD,MAAM;IACN;QACE,OAAO,EAAE,MAAM,EAAE,QAAQ;QACzB,WAAW,EAAE,MAAM,EAAE,YAAY;QACjC,YAAY,EAAE,MAAM,EAAE,aAAa;KACpC;CACF,CAAC,CACH,CAAC","sourcesContent":["import type { ForwardedTokens, ForwardedTokensJWT } from \"@/types.js\";\n\nexport const convertForwardedTokenFormat = (\n inputTokens: ForwardedTokensJWT,\n): ForwardedTokens =>\n Object.fromEntries(\n Object.entries(inputTokens).map(([source, tokens]) => [\n source,\n {\n idToken: tokens?.id_token,\n accessToken: tokens?.access_token,\n refreshToken: tokens?.refresh_token,\n },\n ]),\n );\n"]}
@@ -0,0 +1,26 @@
1
+ export interface Logger {
2
+ debug(message: string, ...args: unknown[]): void;
3
+ info(message: string, ...args: unknown[]): void;
4
+ warn(message: string, ...args: unknown[]): void;
5
+ error(message: string, ...args: unknown[]): void;
6
+ }
7
+ export declare const createLogger: (namespace: string) => Logger;
8
+ export declare const loggers: {
9
+ readonly nextjs: {
10
+ readonly routes: Logger;
11
+ readonly middleware: Logger;
12
+ readonly handlers: {
13
+ readonly auth: Logger;
14
+ };
15
+ };
16
+ readonly react: {
17
+ readonly components: Logger;
18
+ readonly hooks: Logger;
19
+ readonly context: Logger;
20
+ };
21
+ readonly services: {
22
+ readonly validation: Logger;
23
+ readonly network: Logger;
24
+ };
25
+ };
26
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/lib/logger.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,MAAM;IACrB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACjD,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAChD,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAChD,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;CAClD;AAsCD,eAAO,MAAM,YAAY,cAAe,MAAM,KAAG,MACrB,CAAC;AAG7B,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;CAoBV,CAAC"}
@@ -0,0 +1,55 @@
1
+ import debug from "debug";
2
+ const PACKAGE_NAME = "@civic/auth";
3
+ class DebugLogger {
4
+ debugLogger;
5
+ infoLogger;
6
+ warnLogger;
7
+ errorLogger;
8
+ constructor(namespace) {
9
+ // Format: @org/package:library:component:level
10
+ this.debugLogger = debug(`${PACKAGE_NAME}:${namespace}:debug`);
11
+ this.infoLogger = debug(`${PACKAGE_NAME}:${namespace}:info`);
12
+ this.warnLogger = debug(`${PACKAGE_NAME}:${namespace}:warn`);
13
+ this.errorLogger = debug(`${PACKAGE_NAME}:${namespace}:error`);
14
+ this.debugLogger.color = "4";
15
+ this.infoLogger.color = "2";
16
+ this.warnLogger.color = "3";
17
+ this.errorLogger.color = "1";
18
+ }
19
+ debug(message, ...args) {
20
+ this.debugLogger(message, ...args);
21
+ }
22
+ info(message, ...args) {
23
+ this.infoLogger(message, ...args);
24
+ }
25
+ warn(message, ...args) {
26
+ this.warnLogger(message, ...args);
27
+ }
28
+ error(message, ...args) {
29
+ this.errorLogger(message, ...args);
30
+ }
31
+ }
32
+ export const createLogger = (namespace) => new DebugLogger(namespace);
33
+ // Pre-configured loggers for different parts of your package
34
+ export const loggers = {
35
+ // Next.js specific loggers
36
+ nextjs: {
37
+ routes: createLogger("api:routes"),
38
+ middleware: createLogger("api:middleware"),
39
+ handlers: {
40
+ auth: createLogger("api:handlers:auth"),
41
+ },
42
+ },
43
+ // React specific loggers
44
+ react: {
45
+ components: createLogger("react:components"),
46
+ hooks: createLogger("react:hooks"),
47
+ context: createLogger("react:context"),
48
+ },
49
+ // Shared utilities loggers
50
+ services: {
51
+ validation: createLogger("utils:validation"),
52
+ network: createLogger("utils:network"),
53
+ },
54
+ };
55
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/lib/logger.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,YAAY,GAAG,aAAa,CAAC;AASnC,MAAM,WAAW;IACP,WAAW,CAAiB;IAC5B,UAAU,CAAiB;IAC3B,UAAU,CAAiB;IAC3B,WAAW,CAAiB;IAEpC,YAAY,SAAiB;QAC3B,+CAA+C;QAC/C,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,GAAG,YAAY,IAAI,SAAS,QAAQ,CAAC,CAAC;QAC/D,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,GAAG,YAAY,IAAI,SAAS,OAAO,CAAC,CAAC;QAC7D,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,GAAG,YAAY,IAAI,SAAS,OAAO,CAAC,CAAC;QAC7D,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,GAAG,YAAY,IAAI,SAAS,QAAQ,CAAC,CAAC;QAE/D,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,GAAG,CAAC;QAC5B,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,GAAG,CAAC;QAC5B,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,GAAG,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,GAAG,IAAe;QACvC,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,GAAG,IAAe;QACtC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,GAAG,IAAe;QACtC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,GAAG,IAAe;QACvC,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACrC,CAAC;CACF;AAED,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,SAAiB,EAAU,EAAE,CACxD,IAAI,WAAW,CAAC,SAAS,CAAC,CAAC;AAE7B,6DAA6D;AAC7D,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,2BAA2B;IAC3B,MAAM,EAAE;QACN,MAAM,EAAE,YAAY,CAAC,YAAY,CAAC;QAClC,UAAU,EAAE,YAAY,CAAC,gBAAgB,CAAC;QAC1C,QAAQ,EAAE;YACR,IAAI,EAAE,YAAY,CAAC,mBAAmB,CAAC;SACxC;KACF;IACD,yBAAyB;IACzB,KAAK,EAAE;QACL,UAAU,EAAE,YAAY,CAAC,kBAAkB,CAAC;QAC5C,KAAK,EAAE,YAAY,CAAC,aAAa,CAAC;QAClC,OAAO,EAAE,YAAY,CAAC,eAAe,CAAC;KACvC;IACD,2BAA2B;IAC3B,QAAQ,EAAE;QACR,UAAU,EAAE,YAAY,CAAC,kBAAkB,CAAC;QAC5C,OAAO,EAAE,YAAY,CAAC,eAAe,CAAC;KACvC;CACO,CAAC","sourcesContent":["import debug from \"debug\";\n\nconst PACKAGE_NAME = \"@civic/auth\";\n\nexport interface Logger {\n debug(message: string, ...args: unknown[]): void;\n info(message: string, ...args: unknown[]): void;\n warn(message: string, ...args: unknown[]): void;\n error(message: string, ...args: unknown[]): void;\n}\n\nclass DebugLogger implements Logger {\n private debugLogger: debug.Debugger;\n private infoLogger: debug.Debugger;\n private warnLogger: debug.Debugger;\n private errorLogger: debug.Debugger;\n\n constructor(namespace: string) {\n // Format: @org/package:library:component:level\n this.debugLogger = debug(`${PACKAGE_NAME}:${namespace}:debug`);\n this.infoLogger = debug(`${PACKAGE_NAME}:${namespace}:info`);\n this.warnLogger = debug(`${PACKAGE_NAME}:${namespace}:warn`);\n this.errorLogger = debug(`${PACKAGE_NAME}:${namespace}:error`);\n\n this.debugLogger.color = \"4\";\n this.infoLogger.color = \"2\";\n this.warnLogger.color = \"3\";\n this.errorLogger.color = \"1\";\n }\n\n debug(message: string, ...args: unknown[]): void {\n this.debugLogger(message, ...args);\n }\n\n info(message: string, ...args: unknown[]): void {\n this.infoLogger(message, ...args);\n }\n\n warn(message: string, ...args: unknown[]): void {\n this.warnLogger(message, ...args);\n }\n\n error(message: string, ...args: unknown[]): void {\n this.errorLogger(message, ...args);\n }\n}\n\nexport const createLogger = (namespace: string): Logger =>\n new DebugLogger(namespace);\n\n// Pre-configured loggers for different parts of your package\nexport const loggers = {\n // Next.js specific loggers\n nextjs: {\n routes: createLogger(\"api:routes\"),\n middleware: createLogger(\"api:middleware\"),\n handlers: {\n auth: createLogger(\"api:handlers:auth\"),\n },\n },\n // React specific loggers\n react: {\n components: createLogger(\"react:components\"),\n hooks: createLogger(\"react:hooks\"),\n context: createLogger(\"react:context\"),\n },\n // Shared utilities loggers\n services: {\n validation: createLogger(\"utils:validation\"),\n network: createLogger(\"utils:network\"),\n },\n} as const;\n"]}
@@ -0,0 +1,19 @@
1
+ import type { DisplayMode, Endpoints } from "@/types.js";
2
+ declare const getIssuerVariations: (issuer: string) => string[];
3
+ declare const getOauthEndpoints: (oauthServer: string) => Promise<Endpoints>;
4
+ /**
5
+ * creates a state string for the OAuth2 flow, encoding the display mode too for future use
6
+ * @param {DisplayMode} displayMode
7
+ * @returns {string}
8
+ */
9
+ declare const generateState: (displayMode: DisplayMode, serverTokenExchange?: boolean) => string;
10
+ /**
11
+ * parses the state string from the OAuth2 flow, decoding the display mode too
12
+ * @param state
13
+ * @param sessionDisplayMode
14
+ * @returns { uuid: string, displayMode: DisplayMode }
15
+ */
16
+ declare const displayModeFromState: (state: string, sessionDisplayMode: DisplayMode | undefined) => DisplayMode | undefined;
17
+ declare const serverTokenExchangeFromState: (state: string) => boolean | undefined;
18
+ export { serverTokenExchangeFromState, getIssuerVariations, getOauthEndpoints, displayModeFromState, generateState, };
19
+ //# sourceMappingURL=oauth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oauth.d.ts","sourceRoot":"","sources":["../../../src/lib/oauth.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAuB,MAAM,YAAY,CAAC;AAG9E,QAAA,MAAM,mBAAmB,WAAY,MAAM,KAAG,MAAM,EAQnD,CAAC;AAKF,QAAA,MAAM,iBAAiB,gBAAuB,MAAM,KAAG,OAAO,CAAC,SAAS,CAYvE,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,aAAa,gBACJ,WAAW,wBACF,OAAO,KAC5B,MAOF,CAAC;AAEF;;;;;GAKG;AACH,QAAA,MAAM,oBAAoB,UACjB,MAAM,sBACO,WAAW,GAAG,SAAS,KAC1C,WAAW,GAAG,SAQhB,CAAC;AAEF,QAAA,MAAM,4BAA4B,UAAW,MAAM,KAAG,OAAO,GAAG,SAQ/D,CAAC;AAEF,OAAO,EACL,4BAA4B,EAC5B,mBAAmB,EACnB,iBAAiB,EACjB,oBAAoB,EACpB,aAAa,GACd,CAAC"}
@@ -0,0 +1,60 @@
1
+ import { v4 as uuid } from "uuid";
2
+ const getIssuerVariations = (issuer) => {
3
+ const issuerWithoutSlash = issuer.endsWith("/")
4
+ ? issuer.slice(0, issuer.length - 1)
5
+ : issuer;
6
+ const issuerWithSlash = `${issuerWithoutSlash}/`;
7
+ return [issuerWithoutSlash, issuerWithSlash];
8
+ };
9
+ const addSlashIfNeeded = (url) => url.endsWith("/") ? url : `${url}/`;
10
+ const getOauthEndpoints = async (oauthServer) => {
11
+ const openIdConfigResponse = await fetch(`${addSlashIfNeeded(oauthServer)}.well-known/openid-configuration`);
12
+ const openIdConfig = (await openIdConfigResponse.json());
13
+ return {
14
+ jwks: openIdConfig.jwks_uri,
15
+ auth: openIdConfig.authorization_endpoint,
16
+ token: openIdConfig.token_endpoint,
17
+ userinfo: openIdConfig.userinfo_endpoint,
18
+ };
19
+ };
20
+ /**
21
+ * creates a state string for the OAuth2 flow, encoding the display mode too for future use
22
+ * @param {DisplayMode} displayMode
23
+ * @returns {string}
24
+ */
25
+ const generateState = (displayMode, serverTokenExchange) => {
26
+ const jsonString = JSON.stringify({
27
+ uuid: uuid(),
28
+ displayMode,
29
+ ...(serverTokenExchange ? { serverTokenExchange } : {}),
30
+ });
31
+ return btoa(jsonString);
32
+ };
33
+ /**
34
+ * parses the state string from the OAuth2 flow, decoding the display mode too
35
+ * @param state
36
+ * @param sessionDisplayMode
37
+ * @returns { uuid: string, displayMode: DisplayMode }
38
+ */
39
+ const displayModeFromState = (state, sessionDisplayMode) => {
40
+ try {
41
+ const jsonString = atob(state);
42
+ return JSON.parse(jsonString).displayMode;
43
+ }
44
+ catch (e) {
45
+ console.error("Failed to parse displayMode from state:", state, e);
46
+ return sessionDisplayMode;
47
+ }
48
+ };
49
+ const serverTokenExchangeFromState = (state) => {
50
+ try {
51
+ const jsonString = atob(state);
52
+ return JSON.parse(jsonString).serverTokenExchange;
53
+ }
54
+ catch {
55
+ console.error("Failed to parse serverTokenExchange from state:", state);
56
+ return undefined;
57
+ }
58
+ };
59
+ export { serverTokenExchangeFromState, getIssuerVariations, getOauthEndpoints, displayModeFromState, generateState, };
60
+ //# sourceMappingURL=oauth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../../src/lib/oauth.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,IAAI,IAAI,EAAE,MAAM,MAAM,CAAC;AAElC,MAAM,mBAAmB,GAAG,CAAC,MAAc,EAAY,EAAE;IACvD,MAAM,kBAAkB,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC;QAC7C,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;QACpC,CAAC,CAAC,MAAM,CAAC;IAEX,MAAM,eAAe,GAAG,GAAG,kBAAkB,GAAG,CAAC;IAEjD,OAAO,CAAC,kBAAkB,EAAE,eAAe,CAAC,CAAC;AAC/C,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG,CAAC,GAAW,EAAU,EAAE,CAC/C,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAEtC,MAAM,iBAAiB,GAAG,KAAK,EAAE,WAAmB,EAAsB,EAAE;IAC1E,MAAM,oBAAoB,GAAG,MAAM,KAAK,CACtC,GAAG,gBAAgB,CAAC,WAAW,CAAC,kCAAkC,CACnE,CAAC;IACF,MAAM,YAAY,GAChB,CAAC,MAAM,oBAAoB,CAAC,IAAI,EAAE,CAAwB,CAAC;IAC7D,OAAO;QACL,IAAI,EAAE,YAAY,CAAC,QAAQ;QAC3B,IAAI,EAAE,YAAY,CAAC,sBAAsB;QACzC,KAAK,EAAE,YAAY,CAAC,cAAc;QAClC,QAAQ,EAAE,YAAY,CAAC,iBAAiB;KACzC,CAAC;AACJ,CAAC,CAAC;AAEF;;;;GAIG;AACH,MAAM,aAAa,GAAG,CACpB,WAAwB,EACxB,mBAA6B,EACrB,EAAE;IACV,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,IAAI,EAAE,IAAI,EAAE;QACZ,WAAW;QACX,GAAG,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,mBAAmB,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACxD,CAAC,CAAC;IACH,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC;AAC1B,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,oBAAoB,GAAG,CAC3B,KAAa,EACb,kBAA2C,EAClB,EAAE;IAC3B,IAAI,CAAC;QACH,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,WAAW,CAAC;IAC5C,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,CAAC,KAAK,CAAC,yCAAyC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QACnE,OAAO,kBAAkB,CAAC;IAC5B,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,4BAA4B,GAAG,CAAC,KAAa,EAAuB,EAAE;IAC1E,IAAI,CAAC;QACH,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,mBAAmB,CAAC;IACpD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,KAAK,CAAC,iDAAiD,EAAE,KAAK,CAAC,CAAC;QACxE,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC,CAAC;AAEF,OAAO,EACL,4BAA4B,EAC5B,mBAAmB,EACnB,iBAAiB,EACjB,oBAAoB,EACpB,aAAa,GACd,CAAC","sourcesContent":["import type { DisplayMode, Endpoints, OpenIdConfiguration } from \"@/types.js\";\nimport { v4 as uuid } from \"uuid\";\n\nconst getIssuerVariations = (issuer: string): string[] => {\n const issuerWithoutSlash = issuer.endsWith(\"/\")\n ? issuer.slice(0, issuer.length - 1)\n : issuer;\n\n const issuerWithSlash = `${issuerWithoutSlash}/`;\n\n return [issuerWithoutSlash, issuerWithSlash];\n};\n\nconst addSlashIfNeeded = (url: string): string =>\n url.endsWith(\"/\") ? url : `${url}/`;\n\nconst getOauthEndpoints = async (oauthServer: string): Promise<Endpoints> => {\n const openIdConfigResponse = await fetch(\n `${addSlashIfNeeded(oauthServer)}.well-known/openid-configuration`,\n );\n const openIdConfig =\n (await openIdConfigResponse.json()) as OpenIdConfiguration;\n return {\n jwks: openIdConfig.jwks_uri,\n auth: openIdConfig.authorization_endpoint,\n token: openIdConfig.token_endpoint,\n userinfo: openIdConfig.userinfo_endpoint,\n };\n};\n\n/**\n * creates a state string for the OAuth2 flow, encoding the display mode too for future use\n * @param {DisplayMode} displayMode\n * @returns {string}\n */\nconst generateState = (\n displayMode: DisplayMode,\n serverTokenExchange?: boolean,\n): string => {\n const jsonString = JSON.stringify({\n uuid: uuid(),\n displayMode,\n ...(serverTokenExchange ? { serverTokenExchange } : {}),\n });\n return btoa(jsonString);\n};\n\n/**\n * parses the state string from the OAuth2 flow, decoding the display mode too\n * @param state\n * @param sessionDisplayMode\n * @returns { uuid: string, displayMode: DisplayMode }\n */\nconst displayModeFromState = (\n state: string,\n sessionDisplayMode: DisplayMode | undefined,\n): DisplayMode | undefined => {\n try {\n const jsonString = atob(state);\n return JSON.parse(jsonString).displayMode;\n } catch (e) {\n console.error(\"Failed to parse displayMode from state:\", state, e);\n return sessionDisplayMode;\n }\n};\n\nconst serverTokenExchangeFromState = (state: string): boolean | undefined => {\n try {\n const jsonString = atob(state);\n return JSON.parse(jsonString).serverTokenExchange;\n } catch {\n console.error(\"Failed to parse serverTokenExchange from state:\", state);\n return undefined;\n }\n};\n\nexport {\n serverTokenExchangeFromState,\n getIssuerVariations,\n getOauthEndpoints,\n displayModeFromState,\n generateState,\n};\n"]}
@@ -0,0 +1,4 @@
1
+ import type { LoginPostMessage } from "@/types.js";
2
+ declare const validateLoginAppPostMessage: (event: LoginPostMessage, clientId: string) => boolean;
3
+ export { validateLoginAppPostMessage };
4
+ //# sourceMappingURL=postMessage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postMessage.d.ts","sourceRoot":"","sources":["../../../src/lib/postMessage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,QAAA,MAAM,2BAA2B,UACxB,gBAAgB,YACb,MAAM,KACf,OAcF,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC"}
@@ -0,0 +1,15 @@
1
+ const validateLoginAppPostMessage = (event, clientId) => {
2
+ const caseEvent = event;
3
+ console.log("caseEvent", caseEvent);
4
+ if (!caseEvent.clientId ||
5
+ !caseEvent.data.url ||
6
+ !caseEvent.source ||
7
+ !caseEvent.type ||
8
+ caseEvent.clientId !== clientId ||
9
+ caseEvent.source !== "civicloginApp") {
10
+ return false;
11
+ }
12
+ return true;
13
+ };
14
+ export { validateLoginAppPostMessage };
15
+ //# sourceMappingURL=postMessage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postMessage.js","sourceRoot":"","sources":["../../../src/lib/postMessage.ts"],"names":[],"mappings":"AAEA,MAAM,2BAA2B,GAAG,CAClC,KAAuB,EACvB,QAAgB,EACP,EAAE;IACX,MAAM,SAAS,GAAG,KAAyB,CAAC;IAC5C,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IACpC,IACE,CAAC,SAAS,CAAC,QAAQ;QACnB,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG;QACnB,CAAC,SAAS,CAAC,MAAM;QACjB,CAAC,SAAS,CAAC,IAAI;QACf,SAAS,CAAC,QAAQ,KAAK,QAAQ;QAC/B,SAAS,CAAC,MAAM,KAAK,eAAe,EACpC,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC","sourcesContent":["import type { LoginPostMessage } from \"@/types.js\";\n\nconst validateLoginAppPostMessage = (\n event: LoginPostMessage,\n clientId: string,\n): boolean => {\n const caseEvent = event as LoginPostMessage;\n console.log(\"caseEvent\", caseEvent);\n if (\n !caseEvent.clientId ||\n !caseEvent.data.url ||\n !caseEvent.source ||\n !caseEvent.type ||\n caseEvent.clientId !== clientId ||\n caseEvent.source !== \"civicloginApp\"\n ) {\n return false;\n }\n return true;\n};\n\nexport { validateLoginAppPostMessage };\n"]}
@@ -0,0 +1,4 @@
1
+ declare const isWindowInIframe: (window: Window) => boolean;
2
+ declare const removeParamsWithoutReload: (paramsToRemove: string[]) => void;
3
+ export { isWindowInIframe, removeParamsWithoutReload };
4
+ //# sourceMappingURL=windowUtil.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"windowUtil.d.ts","sourceRoot":"","sources":["../../../src/lib/windowUtil.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,gBAAgB,WAAY,MAAM,KAAG,OAc1C,CAAC;AAEF,QAAA,MAAM,yBAAyB,mBAAoB,MAAM,EAAE,SAU1D,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,CAAC"}
@@ -0,0 +1,30 @@
1
+ const isWindowInIframe = (window) => {
2
+ if (typeof window !== "undefined") {
3
+ // use the window width to determine if we're in an iframe or not
4
+ try {
5
+ if (window?.frameElement?.id === "civic-auth-iframe") {
6
+ return true;
7
+ }
8
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
9
+ }
10
+ catch (_e) {
11
+ // If we get an error, we're not in an iframe
12
+ return false;
13
+ }
14
+ }
15
+ return false;
16
+ };
17
+ const removeParamsWithoutReload = (paramsToRemove) => {
18
+ const url = new URL(window.location.href);
19
+ paramsToRemove.forEach((param) => {
20
+ url.searchParams.delete(param);
21
+ });
22
+ try {
23
+ window.history.replaceState({}, "", url);
24
+ }
25
+ catch (error) {
26
+ console.warn("window.history.replaceState failed", error);
27
+ }
28
+ };
29
+ export { isWindowInIframe, removeParamsWithoutReload };
30
+ //# sourceMappingURL=windowUtil.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"windowUtil.js","sourceRoot":"","sources":["../../../src/lib/windowUtil.ts"],"names":[],"mappings":"AAAA,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAW,EAAE;IACnD,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;QAClC,iEAAiE;QACjE,IAAI,CAAC;YACH,IAAI,MAAM,EAAE,YAAY,EAAE,EAAE,KAAK,mBAAmB,EAAE,CAAC;gBACrD,OAAO,IAAI,CAAC;YACd,CAAC;YACD,6DAA6D;QAC/D,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;YACZ,6CAA6C;YAC7C,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,MAAM,yBAAyB,GAAG,CAAC,cAAwB,EAAE,EAAE;IAC7D,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC1C,cAAc,CAAC,OAAO,CAAC,CAAC,KAAa,EAAE,EAAE;QACvC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IACH,IAAI,CAAC;QACH,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;IAC3C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAC;IAC5D,CAAC;AACH,CAAC,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,CAAC","sourcesContent":["const isWindowInIframe = (window: Window): boolean => {\n if (typeof window !== \"undefined\") {\n // use the window width to determine if we're in an iframe or not\n try {\n if (window?.frameElement?.id === \"civic-auth-iframe\") {\n return true;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (_e) {\n // If we get an error, we're not in an iframe\n return false;\n }\n }\n return false;\n};\n\nconst removeParamsWithoutReload = (paramsToRemove: string[]) => {\n const url = new URL(window.location.href);\n paramsToRemove.forEach((param: string) => {\n url.searchParams.delete(param);\n });\n try {\n window.history.replaceState({}, \"\", url);\n } catch (error) {\n console.warn(\"window.history.replaceState failed\", error);\n }\n};\n\nexport { isWindowInIframe, removeParamsWithoutReload };\n"]}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Used on the server-side to get the user object from the cookie
3
+ */
4
+ import type { User } from "@/types.js";
5
+ export declare const getUser: () => Promise<User | null>;
6
+ //# sourceMappingURL=GetUser.d.ts.map
@@ -0,0 +1,18 @@
1
+ import { GenericUserSession } from "@/shared/lib/UserSession.js";
2
+ import { NextjsClientStorage } from "@/nextjs/cookies.js";
3
+ import { retrieveTokens } from "@/shared/lib/util.js";
4
+ export const getUser = async () => {
5
+ const clientStorage = new NextjsClientStorage();
6
+ const userSession = new GenericUserSession(clientStorage);
7
+ const tokens = await retrieveTokens(clientStorage);
8
+ const user = await userSession.get();
9
+ if (!user || !tokens)
10
+ return null;
11
+ return {
12
+ ...user,
13
+ idToken: tokens.id_token,
14
+ accessToken: tokens.access_token,
15
+ refreshToken: tokens.refresh_token ?? "",
16
+ };
17
+ };
18
+ //# sourceMappingURL=GetUser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GetUser.js","sourceRoot":"","sources":["../../../src/nextjs/GetUser.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,IAA0B,EAAE;IACtD,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,MAAM,WAAW,GAAG,IAAI,kBAAkB,CAAC,aAAa,CAAC,CAAC;IAC1D,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,aAAa,CAAC,CAAC;IACnD,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,GAAG,EAAE,CAAC;IACrC,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IAElC,OAAO;QACL,GAAG,IAAK;QACR,OAAO,EAAE,MAAM,CAAC,QAAQ;QACxB,WAAW,EAAE,MAAM,CAAC,YAAY;QAChC,YAAY,EAAE,MAAM,CAAC,aAAa,IAAI,EAAE;KACjC,CAAC;AACZ,CAAC,CAAC","sourcesContent":["/**\n * Used on the server-side to get the user object from the cookie\n */\nimport type { User } from \"@/types.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\nimport { NextjsClientStorage } from \"@/nextjs/cookies.js\";\nimport { retrieveTokens } from \"@/shared/lib/util.js\";\n\nexport const getUser = async (): Promise<User | null> => {\n const clientStorage = new NextjsClientStorage();\n const userSession = new GenericUserSession(clientStorage);\n const tokens = await retrieveTokens(clientStorage);\n const user = await userSession.get();\n if (!user || !tokens) return null;\n\n return {\n ...user!,\n idToken: tokens.id_token,\n accessToken: tokens.access_token,\n refreshToken: tokens.refresh_token ?? \"\",\n } as User;\n};\n"]}