@civic/auth 0.1.2 → 0.1.4-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (737) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/README.md +329 -116
  3. package/dist/cjs/browser/storage.d.ts +3 -0
  4. package/dist/cjs/browser/storage.d.ts.map +1 -1
  5. package/dist/cjs/browser/storage.js +8 -0
  6. package/dist/cjs/browser/storage.js.map +1 -1
  7. package/dist/cjs/lib/cookies.d.ts +2 -2
  8. package/dist/cjs/lib/cookies.d.ts.map +1 -1
  9. package/dist/cjs/lib/cookies.js +7 -5
  10. package/dist/cjs/lib/cookies.js.map +1 -1
  11. package/dist/cjs/lib/postMessage.js +1 -1
  12. package/dist/cjs/lib/postMessage.js.map +1 -1
  13. package/dist/cjs/lib/windowUtil.d.ts.map +1 -1
  14. package/dist/cjs/lib/windowUtil.js +1 -0
  15. package/dist/cjs/lib/windowUtil.js.map +1 -1
  16. package/dist/cjs/nextjs/config.d.ts.map +1 -1
  17. package/dist/cjs/nextjs/config.js +12 -0
  18. package/dist/cjs/nextjs/config.js.map +1 -1
  19. package/dist/cjs/nextjs/hooks/index.d.ts +1 -1
  20. package/dist/cjs/nextjs/hooks/index.d.ts.map +1 -1
  21. package/dist/cjs/nextjs/hooks/index.js +3 -3
  22. package/dist/cjs/nextjs/hooks/index.js.map +1 -1
  23. package/dist/cjs/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  24. package/dist/cjs/nextjs/hooks/useUserCookie.js +43 -14
  25. package/dist/cjs/nextjs/hooks/useUserCookie.js.map +1 -1
  26. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +5 -1
  27. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  28. package/dist/cjs/nextjs/providers/NextAuthProvider.js +74 -35
  29. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -1
  30. package/dist/cjs/reactjs/components/UserButton.js +20 -10
  31. package/dist/cjs/reactjs/components/UserButton.js.map +1 -1
  32. package/dist/cjs/reactjs/hooks/index.d.ts +0 -1
  33. package/dist/cjs/reactjs/hooks/index.d.ts.map +1 -1
  34. package/dist/cjs/reactjs/hooks/index.js +1 -3
  35. package/dist/cjs/reactjs/hooks/index.js.map +1 -1
  36. package/dist/cjs/services/AuthenticationService.d.ts +4 -1
  37. package/dist/cjs/services/AuthenticationService.d.ts.map +1 -1
  38. package/dist/cjs/services/AuthenticationService.js +38 -7
  39. package/dist/cjs/services/AuthenticationService.js.map +1 -1
  40. package/dist/cjs/shared/components/BlockDisplay.d.ts +7 -0
  41. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +1 -0
  42. package/dist/cjs/shared/components/BlockDisplay.js +31 -0
  43. package/dist/cjs/shared/components/BlockDisplay.js.map +1 -0
  44. package/dist/cjs/shared/components/CivicAuthIframe.js +17 -7
  45. package/dist/cjs/shared/components/CivicAuthIframe.js.map +1 -1
  46. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  47. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +39 -20
  48. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +1 -1
  49. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +7 -0
  50. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -0
  51. package/dist/cjs/shared/components/IFrameAndLoading.js +28 -0
  52. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -0
  53. package/dist/cjs/shared/hooks/index.d.ts +5 -1
  54. package/dist/cjs/shared/hooks/index.d.ts.map +1 -1
  55. package/dist/cjs/shared/hooks/index.js +11 -3
  56. package/dist/cjs/shared/hooks/index.js.map +1 -1
  57. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  58. package/dist/cjs/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  59. package/dist/cjs/shared/hooks/useCivicAuthConfig.js +13 -0
  60. package/dist/cjs/shared/hooks/useCivicAuthConfig.js.map +1 -0
  61. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  62. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  63. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js +16 -0
  64. package/dist/cjs/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  65. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts +3 -0
  66. package/dist/cjs/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  67. package/dist/cjs/shared/hooks/useCurrentUrl.js +27 -0
  68. package/dist/cjs/shared/hooks/useCurrentUrl.js.map +1 -0
  69. package/dist/cjs/shared/hooks/useIsInIframe.d.ts +3 -0
  70. package/dist/cjs/shared/hooks/useIsInIframe.d.ts.map +1 -0
  71. package/dist/cjs/shared/hooks/useIsInIframe.js +17 -0
  72. package/dist/cjs/shared/hooks/useIsInIframe.js.map +1 -0
  73. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  74. package/dist/cjs/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  75. package/dist/cjs/shared/hooks/useOAuthEndpoints.js +17 -0
  76. package/dist/cjs/shared/hooks/useOAuthEndpoints.js.map +1 -0
  77. package/dist/cjs/shared/hooks/useRefresh.d.ts +4 -0
  78. package/dist/cjs/shared/hooks/useRefresh.d.ts.map +1 -0
  79. package/dist/cjs/shared/hooks/useRefresh.js +41 -0
  80. package/dist/cjs/shared/hooks/useRefresh.js.map +1 -0
  81. package/dist/cjs/shared/hooks/useSession.d.ts +1 -1
  82. package/dist/cjs/shared/hooks/useSession.d.ts.map +1 -1
  83. package/dist/cjs/shared/hooks/useSignIn.d.ts +14 -0
  84. package/dist/cjs/shared/hooks/useSignIn.d.ts.map +1 -0
  85. package/dist/cjs/shared/hooks/useSignIn.js +74 -0
  86. package/dist/cjs/shared/hooks/useSignIn.js.map +1 -0
  87. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  88. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  89. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js +30 -0
  90. package/dist/cjs/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  91. package/dist/cjs/shared/lib/types.d.ts +14 -1
  92. package/dist/cjs/shared/lib/types.d.ts.map +1 -1
  93. package/dist/cjs/shared/lib/types.js +2 -0
  94. package/dist/cjs/shared/lib/types.js.map +1 -1
  95. package/dist/cjs/shared/lib/util.d.ts.map +1 -1
  96. package/dist/cjs/shared/lib/util.js +27 -9
  97. package/dist/cjs/shared/lib/util.js.map +1 -1
  98. package/dist/cjs/shared/providers/AuthProvider.d.ts +3 -2
  99. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +1 -1
  100. package/dist/cjs/shared/providers/AuthProvider.js +53 -244
  101. package/dist/cjs/shared/providers/AuthProvider.js.map +1 -1
  102. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  103. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  104. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +80 -0
  105. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +1 -0
  106. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  107. package/dist/cjs/shared/providers/CivicAuthProvider.js +23 -6
  108. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +1 -1
  109. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  110. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  111. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +183 -0
  112. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  113. package/dist/cjs/shared/providers/IframeProvider.d.ts +7 -4
  114. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +1 -1
  115. package/dist/cjs/shared/providers/IframeProvider.js +37 -9
  116. package/dist/cjs/shared/providers/IframeProvider.js.map +1 -1
  117. package/dist/cjs/shared/providers/SessionProvider.d.ts +10 -4
  118. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +1 -1
  119. package/dist/cjs/shared/providers/SessionProvider.js +32 -12
  120. package/dist/cjs/shared/providers/SessionProvider.js.map +1 -1
  121. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -1
  122. package/dist/cjs/shared/providers/TokenProvider.js +29 -30
  123. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -1
  124. package/dist/cjs/shared/providers/UserProvider.d.ts +4 -3
  125. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -1
  126. package/dist/cjs/shared/providers/UserProvider.js +46 -25
  127. package/dist/cjs/shared/providers/UserProvider.js.map +1 -1
  128. package/dist/cjs/types.d.ts +1 -0
  129. package/dist/cjs/types.d.ts.map +1 -1
  130. package/dist/cjs/types.js.map +1 -1
  131. package/dist/cjs/utils.d.ts.map +1 -1
  132. package/dist/esm/browser/storage.d.ts +3 -0
  133. package/dist/esm/browser/storage.d.ts.map +1 -1
  134. package/dist/esm/browser/storage.js +8 -0
  135. package/dist/esm/browser/storage.js.map +1 -1
  136. package/dist/esm/lib/cookies.d.ts +2 -2
  137. package/dist/esm/lib/cookies.d.ts.map +1 -1
  138. package/dist/esm/lib/cookies.js +7 -5
  139. package/dist/esm/lib/cookies.js.map +1 -1
  140. package/dist/esm/lib/postMessage.js +1 -1
  141. package/dist/esm/lib/postMessage.js.map +1 -1
  142. package/dist/esm/lib/windowUtil.d.ts.map +1 -1
  143. package/dist/esm/lib/windowUtil.js +1 -0
  144. package/dist/esm/lib/windowUtil.js.map +1 -1
  145. package/dist/esm/nextjs/config.d.ts.map +1 -1
  146. package/dist/esm/nextjs/config.js +12 -0
  147. package/dist/esm/nextjs/config.js.map +1 -1
  148. package/dist/esm/nextjs/hooks/index.d.ts +1 -1
  149. package/dist/esm/nextjs/hooks/index.d.ts.map +1 -1
  150. package/dist/esm/nextjs/hooks/index.js +1 -1
  151. package/dist/esm/nextjs/hooks/index.js.map +1 -1
  152. package/dist/esm/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  153. package/dist/esm/nextjs/hooks/useUserCookie.js +45 -16
  154. package/dist/esm/nextjs/hooks/useUserCookie.js.map +1 -1
  155. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +5 -1
  156. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  157. package/dist/esm/nextjs/providers/NextAuthProvider.js +59 -30
  158. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -1
  159. package/dist/esm/reactjs/components/UserButton.js +3 -3
  160. package/dist/esm/reactjs/components/UserButton.js.map +1 -1
  161. package/dist/esm/reactjs/hooks/index.d.ts +0 -1
  162. package/dist/esm/reactjs/hooks/index.d.ts.map +1 -1
  163. package/dist/esm/reactjs/hooks/index.js +0 -1
  164. package/dist/esm/reactjs/hooks/index.js.map +1 -1
  165. package/dist/esm/services/AuthenticationService.d.ts +4 -1
  166. package/dist/esm/services/AuthenticationService.d.ts.map +1 -1
  167. package/dist/esm/services/AuthenticationService.js +39 -8
  168. package/dist/esm/services/AuthenticationService.js.map +1 -1
  169. package/dist/esm/shared/components/BlockDisplay.d.ts +7 -0
  170. package/dist/esm/shared/components/BlockDisplay.d.ts.map +1 -0
  171. package/dist/esm/shared/components/BlockDisplay.js +25 -0
  172. package/dist/esm/shared/components/BlockDisplay.js.map +1 -0
  173. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  174. package/dist/esm/shared/components/CivicAuthIframeContainer.js +23 -14
  175. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +1 -1
  176. package/dist/esm/shared/components/IFrameAndLoading.d.ts +7 -0
  177. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -0
  178. package/dist/esm/shared/components/IFrameAndLoading.js +22 -0
  179. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -0
  180. package/dist/esm/shared/hooks/index.d.ts +5 -1
  181. package/dist/esm/shared/hooks/index.d.ts.map +1 -1
  182. package/dist/esm/shared/hooks/index.js +5 -1
  183. package/dist/esm/shared/hooks/index.js.map +1 -1
  184. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  185. package/dist/esm/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  186. package/dist/esm/shared/hooks/useCivicAuthConfig.js +10 -0
  187. package/dist/esm/shared/hooks/useCivicAuthConfig.js.map +1 -0
  188. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  189. package/dist/esm/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  190. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js +13 -0
  191. package/dist/esm/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  192. package/dist/esm/shared/hooks/useCurrentUrl.d.ts +3 -0
  193. package/dist/esm/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  194. package/dist/esm/shared/hooks/useCurrentUrl.js +24 -0
  195. package/dist/esm/shared/hooks/useCurrentUrl.js.map +1 -0
  196. package/dist/esm/shared/hooks/useIsInIframe.d.ts +3 -0
  197. package/dist/esm/shared/hooks/useIsInIframe.d.ts.map +1 -0
  198. package/dist/esm/shared/hooks/useIsInIframe.js +14 -0
  199. package/dist/esm/shared/hooks/useIsInIframe.js.map +1 -0
  200. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  201. package/dist/esm/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  202. package/dist/esm/shared/hooks/useOAuthEndpoints.js +14 -0
  203. package/dist/esm/shared/hooks/useOAuthEndpoints.js.map +1 -0
  204. package/dist/esm/shared/hooks/useRefresh.d.ts +4 -0
  205. package/dist/esm/shared/hooks/useRefresh.d.ts.map +1 -0
  206. package/dist/esm/shared/hooks/useRefresh.js +38 -0
  207. package/dist/esm/shared/hooks/useRefresh.js.map +1 -0
  208. package/dist/esm/shared/hooks/useSession.d.ts +1 -1
  209. package/dist/esm/shared/hooks/useSession.d.ts.map +1 -1
  210. package/dist/esm/shared/hooks/useSignIn.d.ts +14 -0
  211. package/dist/esm/shared/hooks/useSignIn.d.ts.map +1 -0
  212. package/dist/esm/shared/hooks/useSignIn.js +71 -0
  213. package/dist/esm/shared/hooks/useSignIn.js.map +1 -0
  214. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts +4 -0
  215. package/dist/esm/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -1
  216. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js +30 -0
  217. package/dist/esm/shared/lib/GenericAuthenticationRefresher.js.map +1 -1
  218. package/dist/esm/shared/lib/types.d.ts +14 -1
  219. package/dist/esm/shared/lib/types.d.ts.map +1 -1
  220. package/dist/esm/shared/lib/types.js +2 -0
  221. package/dist/esm/shared/lib/types.js.map +1 -1
  222. package/dist/esm/shared/lib/util.d.ts.map +1 -1
  223. package/dist/esm/shared/lib/util.js +10 -2
  224. package/dist/esm/shared/lib/util.js.map +1 -1
  225. package/dist/esm/shared/providers/AuthProvider.d.ts +3 -2
  226. package/dist/esm/shared/providers/AuthProvider.d.ts.map +1 -1
  227. package/dist/esm/shared/providers/AuthProvider.js +37 -238
  228. package/dist/esm/shared/providers/AuthProvider.js.map +1 -1
  229. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +16 -0
  230. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  231. package/dist/esm/shared/providers/CivicAuthConfigContext.js +43 -0
  232. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +1 -0
  233. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  234. package/dist/esm/shared/providers/CivicAuthProvider.js +23 -6
  235. package/dist/esm/shared/providers/CivicAuthProvider.js.map +1 -1
  236. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  237. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  238. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +146 -0
  239. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  240. package/dist/esm/shared/providers/IframeProvider.d.ts +7 -4
  241. package/dist/esm/shared/providers/IframeProvider.d.ts.map +1 -1
  242. package/dist/esm/shared/providers/IframeProvider.js +21 -3
  243. package/dist/esm/shared/providers/IframeProvider.js.map +1 -1
  244. package/dist/esm/shared/providers/SessionProvider.d.ts +10 -4
  245. package/dist/esm/shared/providers/SessionProvider.d.ts.map +1 -1
  246. package/dist/esm/shared/providers/SessionProvider.js +15 -5
  247. package/dist/esm/shared/providers/SessionProvider.js.map +1 -1
  248. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -1
  249. package/dist/esm/shared/providers/TokenProvider.js +13 -24
  250. package/dist/esm/shared/providers/TokenProvider.js.map +1 -1
  251. package/dist/esm/shared/providers/UserProvider.d.ts +4 -3
  252. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -1
  253. package/dist/esm/shared/providers/UserProvider.js +30 -19
  254. package/dist/esm/shared/providers/UserProvider.js.map +1 -1
  255. package/dist/esm/types.d.ts +1 -0
  256. package/dist/esm/types.d.ts.map +1 -1
  257. package/dist/esm/types.js.map +1 -1
  258. package/dist/esm/utils.d.ts.map +1 -1
  259. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -1
  260. package/dist/src/nextjs/hooks/useUserCookie.js +45 -16
  261. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -1
  262. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  263. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  264. package/dist/tsconfig.tsbuildinfo +1 -1
  265. package/package.json +9 -3
  266. package/.eslintignore +0 -3
  267. package/.eslintrc.json +0 -10
  268. package/.prettierignore +0 -3
  269. package/.prettierrc +0 -1
  270. package/.turbo/turbo-build.log +0 -13
  271. package/.turbo/turbo-lint$colon$fix.log +0 -10
  272. package/.turbo/turbo-test.log +0 -1153
  273. package/dist/cjs/nextjs/hooks/useTokenCookie.d.ts +0 -3
  274. package/dist/cjs/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  275. package/dist/cjs/nextjs/hooks/useTokenCookie.js +0 -41
  276. package/dist/cjs/nextjs/hooks/useTokenCookie.js.map +0 -1
  277. package/dist/cjs/shared/hooks/useConfig.d.ts +0 -3
  278. package/dist/cjs/shared/hooks/useConfig.d.ts.map +0 -1
  279. package/dist/cjs/shared/hooks/useConfig.js +0 -16
  280. package/dist/cjs/shared/hooks/useConfig.js.map +0 -1
  281. package/dist/cjs/shared/providers/ConfigProvider.d.ts +0 -21
  282. package/dist/cjs/shared/providers/ConfigProvider.d.ts.map +0 -1
  283. package/dist/cjs/shared/providers/ConfigProvider.js +0 -46
  284. package/dist/cjs/shared/providers/ConfigProvider.js.map +0 -1
  285. package/dist/esm/nextjs/hooks/useTokenCookie.d.ts +0 -3
  286. package/dist/esm/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  287. package/dist/esm/nextjs/hooks/useTokenCookie.js +0 -37
  288. package/dist/esm/nextjs/hooks/useTokenCookie.js.map +0 -1
  289. package/dist/esm/shared/hooks/useConfig.d.ts +0 -3
  290. package/dist/esm/shared/hooks/useConfig.d.ts.map +0 -1
  291. package/dist/esm/shared/hooks/useConfig.js +0 -13
  292. package/dist/esm/shared/hooks/useConfig.js.map +0 -1
  293. package/dist/esm/shared/providers/ConfigProvider.d.ts +0 -21
  294. package/dist/esm/shared/providers/ConfigProvider.d.ts.map +0 -1
  295. package/dist/esm/shared/providers/ConfigProvider.js +0 -19
  296. package/dist/esm/shared/providers/ConfigProvider.js.map +0 -1
  297. package/dist/src/browser/storage.d.ts +0 -6
  298. package/dist/src/browser/storage.d.ts.map +0 -1
  299. package/dist/src/browser/storage.js +0 -9
  300. package/dist/src/browser/storage.js.map +0 -1
  301. package/dist/src/config.d.ts +0 -3
  302. package/dist/src/config.d.ts.map +0 -1
  303. package/dist/src/config.js +0 -5
  304. package/dist/src/config.js.map +0 -1
  305. package/dist/src/constants.d.ts +0 -9
  306. package/dist/src/constants.d.ts.map +0 -1
  307. package/dist/src/constants.js +0 -17
  308. package/dist/src/constants.js.map +0 -1
  309. package/dist/src/index.d.ts +0 -4
  310. package/dist/src/index.d.ts.map +0 -1
  311. package/dist/src/index.js +0 -2
  312. package/dist/src/index.js.map +0 -1
  313. package/dist/src/lib/cookies.d.ts +0 -7
  314. package/dist/src/lib/cookies.d.ts.map +0 -1
  315. package/dist/src/lib/cookies.js +0 -23
  316. package/dist/src/lib/cookies.js.map +0 -1
  317. package/dist/src/lib/jwt.d.ts +0 -3
  318. package/dist/src/lib/jwt.d.ts.map +0 -1
  319. package/dist/src/lib/jwt.js +0 -9
  320. package/dist/src/lib/jwt.js.map +0 -1
  321. package/dist/src/lib/logger.d.ts +0 -26
  322. package/dist/src/lib/logger.d.ts.map +0 -1
  323. package/dist/src/lib/logger.js +0 -55
  324. package/dist/src/lib/logger.js.map +0 -1
  325. package/dist/src/lib/oauth.d.ts +0 -19
  326. package/dist/src/lib/oauth.d.ts.map +0 -1
  327. package/dist/src/lib/oauth.js +0 -60
  328. package/dist/src/lib/oauth.js.map +0 -1
  329. package/dist/src/lib/postMessage.d.ts +0 -4
  330. package/dist/src/lib/postMessage.d.ts.map +0 -1
  331. package/dist/src/lib/postMessage.js +0 -15
  332. package/dist/src/lib/postMessage.js.map +0 -1
  333. package/dist/src/lib/windowUtil.d.ts +0 -4
  334. package/dist/src/lib/windowUtil.d.ts.map +0 -1
  335. package/dist/src/lib/windowUtil.js +0 -30
  336. package/dist/src/lib/windowUtil.js.map +0 -1
  337. package/dist/src/nextjs/GetUser.d.ts +0 -6
  338. package/dist/src/nextjs/GetUser.d.ts.map +0 -1
  339. package/dist/src/nextjs/GetUser.js +0 -18
  340. package/dist/src/nextjs/GetUser.js.map +0 -1
  341. package/dist/src/nextjs/config.d.ts +0 -178
  342. package/dist/src/nextjs/config.d.ts.map +0 -1
  343. package/dist/src/nextjs/config.js +0 -161
  344. package/dist/src/nextjs/config.js.map +0 -1
  345. package/dist/src/nextjs/cookies.d.ts +0 -30
  346. package/dist/src/nextjs/cookies.d.ts.map +0 -1
  347. package/dist/src/nextjs/cookies.js +0 -112
  348. package/dist/src/nextjs/cookies.js.map +0 -1
  349. package/dist/src/nextjs/hooks/index.d.ts +0 -2
  350. package/dist/src/nextjs/hooks/index.d.ts.map +0 -1
  351. package/dist/src/nextjs/hooks/index.js +0 -2
  352. package/dist/src/nextjs/hooks/index.js.map +0 -1
  353. package/dist/src/nextjs/hooks/useTokenCookie.d.ts +0 -3
  354. package/dist/src/nextjs/hooks/useTokenCookie.d.ts.map +0 -1
  355. package/dist/src/nextjs/hooks/useTokenCookie.js +0 -37
  356. package/dist/src/nextjs/hooks/useTokenCookie.js.map +0 -1
  357. package/dist/src/nextjs/hooks/useUserCookie.d.ts +0 -3
  358. package/dist/src/nextjs/index.d.ts +0 -7
  359. package/dist/src/nextjs/index.d.ts.map +0 -1
  360. package/dist/src/nextjs/index.js +0 -6
  361. package/dist/src/nextjs/index.js.map +0 -1
  362. package/dist/src/nextjs/middleware/index.d.ts +0 -2
  363. package/dist/src/nextjs/middleware/index.d.ts.map +0 -1
  364. package/dist/src/nextjs/middleware/index.js +0 -2
  365. package/dist/src/nextjs/middleware/index.js.map +0 -1
  366. package/dist/src/nextjs/middleware.d.ts +0 -59
  367. package/dist/src/nextjs/middleware.d.ts.map +0 -1
  368. package/dist/src/nextjs/middleware.js +0 -107
  369. package/dist/src/nextjs/middleware.js.map +0 -1
  370. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +0 -9
  371. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +0 -1
  372. package/dist/src/nextjs/providers/NextAuthProvider.js +0 -50
  373. package/dist/src/nextjs/providers/NextAuthProvider.js.map +0 -1
  374. package/dist/src/nextjs/routeHandler.d.ts +0 -18
  375. package/dist/src/nextjs/routeHandler.d.ts.map +0 -1
  376. package/dist/src/nextjs/routeHandler.js +0 -212
  377. package/dist/src/nextjs/routeHandler.js.map +0 -1
  378. package/dist/src/nextjs/utils.d.ts +0 -3
  379. package/dist/src/nextjs/utils.d.ts.map +0 -1
  380. package/dist/src/nextjs/utils.js +0 -5
  381. package/dist/src/nextjs/utils.js.map +0 -1
  382. package/dist/src/reactjs/components/SignInButton.d.ts +0 -8
  383. package/dist/src/reactjs/components/SignInButton.d.ts.map +0 -1
  384. package/dist/src/reactjs/components/SignInButton.js +0 -14
  385. package/dist/src/reactjs/components/SignInButton.js.map +0 -1
  386. package/dist/src/reactjs/components/SignOutButton.d.ts +0 -6
  387. package/dist/src/reactjs/components/SignOutButton.d.ts.map +0 -1
  388. package/dist/src/reactjs/components/SignOutButton.js +0 -14
  389. package/dist/src/reactjs/components/SignOutButton.js.map +0 -1
  390. package/dist/src/reactjs/components/UserButton.d.ts +0 -8
  391. package/dist/src/reactjs/components/UserButton.d.ts.map +0 -1
  392. package/dist/src/reactjs/components/UserButton.js +0 -118
  393. package/dist/src/reactjs/components/UserButton.js.map +0 -1
  394. package/dist/src/reactjs/components/index.d.ts +0 -6
  395. package/dist/src/reactjs/components/index.d.ts.map +0 -1
  396. package/dist/src/reactjs/components/index.js +0 -6
  397. package/dist/src/reactjs/components/index.js.map +0 -1
  398. package/dist/src/reactjs/hooks/index.d.ts +0 -7
  399. package/dist/src/reactjs/hooks/index.d.ts.map +0 -1
  400. package/dist/src/reactjs/hooks/index.js +0 -7
  401. package/dist/src/reactjs/hooks/index.js.map +0 -1
  402. package/dist/src/reactjs/hooks/useAuth.d.ts +0 -3
  403. package/dist/src/reactjs/hooks/useAuth.d.ts.map +0 -1
  404. package/dist/src/reactjs/hooks/useAuth.js +0 -12
  405. package/dist/src/reactjs/hooks/useAuth.js.map +0 -1
  406. package/dist/src/reactjs/hooks/useUser.d.ts +0 -4
  407. package/dist/src/reactjs/hooks/useUser.d.ts.map +0 -1
  408. package/dist/src/reactjs/hooks/useUser.js +0 -12
  409. package/dist/src/reactjs/hooks/useUser.js.map +0 -1
  410. package/dist/src/reactjs/index.d.ts +0 -6
  411. package/dist/src/reactjs/index.d.ts.map +0 -1
  412. package/dist/src/reactjs/index.js +0 -8
  413. package/dist/src/reactjs/index.js.map +0 -1
  414. package/dist/src/reactjs/providers/index.d.ts +0 -8
  415. package/dist/src/reactjs/providers/index.d.ts.map +0 -1
  416. package/dist/src/reactjs/providers/index.js +0 -7
  417. package/dist/src/reactjs/providers/index.js.map +0 -1
  418. package/dist/src/server/ServerAuthenticationResolver.d.ts +0 -19
  419. package/dist/src/server/ServerAuthenticationResolver.d.ts.map +0 -1
  420. package/dist/src/server/ServerAuthenticationResolver.js +0 -61
  421. package/dist/src/server/ServerAuthenticationResolver.js.map +0 -1
  422. package/dist/src/server/config.d.ts +0 -9
  423. package/dist/src/server/config.d.ts.map +0 -1
  424. package/dist/src/server/config.js +0 -2
  425. package/dist/src/server/config.js.map +0 -1
  426. package/dist/src/server/index.d.ts +0 -7
  427. package/dist/src/server/index.d.ts.map +0 -1
  428. package/dist/src/server/index.js +0 -5
  429. package/dist/src/server/index.js.map +0 -1
  430. package/dist/src/server/login.d.ts +0 -17
  431. package/dist/src/server/login.d.ts.map +0 -1
  432. package/dist/src/server/login.js +0 -37
  433. package/dist/src/server/login.js.map +0 -1
  434. package/dist/src/server/refresh.d.ts +0 -7
  435. package/dist/src/server/refresh.d.ts.map +0 -1
  436. package/dist/src/server/refresh.js +0 -13
  437. package/dist/src/server/refresh.js.map +0 -1
  438. package/dist/src/services/AuthenticationService.d.ts +0 -87
  439. package/dist/src/services/AuthenticationService.d.ts.map +0 -1
  440. package/dist/src/services/AuthenticationService.js +0 -212
  441. package/dist/src/services/AuthenticationService.js.map +0 -1
  442. package/dist/src/services/PKCE.d.ts +0 -20
  443. package/dist/src/services/PKCE.d.ts.map +0 -1
  444. package/dist/src/services/PKCE.js +0 -44
  445. package/dist/src/services/PKCE.js.map +0 -1
  446. package/dist/src/services/types.d.ts +0 -23
  447. package/dist/src/services/types.d.ts.map +0 -1
  448. package/dist/src/services/types.js +0 -7
  449. package/dist/src/services/types.js.map +0 -1
  450. package/dist/src/shared/components/CivicAuthIframe.d.ts +0 -8
  451. package/dist/src/shared/components/CivicAuthIframe.d.ts.map +0 -1
  452. package/dist/src/shared/components/CivicAuthIframe.js +0 -9
  453. package/dist/src/shared/components/CivicAuthIframe.js.map +0 -1
  454. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts +0 -9
  455. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +0 -1
  456. package/dist/src/shared/components/CivicAuthIframeContainer.js +0 -129
  457. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +0 -1
  458. package/dist/src/shared/components/CloseIcon.d.ts +0 -4
  459. package/dist/src/shared/components/CloseIcon.d.ts.map +0 -1
  460. package/dist/src/shared/components/CloseIcon.js +0 -6
  461. package/dist/src/shared/components/CloseIcon.js.map +0 -1
  462. package/dist/src/shared/components/LoadingIcon.d.ts +0 -4
  463. package/dist/src/shared/components/LoadingIcon.d.ts.map +0 -1
  464. package/dist/src/shared/components/LoadingIcon.js +0 -30
  465. package/dist/src/shared/components/LoadingIcon.js.map +0 -1
  466. package/dist/src/shared/hooks/index.d.ts +0 -5
  467. package/dist/src/shared/hooks/index.d.ts.map +0 -1
  468. package/dist/src/shared/hooks/index.js +0 -5
  469. package/dist/src/shared/hooks/index.js.map +0 -1
  470. package/dist/src/shared/hooks/useAuth.d.ts +0 -3
  471. package/dist/src/shared/hooks/useAuth.d.ts.map +0 -1
  472. package/dist/src/shared/hooks/useAuth.js +0 -12
  473. package/dist/src/shared/hooks/useAuth.js.map +0 -1
  474. package/dist/src/shared/hooks/useConfig.d.ts +0 -3
  475. package/dist/src/shared/hooks/useConfig.d.ts.map +0 -1
  476. package/dist/src/shared/hooks/useConfig.js +0 -13
  477. package/dist/src/shared/hooks/useConfig.js.map +0 -1
  478. package/dist/src/shared/hooks/useIframe.d.ts +0 -3
  479. package/dist/src/shared/hooks/useIframe.d.ts.map +0 -1
  480. package/dist/src/shared/hooks/useIframe.js +0 -13
  481. package/dist/src/shared/hooks/useIframe.js.map +0 -1
  482. package/dist/src/shared/hooks/useSession.d.ts +0 -3
  483. package/dist/src/shared/hooks/useSession.d.ts.map +0 -1
  484. package/dist/src/shared/hooks/useSession.js +0 -13
  485. package/dist/src/shared/hooks/useSession.js.map +0 -1
  486. package/dist/src/shared/hooks/useToken.d.ts +0 -3
  487. package/dist/src/shared/hooks/useToken.d.ts.map +0 -1
  488. package/dist/src/shared/hooks/useToken.js +0 -12
  489. package/dist/src/shared/hooks/useToken.js.map +0 -1
  490. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +0 -16
  491. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +0 -1
  492. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +0 -43
  493. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +0 -1
  494. package/dist/src/shared/lib/UserSession.d.ts +0 -12
  495. package/dist/src/shared/lib/UserSession.d.ts.map +0 -1
  496. package/dist/src/shared/lib/UserSession.js +0 -20
  497. package/dist/src/shared/lib/UserSession.js.map +0 -1
  498. package/dist/src/shared/lib/session.d.ts +0 -3
  499. package/dist/src/shared/lib/session.d.ts.map +0 -1
  500. package/dist/src/shared/lib/session.js +0 -10
  501. package/dist/src/shared/lib/session.js.map +0 -1
  502. package/dist/src/shared/lib/storage.d.ts +0 -25
  503. package/dist/src/shared/lib/storage.d.ts.map +0 -1
  504. package/dist/src/shared/lib/storage.js +0 -17
  505. package/dist/src/shared/lib/storage.js.map +0 -1
  506. package/dist/src/shared/lib/types.d.ts +0 -22
  507. package/dist/src/shared/lib/types.d.ts.map +0 -1
  508. package/dist/src/shared/lib/types.js +0 -16
  509. package/dist/src/shared/lib/types.js.map +0 -1
  510. package/dist/src/shared/lib/util.d.ts +0 -33
  511. package/dist/src/shared/lib/util.d.ts.map +0 -1
  512. package/dist/src/shared/lib/util.js +0 -124
  513. package/dist/src/shared/lib/util.js.map +0 -1
  514. package/dist/src/shared/providers/AuthContext.d.ts +0 -10
  515. package/dist/src/shared/providers/AuthContext.d.ts.map +0 -1
  516. package/dist/src/shared/providers/AuthContext.js +0 -3
  517. package/dist/src/shared/providers/AuthContext.js.map +0 -1
  518. package/dist/src/shared/providers/AuthProvider.d.ts +0 -20
  519. package/dist/src/shared/providers/AuthProvider.d.ts.map +0 -1
  520. package/dist/src/shared/providers/AuthProvider.js +0 -264
  521. package/dist/src/shared/providers/AuthProvider.js.map +0 -1
  522. package/dist/src/shared/providers/CivicAuthProvider.d.ts +0 -6
  523. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +0 -1
  524. package/dist/src/shared/providers/CivicAuthProvider.js +0 -15
  525. package/dist/src/shared/providers/CivicAuthProvider.js.map +0 -1
  526. package/dist/src/shared/providers/ConfigProvider.d.ts +0 -21
  527. package/dist/src/shared/providers/ConfigProvider.d.ts.map +0 -1
  528. package/dist/src/shared/providers/ConfigProvider.js +0 -19
  529. package/dist/src/shared/providers/ConfigProvider.js.map +0 -1
  530. package/dist/src/shared/providers/IframeProvider.d.ts +0 -16
  531. package/dist/src/shared/providers/IframeProvider.d.ts.map +0 -1
  532. package/dist/src/shared/providers/IframeProvider.js +0 -11
  533. package/dist/src/shared/providers/IframeProvider.js.map +0 -1
  534. package/dist/src/shared/providers/SessionProvider.d.ts +0 -13
  535. package/dist/src/shared/providers/SessionProvider.d.ts.map +0 -1
  536. package/dist/src/shared/providers/SessionProvider.js +0 -13
  537. package/dist/src/shared/providers/SessionProvider.js.map +0 -1
  538. package/dist/src/shared/providers/TokenProvider.d.ts +0 -18
  539. package/dist/src/shared/providers/TokenProvider.d.ts.map +0 -1
  540. package/dist/src/shared/providers/TokenProvider.js +0 -53
  541. package/dist/src/shared/providers/TokenProvider.js.map +0 -1
  542. package/dist/src/shared/providers/UserProvider.d.ts +0 -18
  543. package/dist/src/shared/providers/UserProvider.d.ts.map +0 -1
  544. package/dist/src/shared/providers/UserProvider.js +0 -38
  545. package/dist/src/shared/providers/UserProvider.js.map +0 -1
  546. package/dist/src/types.d.ts +0 -146
  547. package/dist/src/types.d.ts.map +0 -1
  548. package/dist/src/types.js +0 -2
  549. package/dist/src/types.js.map +0 -1
  550. package/dist/src/utils.d.ts +0 -15
  551. package/dist/src/utils.d.ts.map +0 -1
  552. package/dist/src/utils.js +0 -43
  553. package/dist/src/utils.js.map +0 -1
  554. package/dist/test/integration/sdk.test.d.ts +0 -2
  555. package/dist/test/integration/sdk.test.d.ts.map +0 -1
  556. package/dist/test/integration/sdk.test.js +0 -183
  557. package/dist/test/integration/sdk.test.js.map +0 -1
  558. package/dist/test/support/fixtures.d.ts +0 -26
  559. package/dist/test/support/fixtures.d.ts.map +0 -1
  560. package/dist/test/support/fixtures.js +0 -55
  561. package/dist/test/support/fixtures.js.map +0 -1
  562. package/dist/test/support/tokens.json +0 -26
  563. package/dist/test/unit/lib/oauth.test.d.ts +0 -2
  564. package/dist/test/unit/lib/oauth.test.d.ts.map +0 -1
  565. package/dist/test/unit/lib/oauth.test.js +0 -55
  566. package/dist/test/unit/lib/oauth.test.js.map +0 -1
  567. package/dist/test/unit/logger.test.d.ts +0 -2
  568. package/dist/test/unit/logger.test.d.ts.map +0 -1
  569. package/dist/test/unit/logger.test.js +0 -141
  570. package/dist/test/unit/logger.test.js.map +0 -1
  571. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +0 -2
  572. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts.map +0 -1
  573. package/dist/test/unit/nextjs/NextAuthProvider.test.js +0 -29
  574. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +0 -1
  575. package/dist/test/unit/nextjs/config.test.d.ts +0 -2
  576. package/dist/test/unit/nextjs/config.test.d.ts.map +0 -1
  577. package/dist/test/unit/nextjs/config.test.js +0 -189
  578. package/dist/test/unit/nextjs/config.test.js.map +0 -1
  579. package/dist/test/unit/nextjs/getUser.test.d.ts +0 -2
  580. package/dist/test/unit/nextjs/getUser.test.d.ts.map +0 -1
  581. package/dist/test/unit/nextjs/getUser.test.js +0 -36
  582. package/dist/test/unit/nextjs/getUser.test.js.map +0 -1
  583. package/dist/test/unit/nextjs/middleware.test.d.ts +0 -2
  584. package/dist/test/unit/nextjs/middleware.test.d.ts.map +0 -1
  585. package/dist/test/unit/nextjs/middleware.test.js +0 -113
  586. package/dist/test/unit/nextjs/middleware.test.js.map +0 -1
  587. package/dist/test/unit/nextjs/utils.test.d.ts +0 -2
  588. package/dist/test/unit/nextjs/utils.test.d.ts.map +0 -1
  589. package/dist/test/unit/nextjs/utils.test.js +0 -13
  590. package/dist/test/unit/nextjs/utils.test.js.map +0 -1
  591. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +0 -2
  592. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts.map +0 -1
  593. package/dist/test/unit/publicApi/apiSnapshot.test.js +0 -10
  594. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +0 -1
  595. package/dist/test/unit/react/components/SignInButton.test.d.ts +0 -2
  596. package/dist/test/unit/react/components/SignInButton.test.d.ts.map +0 -1
  597. package/dist/test/unit/react/components/SignInButton.test.js +0 -31
  598. package/dist/test/unit/react/components/SignInButton.test.js.map +0 -1
  599. package/dist/test/unit/react/components/SignOutButton.test.d.ts +0 -2
  600. package/dist/test/unit/react/components/SignOutButton.test.d.ts.map +0 -1
  601. package/dist/test/unit/react/components/SignOutButton.test.js +0 -30
  602. package/dist/test/unit/react/components/SignOutButton.test.js.map +0 -1
  603. package/dist/test/unit/server/login.test.d.ts +0 -2
  604. package/dist/test/unit/server/login.test.d.ts.map +0 -1
  605. package/dist/test/unit/server/login.test.js +0 -127
  606. package/dist/test/unit/server/login.test.js.map +0 -1
  607. package/dist/test/unit/server/session.test.d.ts +0 -2
  608. package/dist/test/unit/server/session.test.d.ts.map +0 -1
  609. package/dist/test/unit/server/session.test.js +0 -41
  610. package/dist/test/unit/server/session.test.js.map +0 -1
  611. package/dist/test/unit/services/AuthenticationService.test.d.ts +0 -2
  612. package/dist/test/unit/services/AuthenticationService.test.d.ts.map +0 -1
  613. package/dist/test/unit/services/AuthenticationService.test.js +0 -104
  614. package/dist/test/unit/services/AuthenticationService.test.js.map +0 -1
  615. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +0 -2
  616. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts.map +0 -1
  617. package/dist/test/unit/services/ServerAuthenticationResolver.test.js +0 -74
  618. package/dist/test/unit/services/ServerAuthenticationResolver.test.js.map +0 -1
  619. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +0 -2
  620. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts.map +0 -1
  621. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js +0 -61
  622. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js.map +0 -1
  623. package/dist/test/unit/shared/UserSession.test.d.ts +0 -2
  624. package/dist/test/unit/shared/UserSession.test.d.ts.map +0 -1
  625. package/dist/test/unit/shared/UserSession.test.js +0 -37
  626. package/dist/test/unit/shared/UserSession.test.js.map +0 -1
  627. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +0 -2
  628. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts.map +0 -1
  629. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +0 -120
  630. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +0 -1
  631. package/dist/test/unit/shared/storage.test.d.ts +0 -2
  632. package/dist/test/unit/shared/storage.test.d.ts.map +0 -1
  633. package/dist/test/unit/shared/storage.test.js +0 -53
  634. package/dist/test/unit/shared/storage.test.js.map +0 -1
  635. package/dist/test/unit/utils.test.d.ts +0 -2
  636. package/dist/test/unit/utils.test.d.ts.map +0 -1
  637. package/dist/test/unit/utils.test.js +0 -40
  638. package/dist/test/unit/utils.test.js.map +0 -1
  639. package/dist/vitest.config.d.ts +0 -3
  640. package/dist/vitest.config.d.ts.map +0 -1
  641. package/dist/vitest.config.js +0 -40
  642. package/dist/vitest.config.js.map +0 -1
  643. package/src/browser/storage.ts +0 -11
  644. package/src/config.ts +0 -6
  645. package/src/constants.ts +0 -29
  646. package/src/index.ts +0 -16
  647. package/src/lib/cookies.ts +0 -28
  648. package/src/lib/jwt.ts +0 -15
  649. package/src/lib/logger.ts +0 -72
  650. package/src/lib/oauth.ts +0 -83
  651. package/src/lib/postMessage.ts +0 -22
  652. package/src/lib/windowUtil.ts +0 -29
  653. package/src/nextjs/GetUser.ts +0 -22
  654. package/src/nextjs/config.ts +0 -203
  655. package/src/nextjs/cookies.ts +0 -162
  656. package/src/nextjs/hooks/index.ts +0 -1
  657. package/src/nextjs/hooks/useTokenCookie.ts +0 -41
  658. package/src/nextjs/hooks/useUserCookie.ts +0 -41
  659. package/src/nextjs/index.ts +0 -20
  660. package/src/nextjs/middleware/index.ts +0 -1
  661. package/src/nextjs/middleware.ts +0 -155
  662. package/src/nextjs/providers/NextAuthProvider.tsx +0 -87
  663. package/src/nextjs/routeHandler.ts +0 -297
  664. package/src/nextjs/utils.ts +0 -9
  665. package/src/reactjs/components/SignInButton.tsx +0 -32
  666. package/src/reactjs/components/SignOutButton.tsx +0 -24
  667. package/src/reactjs/components/UserButton.tsx +0 -239
  668. package/src/reactjs/components/index.ts +0 -5
  669. package/src/reactjs/hooks/index.ts +0 -6
  670. package/src/reactjs/hooks/useAuth.ts +0 -15
  671. package/src/reactjs/hooks/useUser.ts +0 -20
  672. package/src/reactjs/index.ts +0 -19
  673. package/src/reactjs/providers/index.ts +0 -27
  674. package/src/server/ServerAuthenticationResolver.ts +0 -107
  675. package/src/server/config.ts +0 -9
  676. package/src/server/index.ts +0 -13
  677. package/src/server/login.ts +0 -59
  678. package/src/server/refresh.ts +0 -23
  679. package/src/services/AuthenticationService.ts +0 -329
  680. package/src/services/PKCE.ts +0 -45
  681. package/src/services/types.ts +0 -54
  682. package/src/shared/components/CivicAuthIframe.tsx +0 -26
  683. package/src/shared/components/CivicAuthIframeContainer.tsx +0 -195
  684. package/src/shared/components/CloseIcon.tsx +0 -21
  685. package/src/shared/components/LoadingIcon.tsx +0 -53
  686. package/src/shared/hooks/index.ts +0 -4
  687. package/src/shared/hooks/useAuth.ts +0 -15
  688. package/src/shared/hooks/useConfig.ts +0 -14
  689. package/src/shared/hooks/useIframe.ts +0 -14
  690. package/src/shared/hooks/useSession.ts +0 -14
  691. package/src/shared/hooks/useToken.ts +0 -15
  692. package/src/shared/lib/GenericAuthenticationRefresher.ts +0 -75
  693. package/src/shared/lib/UserSession.ts +0 -25
  694. package/src/shared/lib/session.ts +0 -11
  695. package/src/shared/lib/storage.ts +0 -40
  696. package/src/shared/lib/types.ts +0 -26
  697. package/src/shared/lib/util.ts +0 -212
  698. package/src/shared/providers/AuthContext.tsx +0 -11
  699. package/src/shared/providers/AuthProvider.tsx +0 -397
  700. package/src/shared/providers/CivicAuthProvider.tsx +0 -31
  701. package/src/shared/providers/ConfigProvider.tsx +0 -50
  702. package/src/shared/providers/IframeProvider.tsx +0 -34
  703. package/src/shared/providers/SessionProvider.tsx +0 -29
  704. package/src/shared/providers/TokenProvider.tsx +0 -78
  705. package/src/shared/providers/UserProvider.tsx +0 -80
  706. package/src/types.ts +0 -227
  707. package/src/utils.ts +0 -58
  708. package/test/integration/sdk.test.tsx +0 -266
  709. package/test/support/fixtures.ts +0 -56
  710. package/test/support/tokens.json +0 -26
  711. package/test/unit/lib/oauth.test.ts +0 -72
  712. package/test/unit/logger.test.ts +0 -175
  713. package/test/unit/nextjs/NextAuthProvider.test.tsx +0 -38
  714. package/test/unit/nextjs/config.test.ts +0 -218
  715. package/test/unit/nextjs/getUser.test.ts +0 -41
  716. package/test/unit/nextjs/middleware.test.ts +0 -138
  717. package/test/unit/nextjs/routeHandler.test.ts.skipped +0 -369
  718. package/test/unit/nextjs/utils.test.ts +0 -17
  719. package/test/unit/publicApi/__snapshots__/apiSnapshot.test.ts.snap +0 -17
  720. package/test/unit/publicApi/apiSnapshot.test.ts +0 -11
  721. package/test/unit/react/components/SignInButton.test.tsx +0 -50
  722. package/test/unit/react/components/SignOutButton.test.tsx +0 -49
  723. package/test/unit/server/login.test.ts +0 -181
  724. package/test/unit/server/session.test.ts +0 -51
  725. package/test/unit/services/AuthenticationService.test.ts +0 -152
  726. package/test/unit/services/ServerAuthenticationResolver.test.ts +0 -115
  727. package/test/unit/shared/GenericAuthenticationRefresher.test.ts +0 -89
  728. package/test/unit/shared/UserSession.test.ts +0 -42
  729. package/test/unit/shared/components/CivicAuthIframeContainer.test.tsx +0 -154
  730. package/test/unit/shared/storage.test.ts +0 -67
  731. package/test/unit/utils.test.ts +0 -48
  732. package/tsconfig.build.json +0 -9
  733. package/tsconfig.cjs.json +0 -8
  734. package/tsconfig.esm.json +0 -7
  735. package/tsconfig.json +0 -42
  736. package/tsconfig.tsbuildinfo +0 -1
  737. package/vitest.config.ts +0 -41
@@ -1,37 +1,48 @@
1
1
  "use client";
2
- import React, { createContext } from "react";
3
- import { useQuery } from "@tanstack/react-query";
4
- import { useAuth } from "../../shared/hooks/useAuth.js";
5
- import { useToken } from "../../shared/hooks/useToken.js";
2
+ import React, { createContext, useCallback, useEffect, useState } from "react";
6
3
  import { useSession } from "../../shared/hooks/useSession.js";
7
4
  import { GenericUserSession } from "../../shared/lib/UserSession.js";
8
5
  const UserContext = createContext(null);
9
- const UserProvider = ({ children, storage, user: inputUser, signOut: inputSignOut, }) => {
10
- const { isLoading: authLoading, error: authError } = useAuth();
11
- const session = useSession();
12
- const { accessToken, idToken } = useToken();
13
- const { signIn, signOut } = useAuth();
14
- const fetchUser = async () => {
15
- if (!accessToken) {
6
+ const UserProvider = ({ children, storage, user: inputUser = null, signOut, signIn, }) => {
7
+ const { error: authError, isLoading: authLoading } = useSession();
8
+ const { data: session } = useSession();
9
+ const [userLoading, setUserLoading] = useState(false);
10
+ const [userError, setUserError] = useState(null);
11
+ const [user, setUser] = useState(null);
12
+ const fetchUser = useCallback(async () => {
13
+ if (!session?.idToken) {
16
14
  return null;
17
15
  }
18
16
  const userSession = new GenericUserSession(storage);
19
17
  return userSession.get();
20
- };
21
- const { data: user, isLoading: userLoading, error: userError, } = useQuery({
22
- queryKey: ["user", session?.idToken],
23
- queryFn: fetchUser,
24
- enabled: !!session?.idToken, // Only run the query if we have an access token
25
- });
18
+ }, [session?.idToken, storage]);
19
+ useEffect(() => {
20
+ if (!session?.idToken) {
21
+ setUser(null);
22
+ return;
23
+ }
24
+ if (session?.idToken) {
25
+ setUserLoading(true);
26
+ fetchUser()
27
+ .then((user) => {
28
+ setUserLoading(false);
29
+ setUser(user);
30
+ })
31
+ .catch((error) => {
32
+ setUserLoading(false);
33
+ setUserError(error);
34
+ });
35
+ }
36
+ }, [fetchUser, session?.idToken]);
26
37
  const isLoading = authLoading || userLoading;
27
38
  const error = authError || userError;
28
- const userWithIdToken = user ? { ...user, idToken } : null;
39
+ const userWithIdToken = user ? { ...user, idToken: session?.idToken } : null;
29
40
  return (React.createElement(UserContext.Provider, { value: {
30
41
  user: (inputUser || userWithIdToken) ?? null,
31
42
  isLoading,
32
43
  error,
33
44
  signIn,
34
- signOut: inputSignOut || signOut,
45
+ signOut,
35
46
  } }, children));
36
47
  };
37
48
  export { UserProvider, UserContext };
@@ -1 +1 @@
1
- {"version":3,"file":"UserProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAG7C,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAGjD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AASjE,MAAM,WAAW,GAAG,aAAa,CAAyB,IAAI,CAAC,CAAC;AAEhE,MAAM,YAAY,GAAG,CAAwB,EAC3C,QAAQ,EACR,OAAO,EACP,IAAI,EAAE,SAAS,EACf,OAAO,EAAE,YAAY,GAMtB,EAAE,EAAE;IACH,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,OAAO,EAAE,CAAC;IAC/D,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAC7B,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,QAAQ,EAAE,CAAC;IAC5C,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,CAAC;IAEtC,MAAM,SAAS,GAAG,KAAK,IAA0B,EAAE;QACjD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,WAAW,GAAG,IAAI,kBAAkB,CAAC,OAAO,CAAC,CAAC;QACpD,OAAO,WAAW,CAAC,GAAG,EAAE,CAAC;IAC3B,CAAC,CAAC;IAEF,MAAM,EACJ,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,WAAW,EACtB,KAAK,EAAE,SAAS,GACjB,GAA0C,QAAQ,CAAC;QAClD,QAAQ,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC;QACpC,OAAO,EAAE,SAAS;QAClB,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,gDAAgD;KAC9E,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,WAAW,IAAI,WAAW,CAAC;IAC7C,MAAM,KAAK,GAAG,SAAS,IAAI,SAAS,CAAC;IAErC,MAAM,eAAe,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IAE3D,OAAO,CACL,oBAAC,WAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,IAAI,EAAE,CAAC,SAAS,IAAI,eAAe,CAAC,IAAI,IAAI;YAC5C,SAAS;YACT,KAAK;YACL,MAAM;YACN,OAAO,EAAE,YAAY,IAAI,OAAO;SACjC,IAEA,QAAQ,CACY,CACxB,CAAC;AACJ,CAAC,CAAC;AAIF,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC","sourcesContent":["\"use client\";\n\nimport React, { createContext } from \"react\";\nimport type { ReactNode } from \"react\";\nimport type { UseQueryResult } from \"@tanstack/react-query\";\nimport { useQuery } from \"@tanstack/react-query\";\nimport type { JWT } from \"oslo/jwt\";\nimport type { AuthStorage, EmptyObject, User } from \"@/types.js\";\nimport { useAuth } from \"@/shared/hooks/useAuth.js\";\nimport { useToken } from \"@/shared/hooks/useToken.js\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { AuthContextType } from \"@/shared/providers/AuthContext.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\n\ntype UserContextType<\n T extends Record<string, unknown> & JWT[\"payload\"] = Record<string, unknown> &\n JWT[\"payload\"],\n> = {\n user: User<T> | null;\n} & Omit<AuthContextType, \"isAuthenticated\">;\n\nconst UserContext = createContext<UserContextType | null>(null);\n\nconst UserProvider = <T extends EmptyObject>({\n children,\n storage,\n user: inputUser,\n signOut: inputSignOut,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user?: User<T> | null;\n signOut?: () => Promise<void>;\n}) => {\n const { isLoading: authLoading, error: authError } = useAuth();\n const session = useSession();\n const { accessToken, idToken } = useToken();\n const { signIn, signOut } = useAuth();\n\n const fetchUser = async (): Promise<User | null> => {\n if (!accessToken) {\n return null;\n }\n const userSession = new GenericUserSession(storage);\n return userSession.get();\n };\n\n const {\n data: user,\n isLoading: userLoading,\n error: userError,\n }: UseQueryResult<User<T> | null, Error> = useQuery({\n queryKey: [\"user\", session?.idToken],\n queryFn: fetchUser,\n enabled: !!session?.idToken, // Only run the query if we have an access token\n });\n\n const isLoading = authLoading || userLoading;\n const error = authError || userError;\n\n const userWithIdToken = user ? { ...user, idToken } : null;\n\n return (\n <UserContext.Provider\n value={{\n user: (inputUser || userWithIdToken) ?? null,\n isLoading,\n error,\n signIn,\n signOut: inputSignOut || signOut,\n }}\n >\n {children}\n </UserContext.Provider>\n );\n};\n\nexport type { UserContextType };\n\nexport { UserProvider, UserContext };\n"]}
1
+ {"version":3,"file":"UserProvider.js","sourceRoot":"","sources":["../../../../src/shared/providers/UserProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAI/E,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AASjE,MAAM,WAAW,GAAG,aAAa,CAAyB,IAAI,CAAC,CAAC;AAEhE,MAAM,YAAY,GAAG,CAAwB,EAC3C,QAAQ,EACR,OAAO,EACP,IAAI,EAAE,SAAS,GAAG,IAAI,EACtB,OAAO,EACP,MAAM,GAOP,EAAE,EAAE;IACH,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,UAAU,EAAE,CAAC;IAClE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,CAAC;IACvC,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IAC/D,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IAC/D,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAc,IAAI,CAAC,CAAC;IAEpD,MAAM,SAAS,GAAG,WAAW,CAAC,KAAK,IAA0B,EAAE;QAC7D,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,WAAW,GAAG,IAAI,kBAAkB,CAAC,OAAO,CAAC,CAAC;QACpD,OAAO,WAAW,CAAC,GAAG,EAAE,CAAC;IAC3B,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAEhC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YACtB,OAAO,CAAC,IAAI,CAAC,CAAC;YACd,OAAO;QACT,CAAC;QACD,IAAI,OAAO,EAAE,OAAO,EAAE,CAAC;YACrB,cAAc,CAAC,IAAI,CAAC,CAAC;YACrB,SAAS,EAAE;iBACR,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;gBACb,cAAc,CAAC,KAAK,CAAC,CAAC;gBACtB,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC,CAAC;iBACD,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;gBACf,cAAc,CAAC,KAAK,CAAC,CAAC;gBACtB,YAAY,CAAC,KAAK,CAAC,CAAC;YACtB,CAAC,CAAC,CAAC;QACP,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAElC,MAAM,SAAS,GAAG,WAAW,IAAI,WAAW,CAAC;IAC7C,MAAM,KAAK,GAAG,SAAS,IAAI,SAAS,CAAC;IAErC,MAAM,eAAe,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IAC7E,OAAO,CACL,oBAAC,WAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,IAAI,EAAE,CAAC,SAAS,IAAI,eAAe,CAAC,IAAI,IAAI;YAC5C,SAAS;YACT,KAAK;YACL,MAAM;YACN,OAAO;SACR,IAEA,QAAQ,CACY,CACxB,CAAC;AACJ,CAAC,CAAC;AAIF,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC","sourcesContent":["\"use client\";\n\nimport React, { createContext, useCallback, useEffect, useState } from \"react\";\nimport type { ReactNode } from \"react\";\nimport type { JWT } from \"oslo/jwt\";\nimport type { AuthStorage, DisplayMode, EmptyObject, User } from \"@/types.js\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport type { AuthContextType } from \"@/shared/providers/AuthContext.js\";\nimport { GenericUserSession } from \"@/shared/lib/UserSession.js\";\n\ntype UserContextType<\n T extends Record<string, unknown> & JWT[\"payload\"] = Record<string, unknown> &\n JWT[\"payload\"],\n> = {\n user: User<T> | null;\n} & Omit<AuthContextType, \"isAuthenticated\">;\n\nconst UserContext = createContext<UserContextType | null>(null);\n\nconst UserProvider = <T extends EmptyObject>({\n children,\n storage,\n user: inputUser = null,\n signOut,\n signIn,\n}: {\n children: ReactNode;\n storage: AuthStorage;\n user?: User<T> | null;\n signOut: () => Promise<void>;\n signIn: (displayMode?: DisplayMode) => Promise<void>;\n}) => {\n const { error: authError, isLoading: authLoading } = useSession();\n const { data: session } = useSession();\n const [userLoading, setUserLoading] = useState<boolean>(false);\n const [userError, setUserError] = useState<Error | null>(null);\n const [user, setUser] = useState<User | null>(null);\n\n const fetchUser = useCallback(async (): Promise<User | null> => {\n if (!session?.idToken) {\n return null;\n }\n const userSession = new GenericUserSession(storage);\n return userSession.get();\n }, [session?.idToken, storage]);\n\n useEffect(() => {\n if (!session?.idToken) {\n setUser(null);\n return;\n }\n if (session?.idToken) {\n setUserLoading(true);\n fetchUser()\n .then((user) => {\n setUserLoading(false);\n setUser(user);\n })\n .catch((error) => {\n setUserLoading(false);\n setUserError(error);\n });\n }\n }, [fetchUser, session?.idToken]);\n\n const isLoading = authLoading || userLoading;\n const error = authError || userError;\n\n const userWithIdToken = user ? { ...user, idToken: session?.idToken } : null;\n return (\n <UserContext.Provider\n value={{\n user: (inputUser || userWithIdToken) ?? null,\n isLoading,\n error,\n signIn,\n signOut,\n }}\n >\n {children}\n </UserContext.Provider>\n );\n};\n\nexport type { UserContextType };\n\nexport { UserProvider, UserContext };\n"]}
@@ -55,6 +55,7 @@ type SessionData = {
55
55
  };
56
56
  type OIDCTokenResponseBody = TokenResponseBody & {
57
57
  id_token: string;
58
+ timestamp?: number;
58
59
  };
59
60
  type ParsedTokens = {
60
61
  id_token: JWTPayload;
@@ -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":"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"}
@@ -1 +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): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n}\n"]}
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 & {\n id_token: string;\n timestamp?: 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\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): Promise<string | null>;\n set(key: string, value: string): Promise<void>;\n}\n"]}
@@ -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,CAAY,IAAP,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,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 +1 @@
1
- {"version":3,"file":"useUserCookie.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/hooks/useUserCookie.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAUpD,eAAO,MAAM,aAAa,GAAI,CAAC,SAAS,WAAW,qBAyBlD,CAAC"}
1
+ {"version":3,"file":"useUserCookie.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/hooks/useUserCookie.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAqBpD,eAAO,MAAM,aAAa,GAAI,CAAC,SAAS,WAAW,qBAmDlD,CAAC"}
@@ -1,25 +1,54 @@
1
1
  "use client";
2
- import { useEffect, useRef } from "react";
2
+ import { useCallback, useEffect, useRef, useState } from "react";
3
3
  import { useRouter } from "next/navigation.js";
4
- import { useQuery } from "@tanstack/react-query";
5
4
  import { getWindowCookieValue } from "@/lib/cookies.js";
6
- import { UserStorage } from "@/shared/lib/types.js";
7
- const getUserFromCookie = () => getWindowCookieValue({
8
- key: UserStorage.USER,
9
- window: globalThis.window,
10
- parseJson: true,
11
- });
5
+ import { OAuthTokens, UserStorage } from "@/shared/lib/types.js";
6
+ const getUserAndTokenFromCookie = () => getWindowCookieValue([
7
+ {
8
+ key: UserStorage.USER,
9
+ window: globalThis.window,
10
+ parseJson: true,
11
+ },
12
+ {
13
+ key: OAuthTokens.ID_TOKEN,
14
+ window: globalThis.window,
15
+ parseJson: false,
16
+ },
17
+ ]);
12
18
  export const useUserCookie = () => {
19
+ const [user, setUser] = useState(null);
13
20
  const hasRunRef = useRef(false);
14
21
  const router = useRouter();
15
- const { data: user } = useQuery({
16
- queryKey: ["user"],
17
- queryFn: () => getUserFromCookie(),
18
- refetchInterval: 2000,
19
- refetchIntervalInBackground: true,
20
- enabled: !hasRunRef.current,
21
- refetchOnWindowFocus: true,
22
- });
22
+ const fetchUser = useCallback(async (abortController) => {
23
+ if (abortController.signal.aborted)
24
+ return;
25
+ if (!hasRunRef.current) {
26
+ const response = getUserAndTokenFromCookie() || {};
27
+ const userData = response[UserStorage.USER];
28
+ const tokenData = response[OAuthTokens.ID_TOKEN];
29
+ if (abortController.signal.aborted)
30
+ return;
31
+ const combinedUser = userData
32
+ ? { ...(userData || {}), idToken: tokenData }
33
+ : null;
34
+ setUser(combinedUser || null);
35
+ }
36
+ }, []);
37
+ useEffect(() => {
38
+ const abortController = new AbortController();
39
+ const intervalId = setInterval(() => {
40
+ fetchUser(abortController);
41
+ }, 2000);
42
+ const handleFocus = () => {
43
+ fetchUser(abortController);
44
+ };
45
+ window.addEventListener("focus", handleFocus);
46
+ return () => {
47
+ abortController.abort();
48
+ clearInterval(intervalId);
49
+ window.removeEventListener("focus", handleFocus);
50
+ };
51
+ }, [fetchUser]);
23
52
  useEffect(() => {
24
53
  if (user) {
25
54
  if (!hasRunRef.current) {
@@ -1 +1 @@
1
- {"version":3,"file":"useUserCookie.js","sourceRoot":"","sources":["../../../../src/nextjs/hooks/useUserCookie.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAExD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEpD,MAAM,iBAAiB,GAAG,GAAG,EAAE,CAC7B,oBAAoB,CAAC;IACnB,GAAG,EAAE,WAAW,CAAC,IAAI;IACrB,MAAM,EAAE,UAAU,CAAC,MAAM;IACzB,SAAS,EAAE,IAAI;CAChB,CAAC,CAAC;AAEL,MAAM,CAAC,MAAM,aAAa,GAAG,GAA0B,EAAE;IACvD,MAAM,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAChC,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,QAAQ,CAAC;QAC9B,QAAQ,EAAE,CAAC,MAAM,CAAC;QAClB,OAAO,EAAE,GAAG,EAAE,CAAC,iBAAiB,EAAoB;QACpD,eAAe,EAAE,IAAI;QACrB,2BAA2B,EAAE,IAAI;QACjC,OAAO,EAAE,CAAC,SAAS,CAAC,OAAO;QAC3B,oBAAoB,EAAE,IAAI;KAC3B,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;gBACvB,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC;gBACzB,MAAM,CAAC,OAAO,EAAE,CAAC;YACnB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,SAAS,CAAC,OAAO,GAAG,KAAK,CAAC;QAC5B,CAAC;IACH,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;IAEnB,OAAO,IAAI,IAAI,IAAI,CAAC;AACtB,CAAC,CAAC","sourcesContent":["\"use client\";\nimport { useEffect, useRef } from \"react\";\nimport { useRouter } from \"next/navigation.js\";\nimport { useQuery } from \"@tanstack/react-query\";\nimport { getWindowCookieValue } from \"@/lib/cookies.js\";\nimport type { EmptyObject, User } from \"@/types.js\";\nimport { UserStorage } from \"@/shared/lib/types.js\";\n\nconst getUserFromCookie = () =>\n getWindowCookieValue({\n key: UserStorage.USER,\n window: globalThis.window,\n parseJson: true,\n });\n\nexport const useUserCookie = <T extends EmptyObject>() => {\n const hasRunRef = useRef(false);\n const router = useRouter();\n\n const { data: user } = useQuery({\n queryKey: [\"user\"],\n queryFn: () => getUserFromCookie() as User<T> | null,\n refetchInterval: 2000,\n refetchIntervalInBackground: true,\n enabled: !hasRunRef.current,\n refetchOnWindowFocus: true,\n });\n\n useEffect(() => {\n if (user) {\n if (!hasRunRef.current) {\n hasRunRef.current = true;\n router.refresh();\n }\n } else {\n hasRunRef.current = false;\n }\n }, [user, router]);\n\n return user ?? null;\n};\n"]}
1
+ {"version":3,"file":"useUserCookie.js","sourceRoot":"","sources":["../../../../src/nextjs/hooks/useUserCookie.ts"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\nimport { useCallback, useEffect, useRef, useState } from \"react\";\nimport { useRouter } from \"next/navigation.js\";\nimport { getWindowCookieValue } from \"@/lib/cookies.js\";\nimport type { EmptyObject, User } from \"@/types.js\";\nimport { OAuthTokens, UserStorage } from \"@/shared/lib/types.js\";\n\ntype UserAndTokenFromCookie = {\n [UserStorage.USER]: User | undefined;\n [OAuthTokens.ID_TOKEN]: string | undefined;\n};\nconst getUserAndTokenFromCookie = (): UserAndTokenFromCookie =>\n getWindowCookieValue([\n {\n key: UserStorage.USER,\n window: globalThis.window,\n parseJson: true,\n },\n {\n key: OAuthTokens.ID_TOKEN,\n window: globalThis.window,\n parseJson: false,\n },\n ]) as UserAndTokenFromCookie;\n\nexport const useUserCookie = <T extends EmptyObject>() => {\n const [user, setUser] = useState<User<T> | null>(null);\n const hasRunRef = useRef(false);\n const router = useRouter();\n\n const fetchUser = useCallback(async (abortController: AbortController) => {\n if (abortController.signal.aborted) return;\n if (!hasRunRef.current) {\n const response = getUserAndTokenFromCookie() || {};\n const userData = response[UserStorage.USER] as User<T>;\n const tokenData = response[OAuthTokens.ID_TOKEN];\n if (abortController.signal.aborted) return;\n\n const combinedUser = userData\n ? ({ ...(userData || {}), idToken: tokenData } as User<T>)\n : null;\n setUser(combinedUser || null);\n }\n }, []);\n\n useEffect(() => {\n const abortController = new AbortController();\n const intervalId = setInterval(() => {\n fetchUser(abortController);\n }, 2000);\n\n const handleFocus = () => {\n fetchUser(abortController);\n };\n\n window.addEventListener(\"focus\", handleFocus);\n\n return () => {\n abortController.abort();\n clearInterval(intervalId);\n window.removeEventListener(\"focus\", handleFocus);\n };\n }, [fetchUser]);\n\n useEffect(() => {\n if (user) {\n if (!hasRunRef.current) {\n hasRunRef.current = true;\n router.refresh();\n }\n } else {\n hasRunRef.current = false;\n }\n }, [user, router]);\n\n return user ?? null;\n};\n"]}