mirror of
https://github.com/Dan6erbond/sk-auth.git
synced 2024-11-20 19:07:20 +01:00
added twitch provider (#22)
This commit is contained in:
parent
ae203f06db
commit
615ff5fee3
2
app/src/global.d.ts
vendored
2
app/src/global.d.ts
vendored
@ -3,6 +3,8 @@
|
|||||||
interface ImportMetaEnv {
|
interface ImportMetaEnv {
|
||||||
VITE_GOOGLE_OAUTH_CLIENT_ID: string;
|
VITE_GOOGLE_OAUTH_CLIENT_ID: string;
|
||||||
VITE_GOOGLE_OAUTH_CLIENT_SECRET: string;
|
VITE_GOOGLE_OAUTH_CLIENT_SECRET: string;
|
||||||
|
VITE_TWITCH_OAUTH_CLIENT_ID: string;
|
||||||
|
VITE_TWITCH_OAUTH_CLIENT_SECRET: string;
|
||||||
VITE_FACEBOOK_OAUTH_CLIENT_ID: string;
|
VITE_FACEBOOK_OAUTH_CLIENT_ID: string;
|
||||||
VITE_FACEBOOK_OAUTH_CLIENT_SECRET: string;
|
VITE_FACEBOOK_OAUTH_CLIENT_SECRET: string;
|
||||||
VITE_TWITTER_API_KEY: string;
|
VITE_TWITTER_API_KEY: string;
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import { SvelteKitAuth } from "sk-auth";
|
import { SvelteKitAuth } from "sk-auth";
|
||||||
import {
|
import {
|
||||||
|
TwitchOAuth2Provider,
|
||||||
FacebookOAuth2Provider,
|
FacebookOAuth2Provider,
|
||||||
GoogleOAuth2Provider,
|
GoogleOAuth2Provider,
|
||||||
RedditOAuth2Provider,
|
RedditOAuth2Provider,
|
||||||
@ -15,6 +16,13 @@ export const appAuth = new SvelteKitAuth({
|
|||||||
return { ...profile, provider: "google" };
|
return { ...profile, provider: "google" };
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
new TwitchOAuth2Provider({
|
||||||
|
clientId: import.meta.env.VITE_TWITCH_OAUTH_CLIENT_ID,
|
||||||
|
clientSecret: import.meta.env.VITE_TWITCH_OAUTH_CLIENT_SECRET,
|
||||||
|
profile(profile) {
|
||||||
|
return { ...profile, provider: "twitch" };
|
||||||
|
},
|
||||||
|
}),
|
||||||
new FacebookOAuth2Provider({
|
new FacebookOAuth2Provider({
|
||||||
clientId: import.meta.env.VITE_FACEBOOK_OAUTH_CLIENT_ID,
|
clientId: import.meta.env.VITE_FACEBOOK_OAUTH_CLIENT_ID,
|
||||||
clientSecret: import.meta.env.VITE_FACEBOOK_OAUTH_CLIENT_SECRET,
|
clientSecret: import.meta.env.VITE_FACEBOOK_OAUTH_CLIENT_SECRET,
|
||||||
|
@ -36,6 +36,38 @@
|
|||||||
<br />
|
<br />
|
||||||
|
|
||||||
<div class={clsx("flex", "flex-col", "justify-items-stretch", "space-y-4")}>
|
<div class={clsx("flex", "flex-col", "justify-items-stretch", "space-y-4")}>
|
||||||
|
<a
|
||||||
|
href="/api/auth/signin/twitch"
|
||||||
|
class={clsx(
|
||||||
|
"text-sm",
|
||||||
|
"md:text-base",
|
||||||
|
"inline-flex",
|
||||||
|
"space-x-4",
|
||||||
|
"py-2",
|
||||||
|
"px-4",
|
||||||
|
"border-gray-400",
|
||||||
|
"rounded",
|
||||||
|
"hover:no-underline",
|
||||||
|
"border",
|
||||||
|
"hover:bg-gray-100",
|
||||||
|
"transition-colors",
|
||||||
|
"items-center",
|
||||||
|
)}
|
||||||
|
>
|
||||||
|
<svg viewBox="0 0 300 300" class={clsx("h-4", "w-4", "md:h-6", "md:w-6")}>
|
||||||
|
<path
|
||||||
|
fill-rule="evenodd"
|
||||||
|
clip-rule="evenodd"
|
||||||
|
fill="#65459B"
|
||||||
|
d="M215.2 260.8h-58.7L117.4 300H78.3v-39.2H6.6V52.2L26.1 0h267.3v182.6l-78.2 78.2zm52.2-91.2V26.1H52.2v189.1h58.7v39.1l39.1-39.1h71.7l45.7-45.6z"
|
||||||
|
/><path
|
||||||
|
fill="#65459B"
|
||||||
|
d="M195.6 78.3v78.3h26.1V78.3h-26.1zm-71.7 78.2H150V78.3h-26.1v78.2z"
|
||||||
|
/>
|
||||||
|
</svg>
|
||||||
|
<span>Sign in with Twitch</span>
|
||||||
|
</a>
|
||||||
|
|
||||||
<a
|
<a
|
||||||
href="/api/auth/signin/google"
|
href="/api/auth/signin/google"
|
||||||
class={clsx(
|
class={clsx(
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
export { Provider } from "./base";
|
export { Provider } from "./base";
|
||||||
|
export { TwitchOAuth2Provider } from "./twitch";
|
||||||
|
export type { TwitchProfile, TwitchTokens } from "./twitch";
|
||||||
export { GoogleOAuth2Provider } from "./google";
|
export { GoogleOAuth2Provider } from "./google";
|
||||||
export type { GoogleProfile, GoogleTokens } from "./google";
|
export type { GoogleProfile, GoogleTokens } from "./google";
|
||||||
export { TwitterAuthProvider } from "./twitter";
|
export { TwitterAuthProvider } from "./twitter";
|
||||||
|
57
src/providers/twitch.ts
Normal file
57
src/providers/twitch.ts
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
import { OAuth2Provider, OAuth2ProviderConfig } from "./oauth2";
|
||||||
|
import { ucFirst } from "../helpers";
|
||||||
|
|
||||||
|
export interface TwitchProfile {
|
||||||
|
id: string;
|
||||||
|
login: string;
|
||||||
|
display_name: string;
|
||||||
|
type?: string;
|
||||||
|
broadcaster_type?: string;
|
||||||
|
description: boolean;
|
||||||
|
profile_image_url: string;
|
||||||
|
offline_image_url: string;
|
||||||
|
view_count: number;
|
||||||
|
email: string;
|
||||||
|
created_at: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface TwitchTokens {
|
||||||
|
access_token: string;
|
||||||
|
expires_in: number;
|
||||||
|
scope: string;
|
||||||
|
token_type: string;
|
||||||
|
refresh_token: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
type TwitchOAuth2ProviderConfig = OAuth2ProviderConfig<TwitchProfile, TwitchTokens>;
|
||||||
|
|
||||||
|
const defaultConfig: Partial<TwitchOAuth2ProviderConfig> = {
|
||||||
|
id: "twitch",
|
||||||
|
scope: "user:read:email",
|
||||||
|
accessTokenUrl: "https://id.twitch.tv/oauth2/token",
|
||||||
|
authorizationUrl: "https://id.twitch.tv/oauth2/authorize",
|
||||||
|
profileUrl: "https://api.twitch.tv/helix/users",
|
||||||
|
};
|
||||||
|
|
||||||
|
export class TwitchOAuth2Provider extends OAuth2Provider<
|
||||||
|
TwitchProfile,
|
||||||
|
TwitchTokens,
|
||||||
|
TwitchOAuth2ProviderConfig
|
||||||
|
> {
|
||||||
|
constructor(config: TwitchOAuth2ProviderConfig) {
|
||||||
|
super({
|
||||||
|
...defaultConfig,
|
||||||
|
...config,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async getUserProfile(tokens: TwitchTokens): Promise<TwitchProfile> {
|
||||||
|
const headers = {
|
||||||
|
'Client-ID': this.config.clientId + '',
|
||||||
|
'Accept': 'application/vnd.twitchtv.v5+json',
|
||||||
|
'Authorization': `Bearer ${tokens.access_token}`
|
||||||
|
};
|
||||||
|
const { data: [profile] } = await fetch(this.config.profileUrl!, { headers: headers }).then(res => res.json())
|
||||||
|
return profile
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user