JSPM

@svelte-dev/auth-sso

1.0.1
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 60
  • Score
    100M100P100Q34895F
  • License Apache-2.0

SSO for Svelte Auth

Package Exports

  • @svelte-dev/auth-sso

Readme

Logo

@svelte-dev/auth-sso strategy

The SSO strategy is used to authenticate users against a SSO account. It extends the OAuth2Strategy.

For more details: https://github.com/willin/svelte-turbo

Supported runtimes

Runtime Has Support
Node.js
Cloudflare
Vercel

Usage

Create an OAuth application

Follow the steps on the SSO documentation to create a new application and get a client ID and secret.

Create the strategy instance

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);

Setup your routes

export default function Login() {
  return (
    <form action="/auth/sso" method="get">
      <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'
  });
};

赞助 Sponsor

维护者 Owner: Willin Wang

如果您对本项目感兴趣,可以通过以下方式支持我:

Donation ways:

许可证 License

Apache-2.0