The SSO strategy is used to authenticate users against a SSO account. It extends the OAuth2Strategy.
Runtime | Has Support |
---|---|
Node.js | ✅ |
Cloudflare | ✅ |
Vercel | ✅ |
Follow the steps on the SSO documentation to create a new application and get a client ID and secret.
import { SSOStrategy } from '@svelte-dev/auth-sso';
let ssoStrategy = new SSOStrategy(
{
clientID: 'YOUR_CLIENT_ID',
clientSecret: 'YOUR_CLIENT_SECRET',
callbackURL: 'https://example.com/auth/sso/callback'
},
async ({ accessToken, extraParams, profile }) => {
// Get the user data from your DB or API using the tokens and profile
return profile;
}
);
authenticator.use(ssoStrategy);
export default function Login() {
return (
<form action='/auth/sso' method='post'>
<button>Login with SSO</button>
</form>
);
}
// routes/auth/sso/+server
import { authenticator } from '~/auth.server';
import type { RequestHandler } from './$types';
export const POST: RequestHandler = async (event) => {
return authenticator.authenticate('sso', event);
};
// routes/auth/sso/callback/+server
import { authenticator } from '~/auth.server';
import type { PageServerLoad } from './$types';
export const load: PageServerLoad = async ({ event }) => {
return authenticator.authenticate('sso', event, {
successRedirect: '/dashboard',
failureRedirect: '/login'
});
};
维护者 Owner: Willin Wang
如果您对本项目感兴趣,可以通过以下方式支持我:
Donation ways:
Apache-2.0