Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/subhendukundu/worker-auth-providers

worker-auth-providers is an open-source providers to make authentication easy with workers. Very lightweight script which doesn't need a lot of dependencies. Plug it with any framework or template of workers.
https://github.com/subhendukundu/worker-auth-providers

auth authentication aws-sns-login cloudflare cloudflare-workers discord-login facebook-login github-login github-login-with-worker google-login oauth2 spotify worker-discord-login worker-login worker-twilio-otp

Last synced: 2 months ago
JSON representation

worker-auth-providers is an open-source providers to make authentication easy with workers. Very lightweight script which doesn't need a lot of dependencies. Plug it with any framework or template of workers.

Awesome Lists containing this project

README

        

worker-auth-providers

worker-auth-providers


An open-source auth providers for Cloudflare workers


Repo Size

Issues

Pull Requests

Last Commit


worker-auth-providers is an open-source providers to make authentication easy with workers. Very lightweight script which doesn't need a lot of dependencies. Plug it with any framework or template of workers.

## πŸš€ Demo
[Try now](https://worker-auth-providers.coolbio.workers.dev)

## 🧐 Features
- Open Source
- Fast & Lightweight
- Easy

## πŸ› οΈ Installation
**Step 1**: Install the dependencies
```bash
npm install worker-auth-providers
```
**Step 2**: Import the dependencies
```javascript
import {
github, google,
twilio, facebook, discord,
spotify
} from "worker-auth-providers";
```
**Step 3**: Redirect users
```javascript
const githubLoginUrl = await github.redirect({
options: {
clientId,
},
});
return {
status: 302,
headers: {
location: githubLoginUrl,
},
};

// or send otp

const res = await awsSNS.send({
options: {
phone,
region: 'ap-south-1',
kvProvider: WORKER_AUTH_PROVIDERS_STORE,
},
})
```
**Step 4**: Get user
```javascript
const { user: providerUser, tokens } = await github.users({
options: { clientSecret, clientId },
request,
});
console.log("[providerUser]", providerUser);

// or verify otp
const res = await awsSNS.verify({
options: {
phone,
otp,
kvProvider: WORKER_AUTH_PROVIDERS_STORE,
secret: 'eyJhbGciOiJIUzI1NiJ9.ew0KICAic3ViIjogIjE2Mjc4MTE1MDEiLA0KICAibmFtZSI6ICJoYWFsLmluIiwNCiAgImlhdCI6ICIwMTA4MjAyMCINCn0.aNr18szvBz3Db3HAsJ-2KHYbnnHwHfK65CiZ_AWwpc0',
},
})
```

## πŸ“ƒ Documentation
Coming soon

## πŸ‘©β€πŸ’» Tech
- [Cloudflare](https://www.cloudflare.com/)

## 🍰 Contributing
Contributions are always welcome!
See [contributing.md](contributing.md) for ways to get started.
Please adhere to this project's [code of conduct](code-of-conduct.md).

## Roadmap

- [ ] Docs.
- [x] Apple.
- [ ] Azure (Microsoft)
- [x] Google.
- [x] Github
- [x] OTP Twilio
- [x] Mailgun Email
- [x] Sendgrid Email
- [x] Facebook
- [x] Discord
- [ ] Instagram
- [ ] Amazon
- [ ] Twitter
- [x] Spotify
- [ ] Auth0

##FAQs

#### How to persist login?

Use cookie. Setting a cookie to indicate that they’re authorized for future requests

```javascript
const cookieKey = "worker-auth-providers"
const persistAuth = async exchange => {
const date = new Date() date.setDate(date.getDate() + 1)
const headers = {
Location: "/",
"Set-cookie": `${cookieKey}=${id}; Secure; HttpOnly; SameSite=Lax; Expires=${date.toUTCString()}`,
}
return { headers, status: 302 }
}
```

#### How to logout?

Easy, delete the cookie

```javascript
export const logout = event => {
const cookieHeader = event.request.headers.get('Cookie')
if (cookieHeader && cookieHeader.includes(cookieKey)) {
return {
headers: {
'Set-cookie': `${cookieKey}=""; HttpOnly; Secure; SameSite=Lax;`,
},
}
}
return {}
}
```

## Feedback

If you have any feedback, please reach out to me at [email protected]

## ✍️ Authors
- [@subhendukundu](https://www.github.com/subhendukundu)

## πŸ’Ό License
[MIT](https://github.com/subhendukundu/worker-auth-providers/blob/main/LICENSE)