UNPKG

@auth/core

Version:

Authentication for the Web.

75 lines (74 loc) 2.8 kB
import { renderToString } from "preact-render-to-string"; import ErrorPage from "./error.js"; import SigninPage from "./signin.js"; import SignoutPage from "./signout.js"; import css from "./styles.js"; import VerifyRequestPage from "./verify-request.js"; function send({ html, title, status, cookies, theme }) { return { cookies, status, headers: { "Content-Type": "text/html" }, body: `<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><style>${css}</style><title>${title}</title></head><body class="__next-auth-theme-${theme?.colorScheme ?? "auto"}"><div class="page">${renderToString(html)}</div></body></html>`, }; } /** * Unless the user defines their [own pages](https://authjs.dev/guides/basics/pages), * we render a set of default ones, using Preact SSR. */ export default function renderPage(params) { const { url, theme, query, cookies } = params; return { signin(props) { return send({ cookies, theme, html: SigninPage({ csrfToken: params.csrfToken, // We only want to render providers providers: params.providers?.filter((provider) => // Always render oauth and email type providers ["email", "oauth", "oidc"].includes(provider.type) || // Only render credentials type provider if credentials are defined (provider.type === "credentials" && provider.credentials) || // Don't render other provider types false), callbackUrl: params.callbackUrl, theme, ...query, ...props, }), title: "Sign In", }); }, signout(props) { return send({ cookies, theme, html: SignoutPage({ csrfToken: params.csrfToken, url, theme, ...props, }), title: "Sign Out", }); }, verifyRequest(props) { return send({ cookies, theme, html: VerifyRequestPage({ url, theme, ...props }), title: "Verify Request", }); }, error(props) { return send({ cookies, theme, ...ErrorPage({ url, theme, ...props }), title: "Error", }); }, }; }