@mulverse/mulguard-core 1.0.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 (600) hide show
  1. package/README.md +24 -0
  2. package/adapters.d.ts +522 -0
  3. package/adapters.d.ts.map +1 -0
  4. package/adapters.js +170 -0
  5. package/errors.d.ts +429 -0
  6. package/errors.d.ts.map +1 -0
  7. package/errors.js +473 -0
  8. package/index.d.ts +547 -0
  9. package/index.d.ts.map +1 -0
  10. package/index.js +142 -0
  11. package/jwt.d.ts +132 -0
  12. package/jwt.d.ts.map +1 -0
  13. package/jwt.js +123 -0
  14. package/lib/actions/callback/handle-login.d.ts +35 -0
  15. package/lib/actions/callback/handle-login.d.ts.map +1 -0
  16. package/lib/actions/callback/handle-login.js +275 -0
  17. package/lib/actions/callback/index.d.ts +5 -0
  18. package/lib/actions/callback/index.d.ts.map +1 -0
  19. package/lib/actions/callback/index.js +409 -0
  20. package/lib/actions/callback/oauth/callback.d.ts +36 -0
  21. package/lib/actions/callback/oauth/callback.d.ts.map +1 -0
  22. package/lib/actions/callback/oauth/callback.js +248 -0
  23. package/lib/actions/callback/oauth/checks.d.ts +70 -0
  24. package/lib/actions/callback/oauth/checks.d.ts.map +1 -0
  25. package/lib/actions/callback/oauth/checks.js +188 -0
  26. package/lib/actions/callback/oauth/csrf-token.d.ts +33 -0
  27. package/lib/actions/callback/oauth/csrf-token.d.ts.map +1 -0
  28. package/lib/actions/callback/oauth/csrf-token.js +39 -0
  29. package/lib/actions/index.d.ts +6 -0
  30. package/lib/actions/index.d.ts.map +1 -0
  31. package/lib/actions/index.js +5 -0
  32. package/lib/actions/session.d.ts +5 -0
  33. package/lib/actions/session.d.ts.map +1 -0
  34. package/lib/actions/session.js +127 -0
  35. package/lib/actions/signin/authorization-url.d.ts +12 -0
  36. package/lib/actions/signin/authorization-url.d.ts.map +1 -0
  37. package/lib/actions/signin/authorization-url.js +94 -0
  38. package/lib/actions/signin/index.d.ts +4 -0
  39. package/lib/actions/signin/index.d.ts.map +1 -0
  40. package/lib/actions/signin/index.js +22 -0
  41. package/lib/actions/signin/send-token.d.ts +10 -0
  42. package/lib/actions/signin/send-token.d.ts.map +1 -0
  43. package/lib/actions/signin/send-token.js +98 -0
  44. package/lib/actions/signout.d.ts +11 -0
  45. package/lib/actions/signout.d.ts.map +1 -0
  46. package/lib/actions/signout.js +30 -0
  47. package/lib/actions/webauthn-options.d.ts +8 -0
  48. package/lib/actions/webauthn-options.d.ts.map +1 -0
  49. package/lib/actions/webauthn-options.js +60 -0
  50. package/lib/index.d.ts +2 -0
  51. package/lib/index.d.ts.map +1 -0
  52. package/lib/index.js +70 -0
  53. package/lib/init.d.ts +25 -0
  54. package/lib/init.d.ts.map +1 -0
  55. package/lib/init.js +172 -0
  56. package/lib/pages/error.d.ts +17 -0
  57. package/lib/pages/error.d.ts.map +1 -0
  58. package/lib/pages/error.js +40 -0
  59. package/lib/pages/index.d.ts +42 -0
  60. package/lib/pages/index.d.ts.map +1 -0
  61. package/lib/pages/index.js +136 -0
  62. package/lib/pages/signin.d.ts +10 -0
  63. package/lib/pages/signin.d.ts.map +1 -0
  64. package/lib/pages/signin.js +75 -0
  65. package/lib/pages/signout.d.ts +8 -0
  66. package/lib/pages/signout.d.ts.map +1 -0
  67. package/lib/pages/signout.js +17 -0
  68. package/lib/pages/styles.d.ts +3 -0
  69. package/lib/pages/styles.d.ts.map +1 -0
  70. package/lib/pages/styles.js +381 -0
  71. package/lib/pages/verify-request.d.ts +8 -0
  72. package/lib/pages/verify-request.d.ts.map +1 -0
  73. package/lib/pages/verify-request.js +11 -0
  74. package/lib/symbols.d.ts +50 -0
  75. package/lib/symbols.d.ts.map +1 -0
  76. package/lib/symbols.js +57 -0
  77. package/lib/utils/actions.d.ts +3 -0
  78. package/lib/utils/actions.d.ts.map +1 -0
  79. package/lib/utils/actions.js +14 -0
  80. package/lib/utils/assert.d.ts +14 -0
  81. package/lib/utils/assert.d.ts.map +1 -0
  82. package/lib/utils/assert.js +168 -0
  83. package/lib/utils/callback-url.d.ts +17 -0
  84. package/lib/utils/callback-url.d.ts.map +1 -0
  85. package/lib/utils/callback-url.js +27 -0
  86. package/lib/utils/cookie.d.ts +111 -0
  87. package/lib/utils/cookie.d.ts.map +1 -0
  88. package/lib/utils/cookie.js +205 -0
  89. package/lib/utils/date.d.ts +7 -0
  90. package/lib/utils/date.d.ts.map +1 -0
  91. package/lib/utils/date.js +8 -0
  92. package/lib/utils/email.d.ts +20 -0
  93. package/lib/utils/email.d.ts.map +1 -0
  94. package/lib/utils/email.js +57 -0
  95. package/lib/utils/env.d.ts +9 -0
  96. package/lib/utils/env.d.ts.map +1 -0
  97. package/lib/utils/env.js +96 -0
  98. package/lib/utils/logger.d.ts +18 -0
  99. package/lib/utils/logger.d.ts.map +1 -0
  100. package/lib/utils/logger.js +50 -0
  101. package/lib/utils/merge.d.ts +3 -0
  102. package/lib/utils/merge.d.ts.map +1 -0
  103. package/lib/utils/merge.js +23 -0
  104. package/lib/utils/providers.d.ts +19 -0
  105. package/lib/utils/providers.d.ts.map +1 -0
  106. package/lib/utils/providers.js +149 -0
  107. package/lib/utils/session.d.ts +7 -0
  108. package/lib/utils/session.d.ts.map +1 -0
  109. package/lib/utils/session.js +29 -0
  110. package/lib/utils/web.d.ts +10 -0
  111. package/lib/utils/web.d.ts.map +1 -0
  112. package/lib/utils/web.js +109 -0
  113. package/lib/utils/webauthn-client.d.ts +30 -0
  114. package/lib/utils/webauthn-client.d.ts.map +1 -0
  115. package/lib/utils/webauthn-client.js +197 -0
  116. package/lib/utils/webauthn-utils.d.ts +81 -0
  117. package/lib/utils/webauthn-utils.d.ts.map +1 -0
  118. package/lib/utils/webauthn-utils.js +343 -0
  119. package/lib/vendored/cookie.d.ts +120 -0
  120. package/lib/vendored/cookie.d.ts.map +1 -0
  121. package/lib/vendored/cookie.js +237 -0
  122. package/package.json +118 -0
  123. package/providers/42-school.d.ts +240 -0
  124. package/providers/42-school.d.ts.map +1 -0
  125. package/providers/42-school.js +78 -0
  126. package/providers/apple.d.ts +149 -0
  127. package/providers/apple.d.ts.map +1 -0
  128. package/providers/apple.js +104 -0
  129. package/providers/asgardeo.d.ts +102 -0
  130. package/providers/asgardeo.d.ts.map +1 -0
  131. package/providers/asgardeo.js +93 -0
  132. package/providers/atlassian.d.ts +94 -0
  133. package/providers/atlassian.d.ts.map +1 -0
  134. package/providers/atlassian.js +84 -0
  135. package/providers/auth0.d.ts +116 -0
  136. package/providers/auth0.d.ts.map +1 -0
  137. package/providers/auth0.js +49 -0
  138. package/providers/authentik.d.ts +90 -0
  139. package/providers/authentik.d.ts.map +1 -0
  140. package/providers/authentik.js +65 -0
  141. package/providers/azure-ad-b2c.d.ts +104 -0
  142. package/providers/azure-ad-b2c.d.ts.map +1 -0
  143. package/providers/azure-ad-b2c.js +100 -0
  144. package/providers/azure-ad.d.ts +19 -0
  145. package/providers/azure-ad.d.ts.map +1 -0
  146. package/providers/azure-ad.js +23 -0
  147. package/providers/azure-devops.d.ts +128 -0
  148. package/providers/azure-devops.d.ts.map +1 -0
  149. package/providers/azure-devops.js +158 -0
  150. package/providers/bankid-no.d.ts +134 -0
  151. package/providers/bankid-no.d.ts.map +1 -0
  152. package/providers/bankid-no.js +65 -0
  153. package/providers/battlenet.d.ts +85 -0
  154. package/providers/battlenet.d.ts.map +1 -0
  155. package/providers/battlenet.js +81 -0
  156. package/providers/beyondidentity.d.ts +77 -0
  157. package/providers/beyondidentity.d.ts.map +1 -0
  158. package/providers/beyondidentity.js +84 -0
  159. package/providers/bitbucket.d.ts +89 -0
  160. package/providers/bitbucket.d.ts.map +1 -0
  161. package/providers/bitbucket.js +92 -0
  162. package/providers/box.d.ts +63 -0
  163. package/providers/box.d.ts.map +1 -0
  164. package/providers/box.js +73 -0
  165. package/providers/boxyhq-saml.d.ts +121 -0
  166. package/providers/boxyhq-saml.d.ts.map +1 -0
  167. package/providers/boxyhq-saml.js +127 -0
  168. package/providers/bungie.d.ts +167 -0
  169. package/providers/bungie.d.ts.map +1 -0
  170. package/providers/bungie.js +174 -0
  171. package/providers/click-up.d.ts +75 -0
  172. package/providers/click-up.d.ts.map +1 -0
  173. package/providers/click-up.js +89 -0
  174. package/providers/cognito.d.ts +81 -0
  175. package/providers/cognito.d.ts.map +1 -0
  176. package/providers/cognito.js +73 -0
  177. package/providers/coinbase.d.ts +69 -0
  178. package/providers/coinbase.d.ts.map +1 -0
  179. package/providers/coinbase.js +78 -0
  180. package/providers/concept2.d.ts +81 -0
  181. package/providers/concept2.d.ts.map +1 -0
  182. package/providers/concept2.js +86 -0
  183. package/providers/credentials.d.ts +132 -0
  184. package/providers/credentials.d.ts.map +1 -0
  185. package/providers/credentials.js +74 -0
  186. package/providers/descope.d.ts +91 -0
  187. package/providers/descope.d.ts.map +1 -0
  188. package/providers/descope.js +78 -0
  189. package/providers/discord.d.ts +139 -0
  190. package/providers/discord.d.ts.map +1 -0
  191. package/providers/discord.js +86 -0
  192. package/providers/dribbble.d.ts +88 -0
  193. package/providers/dribbble.d.ts.map +1 -0
  194. package/providers/dribbble.js +85 -0
  195. package/providers/dropbox.d.ts +65 -0
  196. package/providers/dropbox.d.ts.map +1 -0
  197. package/providers/dropbox.js +88 -0
  198. package/providers/duende-identity-server6.d.ts +91 -0
  199. package/providers/duende-identity-server6.d.ts.map +1 -0
  200. package/providers/duende-identity-server6.js +80 -0
  201. package/providers/email.d.ts +41 -0
  202. package/providers/email.d.ts.map +1 -0
  203. package/providers/email.js +18 -0
  204. package/providers/eventbrite.d.ts +78 -0
  205. package/providers/eventbrite.d.ts.map +1 -0
  206. package/providers/eventbrite.js +88 -0
  207. package/providers/eveonline.d.ts +94 -0
  208. package/providers/eveonline.d.ts.map +1 -0
  209. package/providers/eveonline.js +92 -0
  210. package/providers/facebook.d.ts +84 -0
  211. package/providers/facebook.d.ts.map +1 -0
  212. package/providers/facebook.js +93 -0
  213. package/providers/faceit.d.ts +64 -0
  214. package/providers/faceit.d.ts.map +1 -0
  215. package/providers/faceit.js +74 -0
  216. package/providers/figma.d.ts +75 -0
  217. package/providers/figma.d.ts.map +1 -0
  218. package/providers/figma.js +81 -0
  219. package/providers/forwardemail.d.ts +4 -0
  220. package/providers/forwardemail.d.ts.map +1 -0
  221. package/providers/forwardemail.js +32 -0
  222. package/providers/foursquare.d.ts +71 -0
  223. package/providers/foursquare.d.ts.map +1 -0
  224. package/providers/foursquare.js +91 -0
  225. package/providers/freshbooks.d.ts +66 -0
  226. package/providers/freshbooks.d.ts.map +1 -0
  227. package/providers/freshbooks.js +76 -0
  228. package/providers/frontegg.d.ts +95 -0
  229. package/providers/frontegg.d.ts.map +1 -0
  230. package/providers/frontegg.js +88 -0
  231. package/providers/fusionauth.d.ts +279 -0
  232. package/providers/fusionauth.d.ts.map +1 -0
  233. package/providers/fusionauth.js +292 -0
  234. package/providers/github.d.ts +127 -0
  235. package/providers/github.d.ts.map +1 -0
  236. package/providers/github.js +115 -0
  237. package/providers/gitlab.d.ts +115 -0
  238. package/providers/gitlab.d.ts.map +1 -0
  239. package/providers/gitlab.js +75 -0
  240. package/providers/google.d.ts +138 -0
  241. package/providers/google.d.ts.map +1 -0
  242. package/providers/google.js +119 -0
  243. package/providers/hubspot.d.ts +76 -0
  244. package/providers/hubspot.d.ts.map +1 -0
  245. package/providers/hubspot.js +93 -0
  246. package/providers/huggingface.d.ts +216 -0
  247. package/providers/huggingface.d.ts.map +1 -0
  248. package/providers/huggingface.js +101 -0
  249. package/providers/identity-server4.d.ts +69 -0
  250. package/providers/identity-server4.d.ts.map +1 -0
  251. package/providers/identity-server4.js +64 -0
  252. package/providers/index.d.ts +61 -0
  253. package/providers/index.d.ts.map +1 -0
  254. package/providers/index.js +3 -0
  255. package/providers/instagram.d.ts +74 -0
  256. package/providers/instagram.d.ts.map +1 -0
  257. package/providers/instagram.js +87 -0
  258. package/providers/kakao.d.ts +148 -0
  259. package/providers/kakao.d.ts.map +1 -0
  260. package/providers/kakao.js +103 -0
  261. package/providers/keycloak.d.ts +100 -0
  262. package/providers/keycloak.d.ts.map +1 -0
  263. package/providers/keycloak.js +73 -0
  264. package/providers/kinde.d.ts +73 -0
  265. package/providers/kinde.d.ts.map +1 -0
  266. package/providers/kinde.js +51 -0
  267. package/providers/line.d.ts +83 -0
  268. package/providers/line.d.ts.map +1 -0
  269. package/providers/line.js +73 -0
  270. package/providers/linkedin.d.ts +77 -0
  271. package/providers/linkedin.d.ts.map +1 -0
  272. package/providers/linkedin.js +65 -0
  273. package/providers/logto.d.ts +98 -0
  274. package/providers/logto.d.ts.map +1 -0
  275. package/providers/logto.js +81 -0
  276. package/providers/loops.d.ts +40 -0
  277. package/providers/loops.d.ts.map +1 -0
  278. package/providers/loops.js +59 -0
  279. package/providers/mailchimp.d.ts +66 -0
  280. package/providers/mailchimp.d.ts.map +1 -0
  281. package/providers/mailchimp.js +76 -0
  282. package/providers/mailgun.d.ts +55 -0
  283. package/providers/mailgun.d.ts.map +1 -0
  284. package/providers/mailgun.js +74 -0
  285. package/providers/mailru.d.ts +63 -0
  286. package/providers/mailru.d.ts.map +1 -0
  287. package/providers/mailru.js +61 -0
  288. package/providers/mastodon.d.ts +90 -0
  289. package/providers/mastodon.d.ts.map +1 -0
  290. package/providers/mastodon.js +75 -0
  291. package/providers/mattermost.d.ts +132 -0
  292. package/providers/mattermost.d.ts.map +1 -0
  293. package/providers/mattermost.js +83 -0
  294. package/providers/medium.d.ts +68 -0
  295. package/providers/medium.d.ts.map +1 -0
  296. package/providers/medium.js +84 -0
  297. package/providers/microsoft-entra-id.d.ts +428 -0
  298. package/providers/microsoft-entra-id.d.ts.map +1 -0
  299. package/providers/microsoft-entra-id.js +156 -0
  300. package/providers/naver.d.ts +80 -0
  301. package/providers/naver.d.ts.map +1 -0
  302. package/providers/naver.js +79 -0
  303. package/providers/netlify.d.ts +66 -0
  304. package/providers/netlify.d.ts.map +1 -0
  305. package/providers/netlify.js +85 -0
  306. package/providers/netsuite.d.ts +189 -0
  307. package/providers/netsuite.d.ts.map +1 -0
  308. package/providers/netsuite.js +170 -0
  309. package/providers/nextcloud.d.ts +150 -0
  310. package/providers/nextcloud.d.ts.map +1 -0
  311. package/providers/nextcloud.js +99 -0
  312. package/providers/nodemailer.d.ts +27 -0
  313. package/providers/nodemailer.d.ts.map +1 -0
  314. package/providers/nodemailer.js +34 -0
  315. package/providers/notion.d.ts +99 -0
  316. package/providers/notion.d.ts.map +1 -0
  317. package/providers/notion.js +110 -0
  318. package/providers/oauth.d.ts +188 -0
  319. package/providers/oauth.d.ts.map +1 -0
  320. package/providers/oauth.js +1 -0
  321. package/providers/okta.d.ts +99 -0
  322. package/providers/okta.d.ts.map +1 -0
  323. package/providers/okta.js +63 -0
  324. package/providers/onelogin.d.ts +65 -0
  325. package/providers/onelogin.d.ts.map +1 -0
  326. package/providers/onelogin.js +61 -0
  327. package/providers/ory-hydra.d.ts +79 -0
  328. package/providers/ory-hydra.d.ts.map +1 -0
  329. package/providers/ory-hydra.js +67 -0
  330. package/providers/osso.d.ts +79 -0
  331. package/providers/osso.d.ts.map +1 -0
  332. package/providers/osso.js +77 -0
  333. package/providers/osu.d.ts +116 -0
  334. package/providers/osu.d.ts.map +1 -0
  335. package/providers/osu.js +75 -0
  336. package/providers/passage.d.ts +88 -0
  337. package/providers/passage.d.ts.map +1 -0
  338. package/providers/passage.js +75 -0
  339. package/providers/passkey.d.ts +65 -0
  340. package/providers/passkey.d.ts.map +1 -0
  341. package/providers/passkey.js +87 -0
  342. package/providers/patreon.d.ts +73 -0
  343. package/providers/patreon.d.ts.map +1 -0
  344. package/providers/patreon.js +77 -0
  345. package/providers/ping-id.d.ts +57 -0
  346. package/providers/ping-id.d.ts.map +1 -0
  347. package/providers/ping-id.js +40 -0
  348. package/providers/pinterest.d.ts +79 -0
  349. package/providers/pinterest.d.ts.map +1 -0
  350. package/providers/pinterest.js +85 -0
  351. package/providers/pipedrive.d.ts +99 -0
  352. package/providers/pipedrive.d.ts.map +1 -0
  353. package/providers/pipedrive.js +71 -0
  354. package/providers/postmark.d.ts +4 -0
  355. package/providers/postmark.d.ts.map +1 -0
  356. package/providers/postmark.js +36 -0
  357. package/providers/provider-types.d.ts +3 -0
  358. package/providers/provider-types.d.ts.map +1 -0
  359. package/providers/provider-types.js +1 -0
  360. package/providers/reddit.d.ts +88 -0
  361. package/providers/reddit.d.ts.map +1 -0
  362. package/providers/reddit.js +90 -0
  363. package/providers/resend.d.ts +4 -0
  364. package/providers/resend.d.ts.map +1 -0
  365. package/providers/resend.js +32 -0
  366. package/providers/roblox.d.ts +67 -0
  367. package/providers/roblox.d.ts.map +1 -0
  368. package/providers/roblox.js +53 -0
  369. package/providers/salesforce.d.ts +59 -0
  370. package/providers/salesforce.d.ts.map +1 -0
  371. package/providers/salesforce.js +52 -0
  372. package/providers/sendgrid.d.ts +4 -0
  373. package/providers/sendgrid.d.ts.map +1 -0
  374. package/providers/sendgrid.js +35 -0
  375. package/providers/simplelogin.d.ts +87 -0
  376. package/providers/simplelogin.d.ts.map +1 -0
  377. package/providers/simplelogin.js +83 -0
  378. package/providers/slack.d.ts +102 -0
  379. package/providers/slack.d.ts.map +1 -0
  380. package/providers/slack.js +69 -0
  381. package/providers/spotify.d.ts +75 -0
  382. package/providers/spotify.d.ts.map +1 -0
  383. package/providers/spotify.js +73 -0
  384. package/providers/strava.d.ts +68 -0
  385. package/providers/strava.d.ts.map +1 -0
  386. package/providers/strava.js +80 -0
  387. package/providers/threads.d.ts +108 -0
  388. package/providers/threads.d.ts.map +1 -0
  389. package/providers/threads.js +89 -0
  390. package/providers/tiktok.d.ts +248 -0
  391. package/providers/tiktok.d.ts.map +1 -0
  392. package/providers/tiktok.js +195 -0
  393. package/providers/todoist.d.ts +76 -0
  394. package/providers/todoist.d.ts.map +1 -0
  395. package/providers/todoist.js +97 -0
  396. package/providers/trakt.d.ts +93 -0
  397. package/providers/trakt.d.ts.map +1 -0
  398. package/providers/trakt.js +91 -0
  399. package/providers/twitch.d.ts +71 -0
  400. package/providers/twitch.d.ts.map +1 -0
  401. package/providers/twitch.js +96 -0
  402. package/providers/twitter.d.ts +183 -0
  403. package/providers/twitter.d.ts.map +1 -0
  404. package/providers/twitter.js +100 -0
  405. package/providers/united-effects.d.ts +80 -0
  406. package/providers/united-effects.d.ts.map +1 -0
  407. package/providers/united-effects.js +72 -0
  408. package/providers/vipps.d.ts +71 -0
  409. package/providers/vipps.d.ts.map +1 -0
  410. package/providers/vipps.js +33 -0
  411. package/providers/vk.d.ts +334 -0
  412. package/providers/vk.d.ts.map +1 -0
  413. package/providers/vk.js +103 -0
  414. package/providers/webauthn.d.ts +148 -0
  415. package/providers/webauthn.d.ts.map +1 -0
  416. package/providers/webauthn.js +128 -0
  417. package/providers/webex.d.ts +78 -0
  418. package/providers/webex.d.ts.map +1 -0
  419. package/providers/webex.js +73 -0
  420. package/providers/wechat.d.ts +78 -0
  421. package/providers/wechat.d.ts.map +1 -0
  422. package/providers/wechat.js +105 -0
  423. package/providers/wikimedia.d.ts +99 -0
  424. package/providers/wikimedia.d.ts.map +1 -0
  425. package/providers/wikimedia.js +90 -0
  426. package/providers/wordpress.d.ts +65 -0
  427. package/providers/wordpress.d.ts.map +1 -0
  428. package/providers/wordpress.js +71 -0
  429. package/providers/workos.d.ts +154 -0
  430. package/providers/workos.d.ts.map +1 -0
  431. package/providers/workos.js +143 -0
  432. package/providers/yandex.d.ts +131 -0
  433. package/providers/yandex.d.ts.map +1 -0
  434. package/providers/yandex.js +80 -0
  435. package/providers/zitadel.d.ts +117 -0
  436. package/providers/zitadel.d.ts.map +1 -0
  437. package/providers/zitadel.js +95 -0
  438. package/providers/zoho.d.ts +63 -0
  439. package/providers/zoho.d.ts.map +1 -0
  440. package/providers/zoho.js +79 -0
  441. package/providers/zoom.d.ts +93 -0
  442. package/providers/zoom.d.ts.map +1 -0
  443. package/providers/zoom.js +82 -0
  444. package/src/adapters/server-actions-helpers.ts +126 -0
  445. package/src/adapters.ts +603 -0
  446. package/src/errors.ts +551 -0
  447. package/src/index.ts +689 -0
  448. package/src/jwt.ts +283 -0
  449. package/src/lib/actions/callback/handle-login.ts +334 -0
  450. package/src/lib/actions/callback/index.ts +554 -0
  451. package/src/lib/actions/callback/oauth/callback.ts +347 -0
  452. package/src/lib/actions/callback/oauth/checks.ts +258 -0
  453. package/src/lib/actions/callback/oauth/csrf-token.ts +60 -0
  454. package/src/lib/actions/index.ts +5 -0
  455. package/src/lib/actions/session.ts +167 -0
  456. package/src/lib/actions/signin/authorization-url.ts +123 -0
  457. package/src/lib/actions/signin/index.ts +37 -0
  458. package/src/lib/actions/signin/send-token.ts +124 -0
  459. package/src/lib/actions/signout.ts +38 -0
  460. package/src/lib/actions/webauthn-options.ts +100 -0
  461. package/src/lib/index.ts +97 -0
  462. package/src/lib/init.ts +236 -0
  463. package/src/lib/pages/error.tsx +106 -0
  464. package/src/lib/pages/index.ts +181 -0
  465. package/src/lib/pages/signin.tsx +255 -0
  466. package/src/lib/pages/signout.tsx +49 -0
  467. package/src/lib/pages/styles.css +377 -0
  468. package/src/lib/pages/styles.ts +381 -0
  469. package/src/lib/pages/verify-request.tsx +36 -0
  470. package/src/lib/symbols.ts +60 -0
  471. package/src/lib/utils/actions.ts +17 -0
  472. package/src/lib/utils/assert.ts +259 -0
  473. package/src/lib/utils/callback-url.ts +42 -0
  474. package/src/lib/utils/cookie.ts +248 -0
  475. package/src/lib/utils/date.ts +8 -0
  476. package/src/lib/utils/email.ts +65 -0
  477. package/src/lib/utils/env.ts +113 -0
  478. package/src/lib/utils/logger.ts +75 -0
  479. package/src/lib/utils/merge.ts +30 -0
  480. package/src/lib/utils/providers.ts +203 -0
  481. package/src/lib/utils/session.ts +41 -0
  482. package/src/lib/utils/web.ts +151 -0
  483. package/src/lib/utils/webauthn-client.js +229 -0
  484. package/src/lib/utils/webauthn-utils.ts +531 -0
  485. package/src/lib/vendored/cookie.ts +383 -0
  486. package/src/providers/42-school.ts +256 -0
  487. package/src/providers/apple.ts +206 -0
  488. package/src/providers/asgardeo.ts +118 -0
  489. package/src/providers/atlassian.ts +120 -0
  490. package/src/providers/auth0.ts +127 -0
  491. package/src/providers/authentik.ts +100 -0
  492. package/src/providers/azure-ad-b2c.ts +124 -0
  493. package/src/providers/azure-ad.ts +30 -0
  494. package/src/providers/azure-devops.ts +184 -0
  495. package/src/providers/bankid-no.ts +161 -0
  496. package/src/providers/battlenet.ts +107 -0
  497. package/src/providers/beyondidentity.ts +102 -0
  498. package/src/providers/bitbucket.ts +122 -0
  499. package/src/providers/box.ts +87 -0
  500. package/src/providers/boxyhq-saml.ts +148 -0
  501. package/src/providers/bungie.ts +192 -0
  502. package/src/providers/click-up.ts +104 -0
  503. package/src/providers/cognito.ts +94 -0
  504. package/src/providers/coinbase.ts +93 -0
  505. package/src/providers/concept2.ts +108 -0
  506. package/src/providers/credentials.ts +157 -0
  507. package/src/providers/descope.ts +105 -0
  508. package/src/providers/discord.ts +176 -0
  509. package/src/providers/dribbble.ts +122 -0
  510. package/src/providers/dropbox.ts +102 -0
  511. package/src/providers/duende-identity-server6.ts +101 -0
  512. package/src/providers/email.ts +60 -0
  513. package/src/providers/eventbrite.ts +105 -0
  514. package/src/providers/eveonline.ts +117 -0
  515. package/src/providers/facebook.ts +119 -0
  516. package/src/providers/faceit.ts +90 -0
  517. package/src/providers/figma.ts +105 -0
  518. package/src/providers/forwardemail.ts +37 -0
  519. package/src/providers/foursquare.ts +105 -0
  520. package/src/providers/freshbooks.ts +90 -0
  521. package/src/providers/frontegg.ts +111 -0
  522. package/src/providers/fusionauth.ts +336 -0
  523. package/src/providers/github.ts +187 -0
  524. package/src/providers/gitlab.ts +140 -0
  525. package/src/providers/google.ts +152 -0
  526. package/src/providers/hubspot.ts +117 -0
  527. package/src/providers/huggingface.ts +234 -0
  528. package/src/providers/identity-server4.ts +78 -0
  529. package/src/providers/index.ts +115 -0
  530. package/src/providers/instagram.ts +103 -0
  531. package/src/providers/kakao.ts +184 -0
  532. package/src/providers/keycloak.ts +111 -0
  533. package/src/providers/kinde.ts +85 -0
  534. package/src/providers/line.ts +99 -0
  535. package/src/providers/linkedin.ts +91 -0
  536. package/src/providers/logto.ts +122 -0
  537. package/src/providers/loops.ts +79 -0
  538. package/src/providers/mailchimp.ts +90 -0
  539. package/src/providers/mailgun.ts +98 -0
  540. package/src/providers/mailru.ts +75 -0
  541. package/src/providers/mastodon.ts +112 -0
  542. package/src/providers/mattermost.ts +154 -0
  543. package/src/providers/medium.ts +89 -0
  544. package/src/providers/microsoft-entra-id.ts +497 -0
  545. package/src/providers/naver.ts +102 -0
  546. package/src/providers/netlify.ts +90 -0
  547. package/src/providers/netsuite.ts +225 -0
  548. package/src/providers/nextcloud.ts +207 -0
  549. package/src/providers/nodemailer.ts +84 -0
  550. package/src/providers/notion.ts +166 -0
  551. package/src/providers/oauth.ts +310 -0
  552. package/src/providers/okta.ts +111 -0
  553. package/src/providers/onelogin.ts +75 -0
  554. package/src/providers/ory-hydra.ts +93 -0
  555. package/src/providers/osso.ts +91 -0
  556. package/src/providers/osu.ts +138 -0
  557. package/src/providers/passage.ts +103 -0
  558. package/src/providers/passkey.ts +94 -0
  559. package/src/providers/patreon.ts +98 -0
  560. package/src/providers/ping-id.ts +68 -0
  561. package/src/providers/pinterest.ts +106 -0
  562. package/src/providers/pipedrive.ts +120 -0
  563. package/src/providers/postmark.ts +38 -0
  564. package/src/providers/provider-types.ts +107 -0
  565. package/src/providers/reddit.ts +104 -0
  566. package/src/providers/resend.ts +35 -0
  567. package/src/providers/roblox.ts +94 -0
  568. package/src/providers/salesforce.ts +73 -0
  569. package/src/providers/sendgrid.ts +36 -0
  570. package/src/providers/simplelogin.ts +107 -0
  571. package/src/providers/slack.ts +115 -0
  572. package/src/providers/spotify.ts +99 -0
  573. package/src/providers/strava.ts +101 -0
  574. package/src/providers/threads.ts +135 -0
  575. package/src/providers/tiktok.ts +319 -0
  576. package/src/providers/todoist.ts +122 -0
  577. package/src/providers/trakt.ts +120 -0
  578. package/src/providers/twitch.ts +121 -0
  579. package/src/providers/twitter.ts +207 -0
  580. package/src/providers/united-effects.ts +89 -0
  581. package/src/providers/vipps.ts +86 -0
  582. package/src/providers/vk.ts +401 -0
  583. package/src/providers/webauthn.ts +296 -0
  584. package/src/providers/webex.ts +102 -0
  585. package/src/providers/wechat.ts +141 -0
  586. package/src/providers/wikimedia.ts +258 -0
  587. package/src/providers/wordpress.ts +86 -0
  588. package/src/providers/workos.ts +180 -0
  589. package/src/providers/yandex.ts +159 -0
  590. package/src/providers/zitadel.ts +128 -0
  591. package/src/providers/zoho.ts +84 -0
  592. package/src/providers/zoom.ts +119 -0
  593. package/src/types.ts +430 -0
  594. package/src/warnings.ts +21 -0
  595. package/types.d.ts +309 -0
  596. package/types.d.ts.map +1 -0
  597. package/types.js +53 -0
  598. package/warnings.d.ts +17 -0
  599. package/warnings.d.ts.map +1 -0
  600. package/warnings.js +1 -0
@@ -0,0 +1,225 @@
1
+ /**
2
+ * <div class="provider" style={{backgroundColor: "#24292f", display: "flex", justifyContent: "space-between", color: "#fff", padding: 16}}>
3
+ * <span>Built-in <b>NetSuite</b> integration.</span>
4
+ * <a href="https://system.netsuite.com">
5
+ * <img style={{display: "block"}} src="https://authjs.dev/img/providers/netsuite.svg" height="48" width="48"/>
6
+ * </a>
7
+ * </div>
8
+ *
9
+ * @module providers/netsuite
10
+ */
11
+
12
+ /*
13
+ * This NetSuite provider uses OAuth 2 Features. Ensure you have an integration record and access token set up in order to use this provider.
14
+ * Read more about OAuth 2 setup here: https://docs.oracle.com/en/cloud/saas/netsuite/ns-online-help/section_157771281570.html
15
+ */
16
+
17
+ import type { OAuthConfig, OAuthUserConfig } from "./index.js"
18
+
19
+ export interface OAuthNetSuiteOptions {
20
+ /**
21
+ * The prompt options - also viewable below
22
+ *
23
+ * @link https://docs.oracle.com/en/cloud/saas/netsuite/ns-online-help/section_160855585734.html
24
+ *
25
+ * authorization.params.prompt
26
+ *
27
+ * The optional prompt parameter provides additional control of when the login/consent screen appears. Following are the values you can use with the prompt parameter:
28
+ * "none" - the consent screen does not appear. If there is no active session, the application returns an error.
29
+ * "login" - the user must authenticate even if there is an active session.
30
+ * This option only works if the application sends the request to the account-specific domain.
31
+ * "consent" - the consent screen appears every time. The user must authenticate if there is no active session.
32
+ * login consent or consent login - the consent screen appears every time, and the user must authenticate even if there is an active session and allow the connection to the NetSuite. Similar to GitHub, Google, and Facebook data consent screens.
33
+ */
34
+ prompt: string | "none" | "login" | "consent"
35
+ /**
36
+ * EX: TSTDRV1234567 or 81555 for prod
37
+ */
38
+ accountID: string
39
+ /**
40
+ * restlets rest_webservices or restlets or rest_webservices suiteanalytics_connect restlets
41
+ */
42
+ scope: string
43
+ /**
44
+ * Either a restlet or suitelet returning runtime info or record info -> RESTlet recommended
45
+ */
46
+ userinfo: string
47
+ }
48
+
49
+ export interface NetSuiteProfile {
50
+ // Main N/runtime.getCurrentUser() object return
51
+ id: number
52
+ name: string
53
+ email: string
54
+ location: number
55
+ role: number
56
+ roleId?: string
57
+ roleCenter?: string
58
+ contact?: number
59
+ subsidiary?: number
60
+ department?: number
61
+ }
62
+
63
+ /**
64
+ * Add Netsuite login to your page and make requests to:
65
+ * - [NetSuite RESTLets](https://docs.oracle.com/en/cloud/saas/netsuite/ns-online-help/section_4567507062.html#Tracking-RESTlet-Calls-Made-with-TBA-and-OAuth-2.0).
66
+ * - [NetSuite REST Web Services](https://docs.oracle.com/en/cloud/saas/netsuite/ns-online-help/book_1559132836.html#SuiteTalk-REST-Web-Services-API-Guide).
67
+ *
68
+ * ### Setup
69
+ *
70
+ * #### Disclaimer
71
+ * By using this provider, you consent to sharing your data with NetSuite.
72
+ * By using this provider we assume you comply with NetSuite's [Terms of Service](https://www.netsuite.com/portal/assets/pdf/terms_of_service.pdf) and [Privacy Policy](https://www.oracle.com/legal/privacy).
73
+ * The author of this provider is not affiliated with NetSuite. Proceeding with this provider you must be a NetSuite customer and have a NetSuite account (Full access user).
74
+ * **Ensure the OAuth 2.0 Feature is enabled in your NetSuite account with the proper permissions set up on the current role/user**
75
+ *
76
+ * Before setting up the provider, you will need to:
77
+ * - [Create an Integration Record](https://docs.oracle.com/en/cloud/saas/netsuite/ns-online-help/section_157771733782.html#procedure_157838925981)
78
+ * - Uncheck the TBA Auth Flow checkbox.
79
+ * - Check OAuth 2.0 Auth Flow checkbox.
80
+ * - Copy and paste the `Callback URL` below into the `Redirect URI` field.
81
+ * - Then select the scope(s) you want to use.
82
+ * - **REST Web Services** (`rest_webservices`) - Access to REST Web Services.
83
+ * - **RESTlets**(`restlets`) - Access to RESTLets.
84
+ * - **SuiteAnalytics Connect** (`suiteanalytics_connect`) - Access to SuiteAnalytics Connect.
85
+ * - Add any policies you want to use.
86
+ * - Application Logo (_Optional_) (Shown to users when they are asked to grant access to your application). - Consent Screen
87
+ * - Application Terms of Use (_Optional_) - A PDF file that contains the terms of use for your application. - Consent Screen
88
+ * - Application Privacy Policy (_Optional_) - A PDF file that contains the privacy policy for your application. - Consent Screen
89
+ * - OAuth 2.0 Consent Policy Preference - This setting determines whether the user is asked to grant access to your application **every time** they sign in or only the **first time** they sign in or **never**.
90
+ * - **Save** the Integration record.
91
+ * - The Integration record will be used to generate the `clientId` and `clientSecret` for the provider. **Save the generated values for later**
92
+ *
93
+ * #### Callback URL
94
+ *
95
+ * :::tip
96
+ * When setting the Redirect URI in the Integration record, you must use the `https` protocol.
97
+ * Otherwise, you will get an error when trying to sign in. (_INVALID_LOGIN_ATTEMPT_).
98
+ * If you are testing locally, you can use a service like [ngrok](https://ngrok.com/) to create a secure tunnel to your localhost.
99
+ * :::
100
+ *
101
+ * ```
102
+ * https://example.com/api/auth/callback/netsuite
103
+ * ```
104
+ *
105
+ * :::tip
106
+ * Our `userinfo` needs to compose of a suitelet or RESTLet url that gives us the information about the user. This has to be very fast in which the handshake profile gather execution can't take long.
107
+ * The best bet is to use the `N/runtime` module to get the basics first. - Here is an example of a RESTlet below. Be sure to deploy and enable access to "All Roles".
108
+ * :::
109
+ *
110
+ * #### Example RESTLet Callback Handler
111
+ * Be sure to deploy and use the **external** RESTLet url of any usage of the URIs.
112
+ *
113
+ * ```js
114
+ * * /**
115
+ * * @NApiVersion 2.1
116
+ * * @NScriptType Restlet
117
+ * *\/
118
+ * define(["N/runtime"], /**
119
+ * @param{runtime} runtimee
120
+ * \/ (runtime) => {
121
+ * /**
122
+ * * Defines the function that is executed when a GET request is sent to a RESTlet.
123
+ * * @param {Object} requestParams - Parameters from HTTP request URL; parameters passed as an Object (for all supported
124
+ * * content types)
125
+ * * @returns {string | Object} HTTP response body; returns a string when request Content-Type is 'text/plain'; returns an
126
+ * * Object when request Content-Type is 'application/json' or 'application/xml'
127
+ * * @since 2015.2
128
+ * *\/
129
+ * const get = (requestParams) => {
130
+ * let userObject = runtime.getCurrentUser();
131
+ *
132
+ * try {
133
+ * log.debug({ title: "Payload received:", details: requestParams });
134
+ *
135
+ * const { id, name, role, location, email, contact } = userObject;
136
+ *
137
+ * log.audit({ title: "Current User Ran", details: name });
138
+ *
139
+ * let user = {
140
+ * id,
141
+ * name,
142
+ * role,
143
+ * location,
144
+ * email,
145
+ * contact,
146
+ * };
147
+ *
148
+ * log.debug({ title: "Returning user", details: user });
149
+ *
150
+ * return JSON.stringify(user);
151
+ * } catch (e) {
152
+ * log.error({ title: "Error grabbing current user:", details: e });
153
+ * }
154
+ * };
155
+ *
156
+ * return {
157
+ * get,
158
+ * };
159
+ * );
160
+ * ```
161
+ *
162
+ * > **Note**: Above is an example of returning the basic runtime information. Be sure to create a new script record and deployment record. Upon saving the deployment record. We will get our URLs for our RESTlet.
163
+ *
164
+ * ### Configuration
165
+ *
166
+ * ```ts
167
+ * import { Auth } from "@auth/core"
168
+ * import Netsuite from "@auth/core/providers/netsuite"
169
+ *
170
+ * const request = new Request(origin)
171
+ * const response = await Auth(request, {
172
+ * providers: [
173
+ * NetSuite({
174
+ * accountID: NETSUITE_ACCOUNT_ID, // EX: TSTDRV1234567 or 81555 for prod, and 1234567-SB1 for Sandbox accounts not "_" use "-".
175
+ * // Returns the current user using the N/runtime module. This url can be a suitelet or RESTlet (Recommended)
176
+ * // Using getCurrentUser(); So we match this schema returned from this RESTlet in the profile callback. (Required)
177
+ * userinfo: "https://1234567.restlets.api.netsuite.com/app/site/hosting/restlet.nl?script=123&deploy=1",
178
+ * })
179
+ * ],
180
+ * })
181
+ * ```
182
+ *
183
+ * ### Resources
184
+ *
185
+ * - [NetSuite - Creating an Integration Record (OAuth 2.0)](https://docs.oracle.com/en/cloud/saas/netsuite/ns-online-help/section_157771733782.html#Related-Topics)
186
+ * - [NetSuite - Authorizing OAuth Requests](https://docs.github.com/en/developers/apps/building-oauth-apps/authorizing-oauth-apps)
187
+ * - [NetSuite - Configure OAuth Roles](https://docs.oracle.com/en/cloud/saas/netsuite/ns-online-help/section_157771510070.html#Set-Up-OAuth-2.0-Roles)
188
+ * - [Learn more about NetSuite OAuth 2.0](https://docs.oracle.com/en/cloud/saas/netsuite/ns-online-help/chapter_157769826287.html#OAuth-2.0)
189
+ *
190
+ * ### Notes
191
+ *
192
+ * :::tip
193
+ * Make sure the `userinfo` matches the return type of the profile callback to ensure the user session gets read correctly.
194
+ * To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/providers/custom-provider#override-default-options).
195
+ * :::
196
+ *
197
+ */
198
+ export default function NetSuite<P extends NetSuiteProfile>(
199
+ config: OAuthUserConfig<P> & OAuthNetSuiteOptions
200
+ ): OAuthConfig<P> {
201
+ const { accountID } = config
202
+
203
+ return {
204
+ id: "netsuite",
205
+ name: "NetSuite",
206
+ type: "oauth",
207
+ checks: ["state"],
208
+ authorization: {
209
+ url: `https://${accountID}.app.netsuite.com/app/login/oauth2/authorize.nl`,
210
+ params: { scope: "restlets rest_webservices" },
211
+ },
212
+ token: `https://${accountID}.suitetalk.api.netsuite.com/services/rest/auth/oauth2/v1/token`,
213
+ profile(profile) {
214
+ // This is the default runtime.getCurrentUser() object returned from the RESTlet or SUITELet
215
+ return {
216
+ id: profile.id.toString(),
217
+ name: profile.name,
218
+ email: profile.email,
219
+ image: null,
220
+ }
221
+ },
222
+ style: { logo: "/netsuite.svg", bg: "#181a1b", text: "#fbfbfb" },
223
+ options: config,
224
+ }
225
+ }
@@ -0,0 +1,207 @@
1
+ /**
2
+ * <div class="provider" style={{backgroundColor: "#0082C9", display: "flex", justifyContent: "space-between", color: "#fff", padding: 16}}>
3
+ * <span>Built-in <b>Nextcloud</b> integration.</span>
4
+ * <a href="https://nextcloud.com">
5
+ * <img style={{display: "block"}} src="https://authjs.dev/img/providers/nextcloud.svg" height="48" width="48"/>
6
+ * </a>
7
+ * </div>
8
+ *
9
+ * @module providers/nextcloud
10
+ */
11
+
12
+ import type { OAuthConfig, OAuthUserConfig } from "./index.js"
13
+
14
+ /**
15
+ * Represents the Nextcloud user profile data returned from the `/ocs/v1.php/cloud/users/`.
16
+ * @see [Check out the documentation for more details](https://docs.nextcloud.com/server/latest/admin_manual/configuration_user/instruction_set_for_users.html#get-data-of-a-single-user)
17
+ */
18
+ export interface NextcloudProfile extends Record<string, any> {
19
+ /**
20
+ * The user's username.
21
+ * @example "frank"
22
+ */
23
+ id: string
24
+
25
+ /**
26
+ * The email address associated with the user.
27
+ * @example "frank@domain.tld"
28
+ */
29
+ email: string | null
30
+
31
+ /**
32
+ * The display name of the user.
33
+ * @example "Frank K."
34
+ */
35
+ displayname: string
36
+
37
+ /**
38
+ * The phone number of the user.
39
+ */
40
+ phone: string
41
+
42
+ /**
43
+ * The address of the user.
44
+ * @example "Foobar 12, 12345 Town"
45
+ */
46
+ address: string
47
+
48
+ /**
49
+ * The website URL of the user.
50
+ * @example "https://nextcloud.com"
51
+ */
52
+ website: string
53
+
54
+ /**
55
+ * The user's Twitter handle.
56
+ * @example "Nextcloud"
57
+ */
58
+ twitter: string
59
+
60
+ /**
61
+ * The user's Fediverse handle.
62
+ */
63
+ fediverse: string
64
+
65
+ /**
66
+ * The organization associated with the user.
67
+ */
68
+ organisation: string
69
+
70
+ /**
71
+ * The role or position of the user.
72
+ */
73
+ role: string
74
+
75
+ /**
76
+ * The headline or brief description of the user.
77
+ */
78
+ headline: string
79
+
80
+ /**
81
+ * The biography or detailed description of the user.
82
+ */
83
+ biography: string
84
+
85
+ /**
86
+ * An array of group names that the user belongs to.
87
+ * @example ["admin", "group1", "group2"]
88
+ */
89
+ groups: string[]
90
+
91
+ /**
92
+ * The language preference of the user.
93
+ * @example "en"
94
+ */
95
+ language: string
96
+
97
+ /**
98
+ * The locale or language locale of the user.
99
+ * @example "en_US"
100
+ */
101
+ locale: string
102
+
103
+ /**
104
+ * Indicates whether the user account is enabled or disabled.
105
+ * @example true
106
+ */
107
+ enabled: boolean
108
+
109
+ /**
110
+ * The storage location of the user's files.
111
+ * @example "/path/to/nextcloud/data/frank"
112
+ */
113
+ storageLocation: string
114
+ }
115
+
116
+ /**
117
+ * Add Nextcloud login to your page.
118
+ *
119
+ * ### Setup
120
+ *
121
+ * #### Callback URL
122
+ * ```
123
+ * https://example.com/auth/callback/nextcloud
124
+ * ```
125
+ *
126
+ * #### Configuration
127
+ * ```ts
128
+ * import { Auth } from "@auth/core"
129
+ * import Nextcloud from "@auth/core/providers/nextcloud"
130
+ *
131
+ * const request = new Request(origin)
132
+ * const response = await Auth(request, {
133
+ * providers: [
134
+ * Nextcloud({ clientId: AUTH_NEXTCLOUD_ID, clientSecret: AUTH_NEXTCLOUD_SECRET, issuer: AUTH_NEXTCLOUD_ISSUER }),
135
+ * ],
136
+ * })
137
+ * ```
138
+ *
139
+ * ### Resources
140
+ *
141
+ * - [Nextcloud Documentation](https://docs.nextcloud.com/)
142
+ * - [Nextcloud OAuth 2](https://docs.nextcloud.com/server/latest/admin_manual/configuration_server/oauth2.html)
143
+ * - [Nextcloud Clients and Client APIs](https://docs.nextcloud.com/server/latest/developer_manual/client_apis/index.html)
144
+ * - [Nextcloud User provisioning API](https://docs.nextcloud.com/server/latest/admin_manual/configuration_user/user_provisioning_api.html)
145
+ *
146
+ * ### Notes
147
+ *
148
+ * By default, Auth.js assumes that the Nextcloud provider is
149
+ * based on the [OAuth 2](https://www.rfc-editor.org/rfc/rfc6749.html) specification.
150
+ *
151
+ * :::tip
152
+ *
153
+ * The Nextcloud provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/nextcloud.ts).
154
+ * To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
155
+ *
156
+ * :::
157
+ *
158
+ * :::info **Disclaimer**
159
+ *
160
+ * If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
161
+ *
162
+ * Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
163
+ * the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
164
+ * we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
165
+ *
166
+ * :::
167
+ */
168
+ export default function Nextcloud(
169
+ options: OAuthUserConfig<NextcloudProfile>
170
+ ): OAuthConfig<NextcloudProfile> {
171
+ return {
172
+ id: "nextcloud",
173
+ name: "Nextcloud",
174
+ type: "oauth",
175
+ authorization: `${options.issuer}/apps/oauth2/authorize`,
176
+ token: `${options.issuer}/apps/oauth2/api/v1/token`,
177
+ userinfo: {
178
+ url: `${options.issuer}/ocs/v1.php/cloud/users`,
179
+ async request({ tokens, provider }) {
180
+ const url = `${provider.userinfo?.url}/${tokens.user_id}`
181
+
182
+ const res = await fetch(url, {
183
+ headers: {
184
+ "OCS-APIRequest": "true",
185
+ Authorization: `Bearer ${tokens.access_token}`,
186
+ Accept: "application/json",
187
+ },
188
+ }).then((res) => res.json())
189
+ return res.ocs.data
190
+ },
191
+ },
192
+ profile(profile) {
193
+ return {
194
+ id: profile.id,
195
+ name: profile.displayname,
196
+ email: profile.email,
197
+ image: `${options.issuer}/avatar/${profile.id}/512`,
198
+ }
199
+ },
200
+ style: {
201
+ logo: "/nextcloud.svg",
202
+ bg: "#fff",
203
+ text: "#0082C9",
204
+ },
205
+ options,
206
+ }
207
+ }
@@ -0,0 +1,84 @@
1
+ import { createTransport } from "nodemailer"
2
+ import { AuthError } from "../errors.js"
3
+ import { html, text } from "../lib/utils/email.js"
4
+
5
+ import type { Transport, TransportOptions } from "nodemailer"
6
+ import * as JSONTransport from "nodemailer/lib/json-transport/index.js"
7
+ import * as SendmailTransport from "nodemailer/lib/sendmail-transport/index.js"
8
+ import * as SESTransport from "nodemailer/lib/ses-transport/index.js"
9
+ import * as SMTPPool from "nodemailer/lib/smtp-pool/index.js"
10
+ import * as SMTPTransport from "nodemailer/lib/smtp-transport/index.js"
11
+ import * as StreamTransport from "nodemailer/lib/stream-transport/index.js"
12
+ import type { Awaitable, Theme } from "../types.js"
13
+ import type { EmailConfig } from "./email.js"
14
+
15
+ type AllTransportOptions =
16
+ | string
17
+ | SMTPTransport
18
+ | SMTPTransport.Options
19
+ | SMTPPool
20
+ | SMTPPool.Options
21
+ | SendmailTransport
22
+ | SendmailTransport.Options
23
+ | StreamTransport
24
+ | StreamTransport.Options
25
+ | JSONTransport
26
+ | JSONTransport.Options
27
+ | SESTransport
28
+ | SESTransport.Options
29
+ | Transport<any>
30
+ | TransportOptions
31
+
32
+ export interface NodemailerConfig extends EmailConfig {
33
+ server?: AllTransportOptions
34
+ sendVerificationRequest: (params: {
35
+ identifier: string
36
+ url: string
37
+ expires: Date
38
+ provider: NodemailerConfig
39
+ token: string
40
+ theme: Theme
41
+ request: Request
42
+ }) => Awaitable<void>
43
+ options?: NodemailerUserConfig
44
+ }
45
+
46
+ export type NodemailerUserConfig = Omit<
47
+ Partial<NodemailerConfig>,
48
+ "options" | "type"
49
+ >
50
+
51
+ export default function Nodemailer(
52
+ config: NodemailerUserConfig
53
+ ): NodemailerConfig {
54
+ if (!config.server)
55
+ throw new AuthError("Nodemailer requires a `server` configuration")
56
+
57
+ return {
58
+ id: "nodemailer",
59
+ type: "email",
60
+ name: "Nodemailer",
61
+ server: { host: "localhost", port: 25, auth: { user: "", pass: "" } },
62
+ from: "Auth.js <no-reply@authjs.dev>",
63
+ maxAge: 24 * 60 * 60,
64
+ async sendVerificationRequest(params) {
65
+ const { identifier, url, provider, theme } = params
66
+ const { host } = new URL(url)
67
+ const transport = createTransport(provider.server)
68
+ const result = await transport.sendMail({
69
+ to: identifier,
70
+ from: provider.from,
71
+ subject: `Sign in to ${host}`,
72
+ text: text({ url, host }),
73
+ html: html({ url, host, theme }),
74
+ })
75
+ const rejected = result.rejected || []
76
+ const pending = result.pending || []
77
+ const failed = rejected.concat(pending).filter(Boolean)
78
+ if (failed.length) {
79
+ throw new Error(`Email (${failed.join(", ")}) could not be sent`)
80
+ }
81
+ },
82
+ options: config,
83
+ }
84
+ }
@@ -0,0 +1,166 @@
1
+ /**
2
+ * <div class="provider" style={{backgroundColor: "#000", display: "flex", justifyContent: "space-between", color: "#fff", padding: 16}}>
3
+ * <span>Built-in <b>Notion</b> integration.</span>
4
+ * <a href="https://notion.so">
5
+ * <img style={{display: "block"}} src="https://authjs.dev/img/providers/notion.svg" height="48" width="48"/>
6
+ * </a>
7
+ * </div>
8
+ *
9
+ * @module providers/notion
10
+ */
11
+
12
+ import type { OAuthConfig, OAuthUserConfig } from "./oauth.js"
13
+
14
+ export interface Person extends Record<string, any> {
15
+ email: string
16
+ }
17
+
18
+ // https://developers.notion.com/reference/user
19
+ export interface User extends Record<string, any> {
20
+ object: "user" | "bot"
21
+ id: string
22
+ type: string
23
+ name: string
24
+ avatar_url: null | string
25
+ person: Person
26
+ owner?: {
27
+ type: "workspace" | "user"
28
+ workspace: string
29
+ }
30
+ workspace_name?: string | null
31
+ }
32
+
33
+ export interface Owner {
34
+ type: string
35
+ user: User
36
+ }
37
+
38
+ // Notion responds with an access_token + some additional information, which we define here
39
+ // More info - https://developers.notion.com/docs/authorization#step-4-notion-responds-with-an-access_token-and-some-additional-information
40
+ export interface NotionProfile extends Record<string, any> {
41
+ access_token: string
42
+ bot_id: string
43
+ duplicated_template_id: string
44
+ owner?: Owner
45
+ workspace_icon: string
46
+ workspace_id: number
47
+ workspace_name: string
48
+ }
49
+
50
+ // Any config required that isn't part of the `OAuthUserConfig` spec should belong here
51
+ // For example, we must pass a `redirectUri` to the Notion API when requesting tokens, therefore we add it here
52
+ interface AdditionalConfig {
53
+ redirectUri: string
54
+ }
55
+
56
+ const NOTION_HOST = "https://api.notion.com"
57
+ const NOTION_API_VERSION = "2022-06-28"
58
+
59
+ /**
60
+ * Add Notion login to your page.
61
+ *
62
+ * ### Setup
63
+ *
64
+ * #### Callback URL
65
+ * ```
66
+ * https://example.com/api/auth/callback/notion
67
+ * ```
68
+ *
69
+ * #### Configuration
70
+ *```ts
71
+ * import { Auth } from "@auth/core"
72
+ * import Notion from "@auth/core/providers/notion"
73
+ *
74
+ * const request = new Request(origin)
75
+ * const response = await Auth(request, {
76
+ * providers: [
77
+ * Notion({
78
+ * clientId: NOTION_CLIENT_ID,
79
+ * clientSecret: NOTION_CLIENT_SECRET,
80
+ * redirectUri: NOTION_CLIENT_REDIRECT_URI,
81
+ * }),
82
+ * ],
83
+ * })
84
+ * ```
85
+ *
86
+ * ### Resources
87
+ * - [Notion Docs](https://developers.notion.com/docs)
88
+ * - [Notion Authorization Docs](https://developers.notion.com/docs/authorization)
89
+ * - [Notion Integrations](https://www.notion.so/my-integrations)
90
+ *
91
+ * ### Notes
92
+ * You need to select "Public Integration" on the configuration page to get an `oauth_id` and `oauth_secret`. Private integrations do not provide these details.
93
+ * You must provide a `clientId` and `clientSecret` to use this provider, as-well as a redirect URI (due to this being required by Notion endpoint to fetch tokens).
94
+ *
95
+ * :::tip
96
+ *
97
+ * The Notion provider comes with a [default configuration](https://github.com/nextauthjs/next-auth/blob/main/packages/core/src/providers/notion.ts).
98
+ * To override the defaults for your use case, check out [customizing a built-in OAuth provider](https://authjs.dev/guides/configuring-oauth-providers).
99
+ *
100
+ * :::
101
+ *
102
+ * :::info **Disclaimer**
103
+ *
104
+ * If you think you found a bug in the default configuration, you can [open an issue](https://authjs.dev/new/provider-issue).
105
+ *
106
+ * Auth.js strictly adheres to the specification and it cannot take responsibility for any deviation from
107
+ * the spec by the provider. You can open an issue, but if the problem is non-compliance with the spec,
108
+ * we might not pursue a resolution. You can ask for more help in [Discussions](https://authjs.dev/new/github-discussions).
109
+ *
110
+ * :::
111
+ */
112
+ export default function NotionProvider<P extends NotionProfile>(
113
+ options: OAuthUserConfig<P> & AdditionalConfig
114
+ ): OAuthConfig<P> {
115
+ return {
116
+ id: "notion",
117
+ name: "Notion",
118
+ type: "oauth",
119
+ token: {
120
+ url: `${NOTION_HOST}/v1/oauth/token`,
121
+ },
122
+ userinfo: {
123
+ url: `${NOTION_HOST}/v1/users`,
124
+
125
+ // The result of this method will be the input to the `profile` callback.
126
+ // We use a custom request handler, since we need to do things such as pass the "Notion-Version" header
127
+ // More info: https://authjs.dev/getting-started/providers/notion
128
+ async request(context) {
129
+ const profile = await fetch(`${NOTION_HOST}/v1/users/me`, {
130
+ headers: {
131
+ Authorization: `Bearer ${context.tokens.access_token}`,
132
+ "Notion-Version": NOTION_API_VERSION,
133
+ },
134
+ })
135
+
136
+ const {
137
+ bot: {
138
+ owner: { user },
139
+ },
140
+ } = await profile.json()
141
+
142
+ return user
143
+ },
144
+ },
145
+ authorization: {
146
+ params: {
147
+ client_id: options.clientId,
148
+ response_type: "code",
149
+ owner: "user",
150
+ redirect_uri: options.redirectUri,
151
+ },
152
+ url: `${NOTION_HOST}/v1/oauth/authorize`,
153
+ },
154
+
155
+ async profile(profile) {
156
+ return {
157
+ id: profile.id,
158
+ name: profile.name,
159
+ email: profile.person.email,
160
+ image: profile.avatar_url,
161
+ }
162
+ },
163
+ style: { bg: "#fff", text: "#000" },
164
+ options,
165
+ }
166
+ }