This is the BARE minimum of the specific configuration of my setup. Read the detailed setup post here.
Synapse
Synapse runs locally on port 8008 and is served on matrix.sspaeth.de. The only change needed, is to set up MAS as the OIDC server. I put the below in a separate OIDC.yaml
file in the conf.d subdirectory of my synapse config:
experimental_features:
msc3861:
enabled: true
issuer: https://auth.sspaeth.de/
# Matches the `client_id` in the MAS config
client_id: 00000000000000000SYNAPSE00
# Matches the `client_auth_method` in the MAS config
client_auth_method: client_secret_basic
# Matches the `client_secret` in the MAS config
client_secret: 1234CLIENTSECRETHERE56789
# Matches the `matrix.secret` in the MAS config
admin_token: 0x97531ADMINTOKENHERE13579
MAS
MAS runs locally on port 8080 and is served on auth.sspaeth.de. Below are snippets that I either added to or where I modified the defaults in config.yaml
.
# Set up the client talking to Synapse.
clients:
- client_id: 00000000000000000SYNAPSE00
client_auth_method: client_secret_basic
client_secret: 1234CLIENTSECRETHERE56789
redirect_uris:
- https://openidconnect.net/callback
# Tell MAS about Synapse and how to talk locally to it:
matrix:
homeserver: sspaeth.de
secret: 0x97531ADMINTOKENHERE13579
endpoint: http://localhost:8008/
This should be OK for local password auth through MAS, but the next section is what I added to configure Nextcloud as an upstream OIDC provider:
upstream_oauth2:
providers:
- id: 01B2BSNY1QVVS9ZG3JTVDHNYYE
# Note, above value is used in the Nextcloud config in the Redirection URI
human_name: Nextcloud
issuer: "https://cloud.sspaeth.de"
client_id: "THISISMYLONGANDSECRETNEXTCLOUDCLIENTID" # needs to be configured in the Nextcloud OIDC settings
client_secret: "THISISMYLONGANDSECRETNEXTCLOUDCLIENSECRET" # needs to be configured in the Nextcloud OIDC settings
token_endpoint_auth_method: "client_secret_post"
scope: "openid profile email"
claims_imports:
localpart:
action: require
template: "{{ user.preferred_username }}"
displayname:
action: suggest
template: "{{ user.name }}"
email:
action: suggest
template: "{{ user.email }}"
set_email_verification: import
# Only allow upstream IdP, no local passwords
passwords:
enabled: false
Nextcloud
The OpenID Connect app/plugin adds the central config option OpenID Connect clients
. In this I have set:
Name auth.sspaeth.de
# Redirect URI uses the upstream_oauth2->providers->id value from my MAS config
Redirection URI: https://auth.sspaeth.de/upstream/callback/01B2BSNY1QVVS9ZG3JTVDHNYYE
Client Identifier: THISISMYLONGANDSECRETNEXTCLOUDCLIENTID
Secret: THISISMYLONGANDSECRETNEXTCLOUDCLIENTSECRET
Signing Algorithm: RS256
Type: confidential
Flows: Code & Implicit Authorization Flow
Limited to Groups: matrix # my choice to only allow specific users to log in.
That was simple wasn’t it? Again, this is just specific config changes to all components to get things running. Check out the detailed post on my setup and nginx proxy configuration.