next-auth-pubkey
Version:
A light-weight Lightning and Nostr auth provider for your Next.js app that's entirely self-hosted and plugs seamlessly into the next-auth framework.
80 lines (79 loc) • 6.76 kB
JavaScript
import { formatConfig } from "./config/index.js";
import getHandler, { appHandler, pagesHandler } from "./utils/handlers.js";
const lightningLogo = "";
const nostrLogo = "";
/**
* Generate a provider and handler to setup Lightning auth.
*
* @param {Object} userConfig - config options, see the package README for details
*
* @returns {Object}
* @returns {String} provider - a provider that can be added to the `next-auth` config's providerArray
* @returns {String} handler - an API handler to be exported in the pages/api/pubkey/[...pubkey] folder
*/
export default function NextAuthPubkey(userConfig) {
const config = formatConfig(userConfig);
const lightningProvider = {
id: "lightning",
name: "Lightning",
type: "oauth",
version: "2.0",
checks: ["state"],
issuer: config.baseUrl,
token: config.baseUrl + config.apis.token,
authorization: config.baseUrl + config.pages.lightningSignIn,
profile(profile) {
return {
id: profile.id,
name: profile.name || profile.id,
image: profile.image,
};
},
idToken: true,
client: {
id_token_signed_response_alg: "HS256",
},
clientId: config.baseUrl,
clientSecret: config.secret,
style: {
logo: lightningLogo,
bg: config.theme.signInButtonBackground,
text: config.theme.signInButtonText,
},
};
const nostrProvider = {
id: "nostr",
name: "Nostr",
type: "oauth",
version: "2.0",
checks: ["state"],
issuer: config.baseUrl,
token: config.baseUrl + config.apis.token,
authorization: config.baseUrl + config.pages.nostrSignIn,
profile(profile) {
return {
id: profile.id,
name: profile.name || profile.id,
image: profile.image,
};
},
idToken: true,
client: {
id_token_signed_response_alg: "HS256",
},
clientId: config.baseUrl,
clientSecret: config.secret,
style: {
logo: nostrLogo,
bg: config.theme.signInButtonBackground,
text: config.theme.signInButtonText,
},
};
return {
lightningProvider,
nostrProvider,
handler: async (req, res) => pagesHandler(req, res, config, getHandler({ req, res, config })),
GET: async (req) => appHandler(req, config, getHandler({ req, config })),
POST: async (req) => appHandler(req, config, getHandler({ req, config })),
};
}