Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kravetsone/elysia-oauth2
Elysia plugin for OAuth 2.0 Authorization Flow with more than 42 providers
https://github.com/kravetsone/elysia-oauth2
auth authorization elysia google oauth2
Last synced: about 1 month ago
JSON representation
Elysia plugin for OAuth 2.0 Authorization Flow with more than 42 providers
- Host: GitHub
- URL: https://github.com/kravetsone/elysia-oauth2
- Owner: kravetsone
- Created: 2023-12-17T19:17:19.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-12-06T12:10:53.000Z (about 2 months ago)
- Last Synced: 2024-12-06T13:40:54.306Z (about 2 months ago)
- Topics: auth, authorization, elysia, google, oauth2
- Language: TypeScript
- Homepage:
- Size: 46.9 KB
- Stars: 45
- Watchers: 1
- Forks: 4
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# elysia-oauth2
[![npm](https://img.shields.io/npm/v/elysia-oauth2?logo=npm&style=flat&labelColor=000&color=3b82f6)](https://www.npmjs.org/package/elysia-oauth2)
[![npm downloads](https://img.shields.io/npm/dw/elysia-oauth2?logo=npm&style=flat&labelColor=000&color=3b82f6)](https://www.npmjs.org/package/elysia-oauth2)[Elysia](https://elysiajs.com/) plugin for [OAuth 2.0](https://en.wikipedia.org/wiki/OAuth) Authorization Flow.
Powered by [Arctic](https://arctic.js.org/) with more than **48** oauth2 providers!
## Installation
```bash
bun install elysia-oauth2 arctic
```### Update
if [Arctic](https://arctic.js.org/) will release some new providers, you can update it with
```bash
bun install arctic@latest
```## Example
```ts
import { Elysia } from "elysia";
import { oauth2 } from "elysia-oauth2";new Elysia()
.use(
oauth2({
VK: [
"clientID",
"clientSecret",
"https://example.com/auth/vk/callback",
],
})
)
.get("/auth/vk", ({ oauth2 }) => oauth2.redirect("VK"))
.get("/auth/vk/callback", async ({ oauth2 }) => {
const token = await oauth2.authorize("VK");// send request to API with token
})
.listen(3001);
```> [!IMPORTANT]
> You should return `oauth2.redirect` from the handler, because it relies on elysia's [redirect()](https://elysiajs.com/essential/handler.html#redirect) which need to return `Response`### CreateURL example
```ts
import { Elysia } from "elysia";
import { oauth2 } from "elysia-oauth2";new Elysia()
.use(
oauth2({
Google: [
"clientID",
"clientSecret",
"https://example.com/auth/Google/callback",
],
})
)
.get("/auth/google", async ({ oauth2, redirect }) => {
const url = await oauth2.createURL("Google");
url.searchParams.set("access_type", "offline");return redirect(url.href);
})
.get("/auth/google/callback", async ({ oauth2 }) => {
const token = await oauth2.authorize("Google");// send request to API with token
})
.listen(3001);
```## Supported providers
- 42 School
- Amazon Cognito
- AniList
- Apple
- Atlassian
- Auth0
- Authentik
- Bitbucket
- Box
- Coinbase
- Discord
- Dribbble
- Dropbox
- Figma
- Github
- GitLab
- Intuit
- Kakao
- Keycloak
- Lichess
- Line
- Linear
- Microsoft Entra ID
- MyAnimeList
- Notion
- Okta
- osu!
- Patreon
- Roblox
- Salesforce
- Shikimori
- Slack
- Spotify
- Strava
- Tiltify
- Tumblr
- Twitch
- VK
- WorkOS
- Yahoo
- Yandex
- Zoom