@civic/auth 0.0.1--.tsc.alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (744) hide show
  1. package/.eslintignore +3 -0
  2. package/.eslintrc.json +10 -0
  3. package/.prettierignore +3 -0
  4. package/.prettierrc +4 -0
  5. package/.turbo/turbo-build.log +13 -0
  6. package/.turbo/turbo-lint.log +6 -0
  7. package/.turbo/turbo-test.log +2415 -0
  8. package/README.md +202 -0
  9. package/civic-auth-0.0.1-beta.21.tgz +0 -0
  10. package/dist/cjs/src/browser/storage.d.ts +6 -0
  11. package/dist/cjs/src/browser/storage.d.ts.map +1 -0
  12. package/dist/cjs/src/browser/storage.js +13 -0
  13. package/dist/cjs/src/browser/storage.js.map +1 -0
  14. package/dist/cjs/src/config.d.ts +3 -0
  15. package/dist/cjs/src/config.d.ts.map +1 -0
  16. package/dist/cjs/src/config.js +8 -0
  17. package/dist/cjs/src/config.js.map +1 -0
  18. package/dist/cjs/src/constants.d.ts +9 -0
  19. package/dist/cjs/src/constants.d.ts.map +1 -0
  20. package/dist/cjs/src/constants.js +26 -0
  21. package/dist/cjs/src/constants.js.map +1 -0
  22. package/dist/cjs/src/index.d.ts +5 -0
  23. package/dist/cjs/src/index.d.ts.map +1 -0
  24. package/dist/cjs/src/index.js +5 -0
  25. package/dist/cjs/src/index.js.map +1 -0
  26. package/dist/cjs/src/lib/cookies.d.ts +7 -0
  27. package/dist/cjs/src/lib/cookies.d.ts.map +1 -0
  28. package/dist/cjs/src/lib/cookies.js +26 -0
  29. package/dist/cjs/src/lib/cookies.js.map +1 -0
  30. package/dist/cjs/src/lib/jwt.d.ts +3 -0
  31. package/dist/cjs/src/lib/jwt.d.ts.map +1 -0
  32. package/dist/cjs/src/lib/jwt.js +13 -0
  33. package/dist/cjs/src/lib/jwt.js.map +1 -0
  34. package/dist/cjs/src/lib/logger.d.ts +26 -0
  35. package/dist/cjs/src/lib/logger.d.ts.map +1 -0
  36. package/dist/cjs/src/lib/logger.js +62 -0
  37. package/dist/cjs/src/lib/logger.js.map +1 -0
  38. package/dist/cjs/src/lib/oauth.d.ts +19 -0
  39. package/dist/cjs/src/lib/oauth.d.ts.map +1 -0
  40. package/dist/cjs/src/lib/oauth.js +67 -0
  41. package/dist/cjs/src/lib/oauth.js.map +1 -0
  42. package/dist/cjs/src/lib/postMessage.d.ts +4 -0
  43. package/dist/cjs/src/lib/postMessage.d.ts.map +1 -0
  44. package/dist/cjs/src/lib/postMessage.js +18 -0
  45. package/dist/cjs/src/lib/postMessage.js.map +1 -0
  46. package/dist/cjs/src/lib/windowUtil.d.ts +4 -0
  47. package/dist/cjs/src/lib/windowUtil.d.ts.map +1 -0
  48. package/dist/cjs/src/lib/windowUtil.js +34 -0
  49. package/dist/cjs/src/lib/windowUtil.js.map +1 -0
  50. package/dist/cjs/src/nextjs/GetUser.d.ts +6 -0
  51. package/dist/cjs/src/nextjs/GetUser.d.ts.map +1 -0
  52. package/dist/cjs/src/nextjs/GetUser.js +22 -0
  53. package/dist/cjs/src/nextjs/GetUser.js.map +1 -0
  54. package/dist/cjs/src/nextjs/client/index.d.ts +2 -0
  55. package/dist/cjs/src/nextjs/client/index.d.ts.map +1 -0
  56. package/dist/cjs/src/nextjs/client/index.js +6 -0
  57. package/dist/cjs/src/nextjs/client/index.js.map +1 -0
  58. package/dist/cjs/src/nextjs/config.d.ts +180 -0
  59. package/dist/cjs/src/nextjs/config.d.ts.map +1 -0
  60. package/dist/cjs/src/nextjs/config.js +163 -0
  61. package/dist/cjs/src/nextjs/config.js.map +1 -0
  62. package/dist/cjs/src/nextjs/cookies.d.ts +30 -0
  63. package/dist/cjs/src/nextjs/cookies.d.ts.map +1 -0
  64. package/dist/cjs/src/nextjs/cookies.js +116 -0
  65. package/dist/cjs/src/nextjs/cookies.js.map +1 -0
  66. package/dist/cjs/src/nextjs/hooks/index.d.ts +2 -0
  67. package/dist/cjs/src/nextjs/hooks/index.d.ts.map +1 -0
  68. package/dist/cjs/src/nextjs/hooks/index.js +6 -0
  69. package/dist/cjs/src/nextjs/hooks/index.js.map +1 -0
  70. package/dist/cjs/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
  71. package/dist/cjs/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
  72. package/dist/cjs/src/nextjs/hooks/useTokenCookie.js +41 -0
  73. package/dist/cjs/src/nextjs/hooks/useTokenCookie.js.map +1 -0
  74. package/dist/cjs/src/nextjs/hooks/useUserCookie.d.ts +3 -0
  75. package/dist/cjs/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  76. package/dist/cjs/src/nextjs/hooks/useUserCookie.js +40 -0
  77. package/dist/cjs/src/nextjs/hooks/useUserCookie.js.map +1 -0
  78. package/dist/cjs/src/nextjs/index.d.ts +7 -0
  79. package/dist/cjs/src/nextjs/index.d.ts.map +1 -0
  80. package/dist/cjs/src/nextjs/index.js +20 -0
  81. package/dist/cjs/src/nextjs/index.js.map +1 -0
  82. package/dist/cjs/src/nextjs/middleware/index.d.ts +2 -0
  83. package/dist/cjs/src/nextjs/middleware/index.d.ts.map +1 -0
  84. package/dist/cjs/src/nextjs/middleware/index.js +8 -0
  85. package/dist/cjs/src/nextjs/middleware/index.js.map +1 -0
  86. package/dist/cjs/src/nextjs/middleware.d.ts +59 -0
  87. package/dist/cjs/src/nextjs/middleware.d.ts.map +1 -0
  88. package/dist/cjs/src/nextjs/middleware.js +116 -0
  89. package/dist/cjs/src/nextjs/middleware.js.map +1 -0
  90. package/dist/cjs/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
  91. package/dist/cjs/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  92. package/dist/cjs/src/nextjs/providers/NextAuthProvider.js +77 -0
  93. package/dist/cjs/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  94. package/dist/cjs/src/nextjs/routeHandler.d.ts +18 -0
  95. package/dist/cjs/src/nextjs/routeHandler.d.ts.map +1 -0
  96. package/dist/cjs/src/nextjs/routeHandler.js +208 -0
  97. package/dist/cjs/src/nextjs/routeHandler.js.map +1 -0
  98. package/dist/cjs/src/nextjs/utils.d.ts +3 -0
  99. package/dist/cjs/src/nextjs/utils.d.ts.map +1 -0
  100. package/dist/cjs/src/nextjs/utils.js +10 -0
  101. package/dist/cjs/src/nextjs/utils.js.map +1 -0
  102. package/dist/cjs/src/nextjs/worker/index.d.ts +2 -0
  103. package/dist/cjs/src/nextjs/worker/index.d.ts.map +1 -0
  104. package/dist/cjs/src/nextjs/worker/index.js +8 -0
  105. package/dist/cjs/src/nextjs/worker/index.js.map +1 -0
  106. package/dist/cjs/src/reactjs/components/NextLogOut.d.ts +7 -0
  107. package/dist/cjs/src/reactjs/components/NextLogOut.d.ts.map +1 -0
  108. package/dist/cjs/src/reactjs/components/NextLogOut.js +18 -0
  109. package/dist/cjs/src/reactjs/components/NextLogOut.js.map +1 -0
  110. package/dist/cjs/src/reactjs/components/SignInButton.d.ts +8 -0
  111. package/dist/cjs/src/reactjs/components/SignInButton.d.ts.map +1 -0
  112. package/dist/cjs/src/reactjs/components/SignInButton.js +16 -0
  113. package/dist/cjs/src/reactjs/components/SignInButton.js.map +1 -0
  114. package/dist/cjs/src/reactjs/components/SignOutButton.d.ts +6 -0
  115. package/dist/cjs/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  116. package/dist/cjs/src/reactjs/components/SignOutButton.js +16 -0
  117. package/dist/cjs/src/reactjs/components/SignOutButton.js.map +1 -0
  118. package/dist/cjs/src/reactjs/components/UserButton.d.ts +8 -0
  119. package/dist/cjs/src/reactjs/components/UserButton.d.ts.map +1 -0
  120. package/dist/cjs/src/reactjs/components/UserButton.js +84 -0
  121. package/dist/cjs/src/reactjs/components/UserButton.js.map +1 -0
  122. package/dist/cjs/src/reactjs/components/index.d.ts +6 -0
  123. package/dist/cjs/src/reactjs/components/index.d.ts.map +1 -0
  124. package/dist/cjs/src/reactjs/components/index.js +14 -0
  125. package/dist/cjs/src/reactjs/components/index.js.map +1 -0
  126. package/dist/cjs/src/reactjs/hooks/index.d.ts +9 -0
  127. package/dist/cjs/src/reactjs/hooks/index.d.ts.map +1 -0
  128. package/dist/cjs/src/reactjs/hooks/index.js +20 -0
  129. package/dist/cjs/src/reactjs/hooks/index.js.map +1 -0
  130. package/dist/cjs/src/reactjs/hooks/useAuth.d.ts +3 -0
  131. package/dist/cjs/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  132. package/dist/cjs/src/reactjs/hooks/useAuth.js +15 -0
  133. package/dist/cjs/src/reactjs/hooks/useAuth.js.map +1 -0
  134. package/dist/cjs/src/reactjs/hooks/useUser.d.ts +4 -0
  135. package/dist/cjs/src/reactjs/hooks/useUser.d.ts.map +1 -0
  136. package/dist/cjs/src/reactjs/hooks/useUser.js +15 -0
  137. package/dist/cjs/src/reactjs/hooks/useUser.js.map +1 -0
  138. package/dist/cjs/src/reactjs/index.d.ts +6 -0
  139. package/dist/cjs/src/reactjs/index.d.ts.map +1 -0
  140. package/dist/cjs/src/reactjs/index.js +30 -0
  141. package/dist/cjs/src/reactjs/index.js.map +1 -0
  142. package/dist/cjs/src/reactjs/providers/index.d.ts +8 -0
  143. package/dist/cjs/src/reactjs/providers/index.d.ts.map +1 -0
  144. package/dist/cjs/src/reactjs/providers/index.js +19 -0
  145. package/dist/cjs/src/reactjs/providers/index.js.map +1 -0
  146. package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts +18 -0
  147. package/dist/cjs/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  148. package/dist/cjs/src/server/ServerAuthenticationResolver.js +66 -0
  149. package/dist/cjs/src/server/ServerAuthenticationResolver.js.map +1 -0
  150. package/dist/cjs/src/server/config.d.ts +16 -0
  151. package/dist/cjs/src/server/config.d.ts.map +1 -0
  152. package/dist/cjs/src/server/config.js +3 -0
  153. package/dist/cjs/src/server/config.js.map +1 -0
  154. package/dist/cjs/src/server/index.d.ts +6 -0
  155. package/dist/cjs/src/server/index.d.ts.map +1 -0
  156. package/dist/cjs/src/server/index.js +14 -0
  157. package/dist/cjs/src/server/index.js.map +1 -0
  158. package/dist/cjs/src/server/login.d.ts +17 -0
  159. package/dist/cjs/src/server/login.d.ts.map +1 -0
  160. package/dist/cjs/src/server/login.js +42 -0
  161. package/dist/cjs/src/server/login.js.map +1 -0
  162. package/dist/cjs/src/server/refresh.d.ts +7 -0
  163. package/dist/cjs/src/server/refresh.d.ts.map +1 -0
  164. package/dist/cjs/src/server/refresh.js +16 -0
  165. package/dist/cjs/src/server/refresh.js.map +1 -0
  166. package/dist/cjs/src/services/AuthenticationService.d.ts +87 -0
  167. package/dist/cjs/src/services/AuthenticationService.d.ts.map +1 -0
  168. package/dist/cjs/src/services/AuthenticationService.js +228 -0
  169. package/dist/cjs/src/services/AuthenticationService.js.map +1 -0
  170. package/dist/cjs/src/services/PKCE.d.ts +20 -0
  171. package/dist/cjs/src/services/PKCE.d.ts.map +1 -0
  172. package/dist/cjs/src/services/PKCE.js +50 -0
  173. package/dist/cjs/src/services/PKCE.js.map +1 -0
  174. package/dist/cjs/src/services/types.d.ts +23 -0
  175. package/dist/cjs/src/services/types.d.ts.map +1 -0
  176. package/dist/cjs/src/services/types.js +11 -0
  177. package/dist/cjs/src/services/types.js.map +1 -0
  178. package/dist/cjs/src/shared/AuthContext.d.ts +10 -0
  179. package/dist/cjs/src/shared/AuthContext.d.ts.map +1 -0
  180. package/dist/cjs/src/shared/AuthContext.js +6 -0
  181. package/dist/cjs/src/shared/AuthContext.js.map +1 -0
  182. package/dist/cjs/src/shared/AuthProvider.d.ts +18 -0
  183. package/dist/cjs/src/shared/AuthProvider.d.ts.map +1 -0
  184. package/dist/cjs/src/shared/AuthProvider.js +276 -0
  185. package/dist/cjs/src/shared/AuthProvider.js.map +1 -0
  186. package/dist/cjs/src/shared/CivicAuthProvider.d.ts +7 -0
  187. package/dist/cjs/src/shared/CivicAuthProvider.d.ts.map +1 -0
  188. package/dist/cjs/src/shared/CivicAuthProvider.js +23 -0
  189. package/dist/cjs/src/shared/CivicAuthProvider.js.map +1 -0
  190. package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts +15 -0
  191. package/dist/cjs/src/shared/GenericAuthenticationRefresher.d.ts.map +1 -0
  192. package/dist/cjs/src/shared/GenericAuthenticationRefresher.js +47 -0
  193. package/dist/cjs/src/shared/GenericAuthenticationRefresher.js.map +1 -0
  194. package/dist/cjs/src/shared/UserProvider.d.ts +18 -0
  195. package/dist/cjs/src/shared/UserProvider.d.ts.map +1 -0
  196. package/dist/cjs/src/shared/UserProvider.js +65 -0
  197. package/dist/cjs/src/shared/UserProvider.js.map +1 -0
  198. package/dist/cjs/src/shared/UserSession.d.ts +12 -0
  199. package/dist/cjs/src/shared/UserSession.d.ts.map +1 -0
  200. package/dist/cjs/src/shared/UserSession.js +24 -0
  201. package/dist/cjs/src/shared/UserSession.js.map +1 -0
  202. package/dist/cjs/src/shared/components/CivicAuthIframe.d.ts +8 -0
  203. package/dist/cjs/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  204. package/dist/cjs/src/shared/components/CivicAuthIframe.js +35 -0
  205. package/dist/cjs/src/shared/components/CivicAuthIframe.js.map +1 -0
  206. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.d.ts +9 -0
  207. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  208. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.js +117 -0
  209. package/dist/cjs/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  210. package/dist/cjs/src/shared/components/CloseIcon.d.ts +4 -0
  211. package/dist/cjs/src/shared/components/CloseIcon.d.ts.map +1 -0
  212. package/dist/cjs/src/shared/components/CloseIcon.js +12 -0
  213. package/dist/cjs/src/shared/components/CloseIcon.js.map +1 -0
  214. package/dist/cjs/src/shared/components/LoadingIcon.d.ts +4 -0
  215. package/dist/cjs/src/shared/components/LoadingIcon.d.ts.map +1 -0
  216. package/dist/cjs/src/shared/components/LoadingIcon.js +14 -0
  217. package/dist/cjs/src/shared/components/LoadingIcon.js.map +1 -0
  218. package/dist/cjs/src/shared/hooks/index.d.ts +5 -0
  219. package/dist/cjs/src/shared/hooks/index.d.ts.map +1 -0
  220. package/dist/cjs/src/shared/hooks/index.js +12 -0
  221. package/dist/cjs/src/shared/hooks/index.js.map +1 -0
  222. package/dist/cjs/src/shared/hooks/useAuth.d.ts +3 -0
  223. package/dist/cjs/src/shared/hooks/useAuth.d.ts.map +1 -0
  224. package/dist/cjs/src/shared/hooks/useAuth.js +15 -0
  225. package/dist/cjs/src/shared/hooks/useAuth.js.map +1 -0
  226. package/dist/cjs/src/shared/hooks/useConfig.d.ts +3 -0
  227. package/dist/cjs/src/shared/hooks/useConfig.d.ts.map +1 -0
  228. package/dist/cjs/src/shared/hooks/useConfig.js +16 -0
  229. package/dist/cjs/src/shared/hooks/useConfig.js.map +1 -0
  230. package/dist/cjs/src/shared/hooks/useIframe.d.ts +3 -0
  231. package/dist/cjs/src/shared/hooks/useIframe.d.ts.map +1 -0
  232. package/dist/cjs/src/shared/hooks/useIframe.js +16 -0
  233. package/dist/cjs/src/shared/hooks/useIframe.js.map +1 -0
  234. package/dist/cjs/src/shared/hooks/useSession.d.ts +3 -0
  235. package/dist/cjs/src/shared/hooks/useSession.d.ts.map +1 -0
  236. package/dist/cjs/src/shared/hooks/useSession.js +16 -0
  237. package/dist/cjs/src/shared/hooks/useSession.js.map +1 -0
  238. package/dist/cjs/src/shared/hooks/useToken.d.ts +3 -0
  239. package/dist/cjs/src/shared/hooks/useToken.d.ts.map +1 -0
  240. package/dist/cjs/src/shared/hooks/useToken.js +15 -0
  241. package/dist/cjs/src/shared/hooks/useToken.js.map +1 -0
  242. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts +15 -0
  243. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  244. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js +47 -0
  245. package/dist/cjs/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  246. package/dist/cjs/src/shared/lib/UserSession.d.ts +12 -0
  247. package/dist/cjs/src/shared/lib/UserSession.d.ts.map +1 -0
  248. package/dist/cjs/src/shared/lib/UserSession.js +24 -0
  249. package/dist/cjs/src/shared/lib/UserSession.js.map +1 -0
  250. package/dist/cjs/src/shared/lib/session.d.ts +3 -0
  251. package/dist/cjs/src/shared/lib/session.d.ts.map +1 -0
  252. package/dist/cjs/src/shared/lib/session.js +13 -0
  253. package/dist/cjs/src/shared/lib/session.js.map +1 -0
  254. package/dist/cjs/src/shared/lib/storage.d.ts +25 -0
  255. package/dist/cjs/src/shared/lib/storage.d.ts.map +1 -0
  256. package/dist/cjs/src/shared/lib/storage.js +21 -0
  257. package/dist/cjs/src/shared/lib/storage.js.map +1 -0
  258. package/dist/cjs/src/shared/lib/types.d.ts +21 -0
  259. package/dist/cjs/src/shared/lib/types.d.ts.map +1 -0
  260. package/dist/cjs/src/shared/lib/types.js +18 -0
  261. package/dist/cjs/src/shared/lib/types.js.map +1 -0
  262. package/dist/cjs/src/shared/lib/util.d.ts +33 -0
  263. package/dist/cjs/src/shared/lib/util.d.ts.map +1 -0
  264. package/dist/cjs/src/shared/lib/util.js +164 -0
  265. package/dist/cjs/src/shared/lib/util.js.map +1 -0
  266. package/dist/cjs/src/shared/providers/AuthContext.d.ts +10 -0
  267. package/dist/cjs/src/shared/providers/AuthContext.d.ts.map +1 -0
  268. package/dist/cjs/src/shared/providers/AuthContext.js +6 -0
  269. package/dist/cjs/src/shared/providers/AuthContext.js.map +1 -0
  270. package/dist/cjs/src/shared/providers/AuthProvider.d.ts +18 -0
  271. package/dist/cjs/src/shared/providers/AuthProvider.d.ts.map +1 -0
  272. package/dist/cjs/src/shared/providers/AuthProvider.js +271 -0
  273. package/dist/cjs/src/shared/providers/AuthProvider.js.map +1 -0
  274. package/dist/cjs/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  275. package/dist/cjs/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  276. package/dist/cjs/src/shared/providers/CivicAuthProvider.js +23 -0
  277. package/dist/cjs/src/shared/providers/CivicAuthProvider.js.map +1 -0
  278. package/dist/cjs/src/shared/providers/ConfigProvider.d.ts +21 -0
  279. package/dist/cjs/src/shared/providers/ConfigProvider.d.ts.map +1 -0
  280. package/dist/cjs/src/shared/providers/ConfigProvider.js +46 -0
  281. package/dist/cjs/src/shared/providers/ConfigProvider.js.map +1 -0
  282. package/dist/cjs/src/shared/providers/IframeProvider.d.ts +16 -0
  283. package/dist/cjs/src/shared/providers/IframeProvider.d.ts.map +1 -0
  284. package/dist/cjs/src/shared/providers/IframeProvider.js +38 -0
  285. package/dist/cjs/src/shared/providers/IframeProvider.js.map +1 -0
  286. package/dist/cjs/src/shared/providers/SessionProvider.d.ts +13 -0
  287. package/dist/cjs/src/shared/providers/SessionProvider.d.ts.map +1 -0
  288. package/dist/cjs/src/shared/providers/SessionProvider.js +40 -0
  289. package/dist/cjs/src/shared/providers/SessionProvider.js.map +1 -0
  290. package/dist/cjs/src/shared/providers/TokenProvider.d.ts +18 -0
  291. package/dist/cjs/src/shared/providers/TokenProvider.d.ts.map +1 -0
  292. package/dist/cjs/src/shared/providers/TokenProvider.js +80 -0
  293. package/dist/cjs/src/shared/providers/TokenProvider.js.map +1 -0
  294. package/dist/cjs/src/shared/providers/UserProvider.d.ts +18 -0
  295. package/dist/cjs/src/shared/providers/UserProvider.d.ts.map +1 -0
  296. package/dist/cjs/src/shared/providers/UserProvider.js +65 -0
  297. package/dist/cjs/src/shared/providers/UserProvider.js.map +1 -0
  298. package/dist/cjs/src/shared/session.d.ts +3 -0
  299. package/dist/cjs/src/shared/session.d.ts.map +1 -0
  300. package/dist/cjs/src/shared/session.js +13 -0
  301. package/dist/cjs/src/shared/session.js.map +1 -0
  302. package/dist/cjs/src/shared/storage.d.ts +25 -0
  303. package/dist/cjs/src/shared/storage.d.ts.map +1 -0
  304. package/dist/cjs/src/shared/storage.js +21 -0
  305. package/dist/cjs/src/shared/storage.js.map +1 -0
  306. package/dist/cjs/src/shared/types.d.ts +21 -0
  307. package/dist/cjs/src/shared/types.d.ts.map +1 -0
  308. package/dist/cjs/src/shared/types.js +18 -0
  309. package/dist/cjs/src/shared/types.js.map +1 -0
  310. package/dist/cjs/src/shared/util.d.ts +33 -0
  311. package/dist/cjs/src/shared/util.d.ts.map +1 -0
  312. package/dist/cjs/src/shared/util.js +164 -0
  313. package/dist/cjs/src/shared/util.js.map +1 -0
  314. package/dist/cjs/src/types.d.ts +146 -0
  315. package/dist/cjs/src/types.d.ts.map +1 -0
  316. package/dist/cjs/src/types.js +3 -0
  317. package/dist/cjs/src/types.js.map +1 -0
  318. package/dist/cjs/src/utils.d.ts +17 -0
  319. package/dist/cjs/src/utils.d.ts.map +1 -0
  320. package/dist/cjs/src/utils.js +53 -0
  321. package/dist/cjs/src/utils.js.map +1 -0
  322. package/dist/cjs/src/worker/index.d.ts +2 -0
  323. package/dist/cjs/src/worker/index.d.ts.map +1 -0
  324. package/dist/cjs/src/worker/index.js +8 -0
  325. package/dist/cjs/src/worker/index.js.map +1 -0
  326. package/dist/cjs/tsconfig.build.tsbuildinfo +1 -0
  327. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -0
  328. package/dist/esm/src/browser/storage.d.ts +6 -0
  329. package/dist/esm/src/browser/storage.d.ts.map +1 -0
  330. package/dist/esm/src/browser/storage.js +9 -0
  331. package/dist/esm/src/browser/storage.js.map +1 -0
  332. package/dist/esm/src/config.d.ts +3 -0
  333. package/dist/esm/src/config.d.ts.map +1 -0
  334. package/dist/esm/src/config.js +5 -0
  335. package/dist/esm/src/config.js.map +1 -0
  336. package/dist/esm/src/constants.d.ts +9 -0
  337. package/dist/esm/src/constants.d.ts.map +1 -0
  338. package/dist/esm/src/constants.js +17 -0
  339. package/dist/esm/src/constants.js.map +1 -0
  340. package/dist/esm/src/index.d.ts +5 -0
  341. package/dist/esm/src/index.d.ts.map +1 -0
  342. package/dist/esm/src/index.js +3 -0
  343. package/dist/esm/src/index.js.map +1 -0
  344. package/dist/esm/src/lib/cookies.d.ts +7 -0
  345. package/dist/esm/src/lib/cookies.d.ts.map +1 -0
  346. package/dist/esm/src/lib/cookies.js +23 -0
  347. package/dist/esm/src/lib/cookies.js.map +1 -0
  348. package/dist/esm/src/lib/jwt.d.ts +3 -0
  349. package/dist/esm/src/lib/jwt.d.ts.map +1 -0
  350. package/dist/esm/src/lib/jwt.js +9 -0
  351. package/dist/esm/src/lib/jwt.js.map +1 -0
  352. package/dist/esm/src/lib/logger.d.ts +26 -0
  353. package/dist/esm/src/lib/logger.d.ts.map +1 -0
  354. package/dist/esm/src/lib/logger.js +55 -0
  355. package/dist/esm/src/lib/logger.js.map +1 -0
  356. package/dist/esm/src/lib/oauth.d.ts +19 -0
  357. package/dist/esm/src/lib/oauth.d.ts.map +1 -0
  358. package/dist/esm/src/lib/oauth.js +60 -0
  359. package/dist/esm/src/lib/oauth.js.map +1 -0
  360. package/dist/esm/src/lib/postMessage.d.ts +4 -0
  361. package/dist/esm/src/lib/postMessage.d.ts.map +1 -0
  362. package/dist/esm/src/lib/postMessage.js +15 -0
  363. package/dist/esm/src/lib/postMessage.js.map +1 -0
  364. package/dist/esm/src/lib/windowUtil.d.ts +4 -0
  365. package/dist/esm/src/lib/windowUtil.d.ts.map +1 -0
  366. package/dist/esm/src/lib/windowUtil.js +30 -0
  367. package/dist/esm/src/lib/windowUtil.js.map +1 -0
  368. package/dist/esm/src/nextjs/GetUser.d.ts +6 -0
  369. package/dist/esm/src/nextjs/GetUser.d.ts.map +1 -0
  370. package/dist/esm/src/nextjs/GetUser.js +18 -0
  371. package/dist/esm/src/nextjs/GetUser.js.map +1 -0
  372. package/dist/esm/src/nextjs/client/index.d.ts +2 -0
  373. package/dist/esm/src/nextjs/client/index.d.ts.map +1 -0
  374. package/dist/esm/src/nextjs/client/index.js +2 -0
  375. package/dist/esm/src/nextjs/client/index.js.map +1 -0
  376. package/dist/esm/src/nextjs/config.d.ts +180 -0
  377. package/dist/esm/src/nextjs/config.d.ts.map +1 -0
  378. package/dist/esm/src/nextjs/config.js +158 -0
  379. package/dist/esm/src/nextjs/config.js.map +1 -0
  380. package/dist/esm/src/nextjs/cookies.d.ts +30 -0
  381. package/dist/esm/src/nextjs/cookies.d.ts.map +1 -0
  382. package/dist/esm/src/nextjs/cookies.js +109 -0
  383. package/dist/esm/src/nextjs/cookies.js.map +1 -0
  384. package/dist/esm/src/nextjs/hooks/index.d.ts +2 -0
  385. package/dist/esm/src/nextjs/hooks/index.d.ts.map +1 -0
  386. package/dist/esm/src/nextjs/hooks/index.js +2 -0
  387. package/dist/esm/src/nextjs/hooks/index.js.map +1 -0
  388. package/dist/esm/src/nextjs/hooks/useTokenCookie.d.ts +3 -0
  389. package/dist/esm/src/nextjs/hooks/useTokenCookie.d.ts.map +1 -0
  390. package/dist/esm/src/nextjs/hooks/useTokenCookie.js +37 -0
  391. package/dist/esm/src/nextjs/hooks/useTokenCookie.js.map +1 -0
  392. package/dist/esm/src/nextjs/hooks/useUserCookie.d.ts +3 -0
  393. package/dist/esm/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  394. package/dist/esm/src/nextjs/hooks/useUserCookie.js +36 -0
  395. package/dist/esm/src/nextjs/hooks/useUserCookie.js.map +1 -0
  396. package/dist/esm/src/nextjs/index.d.ts +7 -0
  397. package/dist/esm/src/nextjs/index.d.ts.map +1 -0
  398. package/dist/esm/src/nextjs/index.js +6 -0
  399. package/dist/esm/src/nextjs/index.js.map +1 -0
  400. package/dist/esm/src/nextjs/middleware/index.d.ts +2 -0
  401. package/dist/esm/src/nextjs/middleware/index.d.ts.map +1 -0
  402. package/dist/esm/src/nextjs/middleware/index.js +2 -0
  403. package/dist/esm/src/nextjs/middleware/index.js.map +1 -0
  404. package/dist/esm/src/nextjs/middleware.d.ts +59 -0
  405. package/dist/esm/src/nextjs/middleware.d.ts.map +1 -0
  406. package/dist/esm/src/nextjs/middleware.js +107 -0
  407. package/dist/esm/src/nextjs/middleware.js.map +1 -0
  408. package/dist/esm/src/nextjs/providers/NextAuthProvider.d.ts +9 -0
  409. package/dist/esm/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  410. package/dist/esm/src/nextjs/providers/NextAuthProvider.js +51 -0
  411. package/dist/esm/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  412. package/dist/esm/src/nextjs/routeHandler.d.ts +18 -0
  413. package/dist/esm/src/nextjs/routeHandler.d.ts.map +1 -0
  414. package/dist/esm/src/nextjs/routeHandler.js +203 -0
  415. package/dist/esm/src/nextjs/routeHandler.js.map +1 -0
  416. package/dist/esm/src/nextjs/utils.d.ts +3 -0
  417. package/dist/esm/src/nextjs/utils.d.ts.map +1 -0
  418. package/dist/esm/src/nextjs/utils.js +6 -0
  419. package/dist/esm/src/nextjs/utils.js.map +1 -0
  420. package/dist/esm/src/nextjs/worker/index.d.ts +2 -0
  421. package/dist/esm/src/nextjs/worker/index.d.ts.map +1 -0
  422. package/dist/esm/src/nextjs/worker/index.js +2 -0
  423. package/dist/esm/src/nextjs/worker/index.js.map +1 -0
  424. package/dist/esm/src/reactjs/components/NextLogOut.d.ts +7 -0
  425. package/dist/esm/src/reactjs/components/NextLogOut.d.ts.map +1 -0
  426. package/dist/esm/src/reactjs/components/NextLogOut.js +12 -0
  427. package/dist/esm/src/reactjs/components/NextLogOut.js.map +1 -0
  428. package/dist/esm/src/reactjs/components/SignInButton.d.ts +8 -0
  429. package/dist/esm/src/reactjs/components/SignInButton.d.ts.map +1 -0
  430. package/dist/esm/src/reactjs/components/SignInButton.js +10 -0
  431. package/dist/esm/src/reactjs/components/SignInButton.js.map +1 -0
  432. package/dist/esm/src/reactjs/components/SignOutButton.d.ts +6 -0
  433. package/dist/esm/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  434. package/dist/esm/src/reactjs/components/SignOutButton.js +10 -0
  435. package/dist/esm/src/reactjs/components/SignOutButton.js.map +1 -0
  436. package/dist/esm/src/reactjs/components/UserButton.d.ts +8 -0
  437. package/dist/esm/src/reactjs/components/UserButton.d.ts.map +1 -0
  438. package/dist/esm/src/reactjs/components/UserButton.js +58 -0
  439. package/dist/esm/src/reactjs/components/UserButton.js.map +1 -0
  440. package/dist/esm/src/reactjs/components/index.d.ts +6 -0
  441. package/dist/esm/src/reactjs/components/index.d.ts.map +1 -0
  442. package/dist/esm/src/reactjs/components/index.js +6 -0
  443. package/dist/esm/src/reactjs/components/index.js.map +1 -0
  444. package/dist/esm/src/reactjs/hooks/index.d.ts +9 -0
  445. package/dist/esm/src/reactjs/hooks/index.d.ts.map +1 -0
  446. package/dist/esm/src/reactjs/hooks/index.js +9 -0
  447. package/dist/esm/src/reactjs/hooks/index.js.map +1 -0
  448. package/dist/esm/src/reactjs/hooks/useAuth.d.ts +3 -0
  449. package/dist/esm/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  450. package/dist/esm/src/reactjs/hooks/useAuth.js +12 -0
  451. package/dist/esm/src/reactjs/hooks/useAuth.js.map +1 -0
  452. package/dist/esm/src/reactjs/hooks/useUser.d.ts +4 -0
  453. package/dist/esm/src/reactjs/hooks/useUser.d.ts.map +1 -0
  454. package/dist/esm/src/reactjs/hooks/useUser.js +12 -0
  455. package/dist/esm/src/reactjs/hooks/useUser.js.map +1 -0
  456. package/dist/esm/src/reactjs/index.d.ts +6 -0
  457. package/dist/esm/src/reactjs/index.d.ts.map +1 -0
  458. package/dist/esm/src/reactjs/index.js +8 -0
  459. package/dist/esm/src/reactjs/index.js.map +1 -0
  460. package/dist/esm/src/reactjs/providers/index.d.ts +8 -0
  461. package/dist/esm/src/reactjs/providers/index.d.ts.map +1 -0
  462. package/dist/esm/src/reactjs/providers/index.js +7 -0
  463. package/dist/esm/src/reactjs/providers/index.js.map +1 -0
  464. package/dist/esm/src/server/ServerAuthenticationResolver.d.ts +18 -0
  465. package/dist/esm/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  466. package/dist/esm/src/server/ServerAuthenticationResolver.js +62 -0
  467. package/dist/esm/src/server/ServerAuthenticationResolver.js.map +1 -0
  468. package/dist/esm/src/server/config.d.ts +16 -0
  469. package/dist/esm/src/server/config.d.ts.map +1 -0
  470. package/dist/esm/src/server/config.js +2 -0
  471. package/dist/esm/src/server/config.js.map +1 -0
  472. package/dist/esm/src/server/index.d.ts +6 -0
  473. package/dist/esm/src/server/index.d.ts.map +1 -0
  474. package/dist/esm/src/server/index.js +5 -0
  475. package/dist/esm/src/server/index.js.map +1 -0
  476. package/dist/esm/src/server/login.d.ts +17 -0
  477. package/dist/esm/src/server/login.d.ts.map +1 -0
  478. package/dist/esm/src/server/login.js +37 -0
  479. package/dist/esm/src/server/login.js.map +1 -0
  480. package/dist/esm/src/server/refresh.d.ts +7 -0
  481. package/dist/esm/src/server/refresh.d.ts.map +1 -0
  482. package/dist/esm/src/server/refresh.js +13 -0
  483. package/dist/esm/src/server/refresh.js.map +1 -0
  484. package/dist/esm/src/services/AuthenticationService.d.ts +87 -0
  485. package/dist/esm/src/services/AuthenticationService.d.ts.map +1 -0
  486. package/dist/esm/src/services/AuthenticationService.js +222 -0
  487. package/dist/esm/src/services/AuthenticationService.js.map +1 -0
  488. package/dist/esm/src/services/PKCE.d.ts +20 -0
  489. package/dist/esm/src/services/PKCE.d.ts.map +1 -0
  490. package/dist/esm/src/services/PKCE.js +44 -0
  491. package/dist/esm/src/services/PKCE.js.map +1 -0
  492. package/dist/esm/src/services/types.d.ts +23 -0
  493. package/dist/esm/src/services/types.d.ts.map +1 -0
  494. package/dist/esm/src/services/types.js +7 -0
  495. package/dist/esm/src/services/types.js.map +1 -0
  496. package/dist/esm/src/shared/AuthContext.d.ts +10 -0
  497. package/dist/esm/src/shared/AuthContext.d.ts.map +1 -0
  498. package/dist/esm/src/shared/AuthContext.js +3 -0
  499. package/dist/esm/src/shared/AuthContext.js.map +1 -0
  500. package/dist/esm/src/shared/AuthProvider.d.ts +18 -0
  501. package/dist/esm/src/shared/AuthProvider.d.ts.map +1 -0
  502. package/dist/esm/src/shared/AuthProvider.js +250 -0
  503. package/dist/esm/src/shared/AuthProvider.js.map +1 -0
  504. package/dist/esm/src/shared/CivicAuthProvider.d.ts +7 -0
  505. package/dist/esm/src/shared/CivicAuthProvider.d.ts.map +1 -0
  506. package/dist/esm/src/shared/CivicAuthProvider.js +17 -0
  507. package/dist/esm/src/shared/CivicAuthProvider.js.map +1 -0
  508. package/dist/esm/src/shared/GenericAuthenticationRefresher.d.ts +15 -0
  509. package/dist/esm/src/shared/GenericAuthenticationRefresher.d.ts.map +1 -0
  510. package/dist/esm/src/shared/GenericAuthenticationRefresher.js +43 -0
  511. package/dist/esm/src/shared/GenericAuthenticationRefresher.js.map +1 -0
  512. package/dist/esm/src/shared/UserProvider.d.ts +18 -0
  513. package/dist/esm/src/shared/UserProvider.d.ts.map +1 -0
  514. package/dist/esm/src/shared/UserProvider.js +38 -0
  515. package/dist/esm/src/shared/UserProvider.js.map +1 -0
  516. package/dist/esm/src/shared/UserSession.d.ts +12 -0
  517. package/dist/esm/src/shared/UserSession.d.ts.map +1 -0
  518. package/dist/esm/src/shared/UserSession.js +20 -0
  519. package/dist/esm/src/shared/UserSession.js.map +1 -0
  520. package/dist/esm/src/shared/components/CivicAuthIframe.d.ts +8 -0
  521. package/dist/esm/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  522. package/dist/esm/src/shared/components/CivicAuthIframe.js +9 -0
  523. package/dist/esm/src/shared/components/CivicAuthIframe.js.map +1 -0
  524. package/dist/esm/src/shared/components/CivicAuthIframeContainer.d.ts +9 -0
  525. package/dist/esm/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  526. package/dist/esm/src/shared/components/CivicAuthIframeContainer.js +91 -0
  527. package/dist/esm/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  528. package/dist/esm/src/shared/components/CloseIcon.d.ts +4 -0
  529. package/dist/esm/src/shared/components/CloseIcon.d.ts.map +1 -0
  530. package/dist/esm/src/shared/components/CloseIcon.js +6 -0
  531. package/dist/esm/src/shared/components/CloseIcon.js.map +1 -0
  532. package/dist/esm/src/shared/components/LoadingIcon.d.ts +4 -0
  533. package/dist/esm/src/shared/components/LoadingIcon.d.ts.map +1 -0
  534. package/dist/esm/src/shared/components/LoadingIcon.js +8 -0
  535. package/dist/esm/src/shared/components/LoadingIcon.js.map +1 -0
  536. package/dist/esm/src/shared/hooks/index.d.ts +5 -0
  537. package/dist/esm/src/shared/hooks/index.d.ts.map +1 -0
  538. package/dist/esm/src/shared/hooks/index.js +5 -0
  539. package/dist/esm/src/shared/hooks/index.js.map +1 -0
  540. package/dist/esm/src/shared/hooks/useAuth.d.ts +3 -0
  541. package/dist/esm/src/shared/hooks/useAuth.d.ts.map +1 -0
  542. package/dist/esm/src/shared/hooks/useAuth.js +12 -0
  543. package/dist/esm/src/shared/hooks/useAuth.js.map +1 -0
  544. package/dist/esm/src/shared/hooks/useConfig.d.ts +3 -0
  545. package/dist/esm/src/shared/hooks/useConfig.d.ts.map +1 -0
  546. package/dist/esm/src/shared/hooks/useConfig.js +13 -0
  547. package/dist/esm/src/shared/hooks/useConfig.js.map +1 -0
  548. package/dist/esm/src/shared/hooks/useIframe.d.ts +3 -0
  549. package/dist/esm/src/shared/hooks/useIframe.d.ts.map +1 -0
  550. package/dist/esm/src/shared/hooks/useIframe.js +13 -0
  551. package/dist/esm/src/shared/hooks/useIframe.js.map +1 -0
  552. package/dist/esm/src/shared/hooks/useSession.d.ts +3 -0
  553. package/dist/esm/src/shared/hooks/useSession.d.ts.map +1 -0
  554. package/dist/esm/src/shared/hooks/useSession.js +13 -0
  555. package/dist/esm/src/shared/hooks/useSession.js.map +1 -0
  556. package/dist/esm/src/shared/hooks/useToken.d.ts +3 -0
  557. package/dist/esm/src/shared/hooks/useToken.d.ts.map +1 -0
  558. package/dist/esm/src/shared/hooks/useToken.js +12 -0
  559. package/dist/esm/src/shared/hooks/useToken.js.map +1 -0
  560. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts +15 -0
  561. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  562. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js +43 -0
  563. package/dist/esm/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  564. package/dist/esm/src/shared/lib/UserSession.d.ts +12 -0
  565. package/dist/esm/src/shared/lib/UserSession.d.ts.map +1 -0
  566. package/dist/esm/src/shared/lib/UserSession.js +20 -0
  567. package/dist/esm/src/shared/lib/UserSession.js.map +1 -0
  568. package/dist/esm/src/shared/lib/session.d.ts +3 -0
  569. package/dist/esm/src/shared/lib/session.d.ts.map +1 -0
  570. package/dist/esm/src/shared/lib/session.js +10 -0
  571. package/dist/esm/src/shared/lib/session.js.map +1 -0
  572. package/dist/esm/src/shared/lib/storage.d.ts +25 -0
  573. package/dist/esm/src/shared/lib/storage.d.ts.map +1 -0
  574. package/dist/esm/src/shared/lib/storage.js +17 -0
  575. package/dist/esm/src/shared/lib/storage.js.map +1 -0
  576. package/dist/esm/src/shared/lib/types.d.ts +21 -0
  577. package/dist/esm/src/shared/lib/types.d.ts.map +1 -0
  578. package/dist/esm/src/shared/lib/types.js +15 -0
  579. package/dist/esm/src/shared/lib/types.js.map +1 -0
  580. package/dist/esm/src/shared/lib/util.d.ts +33 -0
  581. package/dist/esm/src/shared/lib/util.d.ts.map +1 -0
  582. package/dist/esm/src/shared/lib/util.js +128 -0
  583. package/dist/esm/src/shared/lib/util.js.map +1 -0
  584. package/dist/esm/src/shared/providers/AuthContext.d.ts +10 -0
  585. package/dist/esm/src/shared/providers/AuthContext.d.ts.map +1 -0
  586. package/dist/esm/src/shared/providers/AuthContext.js +3 -0
  587. package/dist/esm/src/shared/providers/AuthContext.js.map +1 -0
  588. package/dist/esm/src/shared/providers/AuthProvider.d.ts +18 -0
  589. package/dist/esm/src/shared/providers/AuthProvider.d.ts.map +1 -0
  590. package/dist/esm/src/shared/providers/AuthProvider.js +245 -0
  591. package/dist/esm/src/shared/providers/AuthProvider.js.map +1 -0
  592. package/dist/esm/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  593. package/dist/esm/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  594. package/dist/esm/src/shared/providers/CivicAuthProvider.js +17 -0
  595. package/dist/esm/src/shared/providers/CivicAuthProvider.js.map +1 -0
  596. package/dist/esm/src/shared/providers/ConfigProvider.d.ts +21 -0
  597. package/dist/esm/src/shared/providers/ConfigProvider.d.ts.map +1 -0
  598. package/dist/esm/src/shared/providers/ConfigProvider.js +19 -0
  599. package/dist/esm/src/shared/providers/ConfigProvider.js.map +1 -0
  600. package/dist/esm/src/shared/providers/IframeProvider.d.ts +16 -0
  601. package/dist/esm/src/shared/providers/IframeProvider.d.ts.map +1 -0
  602. package/dist/esm/src/shared/providers/IframeProvider.js +11 -0
  603. package/dist/esm/src/shared/providers/IframeProvider.js.map +1 -0
  604. package/dist/esm/src/shared/providers/SessionProvider.d.ts +13 -0
  605. package/dist/esm/src/shared/providers/SessionProvider.d.ts.map +1 -0
  606. package/dist/esm/src/shared/providers/SessionProvider.js +13 -0
  607. package/dist/esm/src/shared/providers/SessionProvider.js.map +1 -0
  608. package/dist/esm/src/shared/providers/TokenProvider.d.ts +18 -0
  609. package/dist/esm/src/shared/providers/TokenProvider.d.ts.map +1 -0
  610. package/dist/esm/src/shared/providers/TokenProvider.js +53 -0
  611. package/dist/esm/src/shared/providers/TokenProvider.js.map +1 -0
  612. package/dist/esm/src/shared/providers/UserProvider.d.ts +18 -0
  613. package/dist/esm/src/shared/providers/UserProvider.d.ts.map +1 -0
  614. package/dist/esm/src/shared/providers/UserProvider.js +38 -0
  615. package/dist/esm/src/shared/providers/UserProvider.js.map +1 -0
  616. package/dist/esm/src/shared/session.d.ts +3 -0
  617. package/dist/esm/src/shared/session.d.ts.map +1 -0
  618. package/dist/esm/src/shared/session.js +10 -0
  619. package/dist/esm/src/shared/session.js.map +1 -0
  620. package/dist/esm/src/shared/storage.d.ts +25 -0
  621. package/dist/esm/src/shared/storage.d.ts.map +1 -0
  622. package/dist/esm/src/shared/storage.js +17 -0
  623. package/dist/esm/src/shared/storage.js.map +1 -0
  624. package/dist/esm/src/shared/types.d.ts +21 -0
  625. package/dist/esm/src/shared/types.d.ts.map +1 -0
  626. package/dist/esm/src/shared/types.js +15 -0
  627. package/dist/esm/src/shared/types.js.map +1 -0
  628. package/dist/esm/src/shared/util.d.ts +33 -0
  629. package/dist/esm/src/shared/util.d.ts.map +1 -0
  630. package/dist/esm/src/shared/util.js +128 -0
  631. package/dist/esm/src/shared/util.js.map +1 -0
  632. package/dist/esm/src/types.d.ts +146 -0
  633. package/dist/esm/src/types.d.ts.map +1 -0
  634. package/dist/esm/src/types.js +2 -0
  635. package/dist/esm/src/types.js.map +1 -0
  636. package/dist/esm/src/utils.d.ts +17 -0
  637. package/dist/esm/src/utils.d.ts.map +1 -0
  638. package/dist/esm/src/utils.js +48 -0
  639. package/dist/esm/src/utils.js.map +1 -0
  640. package/dist/esm/src/worker/index.d.ts +2 -0
  641. package/dist/esm/src/worker/index.d.ts.map +1 -0
  642. package/dist/esm/src/worker/index.js +2 -0
  643. package/dist/esm/src/worker/index.js.map +1 -0
  644. package/dist/esm/tsconfig.build.tsbuildinfo +1 -0
  645. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -0
  646. package/package.json +115 -0
  647. package/postcss.config.cjs +6 -0
  648. package/src/browser/storage.ts +11 -0
  649. package/src/config.ts +6 -0
  650. package/src/constants.ts +29 -0
  651. package/src/index.ts +18 -0
  652. package/src/lib/cookies.ts +28 -0
  653. package/src/lib/jwt.ts +15 -0
  654. package/src/lib/logger.ts +72 -0
  655. package/src/lib/oauth.ts +83 -0
  656. package/src/lib/postMessage.ts +22 -0
  657. package/src/lib/windowUtil.ts +29 -0
  658. package/src/nextjs/GetUser.ts +22 -0
  659. package/src/nextjs/client/index.ts +4 -0
  660. package/src/nextjs/config.ts +203 -0
  661. package/src/nextjs/cookies.ts +166 -0
  662. package/src/nextjs/hooks/index.ts +1 -0
  663. package/src/nextjs/hooks/useTokenCookie.ts +41 -0
  664. package/src/nextjs/hooks/useUserCookie.ts +41 -0
  665. package/src/nextjs/index.ts +24 -0
  666. package/src/nextjs/middleware/index.ts +1 -0
  667. package/src/nextjs/middleware.ts +155 -0
  668. package/src/nextjs/providers/NextAuthProvider.tsx +89 -0
  669. package/src/nextjs/routeHandler.ts +276 -0
  670. package/src/nextjs/utils.ts +10 -0
  671. package/src/reactjs/components/SignInButton.tsx +30 -0
  672. package/src/reactjs/components/SignOutButton.tsx +22 -0
  673. package/src/reactjs/components/UserButton.tsx +153 -0
  674. package/src/reactjs/components/index.ts +5 -0
  675. package/src/reactjs/hooks/index.ts +8 -0
  676. package/src/reactjs/hooks/useAuth.ts +15 -0
  677. package/src/reactjs/hooks/useUser.ts +20 -0
  678. package/src/reactjs/index.ts +19 -0
  679. package/src/reactjs/providers/index.ts +27 -0
  680. package/src/server/ServerAuthenticationResolver.ts +107 -0
  681. package/src/server/config.ts +17 -0
  682. package/src/server/index.ts +12 -0
  683. package/src/server/login.ts +58 -0
  684. package/src/server/refresh.ts +23 -0
  685. package/src/services/AuthenticationService.ts +334 -0
  686. package/src/services/PKCE.ts +43 -0
  687. package/src/services/types.ts +54 -0
  688. package/src/shared/components/CivicAuthIframe.tsx +26 -0
  689. package/src/shared/components/CivicAuthIframeContainer.tsx +150 -0
  690. package/src/shared/components/CloseIcon.tsx +21 -0
  691. package/src/shared/components/LoadingIcon.tsx +25 -0
  692. package/src/shared/hooks/index.ts +4 -0
  693. package/src/shared/hooks/useAuth.ts +15 -0
  694. package/src/shared/hooks/useConfig.ts +14 -0
  695. package/src/shared/hooks/useIframe.ts +14 -0
  696. package/src/shared/hooks/useSession.ts +14 -0
  697. package/src/shared/hooks/useToken.ts +15 -0
  698. package/src/shared/lib/GenericAuthenticationRefresher.ts +75 -0
  699. package/src/shared/lib/UserSession.ts +25 -0
  700. package/src/shared/lib/session.ts +11 -0
  701. package/src/shared/lib/storage.ts +40 -0
  702. package/src/shared/lib/types.ts +25 -0
  703. package/src/shared/lib/util.ts +217 -0
  704. package/src/shared/providers/AuthContext.tsx +11 -0
  705. package/src/shared/providers/AuthProvider.tsx +364 -0
  706. package/src/shared/providers/CivicAuthProvider.tsx +34 -0
  707. package/src/shared/providers/ConfigProvider.tsx +50 -0
  708. package/src/shared/providers/IframeProvider.tsx +34 -0
  709. package/src/shared/providers/SessionProvider.tsx +29 -0
  710. package/src/shared/providers/TokenProvider.tsx +78 -0
  711. package/src/shared/providers/UserProvider.tsx +80 -0
  712. package/src/styles.css +3 -0
  713. package/src/types.ts +227 -0
  714. package/src/utils.ts +65 -0
  715. package/tailwind.config.js +8 -0
  716. package/test/integration/sdk.test.tsx +266 -0
  717. package/test/support/fixtures.ts +56 -0
  718. package/test/support/tokens.json +26 -0
  719. package/test/unit/lib/oauth.test.ts +72 -0
  720. package/test/unit/logger.test.ts +175 -0
  721. package/test/unit/nextjs/NextAuthProvider.test.tsx +38 -0
  722. package/test/unit/nextjs/config.test.ts +201 -0
  723. package/test/unit/nextjs/getUser.test.ts +41 -0
  724. package/test/unit/nextjs/middleware.test.ts +138 -0
  725. package/test/unit/nextjs/routeHandler.test.ts +369 -0
  726. package/test/unit/nextjs/utils.test.ts +26 -0
  727. package/test/unit/publicApi/__snapshots__/apiSnapshot.test.ts.snap +19 -0
  728. package/test/unit/publicApi/apiSnapshot.test.ts +11 -0
  729. package/test/unit/react/components/SignInButton.test.tsx +50 -0
  730. package/test/unit/react/components/SignOutButton.test.tsx +49 -0
  731. package/test/unit/server/login.test.ts +179 -0
  732. package/test/unit/server/session.test.ts +51 -0
  733. package/test/unit/services/AuthenticationService.test.ts +152 -0
  734. package/test/unit/services/ServerAuthenticationResolver.test.ts +110 -0
  735. package/test/unit/shared/GenericAuthenticationRefresher.test.ts +89 -0
  736. package/test/unit/shared/UserSession.test.ts +42 -0
  737. package/test/unit/shared/components/CivicAuthIframeContainer.test.tsx +154 -0
  738. package/test/unit/shared/storage.test.ts +67 -0
  739. package/test/unit/utils.test.ts +48 -0
  740. package/tsconfig.build.json +5 -0
  741. package/tsconfig.cjs.json +8 -0
  742. package/tsconfig.esm.json +7 -0
  743. package/tsconfig.json +42 -0
  744. package/vitest.config.ts +41 -0
@@ -0,0 +1,3 @@
1
+ import type { AuthStorage, User } from "../types.js";
2
+ export declare function getUser(storage: AuthStorage): Promise<User | null>;
3
+ //# sourceMappingURL=session.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../../../src/shared/session.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAEpD,wBAAsB,OAAO,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAMxE"}
@@ -0,0 +1,10 @@
1
+ import { retrieveTokens } from "../shared/util.js";
2
+ import { parseJWT } from "oslo/jwt";
3
+ export async function getUser(storage) {
4
+ const tokens = retrieveTokens(storage);
5
+ if (!tokens)
6
+ return null;
7
+ // Assumes all information is in the ID token
8
+ return parseJWT(tokens.id_token)?.payload ?? null;
9
+ }
10
+ //# sourceMappingURL=session.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.js","sourceRoot":"","sources":["../../../../src/shared/session.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAGpC,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,OAAoB;IAChD,MAAM,MAAM,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;IACvC,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IAEzB,6CAA6C;IAC7C,OAAQ,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,OAAgB,IAAI,IAAI,CAAC;AAC9D,CAAC","sourcesContent":["import { retrieveTokens } from \"@/shared/util.js\";\nimport { parseJWT } from \"oslo/jwt\";\nimport type { AuthStorage, User } from \"@/types.js\";\n\nexport async function getUser(storage: AuthStorage): Promise<User | null> {\n const tokens = retrieveTokens(storage);\n if (!tokens) return null;\n\n // Assumes all information is in the ID token\n return (parseJWT(tokens.id_token)?.payload as User) ?? null;\n}\n"]}
@@ -0,0 +1,25 @@
1
+ import type { AuthStorage, SessionData, UnknownObject, User } from "../types.js";
2
+ type SameSiteOption = "strict" | "lax" | "none";
3
+ export interface SessionStorage {
4
+ get(): SessionData;
5
+ getUser(): User<UnknownObject> | null;
6
+ set(data: Partial<SessionData>): void;
7
+ setUser(data: User<UnknownObject> | null): void;
8
+ clear(): void;
9
+ }
10
+ export type CookieStorageSettings = {
11
+ httpOnly: boolean;
12
+ secure: boolean;
13
+ sameSite: SameSiteOption;
14
+ expires: Date;
15
+ path: string;
16
+ };
17
+ export declare const DEFAULT_COOKIE_DURATION: number;
18
+ export declare abstract class CookieStorage implements AuthStorage {
19
+ protected settings: CookieStorageSettings;
20
+ protected constructor(settings?: Partial<CookieStorageSettings>);
21
+ abstract get(key: string): string | null;
22
+ abstract set(key: string, value: string): void;
23
+ }
24
+ export {};
25
+ //# sourceMappingURL=storage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../../src/shared/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,aAAa,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAEhF,KAAK,cAAc,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;AAEhD,MAAM,WAAW,cAAc;IAC7B,GAAG,IAAI,WAAW,CAAC;IACnB,OAAO,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;IACtC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC;IACtC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC;IAChD,KAAK,IAAI,IAAI,CAAC;CACf;AAED,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,EAAE,OAAO,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,cAAc,CAAC;IACzB,OAAO,EAAE,IAAI,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,eAAO,MAAM,uBAAuB,QAAU,CAAC;AAE/C,8BAAsB,aAAc,YAAW,WAAW;IACxD,SAAS,CAAC,QAAQ,EAAE,qBAAqB,CAAC;IAC1C,SAAS,aAAa,QAAQ,GAAE,OAAO,CAAC,qBAAqB,CAAM;IAanE,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IACxC,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;CAC/C"}
@@ -0,0 +1,17 @@
1
+ export const DEFAULT_COOKIE_DURATION = 60 * 15; // 15 minutes
2
+ export class CookieStorage {
3
+ settings;
4
+ constructor(settings = {}) {
5
+ this.settings = {
6
+ httpOnly: settings.httpOnly ?? true,
7
+ secure: settings.secure ?? true,
8
+ // the callback request comes the auth server
9
+ // 'lax' ensures the code_verifier cookie is sent with the request
10
+ sameSite: settings.sameSite ?? "lax",
11
+ expires: settings.expires ??
12
+ new Date(Date.now() + 1000 * DEFAULT_COOKIE_DURATION),
13
+ path: settings.path ?? "/",
14
+ };
15
+ }
16
+ }
17
+ //# sourceMappingURL=storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"storage.js","sourceRoot":"","sources":["../../../../src/shared/storage.ts"],"names":[],"mappings":"AAoBA,MAAM,CAAC,MAAM,uBAAuB,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,aAAa;AAE7D,MAAM,OAAgB,aAAa;IACvB,QAAQ,CAAwB;IAC1C,YAAsB,WAA2C,EAAE;QACjE,IAAI,CAAC,QAAQ,GAAG;YACd,QAAQ,EAAE,QAAQ,CAAC,QAAQ,IAAI,IAAI;YACnC,MAAM,EAAE,QAAQ,CAAC,MAAM,IAAI,IAAI;YAC/B,6CAA6C;YAC7C,kEAAkE;YAClE,QAAQ,EAAE,QAAQ,CAAC,QAAQ,IAAI,KAAK;YACpC,OAAO,EACL,QAAQ,CAAC,OAAO;gBAChB,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,uBAAuB,CAAC;YACvD,IAAI,EAAE,QAAQ,CAAC,IAAI,IAAI,GAAG;SAC3B,CAAC;IACJ,CAAC;CAGF","sourcesContent":["import type { AuthStorage, SessionData, UnknownObject, User } from \"@/types.js\";\n\ntype SameSiteOption = \"strict\" | \"lax\" | \"none\";\n\nexport interface SessionStorage {\n get(): SessionData;\n getUser(): User<UnknownObject> | null;\n set(data: Partial<SessionData>): void;\n setUser(data: User<UnknownObject> | null): void;\n clear(): void;\n}\n\nexport type CookieStorageSettings = {\n httpOnly: boolean;\n secure: boolean;\n sameSite: SameSiteOption;\n expires: Date;\n path: string;\n};\n\nexport const DEFAULT_COOKIE_DURATION = 60 * 15; // 15 minutes\n\nexport abstract class CookieStorage implements AuthStorage {\n protected settings: CookieStorageSettings;\n protected constructor(settings: Partial<CookieStorageSettings> = {}) {\n this.settings = {\n httpOnly: settings.httpOnly ?? true,\n secure: settings.secure ?? true,\n // the callback request comes the auth server\n // 'lax' ensures the code_verifier cookie is sent with the request\n sameSite: settings.sameSite ?? \"lax\",\n expires:\n settings.expires ??\n new Date(Date.now() + 1000 * DEFAULT_COOKIE_DURATION),\n path: settings.path ?? \"/\",\n };\n }\n abstract get(key: string): string | null;\n abstract set(key: string, value: string): void;\n}\n"]}
@@ -0,0 +1,21 @@
1
+ export declare enum OAuthTokens {
2
+ ID_TOKEN = "id_token",
3
+ ACCESS_TOKEN = "access_token",
4
+ REFRESH_TOKEN = "refresh_token"
5
+ }
6
+ export declare enum CodeVerifier {
7
+ COOKIE_NAME = "code_verifier"
8
+ }
9
+ export declare enum UserStorage {
10
+ USER = "user"
11
+ }
12
+ export interface CookieConfig {
13
+ secure?: boolean;
14
+ sameSite?: "strict" | "lax" | "none";
15
+ domain?: string;
16
+ path?: string;
17
+ maxAge?: number;
18
+ httpOnly?: boolean;
19
+ }
20
+ export type TokensCookieConfig = Record<OAuthTokens | CodeVerifier, CookieConfig>;
21
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/shared/types.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,QAAQ,aAAa;IACrB,YAAY,iBAAiB;IAC7B,aAAa,kBAAkB;CAChC;AAED,oBAAY,YAAY;IACtB,WAAW,kBAAkB;CAC9B;AACD,oBAAY,WAAW;IACrB,IAAI,SAAS;CACd;AACD,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;IACrC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,MAAM,kBAAkB,GAAG,MAAM,CACrC,WAAW,GAAG,YAAY,EAC1B,YAAY,CACb,CAAC"}
@@ -0,0 +1,15 @@
1
+ export var OAuthTokens;
2
+ (function (OAuthTokens) {
3
+ OAuthTokens["ID_TOKEN"] = "id_token";
4
+ OAuthTokens["ACCESS_TOKEN"] = "access_token";
5
+ OAuthTokens["REFRESH_TOKEN"] = "refresh_token";
6
+ })(OAuthTokens || (OAuthTokens = {}));
7
+ export var CodeVerifier;
8
+ (function (CodeVerifier) {
9
+ CodeVerifier["COOKIE_NAME"] = "code_verifier";
10
+ })(CodeVerifier || (CodeVerifier = {}));
11
+ export var UserStorage;
12
+ (function (UserStorage) {
13
+ UserStorage["USER"] = "user";
14
+ })(UserStorage || (UserStorage = {}));
15
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/shared/types.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,WAIX;AAJD,WAAY,WAAW;IACrB,oCAAqB,CAAA;IACrB,4CAA6B,CAAA;IAC7B,8CAA+B,CAAA;AACjC,CAAC,EAJW,WAAW,KAAX,WAAW,QAItB;AAED,MAAM,CAAN,IAAY,YAEX;AAFD,WAAY,YAAY;IACtB,6CAA6B,CAAA;AAC/B,CAAC,EAFW,YAAY,KAAZ,YAAY,QAEvB;AACD,MAAM,CAAN,IAAY,WAEX;AAFD,WAAY,WAAW;IACrB,4BAAa,CAAA;AACf,CAAC,EAFW,WAAW,KAAX,WAAW,QAEtB","sourcesContent":["export enum OAuthTokens {\n ID_TOKEN = \"id_token\",\n ACCESS_TOKEN = \"access_token\",\n REFRESH_TOKEN = \"refresh_token\",\n}\n\nexport enum CodeVerifier {\n COOKIE_NAME = \"code_verifier\",\n}\nexport enum UserStorage {\n USER = \"user\",\n}\nexport interface CookieConfig {\n secure?: boolean;\n sameSite?: \"strict\" | \"lax\" | \"none\";\n domain?: string;\n path?: string;\n maxAge?: number;\n httpOnly?: boolean;\n}\n\nexport type TokensCookieConfig = Record<\n OAuthTokens | CodeVerifier,\n CookieConfig\n>;\n"]}
@@ -0,0 +1,33 @@
1
+ import type { AuthStorage, Endpoints, OIDCTokenResponseBody, ParsedTokens } from "../types.js";
2
+ import { OAuth2Client } from "oslo/oauth2";
3
+ import type { PKCEConsumer, PKCEProducer } from "../services/types.js";
4
+ /**
5
+ * Given a PKCE code verifier, derive the code challenge using SHA
6
+ */
7
+ export declare function deriveCodeChallenge(codeVerifier: string, method?: "Plain" | "S256"): Promise<string>;
8
+ export declare function getEndpointsWithOverrides(oauthServer: string, endpointOverrides?: Partial<Endpoints>): Promise<Endpoints>;
9
+ export declare function generateOauthLoginUrl(config: {
10
+ clientId: string;
11
+ scopes: string[];
12
+ state: string;
13
+ redirectUrl: string;
14
+ oauthServer: string;
15
+ nonce?: string;
16
+ endpointOverrides?: Partial<Endpoints>;
17
+ pkceConsumer: PKCEConsumer;
18
+ }): Promise<URL>;
19
+ export declare function generateOauthLogoutUrl(config: {
20
+ clientId: string;
21
+ scopes: string[];
22
+ oauthServer: string;
23
+ endpointOverrides?: Partial<Endpoints>;
24
+ pkceConsumer: PKCEConsumer;
25
+ }): Promise<URL>;
26
+ export declare function buildOauth2Client(clientId: string, redirectUri: string, endpoints: Endpoints): OAuth2Client;
27
+ export declare function exchangeTokens(code: string, state: string, pkceProducer: PKCEProducer, oauth2Client: OAuth2Client, oauthServer: string, endpoints: Endpoints): Promise<OIDCTokenResponseBody>;
28
+ export declare function storeTokens(storage: AuthStorage, tokens: OIDCTokenResponseBody): void;
29
+ export declare function clearTokens(storage: AuthStorage): void;
30
+ export declare function clearUser(storage: AuthStorage): void;
31
+ export declare function retrieveTokens(storage: AuthStorage): OIDCTokenResponseBody | null;
32
+ export declare function validateOauth2Tokens(tokens: OIDCTokenResponseBody, endpoints: Endpoints, oauth2Client: OAuth2Client, issuer: string): Promise<ParsedTokens>;
33
+ //# sourceMappingURL=util.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../src/shared/util.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,WAAW,EACX,SAAS,EAET,qBAAqB,EACrB,YAAY,EACb,MAAM,YAAY,CAAC;AAEpB,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAI3C,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGtE;;GAEG;AACH,wBAAsB,mBAAmB,CACvC,YAAY,EAAE,MAAM,EACpB,MAAM,GAAE,OAAO,GAAG,MAAe,GAChC,OAAO,CAAC,MAAM,CAAC,CAajB;AAED,wBAAsB,yBAAyB,CAC7C,WAAW,EAAE,MAAM,EACnB,iBAAiB,GAAE,OAAO,CAAC,SAAS,CAAM,GACzC,OAAO,CAAC,SAAS,CAAC,CAMpB;AAED,wBAAsB,qBAAqB,CAAC,MAAM,EAAE;IAClD,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;IAEvC,YAAY,EAAE,YAAY,CAAC;CAC5B,GAAG,OAAO,CAAC,GAAG,CAAC,CA4Bf;AAED,wBAAsB,sBAAsB,CAAC,MAAM,EAAE;IACnD,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,iBAAiB,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;IAEvC,YAAY,EAAE,YAAY,CAAC;CAC5B,GAAG,OAAO,CAAC,GAAG,CAAC,CAIf;AAED,wBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,SAAS,GACnB,YAAY,CAId;AAED,wBAAsB,cAAc,CAClC,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,MAAM,EACb,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,YAAY,EAC1B,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,SAAS,kCAqBrB;AAED,wBAAgB,WAAW,CACzB,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,qBAAqB,QAO9B;AAED,wBAAgB,WAAW,CAAC,OAAO,EAAE,WAAW,QAO/C;AACD,wBAAgB,SAAS,CAAC,OAAO,EAAE,WAAW,QAG7C;AAED,wBAAgB,cAAc,CAC5B,OAAO,EAAE,WAAW,GACnB,qBAAqB,GAAG,IAAI,CAY9B;AAED,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,qBAAqB,EAC7B,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,YAAY,EAC1B,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,YAAY,CAAC,CA2BvB"}
@@ -0,0 +1,128 @@
1
+ // Utility functions shared by auth server and client integrations
2
+ // Typically these functions should be used inside AuthenticationInitiator and AuthenticationResolver implementations
3
+ import { CodeVerifier, OAuthTokens } from "./types.js";
4
+ import { OAuth2Client } from "oslo/oauth2";
5
+ import { getIssuerVariations, getOauthEndpoints } from "../lib/oauth.js";
6
+ import * as jose from "jose";
7
+ import { withoutUndefined } from "../utils.js";
8
+ import { GenericUserSession } from "../shared/UserSession.js";
9
+ /**
10
+ * Given a PKCE code verifier, derive the code challenge using SHA
11
+ */
12
+ export async function deriveCodeChallenge(codeVerifier, method = "S256") {
13
+ if (method === "Plain") {
14
+ console.warn("Using insecure plain code challenge method");
15
+ return codeVerifier;
16
+ }
17
+ const encoder = new TextEncoder();
18
+ const data = encoder.encode(codeVerifier);
19
+ const digest = await crypto.subtle.digest("SHA-256", data);
20
+ return btoa(String.fromCharCode(...new Uint8Array(digest)))
21
+ .replace(/\+/g, "-")
22
+ .replace(/\//g, "_")
23
+ .replace(/=+$/, "");
24
+ }
25
+ export async function getEndpointsWithOverrides(oauthServer, endpointOverrides = {}) {
26
+ const endpoints = await getOauthEndpoints(oauthServer);
27
+ return {
28
+ ...endpoints,
29
+ ...endpointOverrides,
30
+ };
31
+ }
32
+ export async function generateOauthLoginUrl(config) {
33
+ const endpoints = await getEndpointsWithOverrides(config.oauthServer, config.endpointOverrides);
34
+ const oauth2Client = buildOauth2Client(config.clientId, config.redirectUrl, endpoints);
35
+ const challenge = await config.pkceConsumer.getCodeChallenge();
36
+ const oAuthUrl = await oauth2Client.createAuthorizationURL({
37
+ state: config.state,
38
+ scopes: config.scopes,
39
+ });
40
+ // The OAuth2 client supports PKCE, but does not allow passing in a code challenge from some other source
41
+ // It only allows passing in a code verifier which it then hashes itself.
42
+ oAuthUrl.searchParams.append("code_challenge", challenge);
43
+ oAuthUrl.searchParams.append("code_challenge_method", "S256");
44
+ if (config.nonce) {
45
+ // nonce isn't supported by oslo, so we add it manually
46
+ oAuthUrl.searchParams.append("nonce", config.nonce);
47
+ }
48
+ // Required by the auth server for offline_access scope
49
+ oAuthUrl.searchParams.append("prompt", "consent");
50
+ console.log("Generated OAuth URL", oAuthUrl.toString());
51
+ return oAuthUrl;
52
+ }
53
+ export async function generateOauthLogoutUrl(config) {
54
+ // TODO TECH-676: Implement logout
55
+ console.log("generateOauthLogoutUrl not implemented", config);
56
+ return new URL("http://localhost");
57
+ }
58
+ export function buildOauth2Client(clientId, redirectUri, endpoints) {
59
+ return new OAuth2Client(clientId, endpoints.auth, endpoints.token, {
60
+ redirectURI: redirectUri,
61
+ });
62
+ }
63
+ export async function exchangeTokens(code, state, pkceProducer, oauth2Client, oauthServer, endpoints) {
64
+ const codeVerifier = await pkceProducer.getCodeVerifier();
65
+ if (!codeVerifier)
66
+ throw new Error("Code verifier not found in state");
67
+ const tokens = await oauth2Client.validateAuthorizationCode(code, {
68
+ codeVerifier,
69
+ });
70
+ // Validate relevant tokens
71
+ try {
72
+ await validateOauth2Tokens(tokens, endpoints, oauth2Client, oauthServer);
73
+ }
74
+ catch (error) {
75
+ console.error("tokenExchange error", { error, tokens });
76
+ throw new Error(`OIDC tokens validation failed: ${error.message}`);
77
+ }
78
+ return tokens;
79
+ }
80
+ export function storeTokens(storage, tokens) {
81
+ // store tokens in storage ( TODO we should probably store them against the state to allow multiple logins )
82
+ storage.set(OAuthTokens.ID_TOKEN, tokens.id_token);
83
+ storage.set(OAuthTokens.ACCESS_TOKEN, tokens.access_token);
84
+ if (tokens.refresh_token)
85
+ storage.set(OAuthTokens.REFRESH_TOKEN, tokens.refresh_token);
86
+ }
87
+ export function clearTokens(storage) {
88
+ Object.values(OAuthTokens).forEach((cookie) => {
89
+ storage.set(cookie, "");
90
+ });
91
+ Object.values(CodeVerifier.COOKIE_NAME).forEach((cookie) => {
92
+ storage.set(cookie, "");
93
+ });
94
+ }
95
+ export function clearUser(storage) {
96
+ const userSession = new GenericUserSession(storage);
97
+ userSession.set(null);
98
+ }
99
+ export function retrieveTokens(storage) {
100
+ const idToken = storage.get(OAuthTokens.ID_TOKEN);
101
+ const accessToken = storage.get(OAuthTokens.ACCESS_TOKEN);
102
+ const refreshToken = storage.get(OAuthTokens.REFRESH_TOKEN);
103
+ if (!idToken || !accessToken)
104
+ return null;
105
+ return {
106
+ id_token: idToken,
107
+ access_token: accessToken,
108
+ refresh_token: refreshToken ?? undefined,
109
+ };
110
+ }
111
+ export async function validateOauth2Tokens(tokens, endpoints, oauth2Client, issuer) {
112
+ const JWKS = jose.createRemoteJWKSet(new URL(endpoints.jwks));
113
+ // validate the ID token
114
+ const idTokenResponse = await jose.jwtVerify(tokens.id_token, JWKS, {
115
+ issuer: getIssuerVariations(issuer),
116
+ audience: oauth2Client.clientId,
117
+ });
118
+ // validate the access token
119
+ const accessTokenResponse = await jose.jwtVerify(tokens.access_token, JWKS, {
120
+ issuer: getIssuerVariations(issuer),
121
+ });
122
+ return withoutUndefined({
123
+ id_token: idTokenResponse.payload,
124
+ access_token: accessTokenResponse.payload,
125
+ refresh_token: tokens.refresh_token,
126
+ });
127
+ }
128
+ //# sourceMappingURL=util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../src/shared/util.ts"],"names":[],"mappings":"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","sourcesContent":["// Utility functions shared by auth server and client integrations\n// Typically these functions should be used inside AuthenticationInitiator and AuthenticationResolver implementations\n\n// Utility functions shared by auth server and client integrations\n// Typically these functions should be used inside AuthenticationInitiator and AuthenticationResolver implementations\nimport type {\n AuthStorage,\n Endpoints,\n JWTPayload,\n OIDCTokenResponseBody,\n ParsedTokens,\n} from \"@/types.js\";\nimport { CodeVerifier, OAuthTokens } from \"./types.js\";\nimport { OAuth2Client } from \"oslo/oauth2\";\nimport { getIssuerVariations, getOauthEndpoints } from \"@/lib/oauth.js\";\nimport * as jose from \"jose\";\nimport { withoutUndefined } from \"@/utils.js\";\nimport type { PKCEConsumer, PKCEProducer } from \"@/services/types.js\";\nimport { GenericUserSession } from \"@/shared/UserSession.js\";\n\n/**\n * Given a PKCE code verifier, derive the code challenge using SHA\n */\nexport async function deriveCodeChallenge(\n codeVerifier: string,\n method: \"Plain\" | \"S256\" = \"S256\",\n): Promise<string> {\n if (method === \"Plain\") {\n console.warn(\"Using insecure plain code challenge method\");\n return codeVerifier;\n }\n\n const encoder = new TextEncoder();\n const data = encoder.encode(codeVerifier);\n const digest = await crypto.subtle.digest(\"SHA-256\", data);\n return btoa(String.fromCharCode(...new Uint8Array(digest)))\n .replace(/\\+/g, \"-\")\n .replace(/\\//g, \"_\")\n .replace(/=+$/, \"\");\n}\n\nexport async function getEndpointsWithOverrides(\n oauthServer: string,\n endpointOverrides: Partial<Endpoints> = {},\n): Promise<Endpoints> {\n const endpoints = await getOauthEndpoints(oauthServer);\n return {\n ...endpoints,\n ...endpointOverrides,\n };\n}\n\nexport async function generateOauthLoginUrl(config: {\n clientId: string;\n scopes: string[];\n state: string;\n redirectUrl: string;\n oauthServer: string;\n nonce?: string;\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n}): Promise<URL> {\n const endpoints = await getEndpointsWithOverrides(\n config.oauthServer,\n config.endpointOverrides,\n );\n const oauth2Client = buildOauth2Client(\n config.clientId,\n config.redirectUrl,\n endpoints,\n );\n const challenge = await config.pkceConsumer.getCodeChallenge();\n const oAuthUrl = await oauth2Client.createAuthorizationURL({\n state: config.state,\n scopes: config.scopes,\n });\n // The OAuth2 client supports PKCE, but does not allow passing in a code challenge from some other source\n // It only allows passing in a code verifier which it then hashes itself.\n oAuthUrl.searchParams.append(\"code_challenge\", challenge);\n oAuthUrl.searchParams.append(\"code_challenge_method\", \"S256\");\n if (config.nonce) {\n // nonce isn't supported by oslo, so we add it manually\n oAuthUrl.searchParams.append(\"nonce\", config.nonce);\n }\n // Required by the auth server for offline_access scope\n oAuthUrl.searchParams.append(\"prompt\", \"consent\");\n\n console.log(\"Generated OAuth URL\", oAuthUrl.toString());\n return oAuthUrl;\n}\n\nexport async function generateOauthLogoutUrl(config: {\n clientId: string;\n scopes: string[];\n oauthServer: string;\n endpointOverrides?: Partial<Endpoints>;\n // used to get the PKCE challenge\n pkceConsumer: PKCEConsumer;\n}): Promise<URL> {\n // TODO TECH-676: Implement logout\n console.log(\"generateOauthLogoutUrl not implemented\", config);\n return new URL(\"http://localhost\");\n}\n\nexport function buildOauth2Client(\n clientId: string,\n redirectUri: string,\n endpoints: Endpoints,\n): OAuth2Client {\n return new OAuth2Client(clientId, endpoints.auth, endpoints.token, {\n redirectURI: redirectUri,\n });\n}\n\nexport async function exchangeTokens(\n code: string,\n state: string,\n pkceProducer: PKCEProducer,\n oauth2Client: OAuth2Client,\n oauthServer: string,\n endpoints: Endpoints,\n) {\n const codeVerifier = await pkceProducer.getCodeVerifier();\n if (!codeVerifier) throw new Error(\"Code verifier not found in state\");\n\n const tokens =\n await oauth2Client.validateAuthorizationCode<OIDCTokenResponseBody>(code, {\n codeVerifier,\n });\n\n // Validate relevant tokens\n try {\n await validateOauth2Tokens(tokens, endpoints, oauth2Client, oauthServer);\n } catch (error) {\n console.error(\"tokenExchange error\", { error, tokens });\n throw new Error(\n `OIDC tokens validation failed: ${(error as Error).message}`,\n );\n }\n\n return tokens;\n}\n\nexport function storeTokens(\n storage: AuthStorage,\n tokens: OIDCTokenResponseBody,\n) {\n // store tokens in storage ( TODO we should probably store them against the state to allow multiple logins )\n storage.set(OAuthTokens.ID_TOKEN, tokens.id_token);\n storage.set(OAuthTokens.ACCESS_TOKEN, tokens.access_token);\n if (tokens.refresh_token)\n storage.set(OAuthTokens.REFRESH_TOKEN, tokens.refresh_token);\n}\n\nexport function clearTokens(storage: AuthStorage) {\n Object.values(OAuthTokens).forEach((cookie) => {\n storage.set(cookie, \"\");\n });\n Object.values(CodeVerifier.COOKIE_NAME).forEach((cookie) => {\n storage.set(cookie, \"\");\n });\n}\nexport function clearUser(storage: AuthStorage) {\n const userSession = new GenericUserSession(storage);\n userSession.set(null);\n}\n\nexport function retrieveTokens(\n storage: AuthStorage,\n): OIDCTokenResponseBody | null {\n const idToken = storage.get(OAuthTokens.ID_TOKEN);\n const accessToken = storage.get(OAuthTokens.ACCESS_TOKEN);\n const refreshToken = storage.get(OAuthTokens.REFRESH_TOKEN);\n\n if (!idToken || !accessToken) return null;\n\n return {\n id_token: idToken,\n access_token: accessToken,\n refresh_token: refreshToken ?? undefined,\n };\n}\n\nexport async function validateOauth2Tokens(\n tokens: OIDCTokenResponseBody,\n endpoints: Endpoints,\n oauth2Client: OAuth2Client,\n issuer: string,\n): Promise<ParsedTokens> {\n const JWKS = jose.createRemoteJWKSet(new URL(endpoints.jwks));\n\n // validate the ID token\n const idTokenResponse = await jose.jwtVerify<JWTPayload>(\n tokens.id_token,\n JWKS,\n {\n issuer: getIssuerVariations(issuer),\n audience: oauth2Client.clientId,\n },\n );\n\n // validate the access token\n const accessTokenResponse = await jose.jwtVerify<JWTPayload>(\n tokens.access_token,\n JWKS,\n {\n issuer: getIssuerVariations(issuer),\n },\n );\n\n return withoutUndefined({\n id_token: idTokenResponse.payload,\n access_token: accessTokenResponse.payload,\n refresh_token: tokens.refresh_token,\n });\n}\n"]}
@@ -0,0 +1,146 @@
1
+ import type { TokenResponseBody } from "oslo/oauth2";
2
+ import type { JWT } from "oslo/jwt";
3
+ type UnknownObject = Record<string, unknown>;
4
+ type EmptyObject = Record<string, never>;
5
+ type DisplayMode = "iframe" | "redirect" | "new_tab" | "custom_tab";
6
+ interface AuthSessionService {
7
+ loadAuthorizationUrl(authorizationURL: string, displayMode: DisplayMode): void;
8
+ getAuthorizationUrl(scopes: string[], overrideDisplayMode: DisplayMode, nonce?: string): Promise<string>;
9
+ signIn(displayMode: DisplayMode, scopes: string[], nonce?: string): Promise<void>;
10
+ tokenExchange(responseUrl: string): Promise<SessionData>;
11
+ getSessionData(): SessionData;
12
+ updateSessionData(data: SessionData): void;
13
+ getUserInfoService(): Promise<UserInfoService>;
14
+ }
15
+ interface TokenService {
16
+ exchangeCodeForTokens(authCode: string): Promise<Tokens>;
17
+ validateIdToken(idToken: string, nonce: string): boolean;
18
+ refreshAccessToken(refreshToken: string): Promise<Tokens>;
19
+ }
20
+ interface UserInfoService {
21
+ getUserInfo<T extends UnknownObject>(accessToken: string, idToken: string | null): Promise<User<T> | null>;
22
+ }
23
+ interface ResourceService {
24
+ getProtectedResource(accessToken: string): Promise<unknown>;
25
+ }
26
+ type AuthRequest = {
27
+ clientId: string;
28
+ redirectUri: string;
29
+ state: string;
30
+ nonce: string;
31
+ scope: string;
32
+ };
33
+ type Endpoints = {
34
+ jwks: string;
35
+ auth: string;
36
+ token: string;
37
+ userinfo: string;
38
+ challenge?: string;
39
+ };
40
+ type Config = {
41
+ oauthServer: string;
42
+ endpoints?: Endpoints;
43
+ };
44
+ type SessionData = {
45
+ authenticated: boolean;
46
+ state?: string;
47
+ accessToken?: string;
48
+ refreshToken?: string;
49
+ idToken?: string;
50
+ timestamp?: number;
51
+ expiresIn?: number;
52
+ codeVerifier?: string;
53
+ displayMode?: DisplayMode;
54
+ openerUrl?: string;
55
+ };
56
+ type OIDCTokenResponseBody = TokenResponseBody & {
57
+ id_token: string;
58
+ };
59
+ type ParsedTokens = {
60
+ id_token: JWTPayload;
61
+ access_token: JWTPayload;
62
+ refresh_token?: string;
63
+ };
64
+ type ForwardedTokens = Record<string, {
65
+ idToken?: string;
66
+ accessToken?: string;
67
+ refreshToken?: string;
68
+ }>;
69
+ type ForwardedTokensJWT = Record<string, {
70
+ id_token?: string;
71
+ access_token?: string;
72
+ refresh_token?: string;
73
+ scope?: string;
74
+ }>;
75
+ type JWTPayload = JWT["payload"] & {
76
+ iss: string;
77
+ aud: string;
78
+ sub: string;
79
+ iat: number;
80
+ exp: number;
81
+ };
82
+ type IdTokenPayload = JWTPayload & {
83
+ forwardedTokens?: ForwardedTokensJWT;
84
+ email?: string;
85
+ name?: string;
86
+ picture?: string;
87
+ nonce: string;
88
+ at_hash: string;
89
+ };
90
+ type IdToken = Omit<JWT, "payload"> & {
91
+ payload: IdTokenPayload;
92
+ };
93
+ type Tokens = {
94
+ idToken: string;
95
+ accessToken: string;
96
+ refreshToken: string;
97
+ forwardedTokens: ForwardedTokens;
98
+ };
99
+ type BaseUser = {
100
+ id: string;
101
+ email?: string;
102
+ name?: string;
103
+ given_name?: string;
104
+ family_name?: string;
105
+ picture?: string;
106
+ updated_at?: Date;
107
+ };
108
+ type User<T extends UnknownObject = EmptyObject> = BaseUser & Partial<Tokens> & T;
109
+ type OpenIdConfiguration = {
110
+ authorization_endpoint: string;
111
+ claims_parameter_supported: boolean;
112
+ claims_supported: string[];
113
+ code_challenge_methods_supported: string[];
114
+ end_session_endpoint: string;
115
+ grant_types_supported: string[];
116
+ issuer: string;
117
+ jwks_uri: string;
118
+ authorization_response_iss_parameter_supported: boolean;
119
+ response_modes_supported: string[];
120
+ response_types_supported: string[];
121
+ scopes_supported: string[];
122
+ subject_types_supported: string[];
123
+ token_endpoint_auth_methods_supported: string[];
124
+ token_endpoint_auth_signing_alg_values_supported: string[];
125
+ token_endpoint: string;
126
+ id_token_signing_alg_values_supported: string[];
127
+ pushed_authorization_request_endpoint: string;
128
+ request_parameter_supported: boolean;
129
+ request_uri_parameter_supported: boolean;
130
+ userinfo_endpoint: string;
131
+ claim_types_supported: string[];
132
+ };
133
+ type LoginPostMessage = {
134
+ source: string;
135
+ type: string;
136
+ clientId: string;
137
+ data: {
138
+ url: string;
139
+ };
140
+ };
141
+ export type { LoginPostMessage, AuthSessionService, TokenService, UserInfoService, ResourceService, AuthRequest, Tokens, Endpoints, Config, SessionData, OIDCTokenResponseBody, ParsedTokens, BaseUser, User, DisplayMode, UnknownObject, EmptyObject, ForwardedTokens, ForwardedTokensJWT, JWTPayload, IdTokenPayload, IdToken, OpenIdConfiguration, };
142
+ export interface AuthStorage {
143
+ get(key: string): string | null;
144
+ set(key: string, value: string): void;
145
+ }
146
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/types.ts"],"names":[],"mappings":"","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\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};\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 timestamp?: number;\n expiresIn?: number;\n codeVerifier?: string;\n displayMode?: DisplayMode;\n openerUrl?: string;\n};\n\ntype OIDCTokenResponseBody = TokenResponseBody & { id_token: string };\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\ntype Tokens = {\n idToken: string;\n accessToken: string;\n refreshToken: string;\n forwardedTokens: ForwardedTokens;\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 &\n Partial<Tokens> &\n 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};\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};\n\nexport interface AuthStorage {\n get(key: string): string | null;\n set(key: string, value: string): void;\n}\n"]}
@@ -0,0 +1,17 @@
1
+ import { type ClassValue } from "clsx";
2
+ /**
3
+ * Checks if a popup window is blocked by the browser.
4
+ *
5
+ * This function attempts to open a small popup window and then checks if it was successfully created.
6
+ * If the popup is blocked by the browser, the function returns `true`. Otherwise, it returns `false`.
7
+ *
8
+ * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.
9
+ */
10
+ declare const isPopupBlocked: () => boolean;
11
+ declare const cn: (...inputs: ClassValue[]) => string;
12
+ type WithoutUndefined<T> = {
13
+ [K in keyof T as undefined extends T[K] ? never : K]: T[K];
14
+ };
15
+ export declare const withoutUndefined: <T extends { [K in keyof T]: unknown; }>(obj: T) => WithoutUndefined<T>;
16
+ export { cn, isPopupBlocked };
17
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,UAAU,EAAE,MAAM,MAAM,CAAC;AAG7C;;;;;;;GAOG;AACH,QAAA,MAAM,cAAc,QAAO,OAsB1B,CAAC;AAEF,QAAA,MAAM,EAAE,cAAe,UAAU,EAAE,WAElC,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,CAAY,IAAP,MAAM,CAAC,GAAG,OAAO,GAAE,OAC/D,CAAC,KACL,gBAAgB,CAAC,CAAC,CAapB,CAAC;AAEF,OAAO,EAAE,EAAE,EAAE,cAAc,EAAE,CAAC"}
@@ -0,0 +1,48 @@
1
+ import { clsx } from "clsx";
2
+ import { twMerge } from "tailwind-merge";
3
+ /**
4
+ * Checks if a popup window is blocked by the browser.
5
+ *
6
+ * This function attempts to open a small popup window and then checks if it was successfully created.
7
+ * If the popup is blocked by the browser, the function returns `true`. Otherwise, it returns `false`.
8
+ *
9
+ * @returns {boolean} - `true` if the popup is blocked, `false` otherwise.
10
+ */
11
+ const isPopupBlocked = () => {
12
+ // First we try to open a small popup window. It either returns a window object or null.
13
+ const popup = window.open("", "", "width=1,height=1");
14
+ // If window.open() returns null, popup is definitely blocked
15
+ if (!popup) {
16
+ return true;
17
+ }
18
+ try {
19
+ // Try to access a property of the popup to check if it's usable
20
+ if (typeof popup.closed === "undefined") {
21
+ throw new Error("Popup is blocked");
22
+ }
23
+ }
24
+ catch {
25
+ // Accessing the popup's properties throws an error if the popup is blocked
26
+ return true;
27
+ }
28
+ // Close the popup immediately if it was opened
29
+ popup.close();
30
+ return false;
31
+ };
32
+ const cn = (...inputs) => {
33
+ return twMerge(clsx(inputs));
34
+ };
35
+ export const withoutUndefined = (obj) => {
36
+ const result = {};
37
+ for (const key in obj) {
38
+ if (obj[key] !== undefined) {
39
+ // TypeScript needs assurance that key is a valid key in WithoutUndefined<T>
40
+ // We use type assertion here
41
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
42
+ result[key] = obj[key];
43
+ }
44
+ }
45
+ return result;
46
+ };
47
+ export { cn, isPopupBlocked };
48
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAmB,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAEzC;;;;;;;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;AAEF,MAAM,EAAE,GAAG,CAAC,GAAG,MAAoB,EAAE,EAAE;IACrC,OAAO,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;AAC/B,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,EAAE,EAAE,cAAc,EAAE,CAAC","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\n/**\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\nconst cn = (...inputs: ClassValue[]) => {\n return twMerge(clsx(inputs));\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 { cn, isPopupBlocked };\n"]}
@@ -0,0 +1,2 @@
1
+ export { authMiddleware, auth, withAuth } from "../nextjs/middleware.js";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/worker/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { authMiddleware, auth, withAuth } from "../nextjs/middleware.js";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/worker/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC","sourcesContent":["export { authMiddleware, auth, withAuth } from \"@/nextjs/middleware.js\";"]}