6.6 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	Getting started
Following these quick start instructions, you will have a basic setup that can perform recursive/federated lookups.
This will be a good ground work for further integration with features and your existing Identity stores.
If you would like a more fully integrated setup out of the box, the matrix-docker-ansible-deploy
project provides a turn-key full-stack solution, including LDAP and the various mxisd features enabled and ready.
We work closely with the project owner so the latest mxisd version is always supported.
If you choose to use it, this Getting Started guide is not applicable - See the project documentation. You may then directly go to the Next steps.
Preparation
You will need:
- Working Homeserver, ideally with working federation
- Reverse proxy with regular TLS/SSL certificate (Let's encrypt) for your mxisd domain
If you use synapse:
- It requires an HTTPS connection when talking to an Identity service, a reverse proxy is required as mxisd does not support HTTPS listener at this time.
- HTTPS is hardcoded when talking to the Identity server. If your Identity server URL in your client is https://matrix.example.org/, then you need to ensurehttps://matrix.example.org/_matrix/identity/api/v1/...will reach mxisd if called from the synapse host. In doubt, test withcurlor similar.
For maximum integration, it is best to have your Homeserver and mxisd reachable via the same public hostname.
Be aware of a NAT/Reverse proxy gotcha if you use the same host.
The following Quick Start guide assumes you will host the Homeserver and mxisd under the same hostname.
If you would like a high-level view of the infrastructure and how each feature is integrated, see the
dedicated document
Install
Install via:
See the Latest release for links to each.
Configure
Note
: Please view the install instruction for your platform, as this step might be optional or already handled for you.
Note
: Details about configuration syntax and format are described here
If you haven't created a configuration file yet, copy mxisd.example.yaml to where the configuration file is stored given
your installation method and edit to your needs.
The following items must be at least configured:
- matrix.domainshould be set to your Homeserver domain (- server_namein synapse configuration)
- key.pathwill store the signing keys, which must be kept safe! If the file does not exist, keys will be generated for you.
- storage.provider.sqlite.databaseis the location of the SQLite Database file which will hold state (invites, etc.)
If your HS/mxisd hostname is not the same as your Matrix domain, configure server.name.
Complete configuration guide is available here.
Integrate
For an overview of a typical mxisd infrastructure, see the dedicated document
Reverse proxy
Apache2
In the VirtualHost section handling the domain with SSL, add the following and replace 0.0.0.0 by the internal
hostname/IP pointing to mxisd.
This line MUST be present before the one for the homeserver!
ProxyPass /_matrix/identity http://0.0.0.0:8090/_matrix/identity
Typical configuration would look like:
<VirtualHost *:443>
    ServerName matrix.example.org
    
    # ...
    
    ProxyPreserveHost on
    ProxyPass /_matrix/identity http://localhost:8090/_matrix/identity
    ProxyPass /_matrix http://localhost:8008/_matrix
</VirtualHost>
nginx
In the server section handling the domain with SSL, add the following and replace 0.0.0.0 with the internal
hostname/IP pointing to mxisd.
This line MUST be present before the one for the homeserver!
location /_matrix/identity {
    proxy_pass http://0.0.0.0:8090/_matrix/identity;
}
Typical configuration would look like:
server {
    listen 443 ssl;
    server_name matrix.example.org;
    
    # ...
    
    location /_matrix/identity {
        proxy_pass http://localhost:8090/_matrix/identity;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-For $remote_addr;
    }
    
    location /_matrix {
        proxy_pass http://localhost:8008/_matrix;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-For $remote_addr;
    }
}
Synapse
Add your mxisd domain into the homeserver.yaml at trusted_third_party_id_servers and restart synapse.
In a typical configuration, you would end up with something similar to:
trusted_third_party_id_servers:
    - matrix.example.org
It is highly recommended to remove matrix.org and vector.im (or any other default entry) from your configuration
so only your own Identity server is authoritative for your HS.
Validate
NOTE: In case your homeserver has no working federation, step 5 will not happen. If step 4 took place, consider your installation validated.
- Log in using your Matrix client and set https://matrix.example.orgas your Identity server URL, replacingmatrix.example.orgby the relevant hostname which you configured in your reverse proxy.
- Create a new empty room. All further actions will take place in this room.
- Invite mxisd-federation-test@kamax.io
- The 3PID invite should be turned into a Matrix invite to @mxisd-lookup-test:kamax.io.
- The invited test user will join the room, send a congratulation message and leave. NOTE: You might not see a suggestion for the e-mail address, which is normal. Still proceed with the invite.
If it worked, it means you are up and running and can enjoy mxisd in its basic mode! Congratulations!
If it did not work, read the basic troubleshooting guide, get in touch and
we'll do our best to get you started.
Next steps
Once your mxisd server is up and running, there are several ways you can enhance and integrate further with your infrastructure: