Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marcelcoding/jitsi-openid
Jitsi OpenID is an authentication adapter that allows Jitsi to authorize users with OpenID Connect.
https://github.com/marcelcoding/jitsi-openid
auth axum docker jitsi jwt oauth2 oidc openid-connect rust
Last synced: 3 months ago
JSON representation
Jitsi OpenID is an authentication adapter that allows Jitsi to authorize users with OpenID Connect.
- Host: GitHub
- URL: https://github.com/marcelcoding/jitsi-openid
- Owner: MarcelCoding
- License: agpl-3.0
- Created: 2021-02-26T10:36:05.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-08-21T21:01:18.000Z (5 months ago)
- Last Synced: 2024-08-22T23:06:37.162Z (5 months ago)
- Topics: auth, axum, docker, jitsi, jwt, oauth2, oidc, openid-connect, rust
- Language: Rust
- Homepage:
- Size: 312 KB
- Stars: 29
- Watchers: 2
- Forks: 4
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Jitsi OpenID
Jitsi OpenID is an authentication adapter to provide [jitsi](https://jitsi.org/) the ability to use single sign on
via [OpenID Connect](https://openid.net/connect/).## Deployment
**This guide is based of the [docker setup from jitsi](https://github.com/jitsi/docker-jitsi-meet/).**
This image is available in the
[GitHub Container Registry](https://github.com/users/MarcelCoding/packages/container/package/jitsi-openid):```
ghcr.io/marcelcoding/jitsi-openid:latest
```### Docker "run" Command
```bash
docker run \
-p 3000:3000 \
-e JITSI_SECRET=SECURE_SECRET \
-e JITSI_URL=https://meet.example.com \
-e JITSI_SUB=meet.example.com \
-e ISSUER_URL=https://id.example.com \
-e BASE_URL=https://auth.meet.example.com \
-e CLIENT_ID=meet.example.com \
-e CLIENT_SECRET=SECURE_SECRET \
--rm \
ghcr.io/marcelcoding/jitsi-openid:latest
```### Docker Compose
````yaml
# docker-compose.yaml# ...
services:
# ...
jitsi-openid:
image: ghcr.io/marcelcoding/jitsi-openid:latest
restart: always
environment:
- 'JITSI_SECRET=SECURE_SECRET' # <- shared with jitsi (JWT_APP_SECRET -> see .env from jitsi),
# secret to sign jwt tokens
- 'JITSI_URL=https://meet.example.com' # <- external url of jitsi
- 'JITSI_SUB=meet.example.com' # <- shared with jitsi (JWT_APP_ID -> see .env from jitsi),
# id of jitsi
- 'ISSUER_URL=https://id.example.com' # <- base URL of your OpenID Connect provider
# Keycloak: https://id.example.com/auth/realms/
- 'BASE_URL=https://auth.meet.example.com' # <- base URL of this application
- 'CLIENT_ID=meet.example.com' # <- OpenID Connect Client ID
- 'CLIENT_SECRET=SECURE_SECRET' # <- OpenID Connect Client secret
# - 'ACR_VALUES=password email' # <- OpenID Context Authentication Context Requirements,
# space seperated list of allowed actions (OPTIONAL), see
# https://github.com/MarcelCoding/jitsi-openid/issues/122
# - 'SCOPES=openid email jitsi' # <- OpenID Scopes, space seperated list of scopes (OPTIONAL),
# default: openid email
# - 'VERIFY_ACCESS_TOKEN_HASH=false # <- explicitly disable access token hash verification (OPTIONAL),
# default: true
# - 'SKIP_PREJOIN_SCREEN=false' # <- skips the jitsi prejoin screen after login (default: true)
# - 'GROUP=example' # <- Value for the 'group' field in the token
# default: ''
ports:
- '3000:3000'# ...
````To generate the `JITSI_SECRET` you can use one of the following command:
```bash
cat /dev/urandom | tr -dc a-zA-Z0-9 | head -c128; echo
```### NixOS
```nix
{
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-23.11";
jitsi-openid = {
url = "github:MarcelCoding/jitsi-openid";
inputs.nixpkgs.follows = "nixpkgs";
};
};outputs = { self, nixpkgs, jitsi-openid, ... }: {
nixosConfigurations = {
hostname = nixpkgs.lib.nixosSystem {
modules = [
jitsi-openid.nixosModules.default
{ nixpkgs.overlays = [ jitsi-openid.overlays.default ]; }
];
};
};
};
}
``````nix
# for an explanation see docker compose setup
services.jitsi-openid = {
enable = true;
settings = {
package = pkgs.jitsi-openid;
enable = true;
listen = {
addr = "::1";
port = 6031;
};
jitsiSecretFile = "/run/secrets/jitsi-secret-file";
jitsiUrl = "https://meet.domain.tld";
jitsiSub = "meet.domain.tld";
issuerUrl = "https://auth.domain.tld";
baseUrl = "https://auth.meet.domain.tld";
clientId = "auth.meet.domain.tld";
clientSecretFile = "/run/secrets/client-secret-file";
openFirewall = false;
};
};
```### Jitsi Configuration
If you have problems understating this have a look here: https://github.com/MarcelCoding/jitsi-openid/issues/80
````bash
# for more information see:
# https://github.com/jitsi/docker-jitsi-meet/blob/master/env.example# weather to allow users to join a room without requiring to authenticate
#ENABLE_GUESTS=1# fixed
ENABLE_AUTH=1
AUTH_TYPE=jwt# should be the same as JITSI_ID of jitsi-openid environment variables
JWT_APP_ID=meet.example.com
# should be the same as JITSI_SECRET of jitsi-openid environment variables
JWT_APP_SECRET=SECRET# fixed values
JWT_ACCEPTED_ISSUERS=jitsi
JWT_ACCEPTED_AUDIENCES=jitsi# auth.meet.example.com should be the domain name of jitsi-openid,
# `/room/{room}` is the endpoint that's jitsi redirecting the user to
# `{room}` is is a placeholder, where jitsi inserts the room name
# jitsi-openid should redirect the user after a successfully authentication
# !! it is recommend to use ALWAYS https e.g. using a reverse proxy !!
TOKEN_AUTH_URL=https://auth.meet.example.com/room/{room}
````### Jitsi JWTs
The JWTs are populated using the data returned by your IDP.
This includes the user id, email and name.The `sub` extracted from the `prefered_username` field, if that isn't preset the `sub` field is used.
The `name` is extracted from the `name` field, if that isn't preset a concatenation of `given_name`, `middle_name`
and `family_name` is used. If all tree of them are also not present the `prefered_username` is used.The `affiliation` is straight up passed, without any modifications or alternatives. It can be used to restrict the
permissions a user has in a specific room in jitsi.
See https://github.com/jitsi-contrib/prosody-plugins/tree/main/token_affiliation for more information.The picture (avatar) URL is delegated from the IDP to Jitsi.
Translations aren't respected: https://github.com/MarcelCoding/jitsi-openid/issues/117#issuecomment-1172406703
## License
[LICENSE](LICENSE)