@civic/auth 0.2.5-alpha.3 → 0.2.5

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 (559) hide show
  1. package/CHANGELOG.md +1 -0
  2. package/dist/cjs/lib/cookies.d.ts +1 -12
  3. package/dist/cjs/lib/cookies.d.ts.map +1 -1
  4. package/dist/cjs/lib/cookies.js +2 -30
  5. package/dist/cjs/lib/cookies.js.map +1 -1
  6. package/dist/cjs/nextjs/GetUser.d.ts +6 -0
  7. package/dist/cjs/nextjs/GetUser.d.ts.map +1 -0
  8. package/dist/cjs/nextjs/GetUser.js +11 -0
  9. package/dist/cjs/nextjs/GetUser.js.map +1 -0
  10. package/dist/cjs/nextjs/hooks/useRefresh.d.ts.map +1 -1
  11. package/dist/cjs/nextjs/hooks/useRefresh.js +5 -7
  12. package/dist/cjs/nextjs/hooks/useRefresh.js.map +1 -1
  13. package/dist/cjs/nextjs/routeHandler.js +1 -1
  14. package/dist/cjs/nextjs/routeHandler.js.map +1 -1
  15. package/dist/cjs/reactjs/hooks/useAuth.d.ts +3 -0
  16. package/dist/cjs/reactjs/hooks/useAuth.d.ts.map +1 -0
  17. package/dist/cjs/reactjs/hooks/useAuth.js +15 -0
  18. package/dist/cjs/reactjs/hooks/useAuth.js.map +1 -0
  19. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  20. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  21. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +16 -0
  22. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  23. package/dist/cjs/shared/lib/session.d.ts.map +1 -1
  24. package/dist/cjs/shared/lib/session.js +10 -2
  25. package/dist/cjs/shared/lib/session.js.map +1 -1
  26. package/dist/cjs/shared/lib/types.d.ts +1 -1
  27. package/dist/cjs/shared/lib/types.d.ts.map +1 -1
  28. package/dist/cjs/shared/lib/types.js.map +1 -1
  29. package/dist/cjs/shared/providers/AuthProvider.d.ts +22 -0
  30. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +1 -0
  31. package/dist/cjs/shared/providers/AuthProvider.js +108 -0
  32. package/dist/cjs/shared/providers/AuthProvider.js.map +1 -0
  33. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts +6 -0
  34. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  35. package/dist/cjs/shared/providers/CivicAuthProvider.js +38 -0
  36. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +1 -0
  37. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  38. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  39. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +168 -0
  40. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  41. package/dist/cjs/shared/version.d.ts +1 -1
  42. package/dist/cjs/shared/version.d.ts.map +1 -1
  43. package/dist/cjs/shared/version.js +1 -1
  44. package/dist/cjs/shared/version.js.map +1 -1
  45. package/dist/cjs/types.d.ts.map +1 -1
  46. package/dist/cjs/types.js +7 -1
  47. package/dist/cjs/types.js.map +1 -1
  48. package/dist/cjs/utils.d.ts +2 -2
  49. package/dist/cjs/utils.d.ts.map +1 -1
  50. package/dist/cjs/utils.js +1 -1
  51. package/dist/cjs/utils.js.map +1 -1
  52. package/dist/esm/lib/cookies.d.ts +1 -12
  53. package/dist/esm/lib/cookies.d.ts.map +1 -1
  54. package/dist/esm/lib/cookies.js +2 -29
  55. package/dist/esm/lib/cookies.js.map +1 -1
  56. package/dist/esm/nextjs/GetUser.d.ts +6 -0
  57. package/dist/esm/nextjs/GetUser.d.ts.map +1 -0
  58. package/dist/esm/nextjs/GetUser.js +7 -0
  59. package/dist/esm/nextjs/GetUser.js.map +1 -0
  60. package/dist/esm/nextjs/hooks/useRefresh.d.ts.map +1 -1
  61. package/dist/esm/nextjs/hooks/useRefresh.js +6 -8
  62. package/dist/esm/nextjs/hooks/useRefresh.js.map +1 -1
  63. package/dist/esm/nextjs/routeHandler.js +1 -1
  64. package/dist/esm/nextjs/routeHandler.js.map +1 -1
  65. package/dist/esm/reactjs/hooks/useAuth.d.ts +3 -0
  66. package/dist/esm/reactjs/hooks/useAuth.d.ts.map +1 -0
  67. package/dist/esm/reactjs/hooks/useAuth.js +12 -0
  68. package/dist/esm/reactjs/hooks/useAuth.js.map +1 -0
  69. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  70. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  71. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +13 -0
  72. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  73. package/dist/esm/shared/lib/session.d.ts.map +1 -1
  74. package/dist/esm/shared/lib/session.js +10 -2
  75. package/dist/esm/shared/lib/session.js.map +1 -1
  76. package/dist/esm/shared/lib/types.d.ts +1 -1
  77. package/dist/esm/shared/lib/types.d.ts.map +1 -1
  78. package/dist/esm/shared/lib/types.js.map +1 -1
  79. package/dist/esm/shared/providers/AuthProvider.d.ts +22 -0
  80. package/dist/esm/shared/providers/AuthProvider.d.ts.map +1 -0
  81. package/dist/esm/shared/providers/AuthProvider.js +72 -0
  82. package/dist/esm/shared/providers/AuthProvider.js.map +1 -0
  83. package/dist/esm/shared/providers/CivicAuthProvider.d.ts +6 -0
  84. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  85. package/dist/esm/shared/providers/CivicAuthProvider.js +32 -0
  86. package/dist/esm/shared/providers/CivicAuthProvider.js.map +1 -0
  87. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  88. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  89. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +131 -0
  90. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  91. package/dist/esm/shared/version.d.ts +1 -1
  92. package/dist/esm/shared/version.d.ts.map +1 -1
  93. package/dist/esm/shared/version.js +1 -1
  94. package/dist/esm/shared/version.js.map +1 -1
  95. package/dist/esm/types.d.ts.map +1 -1
  96. package/dist/esm/types.js +7 -1
  97. package/dist/esm/types.js.map +1 -1
  98. package/dist/esm/utils.d.ts +2 -2
  99. package/dist/esm/utils.d.ts.map +1 -1
  100. package/dist/esm/utils.js +1 -2
  101. package/dist/esm/utils.js.map +1 -1
  102. package/dist/generateVersion.d.ts +2 -0
  103. package/dist/generateVersion.d.ts.map +1 -0
  104. package/dist/generateVersion.js +12 -0
  105. package/dist/generateVersion.js.map +1 -0
  106. package/dist/package.json +118 -0
  107. package/dist/src/browser/storage.d.ts +9 -0
  108. package/dist/src/browser/storage.d.ts.map +1 -0
  109. package/dist/src/browser/storage.js +17 -0
  110. package/dist/src/browser/storage.js.map +1 -0
  111. package/dist/src/config.d.ts +3 -0
  112. package/dist/src/config.d.ts.map +1 -0
  113. package/dist/src/config.js +5 -0
  114. package/dist/src/config.js.map +1 -0
  115. package/dist/src/constants.d.ts +8 -0
  116. package/dist/src/constants.d.ts.map +1 -0
  117. package/dist/src/constants.js +16 -0
  118. package/dist/src/constants.js.map +1 -0
  119. package/dist/src/index.d.ts +6 -0
  120. package/dist/src/index.d.ts.map +1 -0
  121. package/dist/src/index.js +4 -0
  122. package/dist/src/index.js.map +1 -0
  123. package/dist/src/lib/cookies.d.ts +7 -0
  124. package/dist/src/lib/cookies.d.ts.map +1 -0
  125. package/dist/src/lib/cookies.js +25 -0
  126. package/dist/src/lib/cookies.js.map +1 -0
  127. package/dist/src/lib/jwt.d.ts +3 -0
  128. package/dist/src/lib/jwt.d.ts.map +1 -0
  129. package/dist/src/lib/jwt.js +9 -0
  130. package/dist/src/lib/jwt.js.map +1 -0
  131. package/dist/src/lib/logger.d.ts +26 -0
  132. package/dist/src/lib/logger.d.ts.map +1 -0
  133. package/dist/src/lib/logger.js +55 -0
  134. package/dist/src/lib/logger.js.map +1 -0
  135. package/dist/src/lib/oauth.d.ts +19 -0
  136. package/dist/src/lib/oauth.d.ts.map +1 -0
  137. package/dist/src/lib/oauth.js +61 -0
  138. package/dist/src/lib/oauth.js.map +1 -0
  139. package/dist/src/lib/obj.d.ts +3 -0
  140. package/dist/src/lib/obj.d.ts.map +1 -0
  141. package/dist/src/lib/obj.js +18 -0
  142. package/dist/src/lib/obj.js.map +1 -0
  143. package/dist/src/lib/postMessage.d.ts +4 -0
  144. package/dist/src/lib/postMessage.d.ts.map +1 -0
  145. package/dist/src/lib/postMessage.js +15 -0
  146. package/dist/src/lib/postMessage.js.map +1 -0
  147. package/dist/src/lib/windowUtil.d.ts +4 -0
  148. package/dist/src/lib/windowUtil.d.ts.map +1 -0
  149. package/dist/src/lib/windowUtil.js +31 -0
  150. package/dist/src/lib/windowUtil.js.map +1 -0
  151. package/dist/src/nextjs/GetUser.d.ts +6 -0
  152. package/dist/src/nextjs/GetUser.d.ts.map +1 -0
  153. package/dist/src/nextjs/GetUser.js +7 -0
  154. package/dist/src/nextjs/GetUser.js.map +1 -0
  155. package/dist/src/nextjs/config.d.ts +181 -0
  156. package/dist/src/nextjs/config.d.ts.map +1 -0
  157. package/dist/src/nextjs/config.js +177 -0
  158. package/dist/src/nextjs/config.js.map +1 -0
  159. package/dist/src/nextjs/cookies.d.ts +30 -0
  160. package/dist/src/nextjs/cookies.d.ts.map +1 -0
  161. package/dist/src/nextjs/cookies.js +112 -0
  162. package/dist/src/nextjs/cookies.js.map +1 -0
  163. package/dist/src/nextjs/hooks/index.d.ts +2 -0
  164. package/dist/src/nextjs/hooks/index.d.ts.map +1 -0
  165. package/dist/src/nextjs/hooks/index.js +2 -0
  166. package/dist/src/nextjs/hooks/index.js.map +1 -0
  167. package/dist/src/nextjs/hooks/usePrevious.d.ts +2 -0
  168. package/dist/src/nextjs/hooks/usePrevious.d.ts.map +1 -0
  169. package/dist/src/nextjs/hooks/usePrevious.js +9 -0
  170. package/dist/src/nextjs/hooks/usePrevious.js.map +1 -0
  171. package/dist/src/nextjs/hooks/useUserCookie.d.ts +8 -0
  172. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  173. package/dist/src/nextjs/hooks/useUserCookie.js +88 -0
  174. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -0
  175. package/dist/src/nextjs/index.d.ts +7 -0
  176. package/dist/src/nextjs/index.d.ts.map +1 -0
  177. package/dist/src/nextjs/index.js +8 -0
  178. package/dist/src/nextjs/index.js.map +1 -0
  179. package/dist/src/nextjs/middleware/index.d.ts +2 -0
  180. package/dist/src/nextjs/middleware/index.d.ts.map +1 -0
  181. package/dist/src/nextjs/middleware/index.js +4 -0
  182. package/dist/src/nextjs/middleware/index.js.map +1 -0
  183. package/dist/src/nextjs/middleware.d.ts +59 -0
  184. package/dist/src/nextjs/middleware.d.ts.map +1 -0
  185. package/dist/src/nextjs/middleware.js +107 -0
  186. package/dist/src/nextjs/middleware.js.map +1 -0
  187. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +13 -0
  188. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  189. package/dist/src/nextjs/providers/NextAuthProvider.js +94 -0
  190. package/dist/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  191. package/dist/src/nextjs/routeHandler.d.ts +19 -0
  192. package/dist/src/nextjs/routeHandler.d.ts.map +1 -0
  193. package/dist/src/nextjs/routeHandler.js +309 -0
  194. package/dist/src/nextjs/routeHandler.js.map +1 -0
  195. package/dist/src/nextjs/utils.d.ts +3 -0
  196. package/dist/src/nextjs/utils.d.ts.map +1 -0
  197. package/dist/src/nextjs/utils.js +5 -0
  198. package/dist/src/nextjs/utils.js.map +1 -0
  199. package/dist/src/reactjs/components/SignInButton.d.ts +8 -0
  200. package/dist/src/reactjs/components/SignInButton.d.ts.map +1 -0
  201. package/dist/src/reactjs/components/SignInButton.js +14 -0
  202. package/dist/src/reactjs/components/SignInButton.js.map +1 -0
  203. package/dist/src/reactjs/components/SignOutButton.d.ts +6 -0
  204. package/dist/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  205. package/dist/src/reactjs/components/SignOutButton.js +14 -0
  206. package/dist/src/reactjs/components/SignOutButton.js.map +1 -0
  207. package/dist/src/reactjs/components/UserButton.d.ts +6 -0
  208. package/dist/src/reactjs/components/UserButton.d.ts.map +1 -0
  209. package/dist/src/reactjs/components/UserButton.js +118 -0
  210. package/dist/src/reactjs/components/UserButton.js.map +1 -0
  211. package/dist/src/reactjs/components/index.d.ts +6 -0
  212. package/dist/src/reactjs/components/index.d.ts.map +1 -0
  213. package/dist/src/reactjs/components/index.js +6 -0
  214. package/dist/src/reactjs/components/index.js.map +1 -0
  215. package/dist/src/reactjs/hooks/index.d.ts +6 -0
  216. package/dist/src/reactjs/hooks/index.d.ts.map +1 -0
  217. package/dist/src/reactjs/hooks/index.js +6 -0
  218. package/dist/src/reactjs/hooks/index.js.map +1 -0
  219. package/dist/src/reactjs/hooks/useAuth.d.ts +3 -0
  220. package/dist/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  221. package/dist/src/reactjs/hooks/useAuth.js +12 -0
  222. package/dist/src/reactjs/hooks/useAuth.js.map +1 -0
  223. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  224. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  225. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.js +13 -0
  226. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  227. package/dist/src/reactjs/hooks/useUser.d.ts +4 -0
  228. package/dist/src/reactjs/hooks/useUser.d.ts.map +1 -0
  229. package/dist/src/reactjs/hooks/useUser.js +12 -0
  230. package/dist/src/reactjs/hooks/useUser.js.map +1 -0
  231. package/dist/src/reactjs/index.d.ts +6 -0
  232. package/dist/src/reactjs/index.d.ts.map +1 -0
  233. package/dist/src/reactjs/index.js +10 -0
  234. package/dist/src/reactjs/index.js.map +1 -0
  235. package/dist/src/reactjs/providers/AuthProvider.d.ts +11 -0
  236. package/dist/src/reactjs/providers/AuthProvider.d.ts.map +1 -0
  237. package/dist/src/reactjs/providers/AuthProvider.js +76 -0
  238. package/dist/src/reactjs/providers/AuthProvider.js.map +1 -0
  239. package/dist/src/reactjs/providers/CivicAuthProvider.d.ts +6 -0
  240. package/dist/src/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  241. package/dist/src/reactjs/providers/CivicAuthProvider.js +32 -0
  242. package/dist/src/reactjs/providers/CivicAuthProvider.js.map +1 -0
  243. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  244. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  245. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.js +148 -0
  246. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  247. package/dist/src/reactjs/providers/index.d.ts +8 -0
  248. package/dist/src/reactjs/providers/index.d.ts.map +1 -0
  249. package/dist/src/reactjs/providers/index.js +7 -0
  250. package/dist/src/reactjs/providers/index.js.map +1 -0
  251. package/dist/src/server/ServerAuthenticationResolver.d.ts +20 -0
  252. package/dist/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  253. package/dist/src/server/ServerAuthenticationResolver.js +67 -0
  254. package/dist/src/server/ServerAuthenticationResolver.js.map +1 -0
  255. package/dist/src/server/config.d.ts +10 -0
  256. package/dist/src/server/config.d.ts.map +1 -0
  257. package/dist/src/server/config.js +2 -0
  258. package/dist/src/server/config.js.map +1 -0
  259. package/dist/src/server/index.d.ts +7 -0
  260. package/dist/src/server/index.d.ts.map +1 -0
  261. package/dist/src/server/index.js +7 -0
  262. package/dist/src/server/index.js.map +1 -0
  263. package/dist/src/server/login.d.ts +21 -0
  264. package/dist/src/server/login.d.ts.map +1 -0
  265. package/dist/src/server/login.js +56 -0
  266. package/dist/src/server/login.js.map +1 -0
  267. package/dist/src/server/refresh.d.ts +7 -0
  268. package/dist/src/server/refresh.d.ts.map +1 -0
  269. package/dist/src/server/refresh.js +13 -0
  270. package/dist/src/server/refresh.js.map +1 -0
  271. package/dist/src/services/AuthenticationService.d.ts +91 -0
  272. package/dist/src/services/AuthenticationService.d.ts.map +1 -0
  273. package/dist/src/services/AuthenticationService.js +322 -0
  274. package/dist/src/services/AuthenticationService.js.map +1 -0
  275. package/dist/src/services/PKCE.d.ts +20 -0
  276. package/dist/src/services/PKCE.d.ts.map +1 -0
  277. package/dist/src/services/PKCE.js +44 -0
  278. package/dist/src/services/PKCE.js.map +1 -0
  279. package/dist/src/services/types.d.ts +24 -0
  280. package/dist/src/services/types.d.ts.map +1 -0
  281. package/dist/src/services/types.js +7 -0
  282. package/dist/src/services/types.js.map +1 -0
  283. package/dist/src/shared/components/BlockDisplay.d.ts +7 -0
  284. package/dist/src/shared/components/BlockDisplay.d.ts.map +1 -0
  285. package/dist/src/shared/components/BlockDisplay.js +25 -0
  286. package/dist/src/shared/components/BlockDisplay.js.map +1 -0
  287. package/dist/src/shared/components/CivicAuthIframe.d.ts +9 -0
  288. package/dist/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  289. package/dist/src/shared/components/CivicAuthIframe.js +8 -0
  290. package/dist/src/shared/components/CivicAuthIframe.js.map +1 -0
  291. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts +13 -0
  292. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  293. package/dist/src/shared/components/CivicAuthIframeContainer.js +138 -0
  294. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  295. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.d.ts +7 -0
  296. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  297. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.js +22 -0
  298. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  299. package/dist/src/shared/components/CloseIcon.d.ts +4 -0
  300. package/dist/src/shared/components/CloseIcon.d.ts.map +1 -0
  301. package/dist/src/shared/components/CloseIcon.js +6 -0
  302. package/dist/src/shared/components/CloseIcon.js.map +1 -0
  303. package/dist/src/shared/components/IFrameAndLoading.d.ts +8 -0
  304. package/dist/src/shared/components/IFrameAndLoading.d.ts.map +1 -0
  305. package/dist/src/shared/components/IFrameAndLoading.js +27 -0
  306. package/dist/src/shared/components/IFrameAndLoading.js.map +1 -0
  307. package/dist/src/shared/components/LoadingIcon.d.ts +4 -0
  308. package/dist/src/shared/components/LoadingIcon.d.ts.map +1 -0
  309. package/dist/src/shared/components/LoadingIcon.js +30 -0
  310. package/dist/src/shared/components/LoadingIcon.js.map +1 -0
  311. package/dist/src/shared/hooks/index.d.ts +11 -0
  312. package/dist/src/shared/hooks/index.d.ts.map +1 -0
  313. package/dist/src/shared/hooks/index.js +11 -0
  314. package/dist/src/shared/hooks/index.js.map +1 -0
  315. package/dist/src/shared/hooks/useAuth.d.ts +3 -0
  316. package/dist/src/shared/hooks/useAuth.d.ts.map +1 -0
  317. package/dist/src/shared/hooks/useAuth.js +12 -0
  318. package/dist/src/shared/hooks/useAuth.js.map +1 -0
  319. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  320. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  321. package/dist/src/shared/hooks/useCivicAuthConfig.js +10 -0
  322. package/dist/src/shared/hooks/useCivicAuthConfig.js.map +1 -0
  323. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  324. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  325. package/dist/src/shared/hooks/useClientTokenExchangeSession.js +13 -0
  326. package/dist/src/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  327. package/dist/src/shared/hooks/useCurrentUrl.d.ts +3 -0
  328. package/dist/src/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  329. package/dist/src/shared/hooks/useCurrentUrl.js +24 -0
  330. package/dist/src/shared/hooks/useCurrentUrl.js.map +1 -0
  331. package/dist/src/shared/hooks/useIframe.d.ts +3 -0
  332. package/dist/src/shared/hooks/useIframe.d.ts.map +1 -0
  333. package/dist/src/shared/hooks/useIframe.js +13 -0
  334. package/dist/src/shared/hooks/useIframe.js.map +1 -0
  335. package/dist/src/shared/hooks/useIsInIframe.d.ts +3 -0
  336. package/dist/src/shared/hooks/useIsInIframe.d.ts.map +1 -0
  337. package/dist/src/shared/hooks/useIsInIframe.js +14 -0
  338. package/dist/src/shared/hooks/useIsInIframe.js.map +1 -0
  339. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  340. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  341. package/dist/src/shared/hooks/useOAuthEndpoints.js +14 -0
  342. package/dist/src/shared/hooks/useOAuthEndpoints.js.map +1 -0
  343. package/dist/src/shared/hooks/useRefresh.d.ts +4 -0
  344. package/dist/src/shared/hooks/useRefresh.d.ts.map +1 -0
  345. package/dist/src/shared/hooks/useRefresh.js +38 -0
  346. package/dist/src/shared/hooks/useRefresh.js.map +1 -0
  347. package/dist/src/shared/hooks/useSession.d.ts +3 -0
  348. package/dist/src/shared/hooks/useSession.d.ts.map +1 -0
  349. package/dist/src/shared/hooks/useSession.js +13 -0
  350. package/dist/src/shared/hooks/useSession.js.map +1 -0
  351. package/dist/src/shared/hooks/useSignIn.d.ts +15 -0
  352. package/dist/src/shared/hooks/useSignIn.d.ts.map +1 -0
  353. package/dist/src/shared/hooks/useSignIn.js +126 -0
  354. package/dist/src/shared/hooks/useSignIn.js.map +1 -0
  355. package/dist/src/shared/hooks/useToken.d.ts +3 -0
  356. package/dist/src/shared/hooks/useToken.d.ts.map +1 -0
  357. package/dist/src/shared/hooks/useToken.js +12 -0
  358. package/dist/src/shared/hooks/useToken.js.map +1 -0
  359. package/dist/src/shared/hooks/useWindowFocused.d.ts +5 -0
  360. package/dist/src/shared/hooks/useWindowFocused.d.ts.map +1 -0
  361. package/dist/src/shared/hooks/useWindowFocused.js +21 -0
  362. package/dist/src/shared/hooks/useWindowFocused.js.map +1 -0
  363. package/dist/src/shared/index.d.ts +5 -0
  364. package/dist/src/shared/index.d.ts.map +1 -0
  365. package/dist/src/shared/index.js +16 -0
  366. package/dist/src/shared/index.js.map +1 -0
  367. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +20 -0
  368. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  369. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +73 -0
  370. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  371. package/dist/src/shared/lib/UserSession.d.ts +12 -0
  372. package/dist/src/shared/lib/UserSession.d.ts.map +1 -0
  373. package/dist/src/shared/lib/UserSession.js +20 -0
  374. package/dist/src/shared/lib/UserSession.js.map +1 -0
  375. package/dist/src/shared/lib/session.d.ts +3 -0
  376. package/dist/src/shared/lib/session.d.ts.map +1 -0
  377. package/dist/src/shared/lib/session.js +21 -0
  378. package/dist/src/shared/lib/session.js.map +1 -0
  379. package/dist/src/shared/lib/storage.d.ts +25 -0
  380. package/dist/src/shared/lib/storage.d.ts.map +1 -0
  381. package/dist/src/shared/lib/storage.js +17 -0
  382. package/dist/src/shared/lib/storage.js.map +1 -0
  383. package/dist/src/shared/lib/types.d.ts +36 -0
  384. package/dist/src/shared/lib/types.d.ts.map +1 -0
  385. package/dist/src/shared/lib/types.js +18 -0
  386. package/dist/src/shared/lib/types.js.map +1 -0
  387. package/dist/src/shared/lib/util.d.ts +34 -0
  388. package/dist/src/shared/lib/util.d.ts.map +1 -0
  389. package/dist/src/shared/lib/util.js +137 -0
  390. package/dist/src/shared/lib/util.js.map +1 -0
  391. package/dist/src/shared/providers/AuthContext.d.ts +11 -0
  392. package/dist/src/shared/providers/AuthContext.d.ts.map +1 -0
  393. package/dist/src/shared/providers/AuthContext.js +3 -0
  394. package/dist/src/shared/providers/AuthContext.js.map +1 -0
  395. package/dist/src/shared/providers/AuthProvider.d.ts +22 -0
  396. package/dist/src/shared/providers/AuthProvider.d.ts.map +1 -0
  397. package/dist/src/shared/providers/AuthProvider.js +72 -0
  398. package/dist/src/shared/providers/AuthProvider.js.map +1 -0
  399. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts +18 -0
  400. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  401. package/dist/src/shared/providers/CivicAuthConfigContext.js +52 -0
  402. package/dist/src/shared/providers/CivicAuthConfigContext.js.map +1 -0
  403. package/dist/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  404. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  405. package/dist/src/shared/providers/CivicAuthProvider.js +32 -0
  406. package/dist/src/shared/providers/CivicAuthProvider.js.map +1 -0
  407. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  408. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  409. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js +131 -0
  410. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  411. package/dist/src/shared/providers/IframeProvider.d.ts +22 -0
  412. package/dist/src/shared/providers/IframeProvider.d.ts.map +1 -0
  413. package/dist/src/shared/providers/IframeProvider.js +35 -0
  414. package/dist/src/shared/providers/IframeProvider.js.map +1 -0
  415. package/dist/src/shared/providers/SessionProvider.d.ts +19 -0
  416. package/dist/src/shared/providers/SessionProvider.d.ts.map +1 -0
  417. package/dist/src/shared/providers/SessionProvider.js +23 -0
  418. package/dist/src/shared/providers/SessionProvider.js.map +1 -0
  419. package/dist/src/shared/providers/TokenProvider.d.ts +18 -0
  420. package/dist/src/shared/providers/TokenProvider.d.ts.map +1 -0
  421. package/dist/src/shared/providers/TokenProvider.js +42 -0
  422. package/dist/src/shared/providers/TokenProvider.js.map +1 -0
  423. package/dist/src/shared/providers/UserProvider.d.ts +24 -0
  424. package/dist/src/shared/providers/UserProvider.d.ts.map +1 -0
  425. package/dist/src/shared/providers/UserProvider.js +52 -0
  426. package/dist/src/shared/providers/UserProvider.js.map +1 -0
  427. package/dist/src/shared/providers/types.d.ts +15 -0
  428. package/dist/src/shared/providers/types.d.ts.map +1 -0
  429. package/dist/src/shared/providers/types.js +2 -0
  430. package/dist/src/shared/providers/types.js.map +1 -0
  431. package/dist/src/shared/version.d.ts +2 -0
  432. package/dist/src/shared/version.d.ts.map +1 -0
  433. package/dist/src/shared/version.js +3 -0
  434. package/dist/src/shared/version.js.map +1 -0
  435. package/dist/src/types.d.ts +148 -0
  436. package/dist/src/types.d.ts.map +1 -0
  437. package/dist/src/types.js +4 -0
  438. package/dist/src/types.js.map +1 -0
  439. package/dist/src/utils.d.ts +15 -0
  440. package/dist/src/utils.d.ts.map +1 -0
  441. package/dist/src/utils.js +43 -0
  442. package/dist/src/utils.js.map +1 -0
  443. package/dist/src/version.d.ts +2 -0
  444. package/dist/src/version.d.ts.map +1 -0
  445. package/dist/src/version.js +3 -0
  446. package/dist/src/version.js.map +1 -0
  447. package/dist/test/integration/sdk.test.d.ts +2 -0
  448. package/dist/test/integration/sdk.test.d.ts.map +1 -0
  449. package/dist/test/integration/sdk.test.js +237 -0
  450. package/dist/test/integration/sdk.test.js.map +1 -0
  451. package/dist/test/support/fixtures.d.ts +26 -0
  452. package/dist/test/support/fixtures.d.ts.map +1 -0
  453. package/dist/test/support/fixtures.js +55 -0
  454. package/dist/test/support/fixtures.js.map +1 -0
  455. package/dist/test/support/tokens.json +26 -0
  456. package/dist/test/unit/lib/oauth.test.d.ts +2 -0
  457. package/dist/test/unit/lib/oauth.test.d.ts.map +1 -0
  458. package/dist/test/unit/lib/oauth.test.js +56 -0
  459. package/dist/test/unit/lib/oauth.test.js.map +1 -0
  460. package/dist/test/unit/lib/obj.test.d.ts +2 -0
  461. package/dist/test/unit/lib/obj.test.d.ts.map +1 -0
  462. package/dist/test/unit/lib/obj.test.js +37 -0
  463. package/dist/test/unit/lib/obj.test.js.map +1 -0
  464. package/dist/test/unit/logger.test.d.ts +2 -0
  465. package/dist/test/unit/logger.test.d.ts.map +1 -0
  466. package/dist/test/unit/logger.test.js +141 -0
  467. package/dist/test/unit/logger.test.js.map +1 -0
  468. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +2 -0
  469. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts.map +1 -0
  470. package/dist/test/unit/nextjs/NextAuthProvider.test.js +31 -0
  471. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +1 -0
  472. package/dist/test/unit/nextjs/config.test.d.ts +2 -0
  473. package/dist/test/unit/nextjs/config.test.d.ts.map +1 -0
  474. package/dist/test/unit/nextjs/config.test.js +203 -0
  475. package/dist/test/unit/nextjs/config.test.js.map +1 -0
  476. package/dist/test/unit/nextjs/getUser.test.d.ts +2 -0
  477. package/dist/test/unit/nextjs/getUser.test.d.ts.map +1 -0
  478. package/dist/test/unit/nextjs/getUser.test.js +22 -0
  479. package/dist/test/unit/nextjs/getUser.test.js.map +1 -0
  480. package/dist/test/unit/nextjs/handler.test.d.ts +2 -0
  481. package/dist/test/unit/nextjs/handler.test.d.ts.map +1 -0
  482. package/dist/test/unit/nextjs/handler.test.js +207 -0
  483. package/dist/test/unit/nextjs/handler.test.js.map +1 -0
  484. package/dist/test/unit/nextjs/middleware.test.d.ts +2 -0
  485. package/dist/test/unit/nextjs/middleware.test.d.ts.map +1 -0
  486. package/dist/test/unit/nextjs/middleware.test.js +113 -0
  487. package/dist/test/unit/nextjs/middleware.test.js.map +1 -0
  488. package/dist/test/unit/nextjs/utils.test.d.ts +2 -0
  489. package/dist/test/unit/nextjs/utils.test.d.ts.map +1 -0
  490. package/dist/test/unit/nextjs/utils.test.js +13 -0
  491. package/dist/test/unit/nextjs/utils.test.js.map +1 -0
  492. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +2 -0
  493. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts.map +1 -0
  494. package/dist/test/unit/publicApi/apiSnapshot.test.js +10 -0
  495. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +1 -0
  496. package/dist/test/unit/react/components/SignInButton.test.d.ts +2 -0
  497. package/dist/test/unit/react/components/SignInButton.test.d.ts.map +1 -0
  498. package/dist/test/unit/react/components/SignInButton.test.js +31 -0
  499. package/dist/test/unit/react/components/SignInButton.test.js.map +1 -0
  500. package/dist/test/unit/react/components/SignOutButton.test.d.ts +2 -0
  501. package/dist/test/unit/react/components/SignOutButton.test.d.ts.map +1 -0
  502. package/dist/test/unit/react/components/SignOutButton.test.js +30 -0
  503. package/dist/test/unit/react/components/SignOutButton.test.js.map +1 -0
  504. package/dist/test/unit/server/login.test.d.ts +2 -0
  505. package/dist/test/unit/server/login.test.d.ts.map +1 -0
  506. package/dist/test/unit/server/login.test.js +184 -0
  507. package/dist/test/unit/server/login.test.js.map +1 -0
  508. package/dist/test/unit/server/refresh.test.d.ts +2 -0
  509. package/dist/test/unit/server/refresh.test.d.ts.map +1 -0
  510. package/dist/test/unit/server/refresh.test.js +55 -0
  511. package/dist/test/unit/server/refresh.test.js.map +1 -0
  512. package/dist/test/unit/server/session.test.d.ts +2 -0
  513. package/dist/test/unit/server/session.test.d.ts.map +1 -0
  514. package/dist/test/unit/server/session.test.js +41 -0
  515. package/dist/test/unit/server/session.test.js.map +1 -0
  516. package/dist/test/unit/services/AuthenticationService.test.d.ts +2 -0
  517. package/dist/test/unit/services/AuthenticationService.test.d.ts.map +1 -0
  518. package/dist/test/unit/services/AuthenticationService.test.js +301 -0
  519. package/dist/test/unit/services/AuthenticationService.test.js.map +1 -0
  520. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +2 -0
  521. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts.map +1 -0
  522. package/dist/test/unit/services/ServerAuthenticationResolver.test.js +75 -0
  523. package/dist/test/unit/services/ServerAuthenticationResolver.test.js.map +1 -0
  524. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +2 -0
  525. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts.map +1 -0
  526. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js +144 -0
  527. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js.map +1 -0
  528. package/dist/test/unit/shared/UserSession.test.d.ts +2 -0
  529. package/dist/test/unit/shared/UserSession.test.d.ts.map +1 -0
  530. package/dist/test/unit/shared/UserSession.test.js +37 -0
  531. package/dist/test/unit/shared/UserSession.test.js.map +1 -0
  532. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +2 -0
  533. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts.map +1 -0
  534. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +122 -0
  535. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +1 -0
  536. package/dist/test/unit/shared/printVersion.test.d.ts +2 -0
  537. package/dist/test/unit/shared/printVersion.test.d.ts.map +1 -0
  538. package/dist/test/unit/shared/printVersion.test.js +39 -0
  539. package/dist/test/unit/shared/printVersion.test.js.map +1 -0
  540. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.d.ts +2 -0
  541. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.d.ts.map +1 -0
  542. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.js +108 -0
  543. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.js.map +1 -0
  544. package/dist/test/unit/shared/storage.test.d.ts +2 -0
  545. package/dist/test/unit/shared/storage.test.d.ts.map +1 -0
  546. package/dist/test/unit/shared/storage.test.js +53 -0
  547. package/dist/test/unit/shared/storage.test.js.map +1 -0
  548. package/dist/test/unit/utils.test.d.ts +2 -0
  549. package/dist/test/unit/utils.test.d.ts.map +1 -0
  550. package/dist/test/unit/utils.test.js +40 -0
  551. package/dist/test/unit/utils.test.js.map +1 -0
  552. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  553. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  554. package/dist/tsconfig.tsbuildinfo +1 -0
  555. package/dist/vitest.config.d.ts +3 -0
  556. package/dist/vitest.config.d.ts.map +1 -0
  557. package/dist/vitest.config.js +44 -0
  558. package/dist/vitest.config.js.map +1 -0
  559. package/package.json +1 -1
@@ -1,2 +1,2 @@
1
- export declare const VERSION = "@civic/auth:0.2.5-alpha.3";
1
+ export declare const VERSION = "@civic/auth:0.2.5";
2
2
  //# sourceMappingURL=version.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,OAAO,8BAA8B,CAAC"}
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,OAAO,sBAAsB,CAAC"}
@@ -1,3 +1,3 @@
1
1
  // This is an auto-generated file. Do not edit.
2
- export const VERSION = "@civic/auth:0.2.5-alpha.3";
2
+ export const VERSION = "@civic/auth:0.2.5";
3
3
  //# sourceMappingURL=version.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAE/C,MAAM,CAAC,MAAM,OAAO,GAAG,2BAA2B,CAAC","sourcesContent":["// This is an auto-generated file. Do not edit.\n\nexport const VERSION = \"@civic/auth:0.2.5-alpha.3\";\n"]}
1
+ {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/shared/version.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAE/C,MAAM,CAAC,MAAM,OAAO,GAAG,mBAAmB,CAAC","sourcesContent":["// This is an auto-generated file. Do not edit.\n\nexport const VERSION = \"@civic/auth:0.2.5\";\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AACrD,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAEpC,KAAK,aAAa,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAC7C,KAAK,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AAEzC,oBAAY,UAAU;IACpB,aAAa,kBAAkB;IAC/B,eAAe,oBAAoB;IACnC,cAAc,mBAAmB;IACjC,KAAK,UAAU;IACf,WAAW,gBAAgB;CAC5B;AAED,KAAK,WAAW,GAAG,QAAQ,GAAG,UAAU,GAAG,SAAS,GAAG,YAAY,CAAC;AAGpE,UAAU,kBAAkB;IAE1B,oBAAoB,CAClB,gBAAgB,EAAE,MAAM,EACxB,WAAW,EAAE,WAAW,GACvB,IAAI,CAAC;IAER,mBAAmB,CACjB,MAAM,EAAE,MAAM,EAAE,EAChB,mBAAmB,EAAE,WAAW,EAChC,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,MAAM,CAAC,CAAC;IAEnB,MAAM,CACJ,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,MAAM,EAAE,EAChB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjB,aAAa,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAEzD,cAAc,IAAI,WAAW,CAAC;IAE9B,iBAAiB,CAAC,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC;IAC3C,kBAAkB,IAAI,OAAO,CAAC,eAAe,CAAC,CAAC;CAChD;AAGD,UAAU,YAAY;IACpB,qBAAqB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACzD,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC;IACzD,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CAC3D;AAGD,UAAU,eAAe;IACvB,WAAW,CAAC,CAAC,SAAS,aAAa,EACjC,WAAW,EAAE,MAAM,EACnB,OAAO,EAAE,MAAM,GAAG,IAAI,GACrB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;CAC5B;AAGD,UAAU,eAAe;IACvB,oBAAoB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CAC7D;AAGD,KAAK,WAAW,GAAG;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,KAAK,SAAS,GAAG;IACf,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,KAAK,MAAM,GAAG;IACZ,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,SAAS,CAAC;CACvB,CAAC;AAEF,KAAK,WAAW,GAAG;IACjB,aAAa,EAAE,OAAO,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,KAAK,qBAAqB,GAAG,iBAAiB,GAAG;IAC/C,QAAQ,EAAE,MAAM,CAAC;IACjB,uBAAuB,CAAC,EAAE,MAAM,CAAC;CAClC,CAAC;AAEF,KAAK,YAAY,GAAG;IAClB,QAAQ,EAAE,UAAU,CAAC;IACrB,YAAY,EAAE,UAAU,CAAC;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAGF,KAAK,eAAe,GAAG,MAAM,CAC3B,MAAM,EACN;IACE,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CACF,CAAC;AAGF,KAAK,kBAAkB,GAAG,MAAM,CAC9B,MAAM,EACN;IACE,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CACF,CAAC;AAEF,KAAK,UAAU,GAAG,GAAG,CAAC,SAAS,CAAC,GAAG;IACjC,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,KAAK,cAAc,GAAG,UAAU,GAAG;IACjC,eAAe,CAAC,EAAE,kBAAkB,CAAC;IACrC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,KAAK,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,SAAS,CAAC,GAAG;IACpC,OAAO,EAAE,cAAc,CAAC;CACzB,CAAC;AAGF,QAAA,MAAM,SAAS,UAMd,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,KAAK,MAAM,GAAG;KACX,CAAC,IAAI,CAAC,OAAO,SAAS,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,iBAAiB,GAC1D,eAAe,GACf,MAAM;CACX,CAAC;AAGF,KAAK,QAAQ,GAAG;IACd,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,IAAI,CAAC;CACnB,CAAC;AAEF,KAAK,IAAI,CAAC,CAAC,SAAS,aAAa,GAAG,WAAW,IAAI,QAAQ,GAAG,CAAC,CAAC;AAEhE,KAAK,mBAAmB,GAAG;IACzB,sBAAsB,EAAE,MAAM,CAAC;IAC/B,0BAA0B,EAAE,OAAO,CAAC;IACpC,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,gCAAgC,EAAE,MAAM,EAAE,CAAC;IAC3C,oBAAoB,EAAE,MAAM,CAAC;IAC7B,qBAAqB,EAAE,MAAM,EAAE,CAAC;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,8CAA8C,EAAE,OAAO,CAAC;IACxD,wBAAwB,EAAE,MAAM,EAAE,CAAC;IACnC,wBAAwB,EAAE,MAAM,EAAE,CAAC;IACnC,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,uBAAuB,EAAE,MAAM,EAAE,CAAC;IAClC,qCAAqC,EAAE,MAAM,EAAE,CAAC;IAChD,gDAAgD,EAAE,MAAM,EAAE,CAAC;IAC3D,cAAc,EAAE,MAAM,CAAC;IACvB,qCAAqC,EAAE,MAAM,EAAE,CAAC;IAChD,qCAAqC,EAAE,MAAM,CAAC;IAC9C,2BAA2B,EAAE,OAAO,CAAC;IACrC,+BAA+B,EAAE,OAAO,CAAC;IACzC,iBAAiB,EAAE,MAAM,CAAC;IAC1B,qBAAqB,EAAE,MAAM,EAAE,CAAC;CACjC,CAAC;AAEF,KAAK,gBAAgB,GAAG;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE;QACJ,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;CACH,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,MAAM,EAAE,eAAe,CAAC;IACxB,IAAI,EAAE,YAAY,GAAG,sBAAsB,CAAC;IAC5C,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE;QACJ,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;CACH,CAAC;AAEF,YAAY,EACV,gBAAgB,EAChB,kBAAkB,EAClB,YAAY,EACZ,eAAe,EACf,eAAe,EACf,WAAW,EACX,MAAM,EACN,SAAS,EACT,MAAM,EACN,WAAW,EACX,qBAAqB,EACrB,YAAY,EACZ,QAAQ,EACR,IAAI,EACJ,WAAW,EACX,aAAa,EACb,WAAW,EACX,eAAe,EACf,kBAAkB,EAClB,UAAU,EACV,cAAc,EACd,OAAO,EACP,mBAAmB,GACpB,CAAC;AACF,OAAO,EAAE,SAAS,EAAE,CAAC;AACrB,MAAM,WAAW,WAAW;IAC1B,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IACzC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAChD;AAED,MAAM,MAAM,UAAU,GAAG,UAAU,GAAG,OAAO,CAAC"}
package/dist/esm/types.js CHANGED
@@ -7,6 +7,12 @@ export var AuthStatus;
7
7
  AuthStatus["SIGNING_OUT"] = "signing_out";
8
8
  })(AuthStatus || (AuthStatus = {}));
9
9
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
10
- const tokenKeys = ["idToken", "accessToken", "refreshToken", "forwardedTokens"];
10
+ const tokenKeys = [
11
+ "sub",
12
+ "idToken",
13
+ "accessToken",
14
+ "refreshToken",
15
+ "forwardedTokens",
16
+ ];
11
17
  export { tokenKeys };
12
18
  //# sourceMappingURL=types.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAMA,MAAM,CAAN,IAAY,UAMX;AAND,WAAY,UAAU;IACpB,6CAA+B,CAAA;IAC/B,iDAAmC,CAAA;IACnC,+CAAiC,CAAA;IACjC,6BAAe,CAAA;IACf,yCAA2B,CAAA;AAC7B,CAAC,EANW,UAAU,KAAV,UAAU,QAMrB;AA4ID,6DAA6D;AAC7D,MAAM,SAAS,GAAG,CAAC,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,iBAAiB,CAAC,CAAC;AAgGhF,OAAO,EAAE,SAAS,EAAE,CAAC","sourcesContent":["import type { TokenResponseBody } from \"oslo/oauth2\";\nimport type { JWT } from \"oslo/jwt\";\n\ntype UnknownObject = Record<string, unknown>;\ntype EmptyObject = Record<string, never>;\n\nexport enum AuthStatus {\n AUTHENTICATED = \"authenticated\",\n UNAUTHENTICATED = \"unauthenticated\",\n AUTHENTICATING = \"authenticating\",\n ERROR = \"error\",\n SIGNING_OUT = \"signing_out\",\n}\n// Display modes for the auth flow\ntype DisplayMode = \"iframe\" | \"redirect\" | \"new_tab\" | \"custom_tab\";\n\n// Combined Auth and Session Service\ninterface AuthSessionService {\n // TODO DK NOTES: Should be in BrowserAuthSessionService, not relevant on backend\n loadAuthorizationUrl(\n authorizationURL: string,\n displayMode: DisplayMode,\n ): void;\n // TODO DK NOTES: overrideDisplayMode parameter not appropriate here - also - do we need both this and the above in the interface?\n getAuthorizationUrl(\n scopes: string[],\n overrideDisplayMode: DisplayMode,\n nonce?: string,\n ): Promise<string>;\n // TODO DK NOTES: display mode should be in browser version only. Also, do we need this and the above two in the top-level interface?\n signIn(\n displayMode: DisplayMode,\n scopes: string[],\n nonce?: string,\n ): Promise<void>;\n // TODO DK NOTES: Input should be an auth code - do not assume it comes via an url\n tokenExchange(responseUrl: string): Promise<SessionData>;\n // TODO DK NOTES: Should be async for flexibility\n getSessionData(): SessionData;\n // TODO DK NOTES: Should be async for flexibility\n updateSessionData(data: SessionData): void;\n getUserInfoService(): Promise<UserInfoService>;\n}\n\n// Token Service\ninterface TokenService {\n exchangeCodeForTokens(authCode: string): Promise<Tokens>;\n validateIdToken(idToken: string, nonce: string): boolean;\n refreshAccessToken(refreshToken: string): Promise<Tokens>;\n}\n\n// User Info Service\ninterface UserInfoService {\n getUserInfo<T extends UnknownObject>(\n accessToken: string,\n idToken: string | null,\n ): Promise<User<T> | null>;\n}\n\n// Resource Service\ninterface ResourceService {\n getProtectedResource(accessToken: string): Promise<unknown>;\n}\n\n// Auth Request (for internal use in AuthSessionService)\ntype AuthRequest = {\n clientId: string;\n redirectUri: string;\n state: string;\n nonce: string;\n scope: string;\n};\n\ntype Endpoints = {\n jwks: string;\n auth: string;\n token: string;\n userinfo: string;\n challenge?: string;\n endsession: string;\n};\n\ntype Config = {\n oauthServer: string;\n endpoints?: Endpoints;\n};\n\ntype SessionData = {\n authenticated: boolean; // TODO can this be inferred from the presence of the tokens?\n state?: string;\n accessToken?: string;\n refreshToken?: string;\n idToken?: string;\n accessTokenExpiresAt?: number;\n codeVerifier?: string;\n displayMode?: DisplayMode;\n openerUrl?: string;\n};\n\ntype OIDCTokenResponseBody = TokenResponseBody & {\n id_token: string;\n access_token_expires_at?: number;\n};\n\ntype ParsedTokens = {\n id_token: JWTPayload;\n access_token: JWTPayload;\n refresh_token?: string;\n};\n\n// The format we expose to the frontend via hooks\ntype ForwardedTokens = Record<\n string,\n {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n }\n>;\n\n// The format in the JWT payload\ntype ForwardedTokensJWT = Record<\n string,\n {\n id_token?: string;\n access_token?: string;\n refresh_token?: string;\n scope?: string;\n }\n>;\n\ntype JWTPayload = JWT[\"payload\"] & {\n iss: string;\n aud: string;\n sub: string;\n iat: number;\n exp: number;\n};\n\ntype IdTokenPayload = JWTPayload & {\n forwardedTokens?: ForwardedTokensJWT;\n email?: string;\n name?: string;\n picture?: string;\n nonce: string;\n at_hash: string;\n};\n\ntype IdToken = Omit<JWT, \"payload\"> & {\n payload: IdTokenPayload;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst tokenKeys = [\"idToken\", \"accessToken\", \"refreshToken\", \"forwardedTokens\"];\n\nexport type OAuthTokens = {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n};\n// Derive the Tokens type from the array\ntype Tokens = {\n [K in (typeof tokenKeys)[number]]: K extends \"forwardedTokens\"\n ? ForwardedTokens\n : string;\n};\n\n// Base user interface\ntype BaseUser = {\n id: string;\n email?: string;\n name?: string;\n given_name?: string;\n family_name?: string;\n picture?: string;\n updated_at?: Date;\n};\n\ntype User<T extends UnknownObject = EmptyObject> = BaseUser & T;\n\ntype OpenIdConfiguration = {\n authorization_endpoint: string;\n claims_parameter_supported: boolean;\n claims_supported: string[];\n code_challenge_methods_supported: string[];\n end_session_endpoint: string;\n grant_types_supported: string[];\n issuer: string;\n jwks_uri: string;\n authorization_response_iss_parameter_supported: boolean;\n response_modes_supported: string[];\n response_types_supported: string[];\n scopes_supported: string[];\n subject_types_supported: string[];\n token_endpoint_auth_methods_supported: string[];\n token_endpoint_auth_signing_alg_values_supported: string[];\n token_endpoint: string;\n id_token_signing_alg_values_supported: string[];\n pushed_authorization_request_endpoint: string;\n request_parameter_supported: boolean;\n request_uri_parameter_supported: boolean;\n userinfo_endpoint: string;\n claim_types_supported: string[];\n};\n\ntype LoginPostMessage = {\n source: string;\n type: string;\n clientId: string;\n data: {\n url: string;\n };\n};\n\nexport type IframeAuthMessage = {\n source: \"civicloginApp\";\n type: \"auth_error\" | \"auth_error_try_again\";\n clientId: string;\n data: {\n url?: string;\n error?: string;\n };\n};\n\nexport type {\n LoginPostMessage,\n AuthSessionService,\n TokenService,\n UserInfoService,\n ResourceService,\n AuthRequest,\n Tokens,\n Endpoints,\n Config,\n SessionData,\n OIDCTokenResponseBody,\n ParsedTokens,\n BaseUser,\n User,\n DisplayMode,\n UnknownObject,\n EmptyObject,\n ForwardedTokens,\n ForwardedTokensJWT,\n JWTPayload,\n IdTokenPayload,\n IdToken,\n OpenIdConfiguration,\n};\nexport { tokenKeys };\nexport interface AuthStorage {\n get(key: string): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n}\n\nexport type IframeMode = \"embedded\" | \"modal\";\n"]}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAMA,MAAM,CAAN,IAAY,UAMX;AAND,WAAY,UAAU;IACpB,6CAA+B,CAAA;IAC/B,iDAAmC,CAAA;IACnC,+CAAiC,CAAA;IACjC,6BAAe,CAAA;IACf,yCAA2B,CAAA;AAC7B,CAAC,EANW,UAAU,KAAV,UAAU,QAMrB;AA4ID,6DAA6D;AAC7D,MAAM,SAAS,GAAG;IAChB,KAAK;IACL,SAAS;IACT,aAAa;IACb,cAAc;IACd,iBAAiB;CAClB,CAAC;AAgGF,OAAO,EAAE,SAAS,EAAE,CAAC","sourcesContent":["import type { TokenResponseBody } from \"oslo/oauth2\";\nimport type { JWT } from \"oslo/jwt\";\n\ntype UnknownObject = Record<string, unknown>;\ntype EmptyObject = Record<string, never>;\n\nexport enum AuthStatus {\n AUTHENTICATED = \"authenticated\",\n UNAUTHENTICATED = \"unauthenticated\",\n AUTHENTICATING = \"authenticating\",\n ERROR = \"error\",\n SIGNING_OUT = \"signing_out\",\n}\n// Display modes for the auth flow\ntype DisplayMode = \"iframe\" | \"redirect\" | \"new_tab\" | \"custom_tab\";\n\n// Combined Auth and Session Service\ninterface AuthSessionService {\n // TODO DK NOTES: Should be in BrowserAuthSessionService, not relevant on backend\n loadAuthorizationUrl(\n authorizationURL: string,\n displayMode: DisplayMode,\n ): void;\n // TODO DK NOTES: overrideDisplayMode parameter not appropriate here - also - do we need both this and the above in the interface?\n getAuthorizationUrl(\n scopes: string[],\n overrideDisplayMode: DisplayMode,\n nonce?: string,\n ): Promise<string>;\n // TODO DK NOTES: display mode should be in browser version only. Also, do we need this and the above two in the top-level interface?\n signIn(\n displayMode: DisplayMode,\n scopes: string[],\n nonce?: string,\n ): Promise<void>;\n // TODO DK NOTES: Input should be an auth code - do not assume it comes via an url\n tokenExchange(responseUrl: string): Promise<SessionData>;\n // TODO DK NOTES: Should be async for flexibility\n getSessionData(): SessionData;\n // TODO DK NOTES: Should be async for flexibility\n updateSessionData(data: SessionData): void;\n getUserInfoService(): Promise<UserInfoService>;\n}\n\n// Token Service\ninterface TokenService {\n exchangeCodeForTokens(authCode: string): Promise<Tokens>;\n validateIdToken(idToken: string, nonce: string): boolean;\n refreshAccessToken(refreshToken: string): Promise<Tokens>;\n}\n\n// User Info Service\ninterface UserInfoService {\n getUserInfo<T extends UnknownObject>(\n accessToken: string,\n idToken: string | null,\n ): Promise<User<T> | null>;\n}\n\n// Resource Service\ninterface ResourceService {\n getProtectedResource(accessToken: string): Promise<unknown>;\n}\n\n// Auth Request (for internal use in AuthSessionService)\ntype AuthRequest = {\n clientId: string;\n redirectUri: string;\n state: string;\n nonce: string;\n scope: string;\n};\n\ntype Endpoints = {\n jwks: string;\n auth: string;\n token: string;\n userinfo: string;\n challenge?: string;\n endsession: string;\n};\n\ntype Config = {\n oauthServer: string;\n endpoints?: Endpoints;\n};\n\ntype SessionData = {\n authenticated: boolean; // TODO can this be inferred from the presence of the tokens?\n state?: string;\n accessToken?: string;\n refreshToken?: string;\n idToken?: string;\n accessTokenExpiresAt?: number;\n codeVerifier?: string;\n displayMode?: DisplayMode;\n openerUrl?: string;\n};\n\ntype OIDCTokenResponseBody = TokenResponseBody & {\n id_token: string;\n access_token_expires_at?: number;\n};\n\ntype ParsedTokens = {\n id_token: JWTPayload;\n access_token: JWTPayload;\n refresh_token?: string;\n};\n\n// The format we expose to the frontend via hooks\ntype ForwardedTokens = Record<\n string,\n {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n }\n>;\n\n// The format in the JWT payload\ntype ForwardedTokensJWT = Record<\n string,\n {\n id_token?: string;\n access_token?: string;\n refresh_token?: string;\n scope?: string;\n }\n>;\n\ntype JWTPayload = JWT[\"payload\"] & {\n iss: string;\n aud: string;\n sub: string;\n iat: number;\n exp: number;\n};\n\ntype IdTokenPayload = JWTPayload & {\n forwardedTokens?: ForwardedTokensJWT;\n email?: string;\n name?: string;\n picture?: string;\n nonce: string;\n at_hash: string;\n};\n\ntype IdToken = Omit<JWT, \"payload\"> & {\n payload: IdTokenPayload;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst tokenKeys = [\n \"sub\",\n \"idToken\",\n \"accessToken\",\n \"refreshToken\",\n \"forwardedTokens\",\n];\n\nexport type OAuthTokens = {\n idToken?: string;\n accessToken?: string;\n refreshToken?: string;\n};\n// Derive the Tokens type from the array\ntype Tokens = {\n [K in (typeof tokenKeys)[number]]: K extends \"forwardedTokens\"\n ? ForwardedTokens\n : string;\n};\n\n// Base user interface\ntype BaseUser = {\n id: string;\n email?: string;\n name?: string;\n given_name?: string;\n family_name?: string;\n picture?: string;\n updated_at?: Date;\n};\n\ntype User<T extends UnknownObject = EmptyObject> = BaseUser & T;\n\ntype OpenIdConfiguration = {\n authorization_endpoint: string;\n claims_parameter_supported: boolean;\n claims_supported: string[];\n code_challenge_methods_supported: string[];\n end_session_endpoint: string;\n grant_types_supported: string[];\n issuer: string;\n jwks_uri: string;\n authorization_response_iss_parameter_supported: boolean;\n response_modes_supported: string[];\n response_types_supported: string[];\n scopes_supported: string[];\n subject_types_supported: string[];\n token_endpoint_auth_methods_supported: string[];\n token_endpoint_auth_signing_alg_values_supported: string[];\n token_endpoint: string;\n id_token_signing_alg_values_supported: string[];\n pushed_authorization_request_endpoint: string;\n request_parameter_supported: boolean;\n request_uri_parameter_supported: boolean;\n userinfo_endpoint: string;\n claim_types_supported: string[];\n};\n\ntype LoginPostMessage = {\n source: string;\n type: string;\n clientId: string;\n data: {\n url: string;\n };\n};\n\nexport type IframeAuthMessage = {\n source: \"civicloginApp\";\n type: \"auth_error\" | \"auth_error_try_again\";\n clientId: string;\n data: {\n url?: string;\n error?: string;\n };\n};\n\nexport type {\n LoginPostMessage,\n AuthSessionService,\n TokenService,\n UserInfoService,\n ResourceService,\n AuthRequest,\n Tokens,\n Endpoints,\n Config,\n SessionData,\n OIDCTokenResponseBody,\n ParsedTokens,\n BaseUser,\n User,\n DisplayMode,\n UnknownObject,\n EmptyObject,\n ForwardedTokens,\n ForwardedTokensJWT,\n JWTPayload,\n IdTokenPayload,\n IdToken,\n OpenIdConfiguration,\n};\nexport { tokenKeys };\nexport interface AuthStorage {\n get(key: string): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n}\n\nexport type IframeMode = \"embedded\" | \"modal\";\n"]}
@@ -6,10 +6,10 @@
6
6
  *
7
7
  * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.
8
8
  */
9
- declare const isPopupBlocked: () => boolean;
9
+ export declare const isPopupBlocked: () => boolean;
10
10
  type WithoutUndefined<T> = {
11
11
  [K in keyof T as undefined extends T[K] ? never : K]: T[K];
12
12
  };
13
13
  export declare const withoutUndefined: <T extends { [K in keyof T]: unknown; }>(obj: T) => WithoutUndefined<T>;
14
- export { isPopupBlocked };
14
+ export {};
15
15
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,QAAA,MAAM,cAAc,QAAO,OAsB1B,CAAC;AAOF,KAAK,gBAAgB,CAAC,CAAC,IAAI;KACxB,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC3D,CAAC;AACF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,GAAG,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,GAAE,OAC/D,CAAC,KACL,gBAAgB,CAAC,CAAC,CAapB,CAAC;AAEF,OAAO,EAAE,cAAc,EAAE,CAAC"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,eAAO,MAAM,cAAc,QAAO,OAsBjC,CAAC;AAOF,KAAK,gBAAgB,CAAC,CAAC,IAAI;KACxB,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC3D,CAAC;AACF,eAAO,MAAM,gBAAgB,GAAI,CAAC,SAAS,GAAG,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,GAAE,OAC/D,CAAC,KACL,gBAAgB,CAAC,CAAC,CAapB,CAAC"}
package/dist/esm/utils.js CHANGED
@@ -6,7 +6,7 @@
6
6
  *
7
7
  * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.
8
8
  */
9
- const isPopupBlocked = () => {
9
+ export const isPopupBlocked = () => {
10
10
  // First we try to open a small popup window. It either returns a window object or null.
11
11
  const popup = window.open("", "", "width=1,height=1");
12
12
  // If window.open() returns null, popup is definitely blocked
@@ -39,5 +39,4 @@ export const withoutUndefined = (obj) => {
39
39
  }
40
40
  return result;
41
41
  };
42
- export { isPopupBlocked };
43
42
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,MAAM,cAAc,GAAG,GAAY,EAAE;IACnC,wFAAwF;IACxF,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC;IAEtD,6DAA6D;IAC7D,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,CAAC;QACH,gEAAgE;QAChE,IAAI,OAAO,KAAK,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;YACxC,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,2EAA2E;QAC3E,OAAO,IAAI,CAAC;IACd,CAAC;IAED,+CAA+C;IAC/C,KAAK,CAAC,KAAK,EAAE,CAAC;IACd,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAUF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,GAAM,EACe,EAAE;IACvB,MAAM,MAAM,GAAG,EAAyB,CAAC;IAEzC,KAAK,MAAM,GAAG,IAAI,GAAG,EAAE,CAAC;QACtB,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,SAAS,EAAE,CAAC;YAC3B,4EAA4E;YAC5E,6BAA6B;YAC7B,8DAA8D;YAC7D,MAAc,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AAEF,OAAO,EAAE,cAAc,EAAE,CAAC","sourcesContent":["/**\n * Checks if a popup window is blocked by the browser.\n *\n * This function attempts to open a small popup window and then checks if it was successfully created.\n * If the popup is blocked by the browser, the function returns `true`. Otherwise, it returns `false`.\n *\n * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.\n */\nconst isPopupBlocked = (): boolean => {\n // First we try to open a small popup window. It either returns a window object or null.\n const popup = window.open(\"\", \"\", \"width=1,height=1\");\n\n // If window.open() returns null, popup is definitely blocked\n if (!popup) {\n return true;\n }\n\n try {\n // Try to access a property of the popup to check if it's usable\n if (typeof popup.closed === \"undefined\") {\n throw new Error(\"Popup is blocked\");\n }\n } catch {\n // Accessing the popup's properties throws an error if the popup is blocked\n return true;\n }\n\n // Close the popup immediately if it was opened\n popup.close();\n return false;\n};\n\n// This type narrows T as far as it can by:\n// - removing all keys where the value is `undefined`\n// - making keys that are not undefined required\n// So, for example: given { a: string | undefined, b: string | undefined },\n// if you pass in { a: \"foo\" }, it returns an object of type: { a: string }\ntype WithoutUndefined<T> = {\n [K in keyof T as undefined extends T[K] ? never : K]: T[K];\n};\nexport const withoutUndefined = <T extends { [K in keyof T]: unknown }>(\n obj: T,\n): WithoutUndefined<T> => {\n const result = {} as WithoutUndefined<T>;\n\n for (const key in obj) {\n if (obj[key] !== undefined) {\n // TypeScript needs assurance that key is a valid key in WithoutUndefined<T>\n // We use type assertion here\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (result as any)[key] = obj[key];\n }\n }\n\n return result;\n};\n\nexport { isPopupBlocked };\n"]}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,GAAY,EAAE;IAC1C,wFAAwF;IACxF,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,kBAAkB,CAAC,CAAC;IAEtD,6DAA6D;IAC7D,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,CAAC;QACH,gEAAgE;QAChE,IAAI,OAAO,KAAK,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;YACxC,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,2EAA2E;QAC3E,OAAO,IAAI,CAAC;IACd,CAAC;IAED,+CAA+C;IAC/C,KAAK,CAAC,KAAK,EAAE,CAAC;IACd,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAUF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,GAAM,EACe,EAAE;IACvB,MAAM,MAAM,GAAG,EAAyB,CAAC;IAEzC,KAAK,MAAM,GAAG,IAAI,GAAG,EAAE,CAAC;QACtB,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,SAAS,EAAE,CAAC;YAC3B,4EAA4E;YAC5E,6BAA6B;YAC7B,8DAA8D;YAC7D,MAAc,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC","sourcesContent":["/**\n * Checks if a popup window is blocked by the browser.\n *\n * This function attempts to open a small popup window and then checks if it was successfully created.\n * If the popup is blocked by the browser, the function returns `true`. Otherwise, it returns `false`.\n *\n * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.\n */\nexport const isPopupBlocked = (): boolean => {\n // First we try to open a small popup window. It either returns a window object or null.\n const popup = window.open(\"\", \"\", \"width=1,height=1\");\n\n // If window.open() returns null, popup is definitely blocked\n if (!popup) {\n return true;\n }\n\n try {\n // Try to access a property of the popup to check if it's usable\n if (typeof popup.closed === \"undefined\") {\n throw new Error(\"Popup is blocked\");\n }\n } catch {\n // Accessing the popup's properties throws an error if the popup is blocked\n return true;\n }\n\n // Close the popup immediately if it was opened\n popup.close();\n return false;\n};\n\n// This type narrows T as far as it can by:\n// - removing all keys where the value is `undefined`\n// - making keys that are not undefined required\n// So, for example: given { a: string | undefined, b: string | undefined },\n// if you pass in { a: \"foo\" }, it returns an object of type: { a: string }\ntype WithoutUndefined<T> = {\n [K in keyof T as undefined extends T[K] ? never : K]: T[K];\n};\nexport const withoutUndefined = <T extends { [K in keyof T]: unknown }>(\n obj: T,\n): WithoutUndefined<T> => {\n const result = {} as WithoutUndefined<T>;\n\n for (const key in obj) {\n if (obj[key] !== undefined) {\n // TypeScript needs assurance that key is a valid key in WithoutUndefined<T>\n // We use type assertion here\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (result as any)[key] = obj[key];\n }\n }\n\n return result;\n};\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=generateVersion.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generateVersion.d.ts","sourceRoot":"","sources":["../generateVersion.ts"],"names":[],"mappings":""}
@@ -0,0 +1,12 @@
1
+ import { writeFileSync, readFileSync } from "fs";
2
+ // Get the path to package.json and output location from the command line arguments
3
+ const packageJsonPath = "./package.json";
4
+ const outputPath = "./src/shared/version.ts";
5
+ // Read the package.json and extract the version
6
+ const packageJsonContent = readFileSync(packageJsonPath, "utf-8");
7
+ const { version, name } = JSON.parse(packageJsonContent);
8
+ // Generate the TypeScript content
9
+ const content = `// This is an auto-generated file. Do not edit.\n\nexport const VERSION = "${name}:${version}";\n`;
10
+ // Write to the specified output file
11
+ writeFileSync(outputPath, content);
12
+ //# sourceMappingURL=generateVersion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generateVersion.js","sourceRoot":"","sources":["../generateVersion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAEjD,mFAAmF;AACnF,MAAM,eAAe,GAAG,gBAAgB,CAAC;AACzC,MAAM,UAAU,GAAG,yBAAyB,CAAC;AAE7C,gDAAgD;AAChD,MAAM,kBAAkB,GAAG,YAAY,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;AAClE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;AAEzD,kCAAkC;AAClC,MAAM,OAAO,GAAG,8EAA8E,IAAI,IAAI,OAAO,MAAM,CAAC;AAEpH,qCAAqC;AACrC,aAAa,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC","sourcesContent":["import { writeFileSync, readFileSync } from \"fs\";\n\n// Get the path to package.json and output location from the command line arguments\nconst packageJsonPath = \"./package.json\";\nconst outputPath = \"./src/shared/version.ts\";\n\n// Read the package.json and extract the version\nconst packageJsonContent = readFileSync(packageJsonPath, \"utf-8\");\nconst { version, name } = JSON.parse(packageJsonContent);\n\n// Generate the TypeScript content\nconst content = `// This is an auto-generated file. Do not edit.\\n\\nexport const VERSION = \"${name}:${version}\";\\n`;\n\n// Write to the specified output file\nwriteFileSync(outputPath, content);\n"]}
@@ -0,0 +1,118 @@
1
+ {
2
+ "name": "@civic/auth",
3
+ "version": "0.1.6-beta.0",
4
+ "type": "module",
5
+ "main": "./dist/cjs/index.js",
6
+ "module": "./dist/esm/index.js",
7
+ "types": "./dist/esm/index.d.ts",
8
+ "files": [
9
+ "dist",
10
+ "README.md",
11
+ "CHANGELOG.md"
12
+ ],
13
+ "exports": {
14
+ ".": {
15
+ "import": {
16
+ "types": "./dist/esm/index.d.ts",
17
+ "default": "./dist/esm/index.js"
18
+ },
19
+ "require": {
20
+ "types": "./dist/cjs/index.d.ts",
21
+ "default": "./dist/cjs/index.js"
22
+ }
23
+ },
24
+ "./react": {
25
+ "import": {
26
+ "types": "./dist/esm/reactjs/index.d.ts",
27
+ "default": "./dist/esm/reactjs/index.js"
28
+ },
29
+ "require": {
30
+ "types": "./dist/cjs/reactjs/index.d.ts",
31
+ "default": "./dist/cjs/reactjs/index.js"
32
+ }
33
+ },
34
+ "./nextjs": {
35
+ "import": {
36
+ "types": "./dist/esm/nextjs/index.d.ts",
37
+ "default": "./dist/esm/nextjs/index.js"
38
+ },
39
+ "require": {
40
+ "types": "./dist/cjs/nextjs/index.d.ts",
41
+ "default": "./dist/cjs/nextjs/index.js"
42
+ }
43
+ },
44
+ "./nextjs/middleware": {
45
+ "import": {
46
+ "types": "./dist/esm/nextjs/middleware/index.d.ts",
47
+ "default": "./dist/esm/nextjs/middleware/index.js"
48
+ },
49
+ "require": {
50
+ "types": "./dist/cjs/nextjs/middleware/index.d.ts",
51
+ "default": "./dist/cjs/nextjs/middleware/index.js"
52
+ }
53
+ },
54
+ "./server": {
55
+ "import": {
56
+ "types": "./dist/esm/server/index.d.ts",
57
+ "default": "./dist/esm/server/index.js"
58
+ },
59
+ "require": {
60
+ "types": "./dist/cjs/server/index.d.ts",
61
+ "default": "./dist/cjs/server/index.js"
62
+ }
63
+ }
64
+ },
65
+ "scripts": {
66
+ "prebuild": "rm -rf dist && pnpm generate-version",
67
+ "build": "pnpm build:cjs && pnpm build:esm",
68
+ "build:cjs": "tsc -p tsconfig.cjs.json --noEmit false && tsc-alias -p tsconfig.cjs.json",
69
+ "build:esm": "tsc -p tsconfig.esm.json --noEmit false && tsc-alias -p tsconfig.esm.json",
70
+ "prepublishOnly": "pnpm generate-version && node ../../etc/scripts/prompt-changelog.js && pnpm build",
71
+ "dev": "tsc --watch",
72
+ "pretest": "pnpm generate-version",
73
+ "test": "vitest",
74
+ "lint": "eslint \"src/**/*.ts*\" --max-warnings 0",
75
+ "lint:fix": "pnpm lint --fix",
76
+ "test:update": "vitest --update",
77
+ "generate-version": "npx tsx ./generateVersion.ts"
78
+ },
79
+ "dependencies": {
80
+ "debug": "^4.3.7",
81
+ "eventemitter3": "^5.0.1",
82
+ "jose": "^5.9.4",
83
+ "oslo": "^1.2.1",
84
+ "picomatch": "^4.0.2",
85
+ "uuid": "^10.0.0"
86
+ },
87
+ "devDependencies": {
88
+ "@repo/eslint-config": "workspace:*",
89
+ "@repo/typescript-config": "workspace:*",
90
+ "@rollup/plugin-typescript": "^12.1.1",
91
+ "@testing-library/jest-dom": "^6.5.0",
92
+ "@testing-library/react": "16.0.1",
93
+ "@types/debug": "^4.1.12",
94
+ "@types/node": "^22.7.4",
95
+ "@types/picomatch": "^3.0.1",
96
+ "@types/react": "18.3.11",
97
+ "@types/react-dom": "18.3.0",
98
+ "@types/uuid": "^10.0.0",
99
+ "@vitejs/plugin-react": "4.3.2",
100
+ "esbuild-plugin-css-modules": "^0.3.0",
101
+ "eslint": "^8.57.1",
102
+ "eslint-plugin-require-extensions": "^0.1.3",
103
+ "next": "14.2.15",
104
+ "prettier": "^3.3.3",
105
+ "react": "18.3.1",
106
+ "react-dom": "18.3.1",
107
+ "ts-jest": "^29.2.5",
108
+ "tsc-alias": "^1.8.10",
109
+ "tsup": "^8.3.0",
110
+ "tsx": "^4.19.1",
111
+ "vite": "^5",
112
+ "vite-plugin-dts": "^4.2.3",
113
+ "vitest": "^2.1.8"
114
+ },
115
+ "optionalDependency": {
116
+ "next": "^14"
117
+ }
118
+ }
@@ -0,0 +1,9 @@
1
+ import type { AuthStorage } from "@/types.js";
2
+ import { EventEmitter } from "eventemitter3";
3
+ export declare class LocalStorageAdapter implements AuthStorage {
4
+ static _emitter: EventEmitter;
5
+ static get emitter(): EventEmitter;
6
+ get(key: string): Promise<string>;
7
+ set(key: string, value: string): Promise<void>;
8
+ }
9
+ //# 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;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7C,qBAAa,mBAAoB,YAAW,WAAW;IACrD,MAAM,CAAC,QAAQ,EAAE,YAAY,CAAC;IAC9B,MAAM,KAAK,OAAO,IAAI,YAAY,CAKjC;IACK,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,17 @@
1
+ import { EventEmitter } from "eventemitter3";
2
+ export class LocalStorageAdapter {
3
+ static _emitter;
4
+ static get emitter() {
5
+ if (!LocalStorageAdapter._emitter) {
6
+ LocalStorageAdapter._emitter = new EventEmitter();
7
+ }
8
+ return LocalStorageAdapter._emitter;
9
+ }
10
+ async get(key) {
11
+ return Promise.resolve(localStorage.getItem(key) || "");
12
+ }
13
+ async set(key, value) {
14
+ localStorage.setItem(key, value);
15
+ }
16
+ }
17
+ //# sourceMappingURL=storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"storage.js","sourceRoot":"","sources":["../../../src/browser/storage.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7C,MAAM,OAAO,mBAAmB;IAC9B,MAAM,CAAC,QAAQ,CAAe;IAC9B,MAAM,KAAK,OAAO;QAChB,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,CAAC;YAClC,mBAAmB,CAAC,QAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QACpD,CAAC;QACD,OAAO,mBAAmB,CAAC,QAAQ,CAAC;IACtC,CAAC;IACD,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\";\nimport { EventEmitter } from \"eventemitter3\";\n\nexport class LocalStorageAdapter implements AuthStorage {\n static _emitter: EventEmitter;\n static get emitter(): EventEmitter {\n if (!LocalStorageAdapter._emitter) {\n LocalStorageAdapter._emitter = new EventEmitter();\n }\n return LocalStorageAdapter._emitter;\n }\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,8 @@
1
+ declare const DEFAULT_SCOPES: string[];
2
+ declare const DEFAULT_AUTH_SERVER = "https://auth.civic.com/oauth";
3
+ declare const DEFAULT_OAUTH_GET_PARAMS: string[];
4
+ declare const TOKEN_EXCHANGE_TRIGGER_TEXT = "sameDomainCodeExchangeRequired";
5
+ declare const TOKEN_EXCHANGE_SUCCESS_TEXT = "serverSideTokenExchangeSuccess";
6
+ declare const DEFAULT_DISPLAY_MODE = "iframe";
7
+ export { DEFAULT_SCOPES, DEFAULT_OAUTH_GET_PARAMS, DEFAULT_DISPLAY_MODE, DEFAULT_AUTH_SERVER, TOKEN_EXCHANGE_TRIGGER_TEXT, TOKEN_EXCHANGE_SUCCESS_TEXT, };
8
+ //# 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,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,mBAAmB,EACnB,2BAA2B,EAC3B,2BAA2B,GAC5B,CAAC"}
@@ -0,0 +1,16 @@
1
+ const DEFAULT_SCOPES = [
2
+ "openid",
3
+ "profile",
4
+ "email",
5
+ "forwardedTokens",
6
+ "offline_access",
7
+ ];
8
+ const DEFAULT_AUTH_SERVER = "https://auth.civic.com/oauth";
9
+ const DEFAULT_OAUTH_GET_PARAMS = ["code", "state", "iss"];
10
+ // The server's callback handler renders this text if it needs the front-end to make an additional token exchange call,
11
+ // for the iframe case where cookies are not sent along with the initial redirect.
12
+ const TOKEN_EXCHANGE_TRIGGER_TEXT = "sameDomainCodeExchangeRequired";
13
+ const TOKEN_EXCHANGE_SUCCESS_TEXT = "serverSideTokenExchangeSuccess";
14
+ const DEFAULT_DISPLAY_MODE = "iframe";
15
+ export { DEFAULT_SCOPES, DEFAULT_OAUTH_GET_PARAMS, DEFAULT_DISPLAY_MODE, DEFAULT_AUTH_SERVER, TOKEN_EXCHANGE_TRIGGER_TEXT, TOKEN_EXCHANGE_SUCCESS_TEXT, };
16
+ //# 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,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,mBAAmB,EACnB,2BAA2B,EAC3B,2BAA2B,GAC5B,CAAC","sourcesContent":["const DEFAULT_SCOPES = [\n \"openid\",\n \"profile\",\n \"email\",\n \"forwardedTokens\",\n \"offline_access\",\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 DEFAULT_AUTH_SERVER,\n TOKEN_EXCHANGE_TRIGGER_TEXT,\n TOKEN_EXCHANGE_SUCCESS_TEXT,\n};\n"]}
@@ -0,0 +1,6 @@
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
+ import { VERSION } from "@/shared/index.js";
5
+ export { VERSION };
6
+ //# 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;AAC1E,OAAO,EAAE,OAAO,EAAgB,MAAM,mBAAmB,CAAC;AAE1D,OAAO,EAAE,OAAO,EAAE,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { VERSION, printVersion } from "@/shared/index.js";
2
+ printVersion();
3
+ export { VERSION };
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAC1D,YAAY,EAAE,CAAC;AACf,OAAO,EAAE,OAAO,EAAE,CAAC","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\";\nimport { VERSION, printVersion } from \"@/shared/index.js\";\nprintVersion();\nexport { VERSION };\n"]}
@@ -0,0 +1,7 @@
1
+ declare const getWindowCookieValue: (requests: {
2
+ key: string;
3
+ window: Window;
4
+ parseJson?: boolean;
5
+ }[]) => Record<string, string | Record<string, unknown>> | null;
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,aACd;IACR,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,EAAE,4DAqBJ,CAAC;AACF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
@@ -0,0 +1,25 @@
1
+ const getWindowCookieValue = (requests) => {
2
+ const cookie = window.document.cookie;
3
+ if (!cookie)
4
+ return null;
5
+ const cookies = cookie.split(";");
6
+ const response = {};
7
+ for (const c of cookies) {
8
+ const [name, value] = c.trim().split("=");
9
+ const request = requests.find((r) => r.key === name);
10
+ if (value && request) {
11
+ try {
12
+ const decodeURIComponentValue = decodeURIComponent(value);
13
+ response[request.key] = request.parseJson
14
+ ? JSON.parse(decodeURIComponentValue)
15
+ : decodeURIComponentValue;
16
+ }
17
+ catch {
18
+ response[request.key] = value;
19
+ }
20
+ }
21
+ }
22
+ return response;
23
+ };
24
+ export { getWindowCookieValue };
25
+ //# 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,CAC3B,QAIG,EACH,EAAE;IACF,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,MAAM,QAAQ,GAAqD,EAAE,CAAC;IACtE,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,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC;QACrD,IAAI,KAAK,IAAI,OAAO,EAAE,CAAC;YACrB,IAAI,CAAC;gBACH,MAAM,uBAAuB,GAAG,kBAAkB,CAAC,KAAK,CAAC,CAAC;gBAC1D,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,SAAS;oBACvC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,uBAAuB,CAAC;oBACrC,CAAC,CAAC,uBAAuB,CAAC;YAC9B,CAAC;YAAC,MAAM,CAAC;gBACP,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YAChC,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC,CAAC;AACF,OAAO,EAAE,oBAAoB,EAAE,CAAC","sourcesContent":["const getWindowCookieValue = (\n requests: {\n key: string;\n window: Window;\n parseJson?: boolean;\n }[],\n) => {\n const cookie = window.document.cookie;\n if (!cookie) return null;\n const cookies = cookie.split(\";\");\n const response: Record<string, string | Record<string, unknown>> = {};\n for (const c of cookies) {\n const [name, value] = c.trim().split(\"=\");\n const request = requests.find((r) => r.key === name);\n if (value && request) {\n try {\n const decodeURIComponentValue = decodeURIComponent(value);\n response[request.key] = request.parseJson\n ? JSON.parse(decodeURIComponentValue)\n : decodeURIComponentValue;\n } catch {\n response[request.key] = value;\n }\n }\n }\n return response;\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,CAavE,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"}