siwe-oidc/README.md

132 lines
4.4 KiB
Markdown
Raw Normal View History

2021-12-15 10:13:26 -05:00
# OpenID Connect Identity Provider for Sign-In with Ethereum
## Getting Started
Two versions are available, a stand-alone binary (using Axum and Redis) and a
Cloudflare Worker. They use the same code base and are selected at compile time
(compiling for `wasm32` will make the Worker version).
### Cloudflare Worker
You will need [`wrangler`](https://github.com/cloudflare/wrangler).
2022-07-26 04:46:00 -04:00
First, copy the configuration file template:
```bash
cp wrangler_example.toml wrangler.toml
```
2022-07-26 04:46:00 -04:00
Then replace the following fields:
- `account_id`: your Cloudflare account ID;
2022-07-26 04:46:00 -04:00
- `zone_id`: (Optional) DNS zone ID;
- `kv_namespaces`: a KV namespace ID (created with `wrangler kv:namespace create SIWE_OIDC`); and
- the environment variables under `vars`.
You will also need to add a secret RSA key in PEM format:
```
2022-08-02 11:14:59 -04:00
wrangler secret put RSA_PEM
2022-07-26 04:46:00 -04:00
```
At this point, you should be able to create/publish the worker:
```
wrangler publish
```
The IdP currently only supports having the **frontend under the same subdomain as
the API**. Here is the configuration for Cloudflare Pages:
- `Build command`: `cd js/ui && npm install && npm run build`;
- `Build output directory`: `/static`; and
- `Root directory`: `/`.
And you will need to add some rules to do the routing between the Page and the
Worker. Here are the rules for the Worker (the Page being used as the fallback
on the subdomain):
```
siweoidc.example.com/s*
siweoidc.example.com/u*
siweoidc.example.com/r*
siweoidc.example.com/a*
siweoidc.example.com/t*
siweoidc.example.com/j*
2022-02-14 07:50:57 -05:00
siweoidc.example.com/c*
siweoidc.example.com/.w*
```
### Stand-Alone Binary
2022-09-28 06:00:50 -04:00
> Note that currently the published Docker image doesn't support all wallets due
> to the need of bundling secrets for web3modal at compile-time.
#### Dependencies
2021-12-15 10:13:26 -05:00
Redis, or a Redis compatible database (e.g. MemoryDB in AWS), is required.
#### Starting the IdP
2021-12-15 10:13:26 -05:00
The Docker image is available at `ghcr.io/spruceid/siwe_oidc:0.1.0`. Here is an
example usage:
```bash
2022-08-19 06:36:36 -04:00
docker run -p 8000:8000 -e SIWEOIDC_REDIS_URL="redis://redis" ghcr.io/spruceid/siwe_oidc:latest
2021-12-15 10:13:26 -05:00
```
It can be configured either with the `siwe-oidc.toml` configuration file, or
through environment variables:
* `SIWEOIDC_ADDRESS` is the IP address to bind to.
* `SIWEOIDC_REDIS_URL` is the URL to the Redis instance.
* `SIWEOIDC_BASE_URL` is the URL you want to advertise in the OIDC configuration
(e.g. `https://oidc.example.com`).
* `SIWEOIDC_RSA_PEM` is the signing key, in PEM format. One will be generated if
none is provided.
### OIDC Functionalities
The current flow is very basic -- after the user is authenticated you will
2022-01-25 11:29:02 -05:00
receive:
- an Ethereum address as the subject (`sub` field); and
- an ENS domain as the `preferred_username` (with a fallback to the address).
2021-12-15 10:13:26 -05:00
For the core OIDC information, it is available under
`/.well-known/openid-configuration`.
2022-01-25 11:29:02 -05:00
OIDC Conformance Suite:
- 🟨 (25/29, and 10 skipped) [basic](https://www.certification.openid.net/plan-detail.html?plan=gXe7Ju1O1afZa&public=true) (`email` scope skipped, `profile` scope partially supported, ACR, `prompt=none` and request URIs yet to be supported);
- 🟩 [config](https://www.certification.openid.net/plan-detail.html?plan=SAmBjvtyfTDVn&public=true);
- 🟧 [dynamic code](https://www.certification.openid.net/plan-detail.html?plan=7rexGcCd4SWJa&public=true).
2021-12-15 10:13:26 -05:00
### TODO Items
2022-01-25 11:29:02 -05:00
* Additional information, from native projects (e.g. ENS domains profile
pictures), to more traditional ones (e.g. email).
2021-12-15 10:13:26 -05:00
## Development
### Cloudflare Worker
```bash
wrangler dev
```
You can now use http://127.0.0.1:8787/.well-known/openid-configuration.
> At the moment it's not possible to use it end-to-end with the frontend as they
> need to share the same host (i.e. port), unless using a local load-balancer.
### Stand Alone Binary
2021-12-15 10:13:26 -05:00
A Docker Compose is available to test the IdP locally with Keycloak.
1. You will first need to run:
```bash
2022-09-28 06:00:50 -04:00
docker-compose -f test/docker-compose.yml up -d
2021-12-15 10:13:26 -05:00
```
2. And then edit your `/etc/hosts` to have `siwe-oidc` point to `127.0.0.1`.
This is so both your browser, and Keycloak, can access the IdP.
3. In Keycloak, you will need to create a new IdP. You can use
`http://siwe-oidc:8000/.well-known/openid-configuration` to fill the settings
automatically. As for the client ID/secret, you can use `sdf`/`sdf`.
2022-01-11 12:25:03 -05:00
## Disclaimer
Our identity provider for Sign-In with Ethereum has not yet undergone a formal
security audit. We welcome continued feedback on the usability, architecture,
and security of this implementation.