@civic/auth 0.3.2-beta.3 → 0.3.2-beta.4

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 (484) hide show
  1. package/dist/cjs/nextjs/config.d.ts +1 -0
  2. package/dist/cjs/nextjs/config.d.ts.map +1 -1
  3. package/dist/cjs/nextjs/config.js +8 -0
  4. package/dist/cjs/nextjs/config.js.map +1 -1
  5. package/dist/cjs/shared/version.d.ts +1 -1
  6. package/dist/cjs/shared/version.js +1 -1
  7. package/dist/cjs/shared/version.js.map +1 -1
  8. package/dist/esm/nextjs/config.d.ts +1 -0
  9. package/dist/esm/nextjs/config.d.ts.map +1 -1
  10. package/dist/esm/nextjs/config.js +8 -0
  11. package/dist/esm/nextjs/config.js.map +1 -1
  12. package/dist/esm/shared/version.d.ts +1 -1
  13. package/dist/esm/shared/version.js +1 -1
  14. package/dist/esm/shared/version.js.map +1 -1
  15. package/dist/generateVersion.d.ts +2 -0
  16. package/dist/generateVersion.d.ts.map +1 -0
  17. package/dist/generateVersion.js +12 -0
  18. package/dist/generateVersion.js.map +1 -0
  19. package/dist/package.json +118 -0
  20. package/dist/src/browser/storage.d.ts +9 -0
  21. package/dist/src/browser/storage.d.ts.map +1 -0
  22. package/dist/src/browser/storage.js +17 -0
  23. package/dist/src/browser/storage.js.map +1 -0
  24. package/dist/src/config.d.ts +3 -0
  25. package/dist/src/config.d.ts.map +1 -0
  26. package/dist/src/config.js +5 -0
  27. package/dist/src/config.js.map +1 -0
  28. package/dist/src/constants.d.ts +8 -0
  29. package/dist/src/constants.d.ts.map +1 -0
  30. package/dist/src/constants.js +16 -0
  31. package/dist/src/constants.js.map +1 -0
  32. package/dist/src/index.d.ts +6 -0
  33. package/dist/src/index.d.ts.map +1 -0
  34. package/dist/src/index.js +4 -0
  35. package/dist/src/index.js.map +1 -0
  36. package/dist/src/lib/cookies.d.ts +7 -0
  37. package/dist/src/lib/cookies.d.ts.map +1 -0
  38. package/dist/src/lib/cookies.js +25 -0
  39. package/dist/src/lib/cookies.js.map +1 -0
  40. package/dist/src/lib/jwt.d.ts +3 -0
  41. package/dist/src/lib/jwt.d.ts.map +1 -0
  42. package/dist/src/lib/jwt.js +9 -0
  43. package/dist/src/lib/jwt.js.map +1 -0
  44. package/dist/src/lib/logger.d.ts +26 -0
  45. package/dist/src/lib/logger.d.ts.map +1 -0
  46. package/dist/src/lib/logger.js +55 -0
  47. package/dist/src/lib/logger.js.map +1 -0
  48. package/dist/src/lib/oauth.d.ts +19 -0
  49. package/dist/src/lib/oauth.d.ts.map +1 -0
  50. package/dist/src/lib/oauth.js +61 -0
  51. package/dist/src/lib/oauth.js.map +1 -0
  52. package/dist/src/lib/obj.d.ts +3 -0
  53. package/dist/src/lib/obj.d.ts.map +1 -0
  54. package/dist/src/lib/obj.js +18 -0
  55. package/dist/src/lib/obj.js.map +1 -0
  56. package/dist/src/lib/postMessage.d.ts +4 -0
  57. package/dist/src/lib/postMessage.d.ts.map +1 -0
  58. package/dist/src/lib/postMessage.js +15 -0
  59. package/dist/src/lib/postMessage.js.map +1 -0
  60. package/dist/src/lib/windowUtil.d.ts +4 -0
  61. package/dist/src/lib/windowUtil.d.ts.map +1 -0
  62. package/dist/src/lib/windowUtil.js +31 -0
  63. package/dist/src/lib/windowUtil.js.map +1 -0
  64. package/dist/src/nextjs/GetUser.d.ts +6 -0
  65. package/dist/src/nextjs/GetUser.d.ts.map +1 -0
  66. package/dist/src/nextjs/GetUser.js +7 -0
  67. package/dist/src/nextjs/GetUser.js.map +1 -0
  68. package/dist/src/nextjs/config.d.ts +181 -0
  69. package/dist/src/nextjs/config.d.ts.map +1 -0
  70. package/dist/src/nextjs/config.js +177 -0
  71. package/dist/src/nextjs/config.js.map +1 -0
  72. package/dist/src/nextjs/cookies.d.ts +30 -0
  73. package/dist/src/nextjs/cookies.d.ts.map +1 -0
  74. package/dist/src/nextjs/cookies.js +112 -0
  75. package/dist/src/nextjs/cookies.js.map +1 -0
  76. package/dist/src/nextjs/hooks/index.d.ts +2 -0
  77. package/dist/src/nextjs/hooks/index.d.ts.map +1 -0
  78. package/dist/src/nextjs/hooks/index.js +2 -0
  79. package/dist/src/nextjs/hooks/index.js.map +1 -0
  80. package/dist/src/nextjs/hooks/usePrevious.d.ts +2 -0
  81. package/dist/src/nextjs/hooks/usePrevious.d.ts.map +1 -0
  82. package/dist/src/nextjs/hooks/usePrevious.js +9 -0
  83. package/dist/src/nextjs/hooks/usePrevious.js.map +1 -0
  84. package/dist/src/nextjs/hooks/useUserCookie.d.ts +8 -0
  85. package/dist/src/nextjs/hooks/useUserCookie.d.ts.map +1 -0
  86. package/dist/src/nextjs/hooks/useUserCookie.js +88 -0
  87. package/dist/src/nextjs/hooks/useUserCookie.js.map +1 -0
  88. package/dist/src/nextjs/index.d.ts +7 -0
  89. package/dist/src/nextjs/index.d.ts.map +1 -0
  90. package/dist/src/nextjs/index.js +8 -0
  91. package/dist/src/nextjs/index.js.map +1 -0
  92. package/dist/src/nextjs/middleware/index.d.ts +2 -0
  93. package/dist/src/nextjs/middleware/index.d.ts.map +1 -0
  94. package/dist/src/nextjs/middleware/index.js +4 -0
  95. package/dist/src/nextjs/middleware/index.js.map +1 -0
  96. package/dist/src/nextjs/middleware.d.ts +59 -0
  97. package/dist/src/nextjs/middleware.d.ts.map +1 -0
  98. package/dist/src/nextjs/middleware.js +107 -0
  99. package/dist/src/nextjs/middleware.js.map +1 -0
  100. package/dist/src/nextjs/providers/NextAuthProvider.d.ts +13 -0
  101. package/dist/src/nextjs/providers/NextAuthProvider.d.ts.map +1 -0
  102. package/dist/src/nextjs/providers/NextAuthProvider.js +94 -0
  103. package/dist/src/nextjs/providers/NextAuthProvider.js.map +1 -0
  104. package/dist/src/nextjs/routeHandler.d.ts +19 -0
  105. package/dist/src/nextjs/routeHandler.d.ts.map +1 -0
  106. package/dist/src/nextjs/routeHandler.js +309 -0
  107. package/dist/src/nextjs/routeHandler.js.map +1 -0
  108. package/dist/src/nextjs/utils.d.ts +3 -0
  109. package/dist/src/nextjs/utils.d.ts.map +1 -0
  110. package/dist/src/nextjs/utils.js +5 -0
  111. package/dist/src/nextjs/utils.js.map +1 -0
  112. package/dist/src/reactjs/components/SignInButton.d.ts +8 -0
  113. package/dist/src/reactjs/components/SignInButton.d.ts.map +1 -0
  114. package/dist/src/reactjs/components/SignInButton.js +14 -0
  115. package/dist/src/reactjs/components/SignInButton.js.map +1 -0
  116. package/dist/src/reactjs/components/SignOutButton.d.ts +6 -0
  117. package/dist/src/reactjs/components/SignOutButton.d.ts.map +1 -0
  118. package/dist/src/reactjs/components/SignOutButton.js +14 -0
  119. package/dist/src/reactjs/components/SignOutButton.js.map +1 -0
  120. package/dist/src/reactjs/components/UserButton.d.ts +6 -0
  121. package/dist/src/reactjs/components/UserButton.d.ts.map +1 -0
  122. package/dist/src/reactjs/components/UserButton.js +118 -0
  123. package/dist/src/reactjs/components/UserButton.js.map +1 -0
  124. package/dist/src/reactjs/components/index.d.ts +6 -0
  125. package/dist/src/reactjs/components/index.d.ts.map +1 -0
  126. package/dist/src/reactjs/components/index.js +6 -0
  127. package/dist/src/reactjs/components/index.js.map +1 -0
  128. package/dist/src/reactjs/hooks/index.d.ts +6 -0
  129. package/dist/src/reactjs/hooks/index.d.ts.map +1 -0
  130. package/dist/src/reactjs/hooks/index.js +6 -0
  131. package/dist/src/reactjs/hooks/index.js.map +1 -0
  132. package/dist/src/reactjs/hooks/useAuth.d.ts +3 -0
  133. package/dist/src/reactjs/hooks/useAuth.d.ts.map +1 -0
  134. package/dist/src/reactjs/hooks/useAuth.js +12 -0
  135. package/dist/src/reactjs/hooks/useAuth.js.map +1 -0
  136. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  137. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  138. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.js +13 -0
  139. package/dist/src/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  140. package/dist/src/reactjs/hooks/useUser.d.ts +4 -0
  141. package/dist/src/reactjs/hooks/useUser.d.ts.map +1 -0
  142. package/dist/src/reactjs/hooks/useUser.js +12 -0
  143. package/dist/src/reactjs/hooks/useUser.js.map +1 -0
  144. package/dist/src/reactjs/index.d.ts +6 -0
  145. package/dist/src/reactjs/index.d.ts.map +1 -0
  146. package/dist/src/reactjs/index.js +10 -0
  147. package/dist/src/reactjs/index.js.map +1 -0
  148. package/dist/src/reactjs/providers/AuthProvider.d.ts +11 -0
  149. package/dist/src/reactjs/providers/AuthProvider.d.ts.map +1 -0
  150. package/dist/src/reactjs/providers/AuthProvider.js +76 -0
  151. package/dist/src/reactjs/providers/AuthProvider.js.map +1 -0
  152. package/dist/src/reactjs/providers/CivicAuthProvider.d.ts +6 -0
  153. package/dist/src/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  154. package/dist/src/reactjs/providers/CivicAuthProvider.js +32 -0
  155. package/dist/src/reactjs/providers/CivicAuthProvider.js.map +1 -0
  156. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  157. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  158. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.js +148 -0
  159. package/dist/src/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  160. package/dist/src/reactjs/providers/index.d.ts +8 -0
  161. package/dist/src/reactjs/providers/index.d.ts.map +1 -0
  162. package/dist/src/reactjs/providers/index.js +7 -0
  163. package/dist/src/reactjs/providers/index.js.map +1 -0
  164. package/dist/src/server/ServerAuthenticationResolver.d.ts +20 -0
  165. package/dist/src/server/ServerAuthenticationResolver.d.ts.map +1 -0
  166. package/dist/src/server/ServerAuthenticationResolver.js +67 -0
  167. package/dist/src/server/ServerAuthenticationResolver.js.map +1 -0
  168. package/dist/src/server/config.d.ts +10 -0
  169. package/dist/src/server/config.d.ts.map +1 -0
  170. package/dist/src/server/config.js +2 -0
  171. package/dist/src/server/config.js.map +1 -0
  172. package/dist/src/server/index.d.ts +7 -0
  173. package/dist/src/server/index.d.ts.map +1 -0
  174. package/dist/src/server/index.js +7 -0
  175. package/dist/src/server/index.js.map +1 -0
  176. package/dist/src/server/login.d.ts +21 -0
  177. package/dist/src/server/login.d.ts.map +1 -0
  178. package/dist/src/server/login.js +56 -0
  179. package/dist/src/server/login.js.map +1 -0
  180. package/dist/src/server/refresh.d.ts +7 -0
  181. package/dist/src/server/refresh.d.ts.map +1 -0
  182. package/dist/src/server/refresh.js +13 -0
  183. package/dist/src/server/refresh.js.map +1 -0
  184. package/dist/src/services/AuthenticationService.d.ts +91 -0
  185. package/dist/src/services/AuthenticationService.d.ts.map +1 -0
  186. package/dist/src/services/AuthenticationService.js +322 -0
  187. package/dist/src/services/AuthenticationService.js.map +1 -0
  188. package/dist/src/services/PKCE.d.ts +20 -0
  189. package/dist/src/services/PKCE.d.ts.map +1 -0
  190. package/dist/src/services/PKCE.js +44 -0
  191. package/dist/src/services/PKCE.js.map +1 -0
  192. package/dist/src/services/types.d.ts +24 -0
  193. package/dist/src/services/types.d.ts.map +1 -0
  194. package/dist/src/services/types.js +7 -0
  195. package/dist/src/services/types.js.map +1 -0
  196. package/dist/src/shared/components/BlockDisplay.d.ts +7 -0
  197. package/dist/src/shared/components/BlockDisplay.d.ts.map +1 -0
  198. package/dist/src/shared/components/BlockDisplay.js +25 -0
  199. package/dist/src/shared/components/BlockDisplay.js.map +1 -0
  200. package/dist/src/shared/components/CivicAuthIframe.d.ts +9 -0
  201. package/dist/src/shared/components/CivicAuthIframe.d.ts.map +1 -0
  202. package/dist/src/shared/components/CivicAuthIframe.js +8 -0
  203. package/dist/src/shared/components/CivicAuthIframe.js.map +1 -0
  204. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts +13 -0
  205. package/dist/src/shared/components/CivicAuthIframeContainer.d.ts.map +1 -0
  206. package/dist/src/shared/components/CivicAuthIframeContainer.js +138 -0
  207. package/dist/src/shared/components/CivicAuthIframeContainer.js.map +1 -0
  208. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.d.ts +7 -0
  209. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -0
  210. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.js +22 -0
  211. package/dist/src/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -0
  212. package/dist/src/shared/components/CloseIcon.d.ts +4 -0
  213. package/dist/src/shared/components/CloseIcon.d.ts.map +1 -0
  214. package/dist/src/shared/components/CloseIcon.js +6 -0
  215. package/dist/src/shared/components/CloseIcon.js.map +1 -0
  216. package/dist/src/shared/components/IFrameAndLoading.d.ts +8 -0
  217. package/dist/src/shared/components/IFrameAndLoading.d.ts.map +1 -0
  218. package/dist/src/shared/components/IFrameAndLoading.js +27 -0
  219. package/dist/src/shared/components/IFrameAndLoading.js.map +1 -0
  220. package/dist/src/shared/components/LoadingIcon.d.ts +4 -0
  221. package/dist/src/shared/components/LoadingIcon.d.ts.map +1 -0
  222. package/dist/src/shared/components/LoadingIcon.js +30 -0
  223. package/dist/src/shared/components/LoadingIcon.js.map +1 -0
  224. package/dist/src/shared/hooks/index.d.ts +11 -0
  225. package/dist/src/shared/hooks/index.d.ts.map +1 -0
  226. package/dist/src/shared/hooks/index.js +11 -0
  227. package/dist/src/shared/hooks/index.js.map +1 -0
  228. package/dist/src/shared/hooks/useAuth.d.ts +3 -0
  229. package/dist/src/shared/hooks/useAuth.d.ts.map +1 -0
  230. package/dist/src/shared/hooks/useAuth.js +12 -0
  231. package/dist/src/shared/hooks/useAuth.js.map +1 -0
  232. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts +3 -0
  233. package/dist/src/shared/hooks/useCivicAuthConfig.d.ts.map +1 -0
  234. package/dist/src/shared/hooks/useCivicAuthConfig.js +10 -0
  235. package/dist/src/shared/hooks/useCivicAuthConfig.js.map +1 -0
  236. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts +3 -0
  237. package/dist/src/shared/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  238. package/dist/src/shared/hooks/useClientTokenExchangeSession.js +13 -0
  239. package/dist/src/shared/hooks/useClientTokenExchangeSession.js.map +1 -0
  240. package/dist/src/shared/hooks/useCurrentUrl.d.ts +3 -0
  241. package/dist/src/shared/hooks/useCurrentUrl.d.ts.map +1 -0
  242. package/dist/src/shared/hooks/useCurrentUrl.js +24 -0
  243. package/dist/src/shared/hooks/useCurrentUrl.js.map +1 -0
  244. package/dist/src/shared/hooks/useIframe.d.ts +3 -0
  245. package/dist/src/shared/hooks/useIframe.d.ts.map +1 -0
  246. package/dist/src/shared/hooks/useIframe.js +13 -0
  247. package/dist/src/shared/hooks/useIframe.js.map +1 -0
  248. package/dist/src/shared/hooks/useIsInIframe.d.ts +3 -0
  249. package/dist/src/shared/hooks/useIsInIframe.d.ts.map +1 -0
  250. package/dist/src/shared/hooks/useIsInIframe.js +14 -0
  251. package/dist/src/shared/hooks/useIsInIframe.js.map +1 -0
  252. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts +4 -0
  253. package/dist/src/shared/hooks/useOAuthEndpoints.d.ts.map +1 -0
  254. package/dist/src/shared/hooks/useOAuthEndpoints.js +14 -0
  255. package/dist/src/shared/hooks/useOAuthEndpoints.js.map +1 -0
  256. package/dist/src/shared/hooks/useRefresh.d.ts +4 -0
  257. package/dist/src/shared/hooks/useRefresh.d.ts.map +1 -0
  258. package/dist/src/shared/hooks/useRefresh.js +38 -0
  259. package/dist/src/shared/hooks/useRefresh.js.map +1 -0
  260. package/dist/src/shared/hooks/useSession.d.ts +3 -0
  261. package/dist/src/shared/hooks/useSession.d.ts.map +1 -0
  262. package/dist/src/shared/hooks/useSession.js +13 -0
  263. package/dist/src/shared/hooks/useSession.js.map +1 -0
  264. package/dist/src/shared/hooks/useSignIn.d.ts +15 -0
  265. package/dist/src/shared/hooks/useSignIn.d.ts.map +1 -0
  266. package/dist/src/shared/hooks/useSignIn.js +126 -0
  267. package/dist/src/shared/hooks/useSignIn.js.map +1 -0
  268. package/dist/src/shared/hooks/useToken.d.ts +3 -0
  269. package/dist/src/shared/hooks/useToken.d.ts.map +1 -0
  270. package/dist/src/shared/hooks/useToken.js +12 -0
  271. package/dist/src/shared/hooks/useToken.js.map +1 -0
  272. package/dist/src/shared/hooks/useWindowFocused.d.ts +5 -0
  273. package/dist/src/shared/hooks/useWindowFocused.d.ts.map +1 -0
  274. package/dist/src/shared/hooks/useWindowFocused.js +21 -0
  275. package/dist/src/shared/hooks/useWindowFocused.js.map +1 -0
  276. package/dist/src/shared/index.d.ts +5 -0
  277. package/dist/src/shared/index.d.ts.map +1 -0
  278. package/dist/src/shared/index.js +16 -0
  279. package/dist/src/shared/index.js.map +1 -0
  280. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts +20 -0
  281. package/dist/src/shared/lib/GenericAuthenticationRefresher.d.ts.map +1 -0
  282. package/dist/src/shared/lib/GenericAuthenticationRefresher.js +73 -0
  283. package/dist/src/shared/lib/GenericAuthenticationRefresher.js.map +1 -0
  284. package/dist/src/shared/lib/UserSession.d.ts +12 -0
  285. package/dist/src/shared/lib/UserSession.d.ts.map +1 -0
  286. package/dist/src/shared/lib/UserSession.js +20 -0
  287. package/dist/src/shared/lib/UserSession.js.map +1 -0
  288. package/dist/src/shared/lib/session.d.ts +3 -0
  289. package/dist/src/shared/lib/session.d.ts.map +1 -0
  290. package/dist/src/shared/lib/session.js +21 -0
  291. package/dist/src/shared/lib/session.js.map +1 -0
  292. package/dist/src/shared/lib/storage.d.ts +25 -0
  293. package/dist/src/shared/lib/storage.d.ts.map +1 -0
  294. package/dist/src/shared/lib/storage.js +17 -0
  295. package/dist/src/shared/lib/storage.js.map +1 -0
  296. package/dist/src/shared/lib/types.d.ts +36 -0
  297. package/dist/src/shared/lib/types.d.ts.map +1 -0
  298. package/dist/src/shared/lib/types.js +18 -0
  299. package/dist/src/shared/lib/types.js.map +1 -0
  300. package/dist/src/shared/lib/util.d.ts +34 -0
  301. package/dist/src/shared/lib/util.d.ts.map +1 -0
  302. package/dist/src/shared/lib/util.js +137 -0
  303. package/dist/src/shared/lib/util.js.map +1 -0
  304. package/dist/src/shared/providers/AuthContext.d.ts +11 -0
  305. package/dist/src/shared/providers/AuthContext.d.ts.map +1 -0
  306. package/dist/src/shared/providers/AuthContext.js +3 -0
  307. package/dist/src/shared/providers/AuthContext.js.map +1 -0
  308. package/dist/src/shared/providers/AuthProvider.d.ts +22 -0
  309. package/dist/src/shared/providers/AuthProvider.d.ts.map +1 -0
  310. package/dist/src/shared/providers/AuthProvider.js +72 -0
  311. package/dist/src/shared/providers/AuthProvider.js.map +1 -0
  312. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts +18 -0
  313. package/dist/src/shared/providers/CivicAuthConfigContext.d.ts.map +1 -0
  314. package/dist/src/shared/providers/CivicAuthConfigContext.js +52 -0
  315. package/dist/src/shared/providers/CivicAuthConfigContext.js.map +1 -0
  316. package/dist/src/shared/providers/CivicAuthProvider.d.ts +6 -0
  317. package/dist/src/shared/providers/CivicAuthProvider.d.ts.map +1 -0
  318. package/dist/src/shared/providers/CivicAuthProvider.js +32 -0
  319. package/dist/src/shared/providers/CivicAuthProvider.js.map +1 -0
  320. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  321. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  322. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js +131 -0
  323. package/dist/src/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  324. package/dist/src/shared/providers/IframeProvider.d.ts +22 -0
  325. package/dist/src/shared/providers/IframeProvider.d.ts.map +1 -0
  326. package/dist/src/shared/providers/IframeProvider.js +35 -0
  327. package/dist/src/shared/providers/IframeProvider.js.map +1 -0
  328. package/dist/src/shared/providers/SessionProvider.d.ts +19 -0
  329. package/dist/src/shared/providers/SessionProvider.d.ts.map +1 -0
  330. package/dist/src/shared/providers/SessionProvider.js +23 -0
  331. package/dist/src/shared/providers/SessionProvider.js.map +1 -0
  332. package/dist/src/shared/providers/TokenProvider.d.ts +18 -0
  333. package/dist/src/shared/providers/TokenProvider.d.ts.map +1 -0
  334. package/dist/src/shared/providers/TokenProvider.js +42 -0
  335. package/dist/src/shared/providers/TokenProvider.js.map +1 -0
  336. package/dist/src/shared/providers/UserProvider.d.ts +24 -0
  337. package/dist/src/shared/providers/UserProvider.d.ts.map +1 -0
  338. package/dist/src/shared/providers/UserProvider.js +52 -0
  339. package/dist/src/shared/providers/UserProvider.js.map +1 -0
  340. package/dist/src/shared/providers/types.d.ts +15 -0
  341. package/dist/src/shared/providers/types.d.ts.map +1 -0
  342. package/dist/src/shared/providers/types.js +2 -0
  343. package/dist/src/shared/providers/types.js.map +1 -0
  344. package/dist/src/shared/version.d.ts +2 -0
  345. package/dist/src/shared/version.d.ts.map +1 -0
  346. package/dist/src/shared/version.js +3 -0
  347. package/dist/src/shared/version.js.map +1 -0
  348. package/dist/src/types.d.ts +148 -0
  349. package/dist/src/types.d.ts.map +1 -0
  350. package/dist/src/types.js +4 -0
  351. package/dist/src/types.js.map +1 -0
  352. package/dist/src/utils.d.ts +15 -0
  353. package/dist/src/utils.d.ts.map +1 -0
  354. package/dist/src/utils.js +43 -0
  355. package/dist/src/utils.js.map +1 -0
  356. package/dist/src/version.d.ts +2 -0
  357. package/dist/src/version.d.ts.map +1 -0
  358. package/dist/src/version.js +3 -0
  359. package/dist/src/version.js.map +1 -0
  360. package/dist/test/integration/sdk.test.d.ts +2 -0
  361. package/dist/test/integration/sdk.test.d.ts.map +1 -0
  362. package/dist/test/integration/sdk.test.js +237 -0
  363. package/dist/test/integration/sdk.test.js.map +1 -0
  364. package/dist/test/support/fixtures.d.ts +26 -0
  365. package/dist/test/support/fixtures.d.ts.map +1 -0
  366. package/dist/test/support/fixtures.js +55 -0
  367. package/dist/test/support/fixtures.js.map +1 -0
  368. package/dist/test/support/tokens.json +26 -0
  369. package/dist/test/unit/lib/oauth.test.d.ts +2 -0
  370. package/dist/test/unit/lib/oauth.test.d.ts.map +1 -0
  371. package/dist/test/unit/lib/oauth.test.js +56 -0
  372. package/dist/test/unit/lib/oauth.test.js.map +1 -0
  373. package/dist/test/unit/lib/obj.test.d.ts +2 -0
  374. package/dist/test/unit/lib/obj.test.d.ts.map +1 -0
  375. package/dist/test/unit/lib/obj.test.js +37 -0
  376. package/dist/test/unit/lib/obj.test.js.map +1 -0
  377. package/dist/test/unit/logger.test.d.ts +2 -0
  378. package/dist/test/unit/logger.test.d.ts.map +1 -0
  379. package/dist/test/unit/logger.test.js +141 -0
  380. package/dist/test/unit/logger.test.js.map +1 -0
  381. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts +2 -0
  382. package/dist/test/unit/nextjs/NextAuthProvider.test.d.ts.map +1 -0
  383. package/dist/test/unit/nextjs/NextAuthProvider.test.js +31 -0
  384. package/dist/test/unit/nextjs/NextAuthProvider.test.js.map +1 -0
  385. package/dist/test/unit/nextjs/config.test.d.ts +2 -0
  386. package/dist/test/unit/nextjs/config.test.d.ts.map +1 -0
  387. package/dist/test/unit/nextjs/config.test.js +203 -0
  388. package/dist/test/unit/nextjs/config.test.js.map +1 -0
  389. package/dist/test/unit/nextjs/getUser.test.d.ts +2 -0
  390. package/dist/test/unit/nextjs/getUser.test.d.ts.map +1 -0
  391. package/dist/test/unit/nextjs/getUser.test.js +22 -0
  392. package/dist/test/unit/nextjs/getUser.test.js.map +1 -0
  393. package/dist/test/unit/nextjs/handler.test.d.ts +2 -0
  394. package/dist/test/unit/nextjs/handler.test.d.ts.map +1 -0
  395. package/dist/test/unit/nextjs/handler.test.js +207 -0
  396. package/dist/test/unit/nextjs/handler.test.js.map +1 -0
  397. package/dist/test/unit/nextjs/middleware.test.d.ts +2 -0
  398. package/dist/test/unit/nextjs/middleware.test.d.ts.map +1 -0
  399. package/dist/test/unit/nextjs/middleware.test.js +113 -0
  400. package/dist/test/unit/nextjs/middleware.test.js.map +1 -0
  401. package/dist/test/unit/nextjs/utils.test.d.ts +2 -0
  402. package/dist/test/unit/nextjs/utils.test.d.ts.map +1 -0
  403. package/dist/test/unit/nextjs/utils.test.js +13 -0
  404. package/dist/test/unit/nextjs/utils.test.js.map +1 -0
  405. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts +2 -0
  406. package/dist/test/unit/publicApi/apiSnapshot.test.d.ts.map +1 -0
  407. package/dist/test/unit/publicApi/apiSnapshot.test.js +10 -0
  408. package/dist/test/unit/publicApi/apiSnapshot.test.js.map +1 -0
  409. package/dist/test/unit/react/components/SignInButton.test.d.ts +2 -0
  410. package/dist/test/unit/react/components/SignInButton.test.d.ts.map +1 -0
  411. package/dist/test/unit/react/components/SignInButton.test.js +31 -0
  412. package/dist/test/unit/react/components/SignInButton.test.js.map +1 -0
  413. package/dist/test/unit/react/components/SignOutButton.test.d.ts +2 -0
  414. package/dist/test/unit/react/components/SignOutButton.test.d.ts.map +1 -0
  415. package/dist/test/unit/react/components/SignOutButton.test.js +30 -0
  416. package/dist/test/unit/react/components/SignOutButton.test.js.map +1 -0
  417. package/dist/test/unit/server/login.test.d.ts +2 -0
  418. package/dist/test/unit/server/login.test.d.ts.map +1 -0
  419. package/dist/test/unit/server/login.test.js +184 -0
  420. package/dist/test/unit/server/login.test.js.map +1 -0
  421. package/dist/test/unit/server/refresh.test.d.ts +2 -0
  422. package/dist/test/unit/server/refresh.test.d.ts.map +1 -0
  423. package/dist/test/unit/server/refresh.test.js +55 -0
  424. package/dist/test/unit/server/refresh.test.js.map +1 -0
  425. package/dist/test/unit/server/session.test.d.ts +2 -0
  426. package/dist/test/unit/server/session.test.d.ts.map +1 -0
  427. package/dist/test/unit/server/session.test.js +41 -0
  428. package/dist/test/unit/server/session.test.js.map +1 -0
  429. package/dist/test/unit/services/AuthenticationService.test.d.ts +2 -0
  430. package/dist/test/unit/services/AuthenticationService.test.d.ts.map +1 -0
  431. package/dist/test/unit/services/AuthenticationService.test.js +301 -0
  432. package/dist/test/unit/services/AuthenticationService.test.js.map +1 -0
  433. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts +2 -0
  434. package/dist/test/unit/services/ServerAuthenticationResolver.test.d.ts.map +1 -0
  435. package/dist/test/unit/services/ServerAuthenticationResolver.test.js +75 -0
  436. package/dist/test/unit/services/ServerAuthenticationResolver.test.js.map +1 -0
  437. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts +2 -0
  438. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.d.ts.map +1 -0
  439. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js +144 -0
  440. package/dist/test/unit/shared/GenericAuthenticationRefresher.test.js.map +1 -0
  441. package/dist/test/unit/shared/UserSession.test.d.ts +2 -0
  442. package/dist/test/unit/shared/UserSession.test.d.ts.map +1 -0
  443. package/dist/test/unit/shared/UserSession.test.js +37 -0
  444. package/dist/test/unit/shared/UserSession.test.js.map +1 -0
  445. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts +2 -0
  446. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.d.ts.map +1 -0
  447. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js +122 -0
  448. package/dist/test/unit/shared/components/CivicAuthIframeContainer.test.js.map +1 -0
  449. package/dist/test/unit/shared/printVersion.test.d.ts +2 -0
  450. package/dist/test/unit/shared/printVersion.test.d.ts.map +1 -0
  451. package/dist/test/unit/shared/printVersion.test.js +39 -0
  452. package/dist/test/unit/shared/printVersion.test.js.map +1 -0
  453. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.d.ts +2 -0
  454. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.d.ts.map +1 -0
  455. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.js +108 -0
  456. package/dist/test/unit/shared/providers/ClientTokenExchangeSessionProvider.test.js.map +1 -0
  457. package/dist/test/unit/shared/storage.test.d.ts +2 -0
  458. package/dist/test/unit/shared/storage.test.d.ts.map +1 -0
  459. package/dist/test/unit/shared/storage.test.js +53 -0
  460. package/dist/test/unit/shared/storage.test.js.map +1 -0
  461. package/dist/test/unit/utils.test.d.ts +2 -0
  462. package/dist/test/unit/utils.test.d.ts.map +1 -0
  463. package/dist/test/unit/utils.test.js +40 -0
  464. package/dist/test/unit/utils.test.js.map +1 -0
  465. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  466. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  467. package/dist/tsconfig.tsbuildinfo +1 -0
  468. package/dist/vitest.config.d.ts +3 -0
  469. package/dist/vitest.config.d.ts.map +1 -0
  470. package/dist/vitest.config.js +44 -0
  471. package/dist/vitest.config.js.map +1 -0
  472. package/package.json +19 -18
  473. package/dist/cjs/reactjs/hooks/useSignIn.d.ts +0 -6
  474. package/dist/cjs/reactjs/hooks/useSignIn.d.ts.map +0 -1
  475. package/dist/cjs/reactjs/hooks/useSignIn.js +0 -38
  476. package/dist/cjs/reactjs/hooks/useSignIn.js.map +0 -1
  477. package/dist/cjs/services/UserinfoService.d.ts +0 -5
  478. package/dist/cjs/services/UserinfoService.d.ts.map +0 -1
  479. package/dist/cjs/services/UserinfoService.js +0 -15
  480. package/dist/cjs/services/UserinfoService.js.map +0 -1
  481. package/dist/esm/reactjs/hooks/useSignIn.d.ts +0 -6
  482. package/dist/esm/reactjs/hooks/useSignIn.d.ts.map +0 -1
  483. package/dist/esm/reactjs/hooks/useSignIn.js +0 -34
  484. package/dist/esm/reactjs/hooks/useSignIn.js.map +0 -1
@@ -0,0 +1,55 @@
1
+ import debug from "debug";
2
+ const PACKAGE_NAME = "@civic/auth";
3
+ class DebugLogger {
4
+ debugLogger;
5
+ infoLogger;
6
+ warnLogger;
7
+ errorLogger;
8
+ constructor(namespace) {
9
+ // Format: @org/package:library:component:level
10
+ this.debugLogger = debug(`${PACKAGE_NAME}:${namespace}:debug`);
11
+ this.infoLogger = debug(`${PACKAGE_NAME}:${namespace}:info`);
12
+ this.warnLogger = debug(`${PACKAGE_NAME}:${namespace}:warn`);
13
+ this.errorLogger = debug(`${PACKAGE_NAME}:${namespace}:error`);
14
+ this.debugLogger.color = "4";
15
+ this.infoLogger.color = "2";
16
+ this.warnLogger.color = "3";
17
+ this.errorLogger.color = "1";
18
+ }
19
+ debug(message, ...args) {
20
+ this.debugLogger(message, ...args);
21
+ }
22
+ info(message, ...args) {
23
+ this.infoLogger(message, ...args);
24
+ }
25
+ warn(message, ...args) {
26
+ this.warnLogger(message, ...args);
27
+ }
28
+ error(message, ...args) {
29
+ this.errorLogger(message, ...args);
30
+ }
31
+ }
32
+ export const createLogger = (namespace) => new DebugLogger(namespace);
33
+ // Pre-configured loggers for different parts of your package
34
+ export const loggers = {
35
+ // Next.js specific loggers
36
+ nextjs: {
37
+ routes: createLogger("api:routes"),
38
+ middleware: createLogger("api:middleware"),
39
+ handlers: {
40
+ auth: createLogger("api:handlers:auth"),
41
+ },
42
+ },
43
+ // React specific loggers
44
+ react: {
45
+ components: createLogger("react:components"),
46
+ hooks: createLogger("react:hooks"),
47
+ context: createLogger("react:context"),
48
+ },
49
+ // Shared utilities loggers
50
+ services: {
51
+ validation: createLogger("utils:validation"),
52
+ network: createLogger("utils:network"),
53
+ },
54
+ };
55
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/lib/logger.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,YAAY,GAAG,aAAa,CAAC;AASnC,MAAM,WAAW;IACP,WAAW,CAAiB;IAC5B,UAAU,CAAiB;IAC3B,UAAU,CAAiB;IAC3B,WAAW,CAAiB;IAEpC,YAAY,SAAiB;QAC3B,+CAA+C;QAC/C,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,GAAG,YAAY,IAAI,SAAS,QAAQ,CAAC,CAAC;QAC/D,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,GAAG,YAAY,IAAI,SAAS,OAAO,CAAC,CAAC;QAC7D,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,GAAG,YAAY,IAAI,SAAS,OAAO,CAAC,CAAC;QAC7D,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,GAAG,YAAY,IAAI,SAAS,QAAQ,CAAC,CAAC;QAE/D,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,GAAG,CAAC;QAC5B,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,GAAG,CAAC;QAC5B,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,GAAG,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,GAAG,IAAe;QACvC,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,GAAG,IAAe;QACtC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,GAAG,IAAe;QACtC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,GAAG,IAAe;QACvC,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACrC,CAAC;CACF;AAED,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,SAAiB,EAAU,EAAE,CACxD,IAAI,WAAW,CAAC,SAAS,CAAC,CAAC;AAE7B,6DAA6D;AAC7D,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,2BAA2B;IAC3B,MAAM,EAAE;QACN,MAAM,EAAE,YAAY,CAAC,YAAY,CAAC;QAClC,UAAU,EAAE,YAAY,CAAC,gBAAgB,CAAC;QAC1C,QAAQ,EAAE;YACR,IAAI,EAAE,YAAY,CAAC,mBAAmB,CAAC;SACxC;KACF;IACD,yBAAyB;IACzB,KAAK,EAAE;QACL,UAAU,EAAE,YAAY,CAAC,kBAAkB,CAAC;QAC5C,KAAK,EAAE,YAAY,CAAC,aAAa,CAAC;QAClC,OAAO,EAAE,YAAY,CAAC,eAAe,CAAC;KACvC;IACD,2BAA2B;IAC3B,QAAQ,EAAE;QACR,UAAU,EAAE,YAAY,CAAC,kBAAkB,CAAC;QAC5C,OAAO,EAAE,YAAY,CAAC,eAAe,CAAC;KACvC;CACO,CAAC","sourcesContent":["import debug from \"debug\";\n\nconst PACKAGE_NAME = \"@civic/auth\";\n\nexport interface Logger {\n debug(message: string, ...args: unknown[]): void;\n info(message: string, ...args: unknown[]): void;\n warn(message: string, ...args: unknown[]): void;\n error(message: string, ...args: unknown[]): void;\n}\n\nclass DebugLogger implements Logger {\n private debugLogger: debug.Debugger;\n private infoLogger: debug.Debugger;\n private warnLogger: debug.Debugger;\n private errorLogger: debug.Debugger;\n\n constructor(namespace: string) {\n // Format: @org/package:library:component:level\n this.debugLogger = debug(`${PACKAGE_NAME}:${namespace}:debug`);\n this.infoLogger = debug(`${PACKAGE_NAME}:${namespace}:info`);\n this.warnLogger = debug(`${PACKAGE_NAME}:${namespace}:warn`);\n this.errorLogger = debug(`${PACKAGE_NAME}:${namespace}:error`);\n\n this.debugLogger.color = \"4\";\n this.infoLogger.color = \"2\";\n this.warnLogger.color = \"3\";\n this.errorLogger.color = \"1\";\n }\n\n debug(message: string, ...args: unknown[]): void {\n this.debugLogger(message, ...args);\n }\n\n info(message: string, ...args: unknown[]): void {\n this.infoLogger(message, ...args);\n }\n\n warn(message: string, ...args: unknown[]): void {\n this.warnLogger(message, ...args);\n }\n\n error(message: string, ...args: unknown[]): void {\n this.errorLogger(message, ...args);\n }\n}\n\nexport const createLogger = (namespace: string): Logger =>\n new DebugLogger(namespace);\n\n// Pre-configured loggers for different parts of your package\nexport const loggers = {\n // Next.js specific loggers\n nextjs: {\n routes: createLogger(\"api:routes\"),\n middleware: createLogger(\"api:middleware\"),\n handlers: {\n auth: createLogger(\"api:handlers:auth\"),\n },\n },\n // React specific loggers\n react: {\n components: createLogger(\"react:components\"),\n hooks: createLogger(\"react:hooks\"),\n context: createLogger(\"react:context\"),\n },\n // Shared utilities loggers\n services: {\n validation: createLogger(\"utils:validation\"),\n network: createLogger(\"utils:network\"),\n },\n} as const;\n"]}
@@ -0,0 +1,19 @@
1
+ import type { DisplayMode, Endpoints } from "@/types.js";
2
+ declare const getIssuerVariations: (issuer: string) => string[];
3
+ declare const getOauthEndpoints: (oauthServer: string) => Promise<Endpoints>;
4
+ /**
5
+ * creates a state string for the OAuth2 flow, encoding the display mode too for future use
6
+ * @param {DisplayMode} displayMode
7
+ * @returns {string}
8
+ */
9
+ declare const generateState: (displayMode: DisplayMode, serverTokenExchange?: boolean) => string;
10
+ /**
11
+ * parses the state string from the OAuth2 flow, decoding the display mode too
12
+ * @param state
13
+ * @param sessionDisplayMode
14
+ * @returns { uuid: string, displayMode: DisplayMode }
15
+ */
16
+ declare const displayModeFromState: (state: string, sessionDisplayMode: DisplayMode | undefined) => DisplayMode | undefined;
17
+ declare const serverTokenExchangeFromState: (state: string) => boolean | undefined;
18
+ export { serverTokenExchangeFromState, getIssuerVariations, getOauthEndpoints, displayModeFromState, generateState, };
19
+ //# sourceMappingURL=oauth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oauth.d.ts","sourceRoot":"","sources":["../../../src/lib/oauth.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAuB,MAAM,YAAY,CAAC;AAG9E,QAAA,MAAM,mBAAmB,WAAY,MAAM,KAAG,MAAM,EAQnD,CAAC;AAKF,QAAA,MAAM,iBAAiB,gBAAuB,MAAM,KAAG,OAAO,CAAC,SAAS,CAavE,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,aAAa,gBACJ,WAAW,wBACF,OAAO,KAC5B,MAOF,CAAC;AAEF;;;;;GAKG;AACH,QAAA,MAAM,oBAAoB,UACjB,MAAM,sBACO,WAAW,GAAG,SAAS,KAC1C,WAAW,GAAG,SAQhB,CAAC;AAEF,QAAA,MAAM,4BAA4B,UAAW,MAAM,KAAG,OAAO,GAAG,SAQ/D,CAAC;AAEF,OAAO,EACL,4BAA4B,EAC5B,mBAAmB,EACnB,iBAAiB,EACjB,oBAAoB,EACpB,aAAa,GACd,CAAC"}
@@ -0,0 +1,61 @@
1
+ import { v4 as uuid } from "uuid";
2
+ const getIssuerVariations = (issuer) => {
3
+ const issuerWithoutSlash = issuer.endsWith("/")
4
+ ? issuer.slice(0, issuer.length - 1)
5
+ : issuer;
6
+ const issuerWithSlash = `${issuerWithoutSlash}/`;
7
+ return [issuerWithoutSlash, issuerWithSlash];
8
+ };
9
+ const addSlashIfNeeded = (url) => url.endsWith("/") ? url : `${url}/`;
10
+ const getOauthEndpoints = async (oauthServer) => {
11
+ const openIdConfigResponse = await fetch(`${addSlashIfNeeded(oauthServer)}.well-known/openid-configuration`);
12
+ const openIdConfig = (await openIdConfigResponse.json());
13
+ return {
14
+ jwks: openIdConfig.jwks_uri,
15
+ auth: openIdConfig.authorization_endpoint,
16
+ token: openIdConfig.token_endpoint,
17
+ userinfo: openIdConfig.userinfo_endpoint,
18
+ endsession: openIdConfig.end_session_endpoint,
19
+ };
20
+ };
21
+ /**
22
+ * creates a state string for the OAuth2 flow, encoding the display mode too for future use
23
+ * @param {DisplayMode} displayMode
24
+ * @returns {string}
25
+ */
26
+ const generateState = (displayMode, serverTokenExchange) => {
27
+ const jsonString = JSON.stringify({
28
+ uuid: uuid(),
29
+ displayMode,
30
+ ...(serverTokenExchange ? { serverTokenExchange } : {}),
31
+ });
32
+ return btoa(jsonString);
33
+ };
34
+ /**
35
+ * parses the state string from the OAuth2 flow, decoding the display mode too
36
+ * @param state
37
+ * @param sessionDisplayMode
38
+ * @returns { uuid: string, displayMode: DisplayMode }
39
+ */
40
+ const displayModeFromState = (state, sessionDisplayMode) => {
41
+ try {
42
+ const jsonString = atob(state);
43
+ return JSON.parse(jsonString).displayMode;
44
+ }
45
+ catch (e) {
46
+ console.error("Failed to parse displayMode from state:", state, e);
47
+ return sessionDisplayMode;
48
+ }
49
+ };
50
+ const serverTokenExchangeFromState = (state) => {
51
+ try {
52
+ const jsonString = atob(state);
53
+ return JSON.parse(jsonString).serverTokenExchange;
54
+ }
55
+ catch {
56
+ console.error("Failed to parse serverTokenExchange from state:", state);
57
+ return undefined;
58
+ }
59
+ };
60
+ export { serverTokenExchangeFromState, getIssuerVariations, getOauthEndpoints, displayModeFromState, generateState, };
61
+ //# sourceMappingURL=oauth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../../src/lib/oauth.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,IAAI,IAAI,EAAE,MAAM,MAAM,CAAC;AAElC,MAAM,mBAAmB,GAAG,CAAC,MAAc,EAAY,EAAE;IACvD,MAAM,kBAAkB,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC;QAC7C,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;QACpC,CAAC,CAAC,MAAM,CAAC;IAEX,MAAM,eAAe,GAAG,GAAG,kBAAkB,GAAG,CAAC;IAEjD,OAAO,CAAC,kBAAkB,EAAE,eAAe,CAAC,CAAC;AAC/C,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG,CAAC,GAAW,EAAU,EAAE,CAC/C,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAEtC,MAAM,iBAAiB,GAAG,KAAK,EAAE,WAAmB,EAAsB,EAAE;IAC1E,MAAM,oBAAoB,GAAG,MAAM,KAAK,CACtC,GAAG,gBAAgB,CAAC,WAAW,CAAC,kCAAkC,CACnE,CAAC;IACF,MAAM,YAAY,GAChB,CAAC,MAAM,oBAAoB,CAAC,IAAI,EAAE,CAAwB,CAAC;IAC7D,OAAO;QACL,IAAI,EAAE,YAAY,CAAC,QAAQ;QAC3B,IAAI,EAAE,YAAY,CAAC,sBAAsB;QACzC,KAAK,EAAE,YAAY,CAAC,cAAc;QAClC,QAAQ,EAAE,YAAY,CAAC,iBAAiB;QACxC,UAAU,EAAE,YAAY,CAAC,oBAAoB;KAC9C,CAAC;AACJ,CAAC,CAAC;AAEF;;;;GAIG;AACH,MAAM,aAAa,GAAG,CACpB,WAAwB,EACxB,mBAA6B,EACrB,EAAE;IACV,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,IAAI,EAAE,IAAI,EAAE;QACZ,WAAW;QACX,GAAG,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,mBAAmB,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACxD,CAAC,CAAC;IACH,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC;AAC1B,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,oBAAoB,GAAG,CAC3B,KAAa,EACb,kBAA2C,EAClB,EAAE;IAC3B,IAAI,CAAC;QACH,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,WAAW,CAAC;IAC5C,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,CAAC,KAAK,CAAC,yCAAyC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QACnE,OAAO,kBAAkB,CAAC;IAC5B,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,4BAA4B,GAAG,CAAC,KAAa,EAAuB,EAAE;IAC1E,IAAI,CAAC;QACH,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,mBAAmB,CAAC;IACpD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,KAAK,CAAC,iDAAiD,EAAE,KAAK,CAAC,CAAC;QACxE,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC,CAAC;AAEF,OAAO,EACL,4BAA4B,EAC5B,mBAAmB,EACnB,iBAAiB,EACjB,oBAAoB,EACpB,aAAa,GACd,CAAC","sourcesContent":["import type { DisplayMode, Endpoints, OpenIdConfiguration } from \"@/types.js\";\nimport { v4 as uuid } from \"uuid\";\n\nconst getIssuerVariations = (issuer: string): string[] => {\n const issuerWithoutSlash = issuer.endsWith(\"/\")\n ? issuer.slice(0, issuer.length - 1)\n : issuer;\n\n const issuerWithSlash = `${issuerWithoutSlash}/`;\n\n return [issuerWithoutSlash, issuerWithSlash];\n};\n\nconst addSlashIfNeeded = (url: string): string =>\n url.endsWith(\"/\") ? url : `${url}/`;\n\nconst getOauthEndpoints = async (oauthServer: string): Promise<Endpoints> => {\n const openIdConfigResponse = await fetch(\n `${addSlashIfNeeded(oauthServer)}.well-known/openid-configuration`,\n );\n const openIdConfig =\n (await openIdConfigResponse.json()) as OpenIdConfiguration;\n return {\n jwks: openIdConfig.jwks_uri,\n auth: openIdConfig.authorization_endpoint,\n token: openIdConfig.token_endpoint,\n userinfo: openIdConfig.userinfo_endpoint,\n endsession: openIdConfig.end_session_endpoint,\n };\n};\n\n/**\n * creates a state string for the OAuth2 flow, encoding the display mode too for future use\n * @param {DisplayMode} displayMode\n * @returns {string}\n */\nconst generateState = (\n displayMode: DisplayMode,\n serverTokenExchange?: boolean,\n): string => {\n const jsonString = JSON.stringify({\n uuid: uuid(),\n displayMode,\n ...(serverTokenExchange ? { serverTokenExchange } : {}),\n });\n return btoa(jsonString);\n};\n\n/**\n * parses the state string from the OAuth2 flow, decoding the display mode too\n * @param state\n * @param sessionDisplayMode\n * @returns { uuid: string, displayMode: DisplayMode }\n */\nconst displayModeFromState = (\n state: string,\n sessionDisplayMode: DisplayMode | undefined,\n): DisplayMode | undefined => {\n try {\n const jsonString = atob(state);\n return JSON.parse(jsonString).displayMode;\n } catch (e) {\n console.error(\"Failed to parse displayMode from state:\", state, e);\n return sessionDisplayMode;\n }\n};\n\nconst serverTokenExchangeFromState = (state: string): boolean | undefined => {\n try {\n const jsonString = atob(state);\n return JSON.parse(jsonString).serverTokenExchange;\n } catch {\n console.error(\"Failed to parse serverTokenExchange from state:\", state);\n return undefined;\n }\n};\n\nexport {\n serverTokenExchangeFromState,\n getIssuerVariations,\n getOauthEndpoints,\n displayModeFromState,\n generateState,\n};\n"]}
@@ -0,0 +1,3 @@
1
+ declare const objectsAreEqual: (obj1: Record<string, unknown> | null | undefined, obj2: Record<string, unknown> | null | undefined) => boolean;
2
+ export { objectsAreEqual };
3
+ //# sourceMappingURL=obj.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"obj.d.ts","sourceRoot":"","sources":["../../../src/lib/obj.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,eAAe,SACb,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,GAAG,SAAS,QAC1C,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,GAAG,SAAS,KAC/C,OAiBF,CAAC;AACF,OAAO,EAAE,eAAe,EAAE,CAAC"}
@@ -0,0 +1,18 @@
1
+ const objectsAreEqual = (obj1, obj2) => {
2
+ if (obj1 === obj2)
3
+ return true;
4
+ if ((obj1 && !obj2) || (obj2 && !obj1)) {
5
+ return false;
6
+ }
7
+ const keys1 = obj1 ? Object.keys(obj1) : [];
8
+ const keys2 = obj2 ? Object.keys(obj2) : [];
9
+ if (keys1.length !== keys2.length)
10
+ return false;
11
+ for (const key of keys1) {
12
+ if ((obj1 || {})[key] !== (obj2 || {})[key])
13
+ return false;
14
+ }
15
+ return true;
16
+ };
17
+ export { objectsAreEqual };
18
+ //# sourceMappingURL=obj.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"obj.js","sourceRoot":"","sources":["../../../src/lib/obj.ts"],"names":[],"mappings":"AAAA,MAAM,eAAe,GAAG,CACtB,IAAgD,EAChD,IAAgD,EACvC,EAAE;IACX,IAAI,IAAI,KAAK,IAAI;QAAE,OAAO,IAAI,CAAC;IAE/B,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACvC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAE5C,IAAI,KAAK,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM;QAAE,OAAO,KAAK,CAAC;IAEhD,KAAK,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC;YAAE,OAAO,KAAK,CAAC;IAC5D,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AACF,OAAO,EAAE,eAAe,EAAE,CAAC","sourcesContent":["const objectsAreEqual = (\n obj1: Record<string, unknown> | null | undefined,\n obj2: Record<string, unknown> | null | undefined,\n): boolean => {\n if (obj1 === obj2) return true;\n\n if ((obj1 && !obj2) || (obj2 && !obj1)) {\n return false;\n }\n\n const keys1 = obj1 ? Object.keys(obj1) : [];\n const keys2 = obj2 ? Object.keys(obj2) : [];\n\n if (keys1.length !== keys2.length) return false;\n\n for (const key of keys1) {\n if ((obj1 || {})[key] !== (obj2 || {})[key]) return false;\n }\n\n return true;\n};\nexport { objectsAreEqual };\n"]}
@@ -0,0 +1,4 @@
1
+ import type { LoginPostMessage } from "@/types.js";
2
+ declare const validateLoginAppPostMessage: (event: LoginPostMessage, clientId: string) => boolean;
3
+ export { validateLoginAppPostMessage };
4
+ //# sourceMappingURL=postMessage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postMessage.d.ts","sourceRoot":"","sources":["../../../src/lib/postMessage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,QAAA,MAAM,2BAA2B,UACxB,gBAAgB,YACb,MAAM,KACf,OAcF,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC"}
@@ -0,0 +1,15 @@
1
+ const validateLoginAppPostMessage = (event, clientId) => {
2
+ const caseEvent = event;
3
+ // console.log("caseEvent", caseEvent);
4
+ if (!caseEvent.clientId ||
5
+ !caseEvent.data.url ||
6
+ !caseEvent.source ||
7
+ !caseEvent.type ||
8
+ caseEvent.clientId !== clientId ||
9
+ caseEvent.source !== "civicloginApp") {
10
+ return false;
11
+ }
12
+ return true;
13
+ };
14
+ export { validateLoginAppPostMessage };
15
+ //# sourceMappingURL=postMessage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postMessage.js","sourceRoot":"","sources":["../../../src/lib/postMessage.ts"],"names":[],"mappings":"AAEA,MAAM,2BAA2B,GAAG,CAClC,KAAuB,EACvB,QAAgB,EACP,EAAE;IACX,MAAM,SAAS,GAAG,KAAyB,CAAC;IAC5C,uCAAuC;IACvC,IACE,CAAC,SAAS,CAAC,QAAQ;QACnB,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG;QACnB,CAAC,SAAS,CAAC,MAAM;QACjB,CAAC,SAAS,CAAC,IAAI;QACf,SAAS,CAAC,QAAQ,KAAK,QAAQ;QAC/B,SAAS,CAAC,MAAM,KAAK,eAAe,EACpC,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC","sourcesContent":["import type { LoginPostMessage } from \"@/types.js\";\n\nconst validateLoginAppPostMessage = (\n event: LoginPostMessage,\n clientId: string,\n): boolean => {\n const caseEvent = event as LoginPostMessage;\n // console.log(\"caseEvent\", caseEvent);\n if (\n !caseEvent.clientId ||\n !caseEvent.data.url ||\n !caseEvent.source ||\n !caseEvent.type ||\n caseEvent.clientId !== clientId ||\n caseEvent.source !== \"civicloginApp\"\n ) {\n return false;\n }\n return true;\n};\n\nexport { validateLoginAppPostMessage };\n"]}
@@ -0,0 +1,4 @@
1
+ declare const isWindowInIframe: (window: Window) => boolean;
2
+ declare const removeParamsWithoutReload: (paramsToRemove: string[]) => void;
3
+ export { isWindowInIframe, removeParamsWithoutReload };
4
+ //# sourceMappingURL=windowUtil.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"windowUtil.d.ts","sourceRoot":"","sources":["../../../src/lib/windowUtil.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,gBAAgB,WAAY,MAAM,KAAG,OAc1C,CAAC;AAEF,QAAA,MAAM,yBAAyB,mBAAoB,MAAM,EAAE,SAW1D,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,CAAC"}
@@ -0,0 +1,31 @@
1
+ const isWindowInIframe = (window) => {
2
+ if (typeof window !== "undefined") {
3
+ // use the window width to determine if we're in an iframe or not
4
+ try {
5
+ if (window?.frameElement?.id === "civic-auth-iframe") {
6
+ return true;
7
+ }
8
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
9
+ }
10
+ catch (_e) {
11
+ // If we get an error, we're not in an iframe
12
+ return false;
13
+ }
14
+ }
15
+ return false;
16
+ };
17
+ const removeParamsWithoutReload = (paramsToRemove) => {
18
+ const url = new URL(window.location.href);
19
+ paramsToRemove.forEach((param) => {
20
+ url.searchParams.delete(param);
21
+ });
22
+ try {
23
+ window.history.replaceState({}, "", url);
24
+ window.dispatchEvent(new Event("popstate"));
25
+ }
26
+ catch (error) {
27
+ console.warn("window.history.replaceState failed", error);
28
+ }
29
+ };
30
+ export { isWindowInIframe, removeParamsWithoutReload };
31
+ //# sourceMappingURL=windowUtil.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"windowUtil.js","sourceRoot":"","sources":["../../../src/lib/windowUtil.ts"],"names":[],"mappings":"AAAA,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAW,EAAE;IACnD,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;QAClC,iEAAiE;QACjE,IAAI,CAAC;YACH,IAAI,MAAM,EAAE,YAAY,EAAE,EAAE,KAAK,mBAAmB,EAAE,CAAC;gBACrD,OAAO,IAAI,CAAC;YACd,CAAC;YACD,6DAA6D;QAC/D,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;YACZ,6CAA6C;YAC7C,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,MAAM,yBAAyB,GAAG,CAAC,cAAwB,EAAE,EAAE;IAC7D,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC1C,cAAc,CAAC,OAAO,CAAC,CAAC,KAAa,EAAE,EAAE;QACvC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IACH,IAAI,CAAC;QACH,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QACzC,MAAM,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC;IAC9C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAC;IAC5D,CAAC;AACH,CAAC,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,CAAC","sourcesContent":["const isWindowInIframe = (window: Window): boolean => {\n if (typeof window !== \"undefined\") {\n // use the window width to determine if we're in an iframe or not\n try {\n if (window?.frameElement?.id === \"civic-auth-iframe\") {\n return true;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (_e) {\n // If we get an error, we're not in an iframe\n return false;\n }\n }\n return false;\n};\n\nconst removeParamsWithoutReload = (paramsToRemove: string[]) => {\n const url = new URL(window.location.href);\n paramsToRemove.forEach((param: string) => {\n url.searchParams.delete(param);\n });\n try {\n window.history.replaceState({}, \"\", url);\n window.dispatchEvent(new Event(\"popstate\"));\n } catch (error) {\n console.warn(\"window.history.replaceState failed\", error);\n }\n};\n\nexport { isWindowInIframe, removeParamsWithoutReload };\n"]}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Used on the server-side to get the user object from the cookie
3
+ */
4
+ import type { User } from "@/types.js";
5
+ export declare const getUser: () => Promise<User | null>;
6
+ //# sourceMappingURL=GetUser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GetUser.d.ts","sourceRoot":"","sources":["../../../src/nextjs/GetUser.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAIvC,eAAO,MAAM,OAAO,QAAa,OAAO,CAAC,IAAI,GAAG,IAAI,CAGnD,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { NextjsClientStorage } from "@/nextjs/cookies.js";
2
+ import { getUser as getSessionUser } from "@/shared/lib/session.js";
3
+ export const getUser = async () => {
4
+ const clientStorage = new NextjsClientStorage();
5
+ return getSessionUser(clientStorage);
6
+ };
7
+ //# sourceMappingURL=GetUser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GetUser.js","sourceRoot":"","sources":["../../../src/nextjs/GetUser.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEpE,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,IAA0B,EAAE;IACtD,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,cAAc,CAAC,aAAa,CAAC,CAAC;AACvC,CAAC,CAAC","sourcesContent":["/**\n * Used on the server-side to get the user object from the cookie\n */\nimport type { User } from \"@/types.js\";\nimport { NextjsClientStorage } from \"@/nextjs/cookies.js\";\nimport { getUser as getSessionUser } from \"@/shared/lib/session.js\";\n\nexport const getUser = async (): Promise<User | null> => {\n const clientStorage = new NextjsClientStorage();\n return getSessionUser(clientStorage);\n};\n"]}
@@ -0,0 +1,181 @@
1
+ import type { NextConfig } from "next";
2
+ import { type CookieConfig, type TokensCookieConfig } from "@/shared/lib/types.js";
3
+ export type CookiesConfigObject = {
4
+ tokens: TokensCookieConfig;
5
+ user: CookieConfig;
6
+ };
7
+ export type AuthConfigWithDefaults = {
8
+ clientId: string;
9
+ oauthServer: string;
10
+ callbackUrl: string;
11
+ loginUrl: string;
12
+ logoutUrl: string;
13
+ logoutCallbackUrl: string;
14
+ challengeUrl: string;
15
+ include: string[];
16
+ exclude: string[];
17
+ cookies: CookiesConfigObject;
18
+ };
19
+ export type AuthConfig = Partial<AuthConfigWithDefaults>;
20
+ export type DefinedAuthConfig = AuthConfigWithDefaults;
21
+ /**
22
+ * Default configuration values that will be used if not overridden
23
+ */
24
+ export declare const defaultAuthConfig: Omit<AuthConfigWithDefaults, "clientId">;
25
+ /**
26
+ * Resolves the authentication configuration by combining:
27
+ * 1. Default values
28
+ * 2. Environment variables (set internally by the plugin)
29
+ * 3. Explicitly passed configuration
30
+ *
31
+ * Note: Developers should not set _civic_auth_* environment variables directly.
32
+ * Instead, pass configuration to the createCivicAuthPlugin in next.config.js:
33
+ *
34
+ * @example
35
+ * ```js
36
+ * // next.config.js
37
+ * export default createCivicAuthPlugin({
38
+ * callbackUrl: '/custom/callback',
39
+ * })
40
+ * ```
41
+ */
42
+ export declare const resolveAuthConfig: (config?: AuthConfig) => AuthConfigWithDefaults;
43
+ /**
44
+ * Creates a Next.js plugin that handles auth configuration.
45
+ *
46
+ * This is the main configuration point for the auth system.
47
+ * Do not set _civic_auth_* environment variables directly - instead,
48
+ * pass your configuration here:
49
+ *
50
+ * @example
51
+ * ```js
52
+ * // next.config.js
53
+ * export default createCivicAuthPlugin({
54
+ * clientId: 'my-client-id',
55
+ * callbackUrl: '/custom/callback',
56
+ * loginUrl: '/custom/login',
57
+ * logoutUrl: '/custom/logout',
58
+ * logoutCallbackUrl: '/custom/logoutcallback',
59
+ * include: ['/protected/*'],
60
+ * exclude: ['/public/*']
61
+ * })
62
+ * ```
63
+ *
64
+ * The plugin sets internal environment variables that are used by
65
+ * the auth system. These variables should not be set manually.
66
+ */
67
+ export declare const createCivicAuthPlugin: (authConfig: AuthConfig & Pick<Required<AuthConfig>, "clientId">) => (nextConfig?: NextConfig) => {
68
+ env: {
69
+ _civic_auth_client_id: string;
70
+ _civic_oauth_server: string;
71
+ _civic_auth_callback_url: string;
72
+ _civic_auth_challenge_url: string;
73
+ _civic_auth_login_url: string;
74
+ _civic_auth_logout_url: string;
75
+ _civic_auth_logout_callback_url: string;
76
+ _civic_auth_includes: string;
77
+ _civic_auth_excludes: string;
78
+ _civic_auth_cookie_config: string;
79
+ };
80
+ exportPathMap?: (defaultMap: import("next/dist/server/config-shared.js").ExportPathMap, ctx: {
81
+ dev: boolean;
82
+ dir: string;
83
+ outDir: string | null;
84
+ distDir: string;
85
+ buildId: string;
86
+ }) => Promise<import("next/dist/server/config-shared.js").ExportPathMap> | import("next/dist/server/config-shared.js").ExportPathMap;
87
+ i18n?: import("next/dist/server/config-shared.js").I18NConfig | null;
88
+ eslint?: import("next/dist/server/config-shared.js").ESLintConfig;
89
+ typescript?: import("next/dist/server/config-shared.js").TypeScriptConfig;
90
+ headers?: () => Promise<import("next/dist/lib/load-custom-routes.js").Header[]>;
91
+ rewrites?: () => Promise<import("next/dist/lib/load-custom-routes.js").Rewrite[] | {
92
+ beforeFiles: import("next/dist/lib/load-custom-routes.js").Rewrite[];
93
+ afterFiles: import("next/dist/lib/load-custom-routes.js").Rewrite[];
94
+ fallback: import("next/dist/lib/load-custom-routes.js").Rewrite[];
95
+ }>;
96
+ redirects?: () => Promise<import("next/dist/lib/load-custom-routes.js").Redirect[]>;
97
+ excludeDefaultMomentLocales?: boolean;
98
+ webpack?: import("next/dist/server/config-shared.js").NextJsWebpackConfig | null;
99
+ trailingSlash?: boolean;
100
+ distDir?: string;
101
+ cleanDistDir?: boolean;
102
+ assetPrefix?: string;
103
+ cacheHandler?: string | undefined;
104
+ cacheMaxMemorySize?: number;
105
+ useFileSystemPublicRoutes?: boolean;
106
+ generateBuildId?: () => string | null | Promise<string | null>;
107
+ generateEtags?: boolean;
108
+ pageExtensions?: string[];
109
+ compress?: boolean;
110
+ analyticsId?: string;
111
+ poweredByHeader?: boolean;
112
+ images?: import("next/dist/shared/lib/image-config.js").ImageConfig;
113
+ devIndicators?: {
114
+ buildActivity?: boolean;
115
+ buildActivityPosition?: "bottom-right" | "bottom-left" | "top-right" | "top-left";
116
+ };
117
+ onDemandEntries?: {
118
+ maxInactiveAge?: number;
119
+ pagesBufferLength?: number;
120
+ };
121
+ amp?: {
122
+ canonicalBase?: string;
123
+ };
124
+ deploymentId?: string;
125
+ basePath?: string;
126
+ sassOptions?: {
127
+ [key: string]: any;
128
+ };
129
+ productionBrowserSourceMaps?: boolean;
130
+ optimizeFonts?: boolean;
131
+ reactProductionProfiling?: boolean;
132
+ reactStrictMode?: boolean | null;
133
+ publicRuntimeConfig?: {
134
+ [key: string]: any;
135
+ };
136
+ serverRuntimeConfig?: {
137
+ [key: string]: any;
138
+ };
139
+ httpAgentOptions?: {
140
+ keepAlive?: boolean;
141
+ };
142
+ outputFileTracing?: boolean;
143
+ staticPageGenerationTimeout?: number;
144
+ crossOrigin?: "anonymous" | "use-credentials";
145
+ swcMinify?: boolean;
146
+ compiler?: {
147
+ reactRemoveProperties?: boolean | {
148
+ properties?: string[];
149
+ };
150
+ relay?: {
151
+ src: string;
152
+ artifactDirectory?: string;
153
+ language?: "typescript" | "javascript" | "flow";
154
+ eagerEsModules?: boolean;
155
+ };
156
+ removeConsole?: boolean | {
157
+ exclude?: string[];
158
+ };
159
+ styledComponents?: boolean | import("next/dist/server/config-shared.js").StyledComponentsConfig;
160
+ emotion?: boolean | import("next/dist/server/config-shared.js").EmotionConfig;
161
+ styledJsx?: boolean | {
162
+ useLightningcss?: boolean;
163
+ };
164
+ };
165
+ output?: "standalone" | "export";
166
+ transpilePackages?: string[];
167
+ skipMiddlewareUrlNormalize?: boolean;
168
+ skipTrailingSlashRedirect?: boolean;
169
+ modularizeImports?: Record<string, {
170
+ transform: string | Record<string, string>;
171
+ preventFullImport?: boolean;
172
+ skipDefaultConversion?: boolean;
173
+ }>;
174
+ logging?: {
175
+ fetches?: {
176
+ fullUrl?: boolean;
177
+ };
178
+ };
179
+ experimental?: import("next/dist/server/config-shared.js").ExperimentalConfig;
180
+ };
181
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/nextjs/config.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAGvC,OAAO,EAEL,KAAK,YAAY,EAEjB,KAAK,kBAAkB,EACxB,MAAM,uBAAuB,CAAC;AAK/B,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,EAAE,kBAAkB,CAAC;IAC3B,IAAI,EAAE,YAAY,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,mBAAmB,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAC;AAEzD,MAAM,MAAM,iBAAiB,GAAG,sBAAsB,CAAC;AAGvD;;GAEG;AACH,eAAO,MAAM,iBAAiB,EAAE,IAAI,CAAC,sBAAsB,EAAE,UAAU,CA8DtE,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,eAAO,MAAM,iBAAiB,YACpB,UAAU,KACjB,sBA2CF,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,eAAO,MAAM,qBAAqB,eACpB,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,UAAU,CAAC,mBAE1C,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAyBk9a,CAAC;6BAAsG,CAAC;;;sBAAke,CAAC;yBAA4H,CAAC;;;qBAA+H,CAAC;;;;;;;;;;;;;;;;;;iBAA8pE,CAAC;;;;;;;6BAAg6C,CAAC;sBAAoC,CAAC;;aAAoC,CAAC;;6BAA0D,CAAC;oBAA8B,CAAC;0BAAkE,CAAC;;qBAA2C,CAAC;mBAAiC,CAAC;;wBAA+C,CAAC;eAAmD,CAAC;iBAA4C,CAAC;2BAAyC,CAAC;;;;;;;;;yBAA4zC,CAAC;6BAAwC,CAAC;;;eAAkD,CAAC;mBAAuB,CAAC;;;;CAD3xnB,CAAC"}