Compare commits
	
		
			14 Commits
		
	
	
		
			v1.2.2
			...
			v1.3.0-alp
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 7ec11ba8cf | ||
|  | 9317c11434 | ||
|  | b257a0275f | ||
|  | 2aaa04062f | ||
|  | 54c3014568 | ||
|  | c3ca73f576 | ||
|  | 4185b644b7 | ||
|  | ace5918342 | ||
|  | 7ad985fead | ||
|  | 6a376db322 | ||
|  | 950f7c931c | ||
|  | d160a44509 | ||
|  | 05493da27c | ||
|  | df44428a85 | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -7,6 +7,7 @@ out/ | |||||||
| .idea/ | .idea/ | ||||||
|  |  | ||||||
| # Local dev config | # Local dev config | ||||||
|  | /mxisd.yaml | ||||||
| /application.yaml | /application.yaml | ||||||
|  |  | ||||||
| # Local dev storage | # Local dev storage | ||||||
|   | |||||||
| @@ -14,4 +14,5 @@ ENV SQLITE_DATABASE_PATH="/var/mxisd/mxisd.db" | |||||||
| CMD [ "/start.sh" ] | CMD [ "/start.sh" ] | ||||||
|  |  | ||||||
| ADD src/docker/start.sh /start.sh | ADD src/docker/start.sh /start.sh | ||||||
| ADD build/libs/mxisd.jar /mxisd.jar | ADD src/script/mxisd /app/mxisd | ||||||
|  | ADD build/libs/mxisd.jar /app/mxisd.jar | ||||||
|   | |||||||
							
								
								
									
										95
									
								
								build.gradle
									
									
									
									
									
								
							
							
						
						
									
										95
									
								
								build.gradle
									
									
									
									
									
								
							| @@ -21,9 +21,11 @@ | |||||||
| import java.util.regex.Pattern | import java.util.regex.Pattern | ||||||
|  |  | ||||||
| apply plugin: 'java' | apply plugin: 'java' | ||||||
| apply plugin: 'org.springframework.boot' | apply plugin: 'application' | ||||||
|  | apply plugin: 'com.github.johnrengelman.shadow' | ||||||
|  | apply plugin: 'idea' | ||||||
|  |  | ||||||
| def confFileName = "application.example.yaml" | def confFileName = "mxisd.example.yaml" | ||||||
| def distDir = "${project.buildDir}/dist" | def distDir = "${project.buildDir}/dist" | ||||||
|  |  | ||||||
| def debBinPath = "/usr/lib/mxisd" | def debBinPath = "/usr/lib/mxisd" | ||||||
| @@ -31,7 +33,8 @@ def debConfPath = "/etc/mxisd" | |||||||
| def debDataPath = "/var/lib/mxisd" | def debDataPath = "/var/lib/mxisd" | ||||||
| def debSystemdPath = "/etc/systemd/system" | def debSystemdPath = "/etc/systemd/system" | ||||||
|  |  | ||||||
| def debConfFileName = "mxisd-sample.yaml" | def debConfFileName = confFileName | ||||||
|  | def debStartScriptFilename = "mxisd" | ||||||
|  |  | ||||||
| def debBuildBasePath = "${project.buildDir}/tmp/debian" | def debBuildBasePath = "${project.buildDir}/tmp/debian" | ||||||
| def debBuildDebianPath = "${debBuildBasePath}/DEBIAN" | def debBuildDebianPath = "${debBuildBasePath}/DEBIAN" | ||||||
| @@ -43,6 +46,9 @@ def debBuildSystemdPath = "${debBuildBasePath}${debSystemdPath}" | |||||||
| def dockerImageName = "kamax/mxisd" | def dockerImageName = "kamax/mxisd" | ||||||
| def dockerImageTag = "${dockerImageName}:${mxisdVersion()}" | def dockerImageTag = "${dockerImageName}:${mxisdVersion()}" | ||||||
|  |  | ||||||
|  | group = 'io.kamax' | ||||||
|  | mainClassName = 'io.kamax.mxisd.MxisdStandaloneExec' | ||||||
|  |  | ||||||
| String mxisdVersion() { | String mxisdVersion() { | ||||||
|     def versionPattern = Pattern.compile("v(\\d+\\.)?(\\d+\\.)?(\\d+)(-.*)?") |     def versionPattern = Pattern.compile("v(\\d+\\.)?(\\d+\\.)?(\\d+)(-.*)?") | ||||||
|  |  | ||||||
| @@ -59,38 +65,41 @@ String gitVersion() { | |||||||
|         commandLine = ['git', 'describe', '--tags', '--always', '--dirty'] |         commandLine = ['git', 'describe', '--tags', '--always', '--dirty'] | ||||||
|         standardOutput = out |         standardOutput = out | ||||||
|     } |     } | ||||||
|     return out.toString().replace(System.lineSeparator(), ''); |     return out.toString().replace(System.lineSeparator(), '') | ||||||
| } | } | ||||||
|  |  | ||||||
| buildscript { | buildscript { | ||||||
|     repositories { |     repositories { | ||||||
|         mavenCentral() |         jcenter() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     dependencies { |     dependencies { | ||||||
|         classpath 'org.springframework.boot:spring-boot-gradle-plugin:1.5.3.RELEASE' |         classpath 'com.github.jengelman.gradle.plugins:shadow:4.0.3' | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| repositories { | repositories { | ||||||
|     mavenCentral() |     jcenter() | ||||||
|     maven { url "https://kamax.io/maven/releases/" } |     maven { url "https://kamax.io/maven/releases/" } | ||||||
|     maven { url "https://kamax.io/maven/snapshots/" } |     maven { url "https://kamax.io/maven/snapshots/" } | ||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|  |     // Logging | ||||||
|  |     compile 'org.slf4j:slf4j-simple:1.7.25' | ||||||
|  |      | ||||||
|     // Easy file management |     // Easy file management | ||||||
|     compile 'commons-io:commons-io:2.5' |     compile 'commons-io:commons-io:2.5' | ||||||
|      |      | ||||||
|     // Spring Boot - standalone app |     // Config management | ||||||
|     compile 'org.springframework.boot:spring-boot-starter-web:1.5.10.RELEASE' |     compile 'org.yaml:snakeyaml:1.23' | ||||||
|  |  | ||||||
|     // Thymeleaf for HTML templates |  | ||||||
|     compile "org.springframework.boot:spring-boot-starter-thymeleaf:1.5.10.RELEASE" |  | ||||||
|  |  | ||||||
|     // Matrix Java SDK |     // Matrix Java SDK | ||||||
|     compile 'io.kamax:matrix-java-sdk:0.0.14-8-g0e57ec6' |     compile 'io.kamax:matrix-java-sdk:0.0.14-8-g0e57ec6' | ||||||
|  |  | ||||||
|  |     // ORMLite | ||||||
|  |     compile 'com.j256.ormlite:ormlite-jdbc:5.0' | ||||||
|  |  | ||||||
|     // ed25519 handling |     // ed25519 handling | ||||||
|     compile 'net.i2p.crypto:eddsa:0.1.0' |     compile 'net.i2p.crypto:eddsa:0.1.0' | ||||||
|  |  | ||||||
| @@ -107,15 +116,12 @@ dependencies { | |||||||
|     compile 'com.googlecode.libphonenumber:libphonenumber:8.7.1' |     compile 'com.googlecode.libphonenumber:libphonenumber:8.7.1' | ||||||
|  |  | ||||||
|     // E-mail sending |     // E-mail sending | ||||||
|     compile 'com.sun.mail:javax.mail:1.6.2' |  | ||||||
|     compile 'javax.mail:javax.mail-api:1.6.2' |     compile 'javax.mail:javax.mail-api:1.6.2' | ||||||
|  |     compile 'com.sun.mail:javax.mail:1.6.2' | ||||||
|  |  | ||||||
|     // Google Firebase Authentication backend |     // Google Firebase Authentication backend | ||||||
|     compile 'com.google.firebase:firebase-admin:5.3.0' |     compile 'com.google.firebase:firebase-admin:5.3.0' | ||||||
|  |  | ||||||
|     // ORMLite |  | ||||||
|     compile 'com.j256.ormlite:ormlite-jdbc:5.0' |  | ||||||
|  |  | ||||||
|     // Connection Pool |     // Connection Pool | ||||||
|     compile 'com.mchange:c3p0:0.9.5.2' |     compile 'com.mchange:c3p0:0.9.5.2' | ||||||
|  |  | ||||||
| @@ -137,37 +143,28 @@ dependencies { | |||||||
|     // ZT-Exec for exec identity store |     // ZT-Exec for exec identity store | ||||||
|     compile 'org.zeroturnaround:zt-exec:1.10' |     compile 'org.zeroturnaround:zt-exec:1.10' | ||||||
|  |  | ||||||
|  |     // HTTP server | ||||||
|  |     compile 'io.undertow:undertow-core:2.0.16.Final' | ||||||
|  |  | ||||||
|     testCompile 'junit:junit:4.12' |     testCompile 'junit:junit:4.12' | ||||||
|     testCompile 'com.github.tomakehurst:wiremock:2.8.0' |     testCompile 'com.github.tomakehurst:wiremock:2.8.0' | ||||||
|     testCompile 'com.unboundid:unboundid-ldapsdk:4.0.9' |     testCompile 'com.unboundid:unboundid-ldapsdk:4.0.9' | ||||||
|  |     testCompile 'com.icegreen:greenmail:1.5.9' | ||||||
| } | } | ||||||
|  |  | ||||||
| springBoot { | shadowJar { | ||||||
|     executable = true |     baseName = project.name | ||||||
|  |     classifier = null | ||||||
|     embeddedLaunchScriptProperties = [ |     version = null | ||||||
|             confFolder: "/etc/default" |  | ||||||
|     ] |  | ||||||
| } | } | ||||||
|  |  | ||||||
| processResources { | task debBuild(dependsOn: shadowJar) { | ||||||
|     doLast { |     doLast { | ||||||
|         copy { |         String debVersion = mxisdVersion() | ||||||
|             from('build/resources/main/application.yaml') { |         println "Version for package: ${debVersion}" | ||||||
|                 rename 'application.yaml', 'mxisd.yaml' |  | ||||||
|             } |  | ||||||
|             into 'build/resources/main' |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| task buildDeb(dependsOn: build) { |  | ||||||
|     doLast { |  | ||||||
|         def v = mxisdVersion() |  | ||||||
|         println "Version for package: ${v}" |  | ||||||
|         mkdir distDir |         mkdir distDir | ||||||
|         mkdir debBuildBasePath |         mkdir debBuildBasePath | ||||||
|         mkdir "${debBuildBasePath}/DEBIAN" |         mkdir debBuildDebianPath | ||||||
|         mkdir debBuildBinPath |         mkdir debBuildBinPath | ||||||
|         mkdir debBuildConfPath |         mkdir debBuildConfPath | ||||||
|         mkdir debBuildDataPath |         mkdir debBuildDataPath | ||||||
| @@ -178,10 +175,10 @@ task buildDeb(dependsOn: build) { | |||||||
|             into debBuildBinPath |             into debBuildBinPath | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         ant.chmod( |         copy { | ||||||
|                 file: "${debBuildBinPath}/mxisd.jar", |             from "${project.file("src/script/" + debStartScriptFilename)}" | ||||||
|                 perm: 'a+x' |             into debBuildBinPath | ||||||
|         ) |         } | ||||||
|  |  | ||||||
|         copy { |         copy { | ||||||
|             from(project.file(confFileName)) { |             from(project.file(confFileName)) { | ||||||
| @@ -190,16 +187,16 @@ task buildDeb(dependsOn: build) { | |||||||
|             into debBuildConfPath |             into debBuildConfPath | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         ant.replaceregexp( |         ant.replaceregexp( // FIXME adapt to new config format | ||||||
|                 file: "${debBuildConfPath}/${debConfFileName}", |                 file: "${debBuildConfPath}/${debConfFileName}", | ||||||
|                 match: "key.path:(.*)", |                 match: "key:\\R  path:(.*)", | ||||||
|                 replace: "key.path: '${debDataPath}/signing.key'" |                 replace: "key:\n  path: '${debDataPath}/signing.key'" | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|         ant.replaceregexp( |         ant.replaceregexp( // FIXME adapt to new config format | ||||||
|                 file: "${debBuildConfPath}/${debConfFileName}", |                 file: "${debBuildConfPath}/${debConfFileName}", | ||||||
|                 match: "storage.provider.sqlite.database:(.*)", |                 match: "storage:\\R  provider:\\R    sqlite:\\R      database:(.*)", | ||||||
|                 replace: "storage.provider.sqlite.database: '${debDataPath}/mxisd.db'" |                 replace: "storage:\n  provider:\n    sqlite:\n      database: '${debDataPath}/mxisd.db'" | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|         copy { |         copy { | ||||||
| @@ -210,7 +207,7 @@ task buildDeb(dependsOn: build) { | |||||||
|         ant.replace( |         ant.replace( | ||||||
|                 file: "${debBuildDebianPath}/control", |                 file: "${debBuildDebianPath}/control", | ||||||
|                 token: 'Version: 0', |                 token: 'Version: 0', | ||||||
|                 value: "Version: ${v}" |                 value: "Version: ${debVersion}" | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|         ant.replace( |         ant.replace( | ||||||
| @@ -246,7 +243,7 @@ task buildDeb(dependsOn: build) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| task dockerBuild(type: Exec, dependsOn: build) { | task dockerBuild(type: Exec, dependsOn: shadowJar) { | ||||||
|     commandLine 'docker', 'build', '-t', dockerImageTag, project.rootDir |     commandLine 'docker', 'build', '-t', dockerImageTag, project.rootDir | ||||||
|  |  | ||||||
|     doLast { |     doLast { | ||||||
|   | |||||||
| @@ -5,6 +5,7 @@ | |||||||
| - Installation | - Installation | ||||||
|   - [Debian package](install/debian.md) |   - [Debian package](install/debian.md) | ||||||
|   - [ArchLinux](install/archlinux.md) |   - [ArchLinux](install/archlinux.md) | ||||||
|  |   - [NixOS](install/nixos.md) | ||||||
|   - [Docker](install/docker.md) |   - [Docker](install/docker.md) | ||||||
|   - [From source](install/source.md) |   - [From source](install/source.md) | ||||||
| - [Architecture overview](architecture.md) | - [Architecture overview](architecture.md) | ||||||
|   | |||||||
| @@ -17,9 +17,8 @@ cd mxisd | |||||||
| ./gradlew build | ./gradlew build | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Create a new configuration file by coping `application.example.yaml` to `application.yaml` and edit to your needs.   | Create a new configuration file by coping `mxisd.example.yaml` to `mxisd.yaml` and edit to your needs.   | ||||||
| For advanced configuration, see the [Configure section](configure.md). | For advanced configuration, see the [Configure section](configure.md). | ||||||
| **NOTE**: `application.yaml` is also called `mxisd.yaml` in some specific installations. |  | ||||||
|  |  | ||||||
| Start the server in foreground to validate the build and configuration: | Start the server in foreground to validate the build and configuration: | ||||||
| ```bash | ```bash | ||||||
| @@ -29,12 +28,14 @@ java -jar build/libs/mxisd.jar | |||||||
| Ensure the signing key is available: | Ensure the signing key is available: | ||||||
| ```bash | ```bash | ||||||
| $ curl 'http://localhost:8090/_matrix/identity/api/v1/pubkey/ed25519:0' | $ curl 'http://localhost:8090/_matrix/identity/api/v1/pubkey/ed25519:0' | ||||||
|  |  | ||||||
| {"public_key":"..."} | {"public_key":"..."} | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Test basic recursive lookup (requires Internet connection with access to TCP 443): | Test basic recursive lookup (requires Internet connection with access to TCP 443): | ||||||
| ```bash | ```bash | ||||||
| $ curl 'http://localhost:8090/_matrix/identity/api/v1/lookup?medium=email&address=mxisd-federation-test@kamax.io' | $ curl 'http://localhost:8090/_matrix/identity/api/v1/lookup?medium=email&address=mxisd-federation-test@kamax.io' | ||||||
|  |  | ||||||
| {"address":"mxisd-federation-test@kamax.io","medium":"email","mxid":"@mxisd-lookup-test:kamax.io",...} | {"address":"mxisd-federation-test@kamax.io","medium":"email","mxid":"@mxisd-lookup-test:kamax.io",...} | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -57,7 +58,7 @@ Requirements: | |||||||
|  |  | ||||||
| [Build mxisd](#build) then: | [Build mxisd](#build) then: | ||||||
| ```bash | ```bash | ||||||
| ./gradlew buildDeb  | ./gradlew debBuild | ||||||
| ``` | ``` | ||||||
| You will find the debian package in `build/dist`.   | You will find the debian package in `build/dist`.   | ||||||
| Then follow the instruction in the [Debian package](install/debian.md) document. | Then follow the instruction in the [Debian package](install/debian.md) document. | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| # Configuration | # Configuration | ||||||
| - [Concepts](#concepts) | - [Concepts](#concepts) | ||||||
|   - [Syntax](#syntax) |   - [Syntax](#syntax) | ||||||
|   - [Variables](#variables) |  | ||||||
| - [Matrix](#matrix) | - [Matrix](#matrix) | ||||||
| - [Server](#server) | - [Server](#server) | ||||||
| - [Storage](#storage) | - [Storage](#storage) | ||||||
| @@ -11,36 +10,15 @@ | |||||||
|  |  | ||||||
| ## Concepts | ## Concepts | ||||||
| ### Syntax | ### Syntax | ||||||
| The configuration file is [YAML](http://yaml.org/) based, allowing two types of syntax. | The configuration file is [YAML](http://yaml.org/) based: | ||||||
|  |  | ||||||
| Properties-like: |  | ||||||
| ```yaml |  | ||||||
| my.config.item: 'value' |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Object-like: |  | ||||||
| ```yaml | ```yaml | ||||||
| my: | my: | ||||||
|   config: |   config: | ||||||
|     item: 'value' |     item: 'value' | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| These can also be combined within the same file.   |  | ||||||
| Both syntax will be used interchangeably in these documents. |  | ||||||
|  |  | ||||||
| ### Variables |  | ||||||
| It is possible to copy the value of a configuration item into another using the syntax `${config.key.item}`.   |  | ||||||
| Example that will copy the value of `matrix.domain` into `server.name`: |  | ||||||
| ```yaml |  | ||||||
| matrix: |  | ||||||
|   domain: 'example.org' |  | ||||||
|  |  | ||||||
| server: |  | ||||||
|   name: '${matrix.domain}' |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| **WARNING:** mxisd might overwrite/adapt some values during launch. Those changes will not be reflected into copied keys. |  | ||||||
|  |  | ||||||
|  | When referencing keys in all documents, a property-like shorthand will be used. The shorthand for the above example would be `my.config.item` | ||||||
|  |  | ||||||
| ## Matrix | ## Matrix | ||||||
| `matrix.domain` | `matrix.domain` | ||||||
| @@ -53,7 +31,9 @@ Namespace to create arbitrary list of Identity servers, usable in other parts of | |||||||
|  |  | ||||||
| Example: | Example: | ||||||
| ```yaml | ```yaml | ||||||
| matrix.identity.servers: | matrix: | ||||||
|  |   identity: | ||||||
|  |     servers: | ||||||
|       myOtherServers: |       myOtherServers: | ||||||
|         - 'https://other1.example.org' |         - 'https://other1.example.org' | ||||||
|         - 'https://other2.example.org' |         - 'https://other2.example.org' | ||||||
| @@ -82,19 +62,23 @@ See the dedicated documents: | |||||||
|  |  | ||||||
| Example: | Example: | ||||||
| ```yaml | ```yaml | ||||||
| notification.handler.email: 'sendgrid' | notification: | ||||||
| notification.handler.msisdn: 'raw' |   handler: | ||||||
|  |     email: 'sendgrid' | ||||||
|  |     msisdn: 'raw' | ||||||
| ``` | ``` | ||||||
| - Emails notifications would use the `sendgrid` handler, which define its own configuration under `notification.handlers.sendgrid` | - Emails notifications would use the `sendgrid` handler, which define its own configuration under `notification.handlers.sendgrid` | ||||||
| - Phone notification would use the `raw` handler, basic default built-in handler of mxisd | - Phone notification would use the `raw` handler, basic default built-in handler in mxisd | ||||||
|  |  | ||||||
| ### Handlers | ### Handlers | ||||||
| - `notification.handers.<handler ID>`: Handler-specific configuration for the given handler ID. Repeatable. | - `notification.handers.<handler ID>`: Handler-specific configuration for the given handler ID. Repeatable. | ||||||
|  |  | ||||||
| Example: | Example: | ||||||
| ```yaml | ```yaml | ||||||
| notification.handlers.raw: ... | notification: | ||||||
| notification.handlers.sendgrid: ... |   handlers: | ||||||
|  |     raw: ... | ||||||
|  |     sendgrid: ... | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Built-in: | Built-in: | ||||||
|   | |||||||
| @@ -151,7 +151,10 @@ the internal IP of the Homeserver so it can talk to it directly to integrate its | |||||||
|  |  | ||||||
| To do so, put the following configuration in your mxisd configuration: | To do so, put the following configuration in your mxisd configuration: | ||||||
| ```yaml | ```yaml | ||||||
| dns.overwrite.homeserver.client: | dns: | ||||||
|  |   overwrite: | ||||||
|  |     homeserver: | ||||||
|  |       client: | ||||||
|         - name: 'example.org' |         - name: 'example.org' | ||||||
|           value: 'http://localhost:8008' |           value: 'http://localhost:8008' | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -5,15 +5,18 @@ to 3PID queries if no mapping was found, allowing seamless bridging to a network | |||||||
| This is performed by implementing a specific endpoint on the bridge to map a 3PID lookup to a virtual user. | This is performed by implementing a specific endpoint on the bridge to map a 3PID lookup to a virtual user. | ||||||
|  |  | ||||||
| **NOTE**: This document is incomplete and might be misleading. In doubt, come in our Matrix room.   | **NOTE**: This document is incomplete and might be misleading. In doubt, come in our Matrix room.   | ||||||
| You can also look at our [Email Bridge README](https://github.com/kamax-io/matrix-appservice-email#mxisd) for an example | You can also look at our [Email Bridge README](https://github.com/kamax-matrix/matrix-appservice-email#mxisd) for an example | ||||||
| of working configuration. | of working configuration. | ||||||
|  |  | ||||||
| ## Configuration | ## Configuration | ||||||
| ```yaml | ```yaml | ||||||
| lookup.recursive.bridge.enabled: <boolean> | lookup: | ||||||
| lookup.recursive.bridge.recursiveOnly: <boolean> |   recursive: | ||||||
| lookup.recursive.bridge.server: <URL to the bridge endpoint for all 3PID medium> |     bridge: | ||||||
| lookup.recursive.bridge.mappings: |       enabled: <boolean> | ||||||
|  |       recursiveOnly: <boolean> | ||||||
|  |       server: <URL to the bridge endpoint for all 3PID medium> | ||||||
|  |       mappings: | ||||||
|         <3PID MEDIUM HERE>: <URL to dedicated bridge for that medium> |         <3PID MEDIUM HERE>: <URL to dedicated bridge for that medium> | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -123,27 +123,31 @@ the internal IP of the Homeserver so it can talk to it directly to integrate its | |||||||
|  |  | ||||||
| To do so, use the following configuration: | To do so, use the following configuration: | ||||||
| ```yaml | ```yaml | ||||||
| dns.overwrite.homeserver.client: | dns: | ||||||
|  |   overwrite: | ||||||
|  |     homeserver: | ||||||
|  |       client: | ||||||
|         - name: 'example.org' |         - name: 'example.org' | ||||||
|           value: 'http://localhost:8008' |           value: 'http://localhost:8008' | ||||||
| ``` | ``` | ||||||
| `name` must be the hostname of the URL that clients use when connecting to the Homeserver.   | - `name` must be the hostname of the URL that clients use when connecting to the Homeserver. | ||||||
| In case the hostname is the same as your Matrix domain, you can use `${matrix.domain}` to auto-populate the value using | - `value` is the base internal URL of the Homeserver, without any `/_matrix/..` or trailing `/`. | ||||||
| the `matrix.domain` configuration option and avoid duplicating it. |  | ||||||
|  |  | ||||||
| `value` is the base internal URL of the Homeserver, without any `/_matrix/..` or trailing `/`. |  | ||||||
|  |  | ||||||
| ## Next steps | ## Next steps | ||||||
| ### Homeserver results | ### Homeserver results | ||||||
| You can configure if the Homeserver should be queried at all when doing a directory search.   | You can configure if the Homeserver should be queried at all when doing a directory search.   | ||||||
| To disable Homeserver results, set the following in mxisd configuration file: | To disable Homeserver results, set the following in mxisd configuration file: | ||||||
| ```yaml | ```yaml | ||||||
| directory.exclude.homeserver: true | directory: | ||||||
|  |   exclude: | ||||||
|  |     homeserver: true | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### 3PID exclusion in search | ### 3PID exclusion in search | ||||||
| You can configure if the 3PID should also be included when doing a directory search. | You can configure if the 3PID should also be included when doing a directory search. | ||||||
| By default, a search is performed on the 3PIDs. If you would like to not include them: | By default, a search is performed on the 3PIDs. If you would like to not include them: | ||||||
| ```yaml | ```yaml | ||||||
| directory.exclude.threepid: true | directory: | ||||||
|  |   exclude: | ||||||
|  |     threepid: true | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -40,10 +40,21 @@ The port must be HTTPS capable which is what you get in a regular setup with a r | |||||||
| If you would like to disable outbound federation and isolate your identity server from the rest of the Matrix network, | If you would like to disable outbound federation and isolate your identity server from the rest of the Matrix network, | ||||||
| use the following mxisd configuration options: | use the following mxisd configuration options: | ||||||
| ```yaml | ```yaml | ||||||
| lookup.recursive.enabled: false | lookup: | ||||||
| invite.resolution.recursive: false |   recursive: | ||||||
| session.policy.validation.forLocal.toRemote.enabled: false |     enabled: false | ||||||
| session.policy.validation.forRemote.toRemote.enabled: false | invite: | ||||||
|  |   resolution: | ||||||
|  |     recursive: false | ||||||
|  | session: | ||||||
|  |   policy: | ||||||
|  |     validation: | ||||||
|  |       forLocal: | ||||||
|  |         toRemote: | ||||||
|  |           enabled: false | ||||||
|  |       forRemote: | ||||||
|  |         toRemote: | ||||||
|  |           enabled: false | ||||||
| ```  | ```  | ||||||
|  |  | ||||||
| There is currently no way to selectively disable federation towards specific servers, but this feature is planned. | There is currently no way to selectively disable federation towards specific servers, but this feature is planned. | ||||||
|   | |||||||
| @@ -7,7 +7,8 @@ Implementation of the [Unofficial Matrix Identity Service API](https://kamax.io/ | |||||||
| If you would like to use the central matrix.org Identity server to ensure maximum discovery at the cost of potentially | If you would like to use the central matrix.org Identity server to ensure maximum discovery at the cost of potentially | ||||||
| leaking all your contacts information, add the following to your configuration: | leaking all your contacts information, add the following to your configuration: | ||||||
| ```yaml | ```yaml | ||||||
| forward.servers: | forward: | ||||||
|  |   servers: | ||||||
|     - 'matrix-org' |     - 'matrix-org' | ||||||
| ``` | ``` | ||||||
| **NOTE:** You should carefully consider enabling this option, which is discouraged.   | **NOTE:** You should carefully consider enabling this option, which is discouraged.   | ||||||
|   | |||||||
| @@ -38,13 +38,20 @@ Install via: | |||||||
| See the [Latest release](https://github.com/kamax-matrix/mxisd/releases/latest) for links to each. | See the [Latest release](https://github.com/kamax-matrix/mxisd/releases/latest) for links to each. | ||||||
|  |  | ||||||
| ## Configure | ## Configure | ||||||
| **NOTE**: please view the install instruction for your platform, as this step might be optional or already handled for you. | > **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](configure.md) | ||||||
|  |  | ||||||
| Create/edit a minimal configuration (see installer doc for the location): | Create/edit a minimal configuration (see installer doc for the location): | ||||||
| ```yaml | ```yaml | ||||||
| matrix.domain: 'example.org' | matrix: | ||||||
| key.path: '/path/to/signing.key.file' |   domain: 'example.org' | ||||||
| storage.provider.sqlite.database: '/path/to/mxisd.db' | key: | ||||||
|  |   path: '/path/to/signing.key.file' | ||||||
|  | storage: | ||||||
|  |   provider: | ||||||
|  |     sqlite: | ||||||
|  |       database: '/path/to/mxisd.db' | ||||||
| ```   | ```   | ||||||
| - `matrix.domain` should be set to your Homeserver domain (`server_name` in synapse configuration) | - `matrix.domain` should be set to your Homeserver domain (`server_name` in synapse configuration) | ||||||
| - `key.path` will store the signing keys, which must be kept safe! If the file does not exist, keys will be generated for you. | - `key.path` will store the signing keys, which must be kept safe! If the file does not exist, keys will be generated for you. | ||||||
|   | |||||||
| @@ -2,37 +2,43 @@ | |||||||
| ## Instructions | ## Instructions | ||||||
| Follow the [build instructions](../build.md) then: | Follow the [build instructions](../build.md) then: | ||||||
|  |  | ||||||
| 1. Prepare files and directories: | ### Prepare files and directories: | ||||||
| ```bash | ```bash | ||||||
| # Create a dedicated user | # Create a dedicated user | ||||||
| useradd -r mxisd | useradd -r mxisd | ||||||
|  |  | ||||||
| # Create bin directory |  | ||||||
| mkdir /opt/mxisd |  | ||||||
|  |  | ||||||
| # Create config directory and set ownership | # Create config directory and set ownership | ||||||
| mkdir -p /etc/opt/mxisd | mkdir -p /etc/mxisd | ||||||
| chown -R mxisd /etc/opt/mxisd |  | ||||||
|  |  | ||||||
| # Create data directory and set ownership | # Create data directory and set ownership | ||||||
| mkdir -p /var/opt/mxisd | mkdir -p /var/lib/mxisd | ||||||
| chown -R mxisd /var/opt/mxisd | chown -R mxisd /var/lib/mxisd | ||||||
|  |  | ||||||
| # Copy <repo root>/build/libs/mxisd.jar to bin directory | # Create bin directory, copy the jar and launch scriot to bin directory | ||||||
| cp ./build/libs/mxisd.jar /opt/mxisd/ | mkdir /usr/lib/mxisd | ||||||
| chown mxisd /opt/mxisd/mxisd.jar | cp ./build/libs/mxisd.jar /usr/lib/mxisd/ | ||||||
| chmod a+x /opt/mxisd/mxisd.jar | cp ./src/script/mxisd /usr/lib/mxisd | ||||||
|  | chown -R mxisd /usr/lib/mxisd | ||||||
|  | chmod a+x /usr/lib/mxisd/mxisd | ||||||
|  |  | ||||||
| # Create symlink for easy exec | # Create symlink for easy exec | ||||||
| ln -s /opt/mxisd/mxisd.jar /usr/bin/mxisd | ln -s /usr/lib/mxisd/mxisd /usr/bin/mxisd | ||||||
| ``` | ``` | ||||||
| 2. Copy the sample config file `./application.example.yaml` to `/etc/opt/mxisd/mxisd.yaml`, edit to your needs |  | ||||||
| 3. Copy `src/systemd/mxisd.service` to `/etc/systemd/system/` and edit if needed | ### Prepare config file | ||||||
| 4. Enable service for auto-startup | Copy the sample config file `./mxisd.example.yaml` to `/etc/mxisd/mxisd.yaml`, edit to your needs | ||||||
|  |  | ||||||
|  | ### Prepare Systemd | ||||||
|  | 1. Copy `src/systemd/mxisd.service` to `/etc/systemd/system/` and edit if needed | ||||||
|  | 2. Enable service for auto-startup | ||||||
| ```bash | ```bash | ||||||
| systemctl enable mxisd | systemctl enable mxisd | ||||||
| ``` | ``` | ||||||
| 5. Start mxisd |  | ||||||
|  | ### Run | ||||||
| ```bash | ```bash | ||||||
| systemctl start mxisd | systemctl start mxisd | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ## Debug | ||||||
|  | mxisd logs to stdout, which is normally sent to `/var/log/syslog` or `/var/log/messages`. | ||||||
|   | |||||||
| @@ -68,7 +68,8 @@ We will use the term `Executable` for each lookup/action and `Processor` for eac | |||||||
|  |  | ||||||
| ### Global | ### Global | ||||||
| ```yaml | ```yaml | ||||||
| exec.enabled: <boolean> | exec: | ||||||
|  |   enabled: <boolean> | ||||||
| ``` | ``` | ||||||
| Enable/disable the Identity store at a global/default level. Each feature can still be individually enabled/disabled. | Enable/disable the Identity store at a global/default level. Each feature can still be individually enabled/disabled. | ||||||
|  |  | ||||||
| @@ -79,7 +80,9 @@ Not all features use all tokens, and each feature might also have its own specif | |||||||
| They can be set within the following scope: | They can be set within the following scope: | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| exec.token.<token>: '<value>' | exec: | ||||||
|  |   token: | ||||||
|  |     <token>: '<value>' | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| --- | --- | ||||||
| @@ -184,12 +187,15 @@ The following types are available: | |||||||
| ### Examples | ### Examples | ||||||
| #### Basic | #### Basic | ||||||
| ```yaml | ```yaml | ||||||
| exec.auth.enabled: true | exec: | ||||||
| exec.auth.command: '/opt/mxisd-exec/auth.sh' |   auth: | ||||||
| exec.auth.args: ['{localpart}'] |     enabled: true | ||||||
| exec.auth.input.type: 'plain' |     command: '/opt/mxisd-exec/auth.sh' | ||||||
| exec.auth.input.template: '{password}' |     args: ['{localpart}'] | ||||||
| exec.auth.env: |     input: | ||||||
|  |       type: 'plain' | ||||||
|  |       template: '{password}' | ||||||
|  |   env: | ||||||
|     DOMAIN: '{domain}' |     DOMAIN: '{domain}' | ||||||
| ``` | ``` | ||||||
| With Authentication enabled, run `/opt/mxisd-exec/auth.sh` when validating credentials, providing: | With Authentication enabled, run `/opt/mxisd-exec/auth.sh` when validating credentials, providing: | ||||||
| @@ -243,14 +249,17 @@ See each dedicated [Feature](#features) section. | |||||||
| ## Authentication | ## Authentication | ||||||
| The Authentication feature can be enabled/disabled using: | The Authentication feature can be enabled/disabled using: | ||||||
| ```yaml | ```yaml | ||||||
| exec.auth.enabled: <true/false> | exec: | ||||||
|  |   auth: | ||||||
|  |     enabled: <true/false> | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| This feature provides a single *Executable* under the namespace: | This feature provides a single *Executable* under the namespace: | ||||||
| ```yaml | ```yaml | ||||||
| exec.auth: | exec: | ||||||
|  |   auth: | ||||||
|   ... |   ... | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -294,7 +303,9 @@ Default template: | |||||||
| ## Directory | ## Directory | ||||||
| The Directory feature can be enabled/disabled using: | The Directory feature can be enabled/disabled using: | ||||||
| ```yaml | ```yaml | ||||||
| exec.directory.enabled: <true/false> | exec: | ||||||
|  |   directory: | ||||||
|  |     enabled: <true/false> | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| --- | --- | ||||||
| @@ -303,12 +314,18 @@ Two search types configuration namespace are available, using the same input/out | |||||||
|  |  | ||||||
| By name: | By name: | ||||||
| ```yaml | ```yaml | ||||||
| exec.directory.search.byName: | exec: | ||||||
|  |   directory: | ||||||
|  |     search: | ||||||
|  |       byName: | ||||||
|         ... |         ... | ||||||
| ``` | ``` | ||||||
| By 3PID: | By 3PID: | ||||||
| ```yaml | ```yaml | ||||||
| exec.directory.search.byThreepid: | exec: | ||||||
|  |   directory: | ||||||
|  |     search: | ||||||
|  |       byThreepid: | ||||||
|         ... |         ... | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -386,7 +403,10 @@ The User ID type will default to `localpart` if: | |||||||
| ### Bulk lookup | ### Bulk lookup | ||||||
| Configuration namespace: | Configuration namespace: | ||||||
| ```yaml | ```yaml | ||||||
| exec.identity.lookup.bulk: | exec: | ||||||
|  |   identity: | ||||||
|  |     lookup: | ||||||
|  |       bulk: | ||||||
|         ... |         ... | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -418,7 +438,9 @@ Same as the [REST Identity Store](rest.md). | |||||||
| ## Profile | ## Profile | ||||||
| The Profile feature can be enabled/disabled using: | The Profile feature can be enabled/disabled using: | ||||||
| ```yaml | ```yaml | ||||||
| exec.profile.enabled: <true/false> | exec: | ||||||
|  |   profile: | ||||||
|  |     enabled: <true/false> | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| --- | --- | ||||||
| @@ -427,19 +449,25 @@ The following *Executable*s namespace are available, share the same input/output | |||||||
|  |  | ||||||
| Get Display name: | Get Display name: | ||||||
| ```yaml | ```yaml | ||||||
| exec.profile.displayName: | exec: | ||||||
|  |   profile: | ||||||
|  |     displayName: | ||||||
|       ... |       ... | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Get 3PIDs: | Get 3PIDs: | ||||||
| ```yaml | ```yaml | ||||||
| exec.profile.threePid: | exec: | ||||||
|  |   profile: | ||||||
|  |     threePid: | ||||||
|       ... |       ... | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Get Roles: | Get Roles: | ||||||
| ```yaml | ```yaml | ||||||
| exec.profile.role: | exec: | ||||||
|  |   profile: | ||||||
|  |     role: | ||||||
|       ... |       ... | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,35 +19,41 @@ If your client is Riot, you will need a custom version. | |||||||
|  |  | ||||||
| ## Configuration | ## Configuration | ||||||
| ```yaml | ```yaml | ||||||
| firebase.enabled: <boolean> | firebase: | ||||||
|  |   enabled: <boolean> | ||||||
| ``` | ``` | ||||||
| Enable/disable this identity store. | Enable/disable this identity store. | ||||||
|  |  | ||||||
| Example: | Example: | ||||||
| ```yaml | ```yaml | ||||||
| firebase.enabled: <boolean> | firebase: | ||||||
|  |   enabled: <boolean> | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| firebase.credentials: <string> | firebase: | ||||||
|  |   credentials: <string> | ||||||
| ``` | ``` | ||||||
| Path to the credentials file provided by Google Firebase to use with an external app. | Path to the credentials file provided by Google Firebase to use with an external app. | ||||||
|  |  | ||||||
| Example: | Example: | ||||||
| ```yaml | ```yaml | ||||||
| firebase.credentials: '/path/to/firebase/credentials.json' | firebase: | ||||||
|  |   credentials: '/path/to/firebase/credentials.json' | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| firebase.database: <string> | firebase: | ||||||
|  |   database: <string> | ||||||
| ``` | ``` | ||||||
| URL to your Firebase database. | URL to your Firebase database. | ||||||
|  |  | ||||||
| Example: | Example: | ||||||
| ```yaml | ```yaml | ||||||
| firebase.database: 'https://my-project.firebaseio.com/' | firebase: | ||||||
|  |   database: 'https://my-project.firebaseio.com/' | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -19,12 +19,14 @@ For NetIQ, replace all the `ldap` prefix in the configuration by `netiq`. | |||||||
| ### Base | ### Base | ||||||
| To use your LDAP backend, add the bare minimum configuration in mxisd config file: | To use your LDAP backend, add the bare minimum configuration in mxisd config file: | ||||||
| ```yaml | ```yaml | ||||||
| ldap.enabled: true | ldap: | ||||||
| ldap.connection.host: 'ldapHostnameOrIp' |   enabled: true | ||||||
| ldap.connection.port: 389 |   connection: | ||||||
| ldap.connection.bindDn: 'CN=My Mxisd User,OU=Users,DC=example,DC=org' |     host: 'ldapHostnameOrIp' | ||||||
| ldap.connection.bindPassword: 'TheUserPassword' |     port: 389 | ||||||
| ldap.connection.baseDNs: |     bindDn: 'CN=My Mxisd User,OU=Users,DC=example,DC=org' | ||||||
|  |     bindPassword: 'TheUserPassword' | ||||||
|  |     baseDNs: | ||||||
|       - 'OU=Users,DC=example,DC=org' |       - 'OU=Users,DC=example,DC=org' | ||||||
| ``` | ``` | ||||||
| These are standard LDAP connection configuration. mxisd will try to connect on port default port 389 without encryption. | These are standard LDAP connection configuration. mxisd will try to connect on port default port 389 without encryption. | ||||||
| @@ -34,14 +36,17 @@ If you would like to use several Base DNs, simply add more entries under `baseDN | |||||||
| ### TLS/SSL connection | ### TLS/SSL connection | ||||||
| If you would like to use a TLS/SSL connection, use the following configuration options (STARTLS not supported): | If you would like to use a TLS/SSL connection, use the following configuration options (STARTLS not supported): | ||||||
| ```yaml | ```yaml | ||||||
| ldap.connection.tls: true | ldap: | ||||||
| ldap.connection.port: 12345 |   connection: | ||||||
|  |     tls: true | ||||||
|  |     port: 12345 | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### Filter results | ### Filter results | ||||||
| You can also set a default global filter on any LDAP queries: | You can also set a default global filter on any LDAP queries: | ||||||
| ```yaml | ```yaml | ||||||
| ldap.filter: '(memberOf=CN=My Matrix Users,OU=Groups,DC=example,DC=org)' | ldap: | ||||||
|  |   filter: '(memberOf=CN=My Matrix Users,OU=Groups,DC=example,DC=org)' | ||||||
| ``` | ``` | ||||||
| This example would only return users part of the group called `My Matrix Users`. | This example would only return users part of the group called `My Matrix Users`. | ||||||
| This can be overwritten or append in each specific flow describe below. | This can be overwritten or append in each specific flow describe below. | ||||||
| @@ -64,8 +69,11 @@ most certainly configure those mappings. | |||||||
|  |  | ||||||
| The following example would set the `sAMAccountName` attribute as a Matrix User ID localpart: | The following example would set the `sAMAccountName` attribute as a Matrix User ID localpart: | ||||||
| ```yaml | ```yaml | ||||||
| ldap.attribute.uid.type: 'uid' | ldap: | ||||||
| ldap.attribute.uid.value: 'sAMAccountName' |   attribute: | ||||||
|  |     uid: | ||||||
|  |       type: 'uid' | ||||||
|  |       value: 'sAMAccountName' | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| #### Display name | #### Display name | ||||||
| @@ -73,7 +81,9 @@ Use `ldap.attribute.name`. | |||||||
|  |  | ||||||
| The following example would set the display name to the value of the `cn` attribute: | The following example would set the display name to the value of the `cn` attribute: | ||||||
| ```yaml | ```yaml | ||||||
| ldap.attribute.name: 'cn' | ldap: | ||||||
|  |   attribute: | ||||||
|  |     name: 'cn' | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| #### 3PIDs | #### 3PIDs | ||||||
| @@ -82,11 +92,13 @@ You can also change the attribute lists for 3PID, like email or phone numbers. | |||||||
| The following example would overwrite the [default list of attributes](../../src/main/resources/application.yaml#L67) | The following example would overwrite the [default list of attributes](../../src/main/resources/application.yaml#L67) | ||||||
| for emails and phone number: | for emails and phone number: | ||||||
| ```yaml | ```yaml | ||||||
| ldap.attribute.threepid.email: | ldap: | ||||||
|  |   attribute: | ||||||
|  |     threepid: | ||||||
|  |       email: | ||||||
|         - 'mail' |         - 'mail' | ||||||
|         - 'otherMailAttribute' |         - 'otherMailAttribute' | ||||||
|  |       msisdn: | ||||||
| ldap.attribute.threepid.msisdn: |  | ||||||
|         - 'phone' |         - 'phone' | ||||||
|         - 'otherPhoneAttribute' |         - 'otherPhoneAttribute' | ||||||
| ``` | ``` | ||||||
| @@ -117,7 +129,10 @@ To set a specific filter applied during directory search, use `ldap.directory.fi | |||||||
|  |  | ||||||
| If you would like to use extra attributes in search that are not 3PIDs, like nicknames, group names, employee number: | If you would like to use extra attributes in search that are not 3PIDs, like nicknames, group names, employee number: | ||||||
| ```yaml | ```yaml | ||||||
| ldap.directory.attribute.other: | ldap: | ||||||
|  |   directory: | ||||||
|  |     attribute: | ||||||
|  |       other: | ||||||
|         - 'myNicknameAttribute' |         - 'myNicknameAttribute' | ||||||
|         - 'memberOf' |         - 'memberOf' | ||||||
|         - 'employeeNumberAttribute' |         - 'employeeNumberAttribute' | ||||||
|   | |||||||
| @@ -15,19 +15,21 @@ | |||||||
|  |  | ||||||
| Due to the implementation complexity of supporting arbitrary hashing/encoding mechanisms or auth flow, Authentication | Due to the implementation complexity of supporting arbitrary hashing/encoding mechanisms or auth flow, Authentication | ||||||
| will be out of scope of SQL Identity stores and should be done via one of the other identity stores, typically | will be out of scope of SQL Identity stores and should be done via one of the other identity stores, typically | ||||||
| the [REST Identity store](rest.md). | the [Exec Identity Store](exec.md) or the [REST Identity Store](rest.md). | ||||||
|  |  | ||||||
| ## Configuration | ## Configuration | ||||||
| ### Basic | ### Basic | ||||||
| ```yaml | ```yaml | ||||||
| sql.enabled: <boolean> | sql: | ||||||
|  |   enabled: <boolean> | ||||||
| ``` | ``` | ||||||
| Enable/disable the identity store | Enable/disable the identity store | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| sql.type: <string> | sql: | ||||||
|  |   type: <string> | ||||||
| ``` | ``` | ||||||
| Set the SQL backend to use: | Set the SQL backend to use: | ||||||
| - `sqlite` | - `sqlite` | ||||||
| @@ -38,14 +40,16 @@ Set the SQL backend to use: | |||||||
| ### Connection | ### Connection | ||||||
| #### SQLite | #### SQLite | ||||||
| ```yaml | ```yaml | ||||||
| sql.connection: <string> | sql: | ||||||
|  |   connection: <string> | ||||||
| ``` | ``` | ||||||
| Set the value to the absolute path to the Synapse SQLite DB file. | Set the value to the absolute path to the Synapse SQLite DB file. | ||||||
| Example: `/path/to/sqlite/file.db` | Example: `/path/to/sqlite/file.db` | ||||||
|  |  | ||||||
| #### Others | #### Others | ||||||
| ```yaml | ```yaml | ||||||
| sql.connection: //<HOST[:PORT]/DB?user=USER&password=PASS | sql: | ||||||
|  |   connection: //<HOST[:PORT]/DB?user=USER&password=PASS | ||||||
| ``` | ``` | ||||||
| Set the connection info for the database by replacing the following values: | Set the connection info for the database by replacing the following values: | ||||||
| - `HOST`: Hostname of the SQL server | - `HOST`: Hostname of the SQL server | ||||||
| @@ -58,14 +62,17 @@ This follow the JDBC URI syntax. See [official website](https://docs.oracle.com/ | |||||||
|  |  | ||||||
| ### Directory | ### Directory | ||||||
| ```yaml | ```yaml | ||||||
| sql.directory.enabled: false | sql: | ||||||
|  |   directory: | ||||||
|  |     enabled: false | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| sql.directory.query: | sql: | ||||||
|  |   directory: | ||||||
|  |     query: | ||||||
|       name: |       name: | ||||||
|         type: <string> |         type: <string> | ||||||
|         value: <string> |         value: <string> | ||||||
| @@ -83,7 +90,9 @@ For each query, `type` can be used to tell mxisd how to process the ID column: | |||||||
|  |  | ||||||
| Example: | Example: | ||||||
| ```yaml | ```yaml | ||||||
| sql.directory.query: | sql: | ||||||
|  |   directory: | ||||||
|  |     query: | ||||||
|       name: |       name: | ||||||
|         type: 'localpart' |         type: 'localpart' | ||||||
|         value: 'SELECT idColumn, displayNameColumn FROM table WHERE displayNameColumn LIKE ?' |         value: 'SELECT idColumn, displayNameColumn FROM table WHERE displayNameColumn LIKE ?' | ||||||
| @@ -94,6 +103,8 @@ sql.directory.query: | |||||||
|  |  | ||||||
| ### Identity | ### Identity | ||||||
| ```yaml | ```yaml | ||||||
| sql.identity.type: <string> | sql: | ||||||
| sql.identity.query: <string> |   identity: | ||||||
|  |     type: <string> | ||||||
|  |     query: <string> | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -14,14 +14,16 @@ Authentication is done by Synapse itself. | |||||||
| ## Configuration | ## Configuration | ||||||
| ### Basic | ### Basic | ||||||
| ```yaml | ```yaml | ||||||
| synapseSql.enabled: <boolean> | synapseSql: | ||||||
|  |   enabled: <boolean> | ||||||
| ``` | ``` | ||||||
| Enable/disable the identity store | Enable/disable the identity store | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| synapseSql.type: <string> | synapseSql: | ||||||
|  |   type: <string> | ||||||
| ``` | ``` | ||||||
| Set the SQL backend to use which is configured in synapse: | Set the SQL backend to use which is configured in synapse: | ||||||
| - `sqlite` | - `sqlite` | ||||||
| @@ -29,14 +31,16 @@ Set the SQL backend to use which is configured in synapse: | |||||||
|  |  | ||||||
| ### SQLite | ### SQLite | ||||||
| ```yaml | ```yaml | ||||||
| synapseSql.connection: <string> | synapseSql: | ||||||
|  |   connection: <string> | ||||||
| ``` | ``` | ||||||
| Set the value to the absolute path to the Synapse SQLite DB file. | Set the value to the absolute path to the Synapse SQLite DB file. | ||||||
| Example: `/path/to/synapse/sqliteFile.db` | Example: `/path/to/synapse/sqliteFile.db` | ||||||
|  |  | ||||||
| ### PostgreSQL | ### PostgreSQL | ||||||
| ```yaml | ```yaml | ||||||
| synapseSql.connection: //<HOST[:PORT]/DB?user=USER&password=PASS | synapseSql: | ||||||
|  |   connection: //<HOST[:PORT]/DB?user=USER&password=PASS | ||||||
| ``` | ``` | ||||||
| Set the connection info for the database by replacing the following values: | Set the connection info for the database by replacing the following values: | ||||||
| - `HOST`: Hostname of the SQL server | - `HOST`: Hostname of the SQL server | ||||||
|   | |||||||
| @@ -34,22 +34,29 @@ If this is not the case for your installation, the mxisd URL will need to be app | |||||||
| ### mxisd | ### mxisd | ||||||
| Enable in the configuration: | Enable in the configuration: | ||||||
| ```yaml | ```yaml | ||||||
| wordpress.enabled: true | wordpress: | ||||||
|  |   enabled: true | ||||||
| ``` | ``` | ||||||
| Configure the URL to your Wordpress installation - see above about added `/index.php`: | Configure the URL to your Wordpress installation - see above about added `/index.php`: | ||||||
| ```yaml | ```yaml | ||||||
| wordpress.rest.base: 'http://localhost:8080' | wordpress: | ||||||
|  |   rest: | ||||||
|  |     base: 'http://localhost:8080' | ||||||
| ``` | ``` | ||||||
| Configure the SQL connection to your Wordpress database: | Configure the SQL connection to your Wordpress database: | ||||||
| ```yaml | ```yaml | ||||||
| wordpress.sql.connection: '//127.0.0.1/wordpress?user=root&password=example' | wordpress: | ||||||
|  |   sql: | ||||||
|  |     connection: '//127.0.0.1/wordpress?user=root&password=example' | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| By default, MySQL database is expected. If you use another database, use: | By default, MySQL database is expected. If you use another database, use: | ||||||
| ```yaml | ```yaml | ||||||
| wordpress.sql.type: <string> | wordpress: | ||||||
|  |   sql: | ||||||
|  |     type: <string> | ||||||
| ``` | ``` | ||||||
| With possible values: | With possible values: | ||||||
| - `mysql` | - `mysql` | ||||||
| @@ -61,6 +68,8 @@ With possible values: | |||||||
|  |  | ||||||
| To configure the tables prefix for default queries, in case a custom value was set during Wordpress install: | To configure the tables prefix for default queries, in case a custom value was set during Wordpress install: | ||||||
| ```yaml | ```yaml | ||||||
| wordpress.sql.tablePrefix: <string> | wordpress: | ||||||
|  |   sql: | ||||||
|  |     tablePrefix: <string> | ||||||
| ``` | ``` | ||||||
| By default, the value is set to `wp_`. | By default, the value is set to `wp_`. | ||||||
|   | |||||||
| @@ -5,7 +5,9 @@ Connector ID: `smtp` | |||||||
|  |  | ||||||
| ## Configuration | ## Configuration | ||||||
| ```yaml | ```yaml | ||||||
| threepid.medium.email: | threepid: | ||||||
|  |   medium: | ||||||
|  |     email: | ||||||
|       identity: |       identity: | ||||||
|         from: 'identityServerEmail@example.org' |         from: 'identityServerEmail@example.org' | ||||||
|         name: 'My Identity Server' |         name: 'My Identity Server' | ||||||
|   | |||||||
| @@ -5,7 +5,12 @@ Connector ID: `twilio` | |||||||
|  |  | ||||||
| ## Configuration | ## Configuration | ||||||
| ```yaml | ```yaml | ||||||
| threepid.medium.msisdn.connectors.twilio.accountSid: 'myAccountSid' | threepid: | ||||||
| threepid.medium.msisdn.connectors.twilio.authToken: 'myAuthToken' |   medium: | ||||||
| threepid.medium.msisdn.connectors.twilio.number: '+123456789' |     msisdn: | ||||||
|  |       connectors: | ||||||
|  |         twilio: | ||||||
|  |           accountSid: 'myAccountSid' | ||||||
|  |           authToken: 'myAuthToken' | ||||||
|  |           number: '+123456789' | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -18,13 +18,16 @@ This handler can be used with the 3PID types: | |||||||
| ## Configuration | ## Configuration | ||||||
| Enabled by default or with: | Enabled by default or with: | ||||||
| ```yaml | ```yaml | ||||||
| notification.handler.email: 'raw' | notification: | ||||||
|  |   handler: | ||||||
|  |     email: 'raw' | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| **WARNING:** Will be consolidated soon, prone to breaking changes.   | **WARNING:** Will be consolidated soon, prone to breaking changes.   | ||||||
| Structure and default values: | Structure and default values: | ||||||
| ```yaml | ```yaml | ||||||
| threepid.medium: | threepid: | ||||||
|  |   medium: | ||||||
|     email: |     email: | ||||||
|       identity: |       identity: | ||||||
|         from: '' |         from: '' | ||||||
|   | |||||||
| @@ -1,7 +1,39 @@ | |||||||
| # SendGrid Notification handler | # SendGrid Notification handler | ||||||
| To be completed. See [raw possible configuration items](https://github.com/kamax-matrix/mxisd/blob/master/src/main/resources/application.yaml#L172). | > **WARNING:** This section is incomplete and may be misleading. Contact us if guidance is needed. | ||||||
|  |  | ||||||
| Enabled with: | Enable with: | ||||||
| ```yaml | ```yaml | ||||||
| notification.handler.email: 'sendgrid' | notification: | ||||||
|  |   handler: | ||||||
|  |     email: 'sendgrid' | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Available Configuration keys: | ||||||
|  | ```yaml | ||||||
|  | notification: | ||||||
|  |   handlers: | ||||||
|  |     sendgrid: | ||||||
|  |       api: | ||||||
|  |         key: <API key> | ||||||
|  |       identity: | ||||||
|  |         from: <Sender email address> | ||||||
|  |         name: <Sender name> | ||||||
|  |       templates: | ||||||
|  |         invite: | ||||||
|  |           subject: <Subject of the email notification sent for room invites> | ||||||
|  |           body: | ||||||
|  |             text: <Path to file containing the raw text part of the email. Do not set to not use one> | ||||||
|  |             html: <Path to file containing the HTML part of the email. Do not set to not use one> | ||||||
|  |         session: | ||||||
|  |           validation: | ||||||
|  |             local: | ||||||
|  |               subject: <Subject of the email notification sent for local 3PID sessions> | ||||||
|  |               body: | ||||||
|  |                 text: <Path to file containing the raw text part of the email. Do not set to not use one> | ||||||
|  |                 html: <Path to file containing the HTML part of the email. Do not set to not use one> | ||||||
|  |             remote: | ||||||
|  |               subject: <Subject of the email notification sent for remote 3PID sessions> | ||||||
|  |               body: | ||||||
|  |                 text: <Path to file containing the raw text part of the email. Do not set to not use one> | ||||||
|  |                 html: <Path to file containing the HTML part of the email. Do not set to not use one> | ||||||
| ```  | ```  | ||||||
|   | |||||||
| @@ -11,7 +11,9 @@ placeholders and also have their own individual set of placeholders. | |||||||
| ## Configuration | ## Configuration | ||||||
| To configure paths to the various templates: | To configure paths to the various templates: | ||||||
| ```yaml | ```yaml | ||||||
| threepid.medium.<YOUR 3PID MEDIUM HERE>: | threepid: | ||||||
|  |   medium: | ||||||
|  |     <YOUR 3PID MEDIUM HERE>: | ||||||
|       generators: |       generators: | ||||||
|         template: |         template: | ||||||
|           invite: '/path/to/invite-template.eml' |           invite: '/path/to/invite-template.eml' | ||||||
|   | |||||||
| @@ -1,20 +1,22 @@ | |||||||
| # Web pages for the 3PID sessions | # Web pages for the 3PID sessions | ||||||
| You can customize the various pages used during a 3PID validation using [Thymeleaf templates](http://www.thymeleaf.org/). | You can customize the various pages used during a 3PID validation using the options below. | ||||||
|  |  | ||||||
| ## Configuration | ## Configuration | ||||||
| Pseudo-configuration to illustrate the structure: | Pseudo-configuration to illustrate the structure: | ||||||
| ```yaml | ```yaml | ||||||
| # CONFIGURATION EXAMPLE | # CONFIGURATION EXAMPLE | ||||||
| # DO NOT COPY/PASTE THIS IN YOUR CONFIGURATION | # DO NOT COPY/PASTE THIS IN YOUR CONFIGURATION | ||||||
| view.session.local: | view: | ||||||
|  |   session: | ||||||
|  |     local: | ||||||
|       onTokenSubmit: |       onTokenSubmit: | ||||||
|         success: '/path/to/session/local/tokenSubmitSuccess-page.html' |         success: '/path/to/session/local/tokenSubmitSuccess-page.html' | ||||||
|         failure: '/path/to/session/local/tokenSubmitFailure-page.html' |         failure: '/path/to/session/local/tokenSubmitFailure-page.html' | ||||||
| view.session.localRemote: |     localRemote: | ||||||
|       onTokenSubmit: |       onTokenSubmit: | ||||||
|         success: '/path/to/session/localRemote/tokenSubmitSuccess-page.html' |         success: '/path/to/session/localRemote/tokenSubmitSuccess-page.html' | ||||||
|         failure: '/path/to/session/local/tokenSubmitFailure-page.html' |         failure: '/path/to/session/local/tokenSubmitFailure-page.html' | ||||||
| view.session.remote: |     remote: | ||||||
|       onRequest: |       onRequest: | ||||||
|         success: '/path/to/session/remote/requestSuccess-page.html' |         success: '/path/to/session/remote/requestSuccess-page.html' | ||||||
|         failure: '/path/to/session/remote/requestFailure-page.html' |         failure: '/path/to/session/remote/requestFailure-page.html' | ||||||
| @@ -55,7 +57,7 @@ client if they do not wish to proceed any further. | |||||||
|  |  | ||||||
| #### Placeholders | #### Placeholders | ||||||
| ##### Success | ##### Success | ||||||
| `<a th:href="${remoteSessionLink}">text</a>` can be used to display the link to start a Remote 3PID session. | `<a href="${remoteSessionLink}">text</a>` can be used to display the link to start a Remote 3PID session. | ||||||
|  |  | ||||||
| ##### Failure | ##### Failure | ||||||
| No object/placeholder are currently available. | No object/placeholder are currently available. | ||||||
| @@ -70,7 +72,7 @@ the remote Identity server and, once that is done, click a link to validate the | |||||||
|  |  | ||||||
| #### Placeholders | #### Placeholders | ||||||
| ##### Success | ##### Success | ||||||
| `<a th:href="${checkLink}">text</a>` can be used to display the link to validate the Remote 3PID session. | `<a href="${checkLink}">text</a>` can be used to display the link to validate the Remote 3PID session. | ||||||
|  |  | ||||||
| ##### Failure | ##### Failure | ||||||
| No object/placeholder are currently available. | No object/placeholder are currently available. | ||||||
|   | |||||||
| @@ -133,14 +133,17 @@ file unless you want to specifically overwrite them. | |||||||
| ```yaml | ```yaml | ||||||
| # CONFIGURATION EXAMPLE | # CONFIGURATION EXAMPLE | ||||||
| # DO NOT COPY/PASTE THIS IN YOUR CONFIGURATION | # DO NOT COPY/PASTE THIS IN YOUR CONFIGURATION | ||||||
| session.policy.validation.enabled: true | session: | ||||||
| session.policy.validation.forLocal: |   policy: | ||||||
|  |     validation: | ||||||
|  |       enabled: true | ||||||
|  |       forLocal: | ||||||
|         enabled: true |         enabled: true | ||||||
|         toLocal: true |         toLocal: true | ||||||
|         toRemote: |         toRemote: | ||||||
|           enabled: true |           enabled: true | ||||||
|           server: 'configExample'  # Not to be included in config! Already present in default config! |           server: 'configExample'  # Not to be included in config! Already present in default config! | ||||||
| session.policy.validation.forRemote: |       forRemote: | ||||||
|         enabled: true |         enabled: true | ||||||
|         toLocal: true |         toLocal: true | ||||||
|         toRemote: |         toRemote: | ||||||
| @@ -219,13 +222,16 @@ On the flip side, people with *Remote* 3PID scopes will not be found from other | |||||||
|  |  | ||||||
| Use the following values: | Use the following values: | ||||||
| ```yaml | ```yaml | ||||||
| session.policy.validation.enabled: true | session: | ||||||
| session.policy.validation.forLocal: |   policy: | ||||||
|  |     validation: | ||||||
|  |       enabled: true | ||||||
|  |       forLocal: | ||||||
|         enabled: true |         enabled: true | ||||||
|         toLocal: true |         toLocal: true | ||||||
|         toRemote: |         toRemote: | ||||||
|           enabled: false |           enabled: false | ||||||
| session.policy.validation.forRemote: |       forRemote: | ||||||
|         enabled: true |         enabled: true | ||||||
|         toLocal: true |         toLocal: true | ||||||
|         toRemote: |         toRemote: | ||||||
| @@ -245,13 +251,16 @@ Typical use cases: | |||||||
|  |  | ||||||
| Use the following values: | Use the following values: | ||||||
| ```yaml | ```yaml | ||||||
| session.policy.validation.enabled: true | session: | ||||||
| session.policy.validation.forLocal: |   policy: | ||||||
|  |     validation: | ||||||
|  |       enabled: true | ||||||
|  |       forLocal: | ||||||
|         enabled: true |         enabled: true | ||||||
|         toLocal: false |         toLocal: false | ||||||
|         toRemote: |         toRemote: | ||||||
|           enabled: true |           enabled: true | ||||||
| session.policy.validation.forRemote: |       forRemote: | ||||||
|         enabled: true |         enabled: true | ||||||
|         toLocal: false |         toLocal: false | ||||||
|         toRemote: |         toRemote: | ||||||
| @@ -272,5 +281,8 @@ It is therefore recommended to not fully disable sessions but instead restrict s | |||||||
|  |  | ||||||
| Use the following values to enable this mode: | Use the following values to enable this mode: | ||||||
| ```yaml | ```yaml | ||||||
| session.policy.validation.enabled: false | session: | ||||||
|  |   policy: | ||||||
|  |     validation: | ||||||
|  |       enabled: false | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -1,50 +1,46 @@ | |||||||
| # Sample configuration file explaining the minimum required keys to be set to run mxisd | # Sample configuration file explaining the minimum required keys to be set to run mxisd | ||||||
| # | # | ||||||
| # For a complete list of options, see https://github.com/kamax-matrix/mxisd | # For a complete list of options, see https://github.com/kamax-matrix/mxisd/docs/README.md | ||||||
| 
 | 
 | ||||||
| ####################### | ####################### | ||||||
| # Matrix config items # | # Matrix config items # | ||||||
| ####################### | ####################### | ||||||
| # Matrix domain, same as the domain configure in your Homeserver configuration. | # Matrix domain, same as the domain configure in your Homeserver configuration. | ||||||
| # (note: in Synapse Homeserver, the Matrix domain may be defined as 'server_name' in configuration file). | # NOTE: in Synapse Homeserver, the Matrix domain is defined as 'server_name' in configuration file. | ||||||
| # | # | ||||||
| # This is used to build the various identifiers for identity, auth and directory. | # This is used to build the various identifiers in all the features. | ||||||
| matrix.domain: '' | matrix: | ||||||
|  |   domain: '' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ################ | ################ | ||||||
| # Signing keys # | # Signing keys # | ||||||
| ################ | ################ | ||||||
| # Absolute path for the Identity Server signing key. | # Absolute path for the Identity Server signing key. | ||||||
| # During testing, /var/tmp/mxisd.key is a possible value | # This is **NOT** your homeserver key. | ||||||
|  | # The signing key is auto-generated during execution time if not present. | ||||||
| # | # | ||||||
|  | # During testing, /var/tmp/mxisd.key is a possible value | ||||||
| # For production, recommended location shall be one of the following: | # For production, recommended location shall be one of the following: | ||||||
| #   - /var/opt/mxisd/sign.key | #   - /var/opt/mxisd/sign.key | ||||||
| #   - /var/local/mxisd/sign.key | #   - /var/local/mxisd/sign.key | ||||||
| #   - /var/lib/mxisd/sign.key | #   - /var/lib/mxisd/sign.key | ||||||
| # | # | ||||||
| # The signing key is auto-generated during execution time if not present. | key: | ||||||
| key.path: '' |   path: '' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ############################ | # Path to the SQLite DB file for mxisd internal storage | ||||||
| # Persistence config items # |  | ||||||
| ############################ |  | ||||||
| 
 |  | ||||||
| # Configure the storage backend, usually a DB |  | ||||||
| # Possible built-in values: |  | ||||||
| #   sqlite                      SQLite backend, default |  | ||||||
| # |  | ||||||
| #storage.backend: 'sqlite' |  | ||||||
| 
 |  | ||||||
| # Path to the SQLite DB file |  | ||||||
| # | # | ||||||
| # Examples: | # Examples: | ||||||
| #  - /var/opt/mxisd/mxisd.db | #  - /var/opt/mxisd/mxisd.db | ||||||
| #  - /var/local/mxisd/mxisd.db | #  - /var/local/mxisd/mxisd.db | ||||||
| #  - /var/lib/mxisd/mxisd.db | #  - /var/lib/mxisd/mxisd.db | ||||||
| # | # | ||||||
| storage.provider.sqlite.database: '/path/to/mxisd.db' | storage: | ||||||
|  |   provider: | ||||||
|  |     sqlite: | ||||||
|  |       database: '/path/to/mxisd.db' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| #################### | #################### | ||||||
| @@ -52,12 +48,13 @@ storage.provider.sqlite.database: '/path/to/mxisd.db' | |||||||
| #################### | #################### | ||||||
| # | # | ||||||
| # Root/Central servers to be used as final fallback when performing lookups. | # Root/Central servers to be used as final fallback when performing lookups. | ||||||
| # By default, for privacy reasons, matrix.org servers are not enabled anymore. | # By default, for privacy reasons, matrix.org servers are not enabled. | ||||||
| # See the following issue: https://github.com/kamax-matrix/mxisd/issues/76 | # See the following issue: https://github.com/kamax-matrix/mxisd/issues/76 | ||||||
| # | # | ||||||
| # If you would like to use them and trade away your privacy for convenience, uncomment the following option: | # If you would like to use them and trade away your privacy for convenience, uncomment the following option: | ||||||
| # | # | ||||||
| #forward.servers: ['matrix-org'] | #forward: | ||||||
|  | #  servers: ['matrix-org'] | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ################ | ################ | ||||||
| @@ -88,12 +85,20 @@ storage.provider.sqlite.database: '/path/to/mxisd.db' | |||||||
| # see https://github.com/kamax-matrix/mxisd/blob/master/docs/threepids/notification/template-generator.md | # see https://github.com/kamax-matrix/mxisd/blob/master/docs/threepids/notification/template-generator.md | ||||||
| # | # | ||||||
| #### E-mail invite sender | #### E-mail invite sender | ||||||
| # | threepid: | ||||||
|  |   medium: | ||||||
|  |     email: | ||||||
|  |       identity: | ||||||
|  |         # The e-mail to send as. | ||||||
|  |         from: "matrix-identity@example.org" | ||||||
|  | 
 | ||||||
|  |       connectors: | ||||||
|  |         smtp: | ||||||
|           # SMTP host |           # SMTP host | ||||||
| threepid.medium.email.connectors.smtp.host: "smtp.example.org" |           host: "smtp.example.org" | ||||||
| 
 | 
 | ||||||
|           # SMTP port |           # SMTP port | ||||||
| threepid.medium.email.connectors.smtp.port: 587 |           port: 587 | ||||||
| 
 | 
 | ||||||
|           # TLS mode for the connection. |           # TLS mode for the connection. | ||||||
|           # |           # | ||||||
| @@ -102,13 +107,10 @@ threepid.medium.email.connectors.smtp.port: 587 | |||||||
|           #  1    Enable TLS if supported by server (default) |           #  1    Enable TLS if supported by server (default) | ||||||
|           #  2    Force TLS and fail if not available |           #  2    Force TLS and fail if not available | ||||||
|           # |           # | ||||||
| #threepid.medium.email.connectors.smtp.tls: 1 |           tls: 1 | ||||||
| 
 | 
 | ||||||
|           # Login for SMTP |           # Login for SMTP | ||||||
| threepid.medium.email.connectors.smtp.login: "matrix-identity@example.org" |           login: "matrix-identity@example.org" | ||||||
| 
 | 
 | ||||||
|           # Password for the account |           # Password for the account | ||||||
| threepid.medium.email.connectors.smtp.password: "ThePassword" |           password: "ThePassword" | ||||||
| 
 |  | ||||||
| # The e-mail to send as. |  | ||||||
| threepid.medium.email.identity.from: "matrix-identity@example.org" |  | ||||||
| @@ -6,8 +6,8 @@ useradd -r mxisd || true | |||||||
| # Set permissions for data directory | # Set permissions for data directory | ||||||
| chown -R mxisd:mxisd %DEB_DATA_DIR% | chown -R mxisd:mxisd %DEB_DATA_DIR% | ||||||
|  |  | ||||||
| # Create symlink to mxusd | # Create symlink to mxisd run script | ||||||
| ln -sfT /usr/lib/mxisd/mxisd.jar /usr/bin/mxisd | ln -sfT /usr/lib/mxisd/mxisd /usr/bin/mxisd | ||||||
|  |  | ||||||
| # Enable systemd service | # Enable systemd service | ||||||
| systemctl enable mxisd.service | systemctl enable mxisd.service | ||||||
|   | |||||||
| @@ -1,25 +1,34 @@ | |||||||
| #!/usr/bin/env bash | #!/bin/bash | ||||||
|  |  | ||||||
| if [[ -n "$CONF_FILE_PATH" ]] && [ ! -f "$CONF_FILE_PATH" ]; then | if [[ -n "$CONF_FILE_PATH" ]] && [ ! -f "$CONF_FILE_PATH" ]; then | ||||||
|     echo "Generating config file $CONF_FILE_PATH" |     echo "Generating config file $CONF_FILE_PATH" | ||||||
|     touch "CONF_FILE_PATH" |     touch "CONF_FILE_PATH" | ||||||
|  |  | ||||||
|     if [[ -n "$MATRIX_DOMAIN" ]]; then |     if [[ -n "$MATRIX_DOMAIN" ]]; then | ||||||
|         echo "Setting matrix domain to $MATRIX_DOMAIN" |         echo "Setting matrix domain to $MATRIX_DOMAIN" | ||||||
|         echo "matrix.domain: $MATRIX_DOMAIN" >> "$CONF_FILE_PATH" |         echo "matrix:" >> "$CONF_FILE_PATH" | ||||||
|  |         echo "  domain: '$MATRIX_DOMAIN'" >> "$CONF_FILE_PATH" | ||||||
|  |         echo >> "$CONF_FILE_PATH" | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     if [[ -n "$SIGN_KEY_PATH" ]]; then |     if [[ -n "$SIGN_KEY_PATH" ]]; then | ||||||
|         echo "Setting signing key path to $SIGN_KEY_PATH" |         echo "Setting signing key path to $SIGN_KEY_PATH" | ||||||
|         echo "key.path: $SIGN_KEY_PATH" >> "$CONF_FILE_PATH" |         echo "key:" >> "$CONF_FILE_PATH" | ||||||
|  |         echo "  path: '$SIGN_KEY_PATH'" >> "$CONF_FILE_PATH" | ||||||
|  |         echo >> "$CONF_FILE_PATH" | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     if [[ -n "$SQLITE_DATABASE_PATH" ]]; then |     if [[ -n "$SQLITE_DATABASE_PATH" ]]; then | ||||||
|         echo "Setting SQLite DB path to $SQLITE_DATABASE_PATH" |         echo "Setting SQLite DB path to $SQLITE_DATABASE_PATH" | ||||||
|         echo "storage.provider.sqlite.database: $SQLITE_DATABASE_PATH" >> "$CONF_FILE_PATH" |         echo "storage:" >> "$CONF_FILE_PATH" | ||||||
|  |         echo "  provider:" >> "$CONF_FILE_PATH" | ||||||
|  |         echo "    sqlite:" >> "$CONF_FILE_PATH" | ||||||
|  |         echo "      database: '$SQLITE_DATABASE_PATH'" >> "$CONF_FILE_PATH" | ||||||
|  |         echo >> "$CONF_FILE_PATH" | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     echo "Starting mxisd..." |     echo "Starting mxisd..." | ||||||
|     echo |     echo | ||||||
| fi | fi | ||||||
|  |  | ||||||
| exec java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -Dspring.config.location=/etc/mxisd/ -Dspring.config.name=mxisd -jar /mxisd.jar | exec java -jar /app/mxisd.jar -c /etc/mxisd/mxisd.yaml | ||||||
|   | |||||||
| @@ -37,6 +37,7 @@ import java.util.List; | |||||||
|  * both IPv4 and IPv6. |  * both IPv4 and IPv6. | ||||||
|  */ |  */ | ||||||
| public class CIDRUtils { | public class CIDRUtils { | ||||||
|  |  | ||||||
|     private final String cidr; |     private final String cidr; | ||||||
|  |  | ||||||
|     private InetAddress inetAddress; |     private InetAddress inetAddress; | ||||||
| @@ -44,7 +45,6 @@ public class CIDRUtils { | |||||||
|     private InetAddress endAddress; |     private InetAddress endAddress; | ||||||
|     private final int prefixLength; |     private final int prefixLength; | ||||||
|  |  | ||||||
|  |  | ||||||
|     public CIDRUtils(String cidr) throws UnknownHostException { |     public CIDRUtils(String cidr) throws UnknownHostException { | ||||||
|  |  | ||||||
|         this.cidr = cidr; |         this.cidr = cidr; | ||||||
| @@ -66,7 +66,6 @@ public class CIDRUtils { | |||||||
|  |  | ||||||
|  |  | ||||||
|     private void calculate() throws UnknownHostException { |     private void calculate() throws UnknownHostException { | ||||||
|  |  | ||||||
|         ByteBuffer maskBuffer; |         ByteBuffer maskBuffer; | ||||||
|         int targetSize; |         int targetSize; | ||||||
|         if (inetAddress.getAddress().length == 4) { |         if (inetAddress.getAddress().length == 4) { | ||||||
| @@ -120,14 +119,9 @@ public class CIDRUtils { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public String getNetworkAddress() { |     public String getNetworkAddress() { | ||||||
|  |  | ||||||
|         return this.startAddress.getHostAddress(); |         return this.startAddress.getHostAddress(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public String getBroadcastAddress() { |  | ||||||
|         return this.endAddress.getHostAddress(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public boolean isInRange(String ipAddress) throws UnknownHostException { |     public boolean isInRange(String ipAddress) throws UnknownHostException { | ||||||
|         InetAddress address = InetAddress.getByName(ipAddress); |         InetAddress address = InetAddress.getByName(ipAddress); | ||||||
|         BigInteger start = new BigInteger(1, this.startAddress.getAddress()); |         BigInteger start = new BigInteger(1, this.startAddress.getAddress()); | ||||||
| @@ -139,4 +133,5 @@ public class CIDRUtils { | |||||||
|  |  | ||||||
|         return (st == -1 || st == 0) && (te == -1 || te == 0); |         return (st == -1 || st == 0) && (te == -1 || te == 0); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										114
									
								
								src/main/java/io/kamax/mxisd/HttpMxisd.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								src/main/java/io/kamax/mxisd/HttpMxisd.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,114 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.SaneHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.as.v1.AsNotFoundHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.as.v1.AsTransactionHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.auth.RestAuthHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.auth.v1.LoginGetHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.auth.v1.LoginHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.auth.v1.LoginPostHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.directory.v1.UserDirectorySearchHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.identity.v1.*; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.profile.v1.InternalProfileHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.profile.v1.ProfileHandler; | ||||||
|  | import io.kamax.mxisd.http.undertow.handler.status.StatusHandler; | ||||||
|  | import io.undertow.Handlers; | ||||||
|  | import io.undertow.Undertow; | ||||||
|  | import io.undertow.server.HttpHandler; | ||||||
|  |  | ||||||
|  | public class HttpMxisd { | ||||||
|  |  | ||||||
|  |     // Core | ||||||
|  |     private Mxisd m; | ||||||
|  |  | ||||||
|  |     // I/O | ||||||
|  |     private Undertow httpSrv; | ||||||
|  |  | ||||||
|  |     public HttpMxisd(MxisdConfig cfg) { | ||||||
|  |         m = new Mxisd(cfg); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void start() { | ||||||
|  |         m.start(); | ||||||
|  |  | ||||||
|  |         HttpHandler asNotFoundHandler = SaneHandler.around(new AsNotFoundHandler(m.getAs())); | ||||||
|  |         HttpHandler asTxnHandler = SaneHandler.around(new AsTransactionHandler(m.getAs())); | ||||||
|  |         HttpHandler storeInvHandler = SaneHandler.around(new StoreInviteHandler(m.getConfig().getServer(), m.getInvitationManager(), m.getKeyManager())); | ||||||
|  |         HttpHandler sessValidateHandler = SaneHandler.around(new SessionValidateHandler(m.getSession(), m.getConfig().getServer(), m.getConfig().getView())); | ||||||
|  |  | ||||||
|  |         httpSrv = Undertow.builder().addHttpListener(m.getConfig().getServer().getPort(), "0.0.0.0").setHandler(Handlers.routing() | ||||||
|  |  | ||||||
|  |                 // Status endpoints | ||||||
|  |                 .get(StatusHandler.Path, SaneHandler.around(new StatusHandler())) | ||||||
|  |  | ||||||
|  |                 // Authentication endpoints | ||||||
|  |                 .get(LoginHandler.Path, SaneHandler.around(new LoginGetHandler(m.getAuth(), m.getHttpClient()))) | ||||||
|  |                 .post(LoginHandler.Path, SaneHandler.around(new LoginPostHandler(m.getAuth()))) | ||||||
|  |                 .post(RestAuthHandler.Path, SaneHandler.around(new RestAuthHandler(m.getAuth()))) | ||||||
|  |  | ||||||
|  |                 // Directory endpoints | ||||||
|  |                 .post(UserDirectorySearchHandler.Path, SaneHandler.around(new UserDirectorySearchHandler(m.getDirectory()))) | ||||||
|  |  | ||||||
|  |                 // Key endpoints | ||||||
|  |                 .get(KeyGetHandler.Path, SaneHandler.around(new KeyGetHandler(m.getKeyManager()))) | ||||||
|  |                 .get(RegularKeyIsValidHandler.Path, SaneHandler.around(new RegularKeyIsValidHandler(m.getKeyManager()))) | ||||||
|  |                 .get(EphemeralKeyIsValidHandler.Path, SaneHandler.around(new EphemeralKeyIsValidHandler())) | ||||||
|  |  | ||||||
|  |                 // Identity endpoints | ||||||
|  |                 .get(HelloHandler.Path, SaneHandler.around(new HelloHandler())) | ||||||
|  |                 .get(SingleLookupHandler.Path, SaneHandler.around(new SingleLookupHandler(m.getIdentity(), m.getSign()))) | ||||||
|  |                 .post(BulkLookupHandler.Path, SaneHandler.around(new BulkLookupHandler(m.getIdentity()))) | ||||||
|  |                 .post(StoreInviteHandler.Path, storeInvHandler) | ||||||
|  |                 .post(SessionStartHandler.Path, SaneHandler.around(new SessionStartHandler(m.getSession()))) | ||||||
|  |                 .get(SessionValidateHandler.Path, sessValidateHandler) | ||||||
|  |                 .post(SessionValidateHandler.Path, sessValidateHandler) | ||||||
|  |                 .get(SessionTpidGetValidatedHandler.Path, SaneHandler.around(new SessionTpidGetValidatedHandler(m.getSession()))) | ||||||
|  |                 .post(SessionTpidBindHandler.Path, SaneHandler.around(new SessionTpidBindHandler(m.getSession(), m.getInvitationManager()))) | ||||||
|  |                 .get(RemoteIdentityAPIv1.SESSION_REQUEST_TOKEN, SaneHandler.around(new RemoteSessionStartHandler(m.getSession(), m.getConfig().getView()))) | ||||||
|  |                 .get(RemoteIdentityAPIv1.SESSION_CHECK, SaneHandler.around(new RemoteSessionCheckHandler(m.getSession(), m.getConfig().getView()))) | ||||||
|  |  | ||||||
|  |                 // Profile endpoints | ||||||
|  |                 .get(ProfileHandler.Path, SaneHandler.around(new ProfileHandler(m.getProfile()))) | ||||||
|  |                 .get(InternalProfileHandler.Path, SaneHandler.around(new InternalProfileHandler(m.getProfile()))) | ||||||
|  |  | ||||||
|  |                 // Application Service endpoints | ||||||
|  |                 .get("/_matrix/app/v1/users/**", asNotFoundHandler) | ||||||
|  |                 .get("/users/**", asNotFoundHandler) // Legacy endpoint | ||||||
|  |                 .get("/_matrix/app/v1/rooms/**", asNotFoundHandler) | ||||||
|  |                 .get("/rooms/**", asNotFoundHandler) // Legacy endpoint | ||||||
|  |                 .put(AsTransactionHandler.Path, asTxnHandler) | ||||||
|  |                 .put("/transactions/{" + AsTransactionHandler.ID + "}", asTxnHandler) // Legacy endpoint | ||||||
|  |  | ||||||
|  |         ).build(); | ||||||
|  |  | ||||||
|  |         httpSrv.start(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void stop() { | ||||||
|  |         httpSrv.stop(); | ||||||
|  |  | ||||||
|  |         m.stop(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										172
									
								
								src/main/java/io/kamax/mxisd/Mxisd.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										172
									
								
								src/main/java/io/kamax/mxisd/Mxisd.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,172 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd; | ||||||
|  |  | ||||||
|  | import io.kamax.matrix.crypto.KeyManager; | ||||||
|  | import io.kamax.matrix.crypto.SignatureManager; | ||||||
|  | import io.kamax.mxisd.as.AppSvcManager; | ||||||
|  | import io.kamax.mxisd.auth.AuthManager; | ||||||
|  | import io.kamax.mxisd.auth.AuthProviders; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.backend.sql.synapse.Synapse; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.crypto.CryptoFactory; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryManager; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.dns.ClientDnsOverwrite; | ||||||
|  | import io.kamax.mxisd.dns.FederationDnsOverwrite; | ||||||
|  | import io.kamax.mxisd.invitation.InvitationManager; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  | import io.kamax.mxisd.lookup.fetcher.IRemoteIdentityServerFetcher; | ||||||
|  | import io.kamax.mxisd.lookup.provider.BridgeFetcher; | ||||||
|  | import io.kamax.mxisd.lookup.provider.RemoteIdentityServerFetcher; | ||||||
|  | import io.kamax.mxisd.lookup.strategy.LookupStrategy; | ||||||
|  | import io.kamax.mxisd.lookup.strategy.RecursivePriorityLookupStrategy; | ||||||
|  | import io.kamax.mxisd.notification.NotificationHandlerSupplier; | ||||||
|  | import io.kamax.mxisd.notification.NotificationHandlers; | ||||||
|  | import io.kamax.mxisd.notification.NotificationManager; | ||||||
|  | import io.kamax.mxisd.profile.ProfileManager; | ||||||
|  | import io.kamax.mxisd.profile.ProfileProviders; | ||||||
|  | import io.kamax.mxisd.session.SessionMananger; | ||||||
|  | import io.kamax.mxisd.storage.IStorage; | ||||||
|  | import io.kamax.mxisd.storage.ormlite.OrmLiteSqliteStorage; | ||||||
|  | import org.apache.http.impl.client.CloseableHttpClient; | ||||||
|  | import org.apache.http.impl.client.HttpClients; | ||||||
|  |  | ||||||
|  | import java.util.ServiceLoader; | ||||||
|  |  | ||||||
|  | public class Mxisd { | ||||||
|  |  | ||||||
|  |     protected MxisdConfig cfg; | ||||||
|  |  | ||||||
|  |     protected CloseableHttpClient httpClient; | ||||||
|  |     protected IRemoteIdentityServerFetcher srvFetcher; | ||||||
|  |  | ||||||
|  |     protected IStorage store; | ||||||
|  |  | ||||||
|  |     protected KeyManager keyMgr; | ||||||
|  |     protected SignatureManager signMgr; | ||||||
|  |  | ||||||
|  |     // Features | ||||||
|  |     protected AuthManager authMgr; | ||||||
|  |     protected DirectoryManager dirMgr; | ||||||
|  |     protected LookupStrategy idStrategy; | ||||||
|  |     protected InvitationManager invMgr; | ||||||
|  |     protected ProfileManager pMgr; | ||||||
|  |     protected AppSvcManager asHander; | ||||||
|  |     protected SessionMananger sessMgr; | ||||||
|  |     protected NotificationManager notifMgr; | ||||||
|  |  | ||||||
|  |     public Mxisd(MxisdConfig cfg) { | ||||||
|  |         this.cfg = cfg.build(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected void build() { | ||||||
|  |         httpClient = HttpClients.custom() | ||||||
|  |                 .setUserAgent("mxisd") | ||||||
|  |                 .setMaxConnPerRoute(Integer.MAX_VALUE) | ||||||
|  |                 .setMaxConnTotal(Integer.MAX_VALUE) | ||||||
|  |                 .build(); | ||||||
|  |  | ||||||
|  |         srvFetcher = new RemoteIdentityServerFetcher(httpClient); | ||||||
|  |  | ||||||
|  |         store = new OrmLiteSqliteStorage(cfg); | ||||||
|  |         keyMgr = CryptoFactory.getKeyManager(cfg.getKey()); | ||||||
|  |         signMgr = CryptoFactory.getSignatureManager(keyMgr, cfg.getServer()); | ||||||
|  |         ClientDnsOverwrite clientDns = new ClientDnsOverwrite(cfg.getDns().getOverwrite()); | ||||||
|  |         FederationDnsOverwrite fedDns = new FederationDnsOverwrite(cfg.getDns().getOverwrite()); | ||||||
|  |         Synapse synapse = new Synapse(cfg.getSynapseSql()); | ||||||
|  |         BridgeFetcher bridgeFetcher = new BridgeFetcher(cfg.getLookup().getRecursive().getBridge(), srvFetcher); | ||||||
|  |  | ||||||
|  |         ServiceLoader.load(IdentityStoreSupplier.class).iterator().forEachRemaining(p -> p.accept(this)); | ||||||
|  |         ServiceLoader.load(NotificationHandlerSupplier.class).iterator().forEachRemaining(p -> p.accept(this)); | ||||||
|  |  | ||||||
|  |         idStrategy = new RecursivePriorityLookupStrategy(cfg.getLookup(), ThreePidProviders.get(), bridgeFetcher); | ||||||
|  |         pMgr = new ProfileManager(ProfileProviders.get(), clientDns, httpClient); | ||||||
|  |         notifMgr = new NotificationManager(cfg.getNotification(), NotificationHandlers.get()); | ||||||
|  |         sessMgr = new SessionMananger(cfg.getSession(), cfg.getMatrix(), store, notifMgr, httpClient); | ||||||
|  |         invMgr = new InvitationManager(cfg.getInvite(), store, idStrategy, signMgr, fedDns, notifMgr); | ||||||
|  |         authMgr = new AuthManager(cfg, AuthProviders.get(), idStrategy, invMgr, clientDns, httpClient); | ||||||
|  |         dirMgr = new DirectoryManager(cfg.getDirectory(), clientDns, httpClient, DirectoryProviders.get()); | ||||||
|  |         asHander = new AppSvcManager(cfg, store, pMgr, notifMgr, synapse); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public MxisdConfig getConfig() { | ||||||
|  |         return cfg; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public CloseableHttpClient getHttpClient() { | ||||||
|  |         return httpClient; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public IRemoteIdentityServerFetcher getServerFetcher() { | ||||||
|  |         return srvFetcher; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public KeyManager getKeyManager() { | ||||||
|  |         return keyMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public InvitationManager getInvitationManager() { | ||||||
|  |         return invMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LookupStrategy getIdentity() { | ||||||
|  |         return idStrategy; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public AuthManager getAuth() { | ||||||
|  |         return authMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public SessionMananger getSession() { | ||||||
|  |         return sessMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public DirectoryManager getDirectory() { | ||||||
|  |         return dirMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public ProfileManager getProfile() { | ||||||
|  |         return pMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public SignatureManager getSign() { | ||||||
|  |         return signMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public AppSvcManager getAs() { | ||||||
|  |         return asHander; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public NotificationManager getNotif() { | ||||||
|  |         return notifMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void start() { | ||||||
|  |         build(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void stop() { | ||||||
|  |         // no-op | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										69
									
								
								src/main/java/io/kamax/mxisd/MxisdStandaloneExec.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/main/java/io/kamax/mxisd/MxisdStandaloneExec.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.config.YamlConfigLoader; | ||||||
|  | import org.apache.commons.lang3.StringUtils; | ||||||
|  |  | ||||||
|  | import java.io.IOException; | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.Iterator; | ||||||
|  | import java.util.Objects; | ||||||
|  |  | ||||||
|  | public class MxisdStandaloneExec { | ||||||
|  |  | ||||||
|  |     public static void main(String[] args) throws IOException { | ||||||
|  |         MxisdConfig cfg = null; | ||||||
|  |  | ||||||
|  |         Iterator<String> argsIt = Arrays.asList(args).iterator(); | ||||||
|  |         while (argsIt.hasNext()) { | ||||||
|  |             String arg = argsIt.next(); | ||||||
|  |             if (StringUtils.equals("-c", arg)) { | ||||||
|  |                 String cfgFile = argsIt.next(); | ||||||
|  |                 cfg = YamlConfigLoader.loadFromFile(cfgFile); | ||||||
|  |                 System.out.println("Loaded configuration from " + cfgFile); | ||||||
|  |             } else { | ||||||
|  |                 System.out.println("Invalid argument: " + arg); | ||||||
|  |                 System.exit(1); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (Objects.isNull(cfg)) { | ||||||
|  |             cfg = YamlConfigLoader.tryLoadFromFile("mxisd.yaml").orElseGet(MxisdConfig::new); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             HttpMxisd mxisd = new HttpMxisd(cfg); | ||||||
|  |             Runtime.getRuntime().addShutdownHook(new Thread(() -> { | ||||||
|  |                 mxisd.stop(); | ||||||
|  |                 System.out.println("------------- mxisd stopped -------------"); | ||||||
|  |             })); | ||||||
|  |             mxisd.start(); | ||||||
|  |  | ||||||
|  |             System.out.println("------------- mxisd started -------------"); | ||||||
|  |         } catch (Throwable t) { | ||||||
|  |             t.printStackTrace(); | ||||||
|  |             System.exit(1); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -28,8 +28,10 @@ import io.kamax.matrix._ThreePid; | |||||||
| import io.kamax.matrix.event.EventKey; | import io.kamax.matrix.event.EventKey; | ||||||
| import io.kamax.matrix.json.GsonUtil; | import io.kamax.matrix.json.GsonUtil; | ||||||
| import io.kamax.mxisd.backend.sql.synapse.Synapse; | import io.kamax.mxisd.backend.sql.synapse.Synapse; | ||||||
| import io.kamax.mxisd.config.ListenerConfig; |  | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.exception.HttpMatrixException; | ||||||
|  | import io.kamax.mxisd.exception.NotAllowedException; | ||||||
| import io.kamax.mxisd.notification.NotificationManager; | import io.kamax.mxisd.notification.NotificationManager; | ||||||
| import io.kamax.mxisd.profile.ProfileManager; | import io.kamax.mxisd.profile.ProfileManager; | ||||||
| import io.kamax.mxisd.storage.IStorage; | import io.kamax.mxisd.storage.IStorage; | ||||||
| @@ -38,8 +40,6 @@ import io.kamax.mxisd.util.GsonParser; | |||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
| 
 | 
 | ||||||
| import java.io.InputStream; | import java.io.InputStream; | ||||||
| import java.time.Instant; | import java.time.Instant; | ||||||
| @@ -48,14 +48,12 @@ import java.util.concurrent.CompletableFuture; | |||||||
| import java.util.concurrent.ConcurrentHashMap; | import java.util.concurrent.ConcurrentHashMap; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| 
 | 
 | ||||||
| @Component | public class AppSvcManager { | ||||||
| public class AppServiceHandler { |  | ||||||
| 
 | 
 | ||||||
|     private final Logger log = LoggerFactory.getLogger(AppServiceHandler.class); |     private transient final Logger log = LoggerFactory.getLogger(AppSvcManager.class); | ||||||
| 
 | 
 | ||||||
|     private final GsonParser parser; |     private final GsonParser parser; | ||||||
| 
 | 
 | ||||||
|     private String localpart; |  | ||||||
|     private MatrixConfig cfg; |     private MatrixConfig cfg; | ||||||
|     private IStorage store; |     private IStorage store; | ||||||
|     private ProfileManager profiler; |     private ProfileManager profiler; | ||||||
| @@ -64,22 +62,36 @@ public class AppServiceHandler { | |||||||
| 
 | 
 | ||||||
|     private Map<String, CompletableFuture<String>> transactionsInProgress; |     private Map<String, CompletableFuture<String>> transactionsInProgress; | ||||||
| 
 | 
 | ||||||
|     @Autowired |     public AppSvcManager(MxisdConfig cfg, IStorage store, ProfileManager profiler, NotificationManager notif, Synapse synapse) { | ||||||
|     public AppServiceHandler(ListenerConfig lCfg, MatrixConfig cfg, IStorage store, ProfileManager profiler, NotificationManager notif, Synapse synapse) { |         this.cfg = cfg.getMatrix(); | ||||||
|         this.cfg = cfg; |  | ||||||
|         this.store = store; |         this.store = store; | ||||||
|         this.profiler = profiler; |         this.profiler = profiler; | ||||||
|         this.notif = notif; |         this.notif = notif; | ||||||
|         this.synapse = synapse; |         this.synapse = synapse; | ||||||
| 
 | 
 | ||||||
|         localpart = lCfg.getLocalpart(); |  | ||||||
|         parser = new GsonParser(); |         parser = new GsonParser(); | ||||||
|         transactionsInProgress = new ConcurrentHashMap<>(); |         transactionsInProgress = new ConcurrentHashMap<>(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public AppSvcManager withToken(String token) { | ||||||
|  |         if (StringUtils.isBlank(token)) { | ||||||
|  |             throw new HttpMatrixException(401, "M_UNAUTHORIZED", "No HS token"); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (!StringUtils.equals(cfg.getListener().getToken().getHs(), token)) { | ||||||
|  |             throw new NotAllowedException("Invalid HS token"); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return this; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public CompletableFuture<String> processTransaction(String txnId, InputStream is) { |     public CompletableFuture<String> processTransaction(String txnId, InputStream is) { | ||||||
|  |         if (StringUtils.isEmpty(txnId)) { | ||||||
|  |             throw new IllegalArgumentException("Transaction ID cannot be empty"); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         synchronized (this) { |         synchronized (this) { | ||||||
|             Optional<ASTransactionDao> dao = store.getTransactionResult(localpart, txnId); |             Optional<ASTransactionDao> dao = store.getTransactionResult(cfg.getListener().getLocalpart(), txnId); | ||||||
|             if (dao.isPresent()) { |             if (dao.isPresent()) { | ||||||
|                 log.info("AS Transaction {} already processed - returning computed result", txnId); |                 log.info("AS Transaction {} already processed - returning computed result", txnId); | ||||||
|                 return CompletableFuture.completedFuture(dao.get().getResult()); |                 return CompletableFuture.completedFuture(dao.get().getResult()); | ||||||
| @@ -104,19 +116,19 @@ public class AppServiceHandler { | |||||||
|             log.debug("{} event(s) parsed", events.size()); |             log.debug("{} event(s) parsed", events.size()); | ||||||
| 
 | 
 | ||||||
|             processTransaction(events); |             processTransaction(events); | ||||||
|             Instant end = Instant.now(); |  | ||||||
|             log.info("Processed AS transaction {} in {} ms", txnId, (Instant.now().toEpochMilli() - start.toEpochMilli())); |  | ||||||
| 
 | 
 | ||||||
|  |             Instant end = Instant.now(); | ||||||
|             String result = "{}"; |             String result = "{}"; | ||||||
| 
 | 
 | ||||||
|             try { |             try { | ||||||
|                 log.info("Saving transaction details to store"); |                 log.info("Saving transaction details to store"); | ||||||
|                 store.insertTransactionResult(localpart, txnId, end, result); |                 store.insertTransactionResult(cfg.getListener().getLocalpart(), txnId, end, result); | ||||||
|             } finally { |             } finally { | ||||||
|                 log.debug("Removing CompletedFuture from transaction map"); |                 log.debug("Removing CompletedFuture from transaction map"); | ||||||
|                 transactionsInProgress.remove(txnId); |                 transactionsInProgress.remove(txnId); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             log.info("Processed AS transaction {} in {} ms", txnId, (Instant.now().toEpochMilli() - start.toEpochMilli())); | ||||||
|             future.complete(result); |             future.complete(result); | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|             log.error("Unable to properly process transaction {}", txnId, e); |             log.error("Unable to properly process transaction {}", txnId, e); | ||||||
| @@ -37,6 +37,7 @@ import io.kamax.mxisd.auth.provider.AuthenticatorProvider; | |||||||
| import io.kamax.mxisd.auth.provider.BackendAuthResult; | import io.kamax.mxisd.auth.provider.BackendAuthResult; | ||||||
| import io.kamax.mxisd.config.AuthenticationConfig; | import io.kamax.mxisd.config.AuthenticationConfig; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
| import io.kamax.mxisd.dns.ClientDnsOverwrite; | import io.kamax.mxisd.dns.ClientDnsOverwrite; | ||||||
| import io.kamax.mxisd.exception.RemoteLoginException; | import io.kamax.mxisd.exception.RemoteLoginException; | ||||||
| import io.kamax.mxisd.invitation.InvitationManager; | import io.kamax.mxisd.invitation.InvitationManager; | ||||||
| @@ -53,8 +54,6 @@ import org.apache.http.impl.client.CloseableHttpClient; | |||||||
| import org.apache.http.util.EntityUtils; | import org.apache.http.util.EntityUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.net.URI; | import java.net.URI; | ||||||
| @@ -63,7 +62,6 @@ import java.util.ArrayList; | |||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
|  |  | ||||||
| @Service |  | ||||||
| public class AuthManager { | public class AuthManager { | ||||||
|  |  | ||||||
|     private static final String TypeKey = "type"; |     private static final String TypeKey = "type"; | ||||||
| @@ -74,8 +72,8 @@ public class AuthManager { | |||||||
|     private static final String UserIdTypeValue = "m.id.user"; |     private static final String UserIdTypeValue = "m.id.user"; | ||||||
|     private static final String ThreepidTypeValue = "m.id.thirdparty"; |     private static final String ThreepidTypeValue = "m.id.thirdparty"; | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(AuthManager.class); |     private transient final Logger log = LoggerFactory.getLogger(AuthManager.class); | ||||||
|     private final Gson gson = GsonUtil.get(); |     private final Gson gson = GsonUtil.get(); // FIXME replace | ||||||
|  |  | ||||||
|     private List<AuthenticatorProvider> providers; |     private List<AuthenticatorProvider> providers; | ||||||
|     private MatrixConfig mxCfg; |     private MatrixConfig mxCfg; | ||||||
| @@ -85,18 +83,16 @@ public class AuthManager { | |||||||
|     private LookupStrategy strategy; |     private LookupStrategy strategy; | ||||||
|     private CloseableHttpClient client; |     private CloseableHttpClient client; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public AuthManager( |     public AuthManager( | ||||||
|             AuthenticationConfig cfg, |             MxisdConfig cfg, | ||||||
|             MatrixConfig mxCfg, |             List<? extends AuthenticatorProvider> providers, | ||||||
|             List<AuthenticatorProvider> providers, |  | ||||||
|             LookupStrategy strategy, |             LookupStrategy strategy, | ||||||
|             InvitationManager invMgr, |             InvitationManager invMgr, | ||||||
|             ClientDnsOverwrite dns, |             ClientDnsOverwrite dns, | ||||||
|             CloseableHttpClient client |             CloseableHttpClient client | ||||||
|     ) { |     ) { | ||||||
|         this.cfg = cfg; |         this.cfg = cfg.getAuth(); | ||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = cfg.getMatrix(); | ||||||
|         this.providers = new ArrayList<>(providers); |         this.providers = new ArrayList<>(providers); | ||||||
|         this.strategy = strategy; |         this.strategy = strategy; | ||||||
|         this.invMgr = invMgr; |         this.invMgr = invMgr; | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								src/main/java/io/kamax/mxisd/auth/AuthProviders.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								src/main/java/io/kamax/mxisd/auth/AuthProviders.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2017 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.auth; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.auth.provider.AuthenticatorProvider; | ||||||
|  |  | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.function.Supplier; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
|  | public class AuthProviders { | ||||||
|  |  | ||||||
|  |     private static final List<Supplier<? extends AuthenticatorProvider>> suppliers = new ArrayList<>(); | ||||||
|  |  | ||||||
|  |     public static void register(Supplier<? extends AuthenticatorProvider> supplier) { | ||||||
|  |         suppliers.add(supplier); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static List<? extends AuthenticatorProvider> get() { | ||||||
|  |         return suppliers.stream().map(Supplier::get).collect(Collectors.toList()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,29 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  |  | ||||||
|  | import java.util.function.Consumer; | ||||||
|  |  | ||||||
|  | public interface IdentityStoreSupplier extends Consumer<Mxisd> { | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -33,20 +33,16 @@ import io.kamax.mxisd.exception.InternalServerError; | |||||||
| import org.apache.commons.lang3.StringUtils; | import org.apache.commons.lang3.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class ExecAuthStore extends ExecStore implements AuthenticatorProvider { | public class ExecAuthStore extends ExecStore implements AuthenticatorProvider { | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(ExecAuthStore.class); |     private transient final Logger log = LoggerFactory.getLogger(ExecAuthStore.class); | ||||||
|  |  | ||||||
|     private ExecConfig.Auth cfg; |     private ExecConfig.Auth cfg; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public ExecAuthStore(ExecConfig cfg) { |     public ExecAuthStore(ExecConfig cfg) { | ||||||
|         this.cfg = Objects.requireNonNull(cfg.getAuth()); |         this.cfg = Objects.requireNonNull(cfg.getAuth()); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -24,22 +24,19 @@ import io.kamax.matrix.MatrixID; | |||||||
| import io.kamax.matrix.json.GsonUtil; | import io.kamax.matrix.json.GsonUtil; | ||||||
| import io.kamax.mxisd.config.ExecConfig; | import io.kamax.mxisd.config.ExecConfig; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchRequest; | import io.kamax.mxisd.config.MxisdConfig; | ||||||
| import io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchResult; | import io.kamax.mxisd.directory.DirectoryProvider; | ||||||
| import io.kamax.mxisd.directory.IDirectoryProvider; | import io.kamax.mxisd.http.io.UserDirectorySearchRequest; | ||||||
|  | import io.kamax.mxisd.http.io.UserDirectorySearchResult; | ||||||
| import org.apache.commons.lang3.StringUtils; | import org.apache.commons.lang3.StringUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component | public class ExecDirectoryStore extends ExecStore implements DirectoryProvider { | ||||||
| public class ExecDirectoryStore extends ExecStore implements IDirectoryProvider { |  | ||||||
|  |  | ||||||
|     private ExecConfig.Directory cfg; |     private ExecConfig.Directory cfg; | ||||||
|     private MatrixConfig mxCfg; |     private MatrixConfig mxCfg; | ||||||
|  |  | ||||||
|     @Autowired |     public ExecDirectoryStore(MxisdConfig cfg) { | ||||||
|     public ExecDirectoryStore(ExecConfig cfg, MatrixConfig mxCfg) { |         this(cfg.getExec().getDirectory(), cfg.getMatrix()); | ||||||
|         this(cfg.getDirectory(), mxCfg); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public ExecDirectoryStore(ExecConfig.Directory cfg, MatrixConfig mxCfg) { |     public ExecDirectoryStore(ExecConfig.Directory cfg, MatrixConfig mxCfg) { | ||||||
| @@ -47,11 +44,6 @@ public class ExecDirectoryStore extends ExecStore implements IDirectoryProvider | |||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private UserDirectorySearchResult search(ExecConfig.Process cfg, UserDirectorySearchRequest request) { |     private UserDirectorySearchResult search(ExecConfig.Process cfg, UserDirectorySearchRequest request) { | ||||||
|         if (StringUtils.isEmpty(cfg.getCommand())) { |         if (StringUtils.isEmpty(cfg.getCommand())) { | ||||||
|             return UserDirectorySearchResult.empty(); |             return UserDirectorySearchResult.empty(); | ||||||
|   | |||||||
| @@ -40,8 +40,6 @@ import io.kamax.mxisd.lookup.provider.IThreePidProvider; | |||||||
| import org.apache.commons.lang3.StringUtils; | import org.apache.commons.lang3.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| @@ -49,15 +47,13 @@ import java.util.Objects; | |||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class ExecIdentityStore extends ExecStore implements IThreePidProvider { | public class ExecIdentityStore extends ExecStore implements IThreePidProvider { | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(ExecIdentityStore.class); |     private transient final Logger log = LoggerFactory.getLogger(ExecIdentityStore.class); | ||||||
|  |  | ||||||
|     private final ExecConfig.Identity cfg; |     private final ExecConfig.Identity cfg; | ||||||
|     private final MatrixConfig mxCfg; |     private final MatrixConfig mxCfg; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public ExecIdentityStore(ExecConfig cfg, MatrixConfig mxCfg) { |     public ExecIdentityStore(ExecConfig cfg, MatrixConfig mxCfg) { | ||||||
|         this(cfg.getIdentity(), mxCfg); |         this(cfg.getIdentity(), mxCfg); | ||||||
|     } |     } | ||||||
| @@ -67,11 +63,6 @@ public class ExecIdentityStore extends ExecStore implements IThreePidProvider { | |||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isLocal() { |     public boolean isLocal() { | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
| @@ -0,0 +1,56 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend.exec; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  | import io.kamax.mxisd.auth.AuthProviders; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  | import io.kamax.mxisd.profile.ProfileProviders; | ||||||
|  |  | ||||||
|  | public class ExecIdentityStoreSupplier implements IdentityStoreSupplier { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void accept(Mxisd mxisd) { | ||||||
|  |         accept(mxisd.getConfig()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void accept(MxisdConfig cfg) { | ||||||
|  |         if (cfg.getExec().getAuth().isEnabled()) { | ||||||
|  |             AuthProviders.register(() -> new ExecAuthStore(cfg.getExec())); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (cfg.getExec().getDirectory().isEnabled()) { | ||||||
|  |             DirectoryProviders.register(() -> new ExecDirectoryStore(cfg)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (cfg.getExec().getIdentity().isEnabled()) { | ||||||
|  |             ThreePidProviders.register(() -> new ExecIdentityStore(cfg.getExec(), cfg.getMatrix())); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (cfg.getExec().getProfile().isEnabled()) { | ||||||
|  |             ProfileProviders.register(() -> new ExecProfileStore(cfg.getExec())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -28,19 +28,15 @@ import io.kamax.mxisd.profile.JsonProfileRequest; | |||||||
| import io.kamax.mxisd.profile.JsonProfileResult; | import io.kamax.mxisd.profile.JsonProfileResult; | ||||||
| import io.kamax.mxisd.profile.ProfileProvider; | import io.kamax.mxisd.profile.ProfileProvider; | ||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class ExecProfileStore extends ExecStore implements ProfileProvider { | public class ExecProfileStore extends ExecStore implements ProfileProvider { | ||||||
|  |  | ||||||
|     private ExecConfig.Profile cfg; |     private ExecConfig.Profile cfg; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public ExecProfileStore(ExecConfig cfg) { |     public ExecProfileStore(ExecConfig cfg) { | ||||||
|         this(cfg.getProfile()); |         this(cfg.getProfile()); | ||||||
|     } |     } | ||||||
| @@ -49,11 +45,6 @@ public class ExecProfileStore extends ExecStore implements ProfileProvider { | |||||||
|         this.cfg = cfg; |         this.cfg = cfg; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private Optional<JsonProfileResult> getFull(_MatrixID userId, ExecConfig.Process cfg) { |     private Optional<JsonProfileResult> getFull(_MatrixID userId, ExecConfig.Process cfg) { | ||||||
|         Processor<Optional<JsonProfileResult>> p = new Processor<>(cfg); |         Processor<Optional<JsonProfileResult>> p = new Processor<>(cfg); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -47,7 +47,7 @@ public class ExecStore { | |||||||
|         return GsonUtil.get().toJson(o); |         return GsonUtil.get().toJson(o); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(ExecStore.class); |     private transient final Logger log = LoggerFactory.getLogger(ExecStore.class); | ||||||
|  |  | ||||||
|     private Supplier<ProcessExecutor> executorSupplier = () -> new ProcessExecutor().readOutput(true); |     private Supplier<ProcessExecutor> executorSupplier = () -> new ProcessExecutor().readOutput(true); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -29,6 +29,7 @@ import io.kamax.matrix._MatrixID; | |||||||
| import io.kamax.mxisd.UserIdType; | import io.kamax.mxisd.UserIdType; | ||||||
| import io.kamax.mxisd.auth.provider.AuthenticatorProvider; | import io.kamax.mxisd.auth.provider.AuthenticatorProvider; | ||||||
| import io.kamax.mxisd.auth.provider.BackendAuthResult; | import io.kamax.mxisd.auth.provider.BackendAuthResult; | ||||||
|  | import io.kamax.mxisd.config.FirebaseConfig; | ||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| @@ -38,10 +39,14 @@ import java.util.concurrent.TimeUnit; | |||||||
|  |  | ||||||
| public class GoogleFirebaseAuthenticator extends GoogleFirebaseBackend implements AuthenticatorProvider { | public class GoogleFirebaseAuthenticator extends GoogleFirebaseBackend implements AuthenticatorProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(GoogleFirebaseAuthenticator.class); |     private transient final Logger log = LoggerFactory.getLogger(GoogleFirebaseAuthenticator.class); | ||||||
|  |  | ||||||
|     private PhoneNumberUtil phoneUtil = PhoneNumberUtil.getInstance(); |     private PhoneNumberUtil phoneUtil = PhoneNumberUtil.getInstance(); | ||||||
|  |  | ||||||
|  |     public GoogleFirebaseAuthenticator(FirebaseConfig cfg) { | ||||||
|  |         this(cfg.isEnabled(), cfg.getCredentials(), cfg.getDatabase()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public GoogleFirebaseAuthenticator(boolean isEnabled, String credsPath, String db) { |     public GoogleFirebaseAuthenticator(boolean isEnabled, String credsPath, String db) { | ||||||
|         super(isEnabled, "AuthenticationProvider", credsPath, db); |         super(isEnabled, "AuthenticationProvider", credsPath, db); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -35,7 +35,7 @@ import java.io.IOException; | |||||||
|  |  | ||||||
| public class GoogleFirebaseBackend { | public class GoogleFirebaseBackend { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(GoogleFirebaseBackend.class); |     private transient final Logger log = LoggerFactory.getLogger(GoogleFirebaseBackend.class); | ||||||
|  |  | ||||||
|     private boolean isEnabled; |     private boolean isEnabled; | ||||||
|     private FirebaseAuth fbAuth; |     private FirebaseAuth fbAuth; | ||||||
|   | |||||||
| @@ -25,6 +25,7 @@ import com.google.firebase.tasks.OnFailureListener; | |||||||
| import com.google.firebase.tasks.OnSuccessListener; | import com.google.firebase.tasks.OnSuccessListener; | ||||||
| import io.kamax.matrix.MatrixID; | import io.kamax.matrix.MatrixID; | ||||||
| import io.kamax.matrix.ThreePidMedium; | import io.kamax.matrix.ThreePidMedium; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
| import io.kamax.mxisd.lookup.SingleLookupReply; | import io.kamax.mxisd.lookup.SingleLookupReply; | ||||||
| import io.kamax.mxisd.lookup.SingleLookupRequest; | import io.kamax.mxisd.lookup.SingleLookupRequest; | ||||||
| import io.kamax.mxisd.lookup.ThreePidMapping; | import io.kamax.mxisd.lookup.ThreePidMapping; | ||||||
| @@ -40,9 +41,13 @@ import java.util.concurrent.TimeUnit; | |||||||
|  |  | ||||||
| public class GoogleFirebaseProvider extends GoogleFirebaseBackend implements IThreePidProvider { | public class GoogleFirebaseProvider extends GoogleFirebaseBackend implements IThreePidProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(GoogleFirebaseProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(GoogleFirebaseProvider.class); | ||||||
|     private String domain; |     private String domain; | ||||||
|  |  | ||||||
|  |     public GoogleFirebaseProvider(MxisdConfig cfg) { | ||||||
|  |         this(cfg.getFirebase().isEnabled(), cfg.getFirebase().getCredentials(), cfg.getFirebase().getDatabase(), cfg.getMatrix().getDomain()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public GoogleFirebaseProvider(boolean isEnabled, String credsPath, String db, String domain) { |     public GoogleFirebaseProvider(boolean isEnabled, String credsPath, String db, String domain) { | ||||||
|         super(isEnabled, "ThreePidProvider", credsPath, db); |         super(isEnabled, "ThreePidProvider", credsPath, db); | ||||||
|         this.domain = domain; |         this.domain = domain; | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| /* | /* | ||||||
|  * mxisd - Matrix Identity Server Daemon |  * mxisd - Matrix Identity Server Daemon | ||||||
|  * Copyright (C) 2017 Kamax Sarl |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  * |  * | ||||||
|  * https://www.kamax.io/ |  * https://www.kamax.io/ | ||||||
|  * |  * | ||||||
| @@ -18,21 +18,26 @@ | |||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| package io.kamax.mxisd.spring; | package io.kamax.mxisd.backend.firebase; | ||||||
| 
 | 
 | ||||||
| import io.kamax.mxisd.exception.ConfigurationException; | import io.kamax.mxisd.Mxisd; | ||||||
| import org.springframework.boot.diagnostics.AbstractFailureAnalyzer; | import io.kamax.mxisd.auth.AuthProviders; | ||||||
| import org.springframework.boot.diagnostics.FailureAnalysis; | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
| 
 | 
 | ||||||
| public class ConfigurationFailureAnalyzer extends AbstractFailureAnalyzer<ConfigurationException> { | public class GoogleFirebaseStoreSupplier implements IdentityStoreSupplier { | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     protected FailureAnalysis analyze(Throwable rootFailure, ConfigurationException cause) { |     public void accept(Mxisd mxisd) { | ||||||
|         String message = cause.getMessage(); |         accept(mxisd.getConfig()); | ||||||
|         if (cause.getDetailedMessage().isPresent()) { |     } | ||||||
|             message += " - " + cause.getDetailedMessage().get(); | 
 | ||||||
|  |     public void accept(MxisdConfig cfg) { | ||||||
|  |         if (cfg.getFirebase().isEnabled()) { | ||||||
|  |             AuthProviders.register(() -> new GoogleFirebaseAuthenticator(cfg.getFirebase())); | ||||||
|  |             ThreePidProviders.register(() -> new GoogleFirebaseProvider(cfg)); | ||||||
|         } |         } | ||||||
|         return new FailureAnalysis(message, "Double check the key value", cause); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| @@ -43,8 +43,6 @@ import org.apache.directory.api.ldap.model.message.SearchScope; | |||||||
| import org.apache.directory.ldap.client.api.LdapConnection; | import org.apache.directory.ldap.client.api.LdapConnection; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| @@ -52,14 +50,12 @@ import java.util.List; | |||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class LdapAuthProvider extends LdapBackend implements AuthenticatorProvider { | public class LdapAuthProvider extends LdapBackend implements AuthenticatorProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(LdapAuthProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(LdapAuthProvider.class); | ||||||
|  |  | ||||||
|     private PhoneNumberUtil phoneUtil = PhoneNumberUtil.getInstance(); |     private PhoneNumberUtil phoneUtil = PhoneNumberUtil.getInstance(); | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public LdapAuthProvider(LdapConfig cfg, MatrixConfig mxCfg) { |     public LdapAuthProvider(LdapConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg, mxCfg); |         super(cfg, mxCfg); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -45,7 +45,7 @@ public abstract class LdapBackend { | |||||||
|     public static final String UID = "uid"; |     public static final String UID = "uid"; | ||||||
|     public static final String MATRIX_ID = "mxid"; |     public static final String MATRIX_ID = "mxid"; | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(LdapBackend.class); |     private transient final Logger log = LoggerFactory.getLogger(LdapBackend.class); | ||||||
|  |  | ||||||
|     private LdapConfig cfg; |     private LdapConfig cfg; | ||||||
|     private MatrixConfig mxCfg; |     private MatrixConfig mxCfg; | ||||||
|   | |||||||
| @@ -22,9 +22,9 @@ package io.kamax.mxisd.backend.ldap; | |||||||
|  |  | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.ldap.LdapConfig; | import io.kamax.mxisd.config.ldap.LdapConfig; | ||||||
| import io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchResult; | import io.kamax.mxisd.directory.DirectoryProvider; | ||||||
| import io.kamax.mxisd.directory.IDirectoryProvider; |  | ||||||
| import io.kamax.mxisd.exception.InternalServerError; | import io.kamax.mxisd.exception.InternalServerError; | ||||||
|  | import io.kamax.mxisd.http.io.UserDirectorySearchResult; | ||||||
| import io.kamax.mxisd.util.GsonUtil; | import io.kamax.mxisd.util.GsonUtil; | ||||||
| import org.apache.directory.api.ldap.model.cursor.CursorException; | import org.apache.directory.api.ldap.model.cursor.CursorException; | ||||||
| import org.apache.directory.api.ldap.model.cursor.CursorLdapReferralException; | import org.apache.directory.api.ldap.model.cursor.CursorLdapReferralException; | ||||||
| @@ -35,28 +35,19 @@ import org.apache.directory.api.ldap.model.message.SearchScope; | |||||||
| import org.apache.directory.ldap.client.api.LdapConnection; | import org.apache.directory.ldap.client.api.LdapConnection; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| @Component | public class LdapDirectoryProvider extends LdapBackend implements DirectoryProvider { | ||||||
| public class LdapDirectoryProvider extends LdapBackend implements IDirectoryProvider { |  | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(LdapDirectoryProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(LdapDirectoryProvider.class); | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public LdapDirectoryProvider(LdapConfig cfg, MatrixConfig mxCfg) { |     public LdapDirectoryProvider(LdapConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg, mxCfg); |         super(cfg, mxCfg); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return getCfg().isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     protected UserDirectorySearchResult search(String query, List<String> attributes) { |     protected UserDirectorySearchResult search(String query, List<String> attributes) { | ||||||
|         UserDirectorySearchResult result = new UserDirectorySearchResult(); |         UserDirectorySearchResult result = new UserDirectorySearchResult(); | ||||||
|         result.setLimited(false); |         result.setLimited(false); | ||||||
| @@ -95,7 +86,6 @@ public class LdapDirectoryProvider extends LdapBackend implements IDirectoryProv | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|         } catch (CursorLdapReferralException e) { |         } catch (CursorLdapReferralException e) { | ||||||
|             log.warn("An entry is only available via referral, skipping"); |             log.warn("An entry is only available via referral, skipping"); | ||||||
|         } catch (IOException | LdapException | CursorException e) { |         } catch (IOException | LdapException | CursorException e) { | ||||||
|   | |||||||
| @@ -36,8 +36,6 @@ import org.apache.directory.api.ldap.model.message.SearchScope; | |||||||
| import org.apache.directory.ldap.client.api.LdapConnection; | import org.apache.directory.ldap.client.api.LdapConnection; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| @@ -45,21 +43,14 @@ import java.util.Collections; | |||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class LdapProfileProvider extends LdapBackend implements ProfileProvider { | public class LdapProfileProvider extends LdapBackend implements ProfileProvider { | ||||||
|  |  | ||||||
|     private transient Logger log = LoggerFactory.getLogger(LdapProfileProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(LdapProfileProvider.class); | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public LdapProfileProvider(LdapConfig cfg, MatrixConfig mxCfg) { |     public LdapProfileProvider(LdapConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg, mxCfg); |         super(cfg, mxCfg); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return getCfg().isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Optional<String> getDisplayName(_MatrixID userId) { |     public Optional<String> getDisplayName(_MatrixID userId) { | ||||||
|         String uid = buildUidFromMatrixId(userId); |         String uid = buildUidFromMatrixId(userId); | ||||||
|   | |||||||
| @@ -0,0 +1,47 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend.ldap; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  | import io.kamax.mxisd.auth.AuthProviders; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  | import io.kamax.mxisd.profile.ProfileProviders; | ||||||
|  |  | ||||||
|  | public class LdapStoreSupplier implements IdentityStoreSupplier { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void accept(Mxisd mxisd) { | ||||||
|  |         accept(mxisd.getConfig()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void accept(MxisdConfig cfg) { | ||||||
|  |         if (cfg.getLdap().isEnabled()) { | ||||||
|  |             AuthProviders.register(() -> new LdapAuthProvider(cfg.getLdap(), cfg.getMatrix())); | ||||||
|  |             DirectoryProviders.register(() -> new LdapDirectoryProvider(cfg.getLdap(), cfg.getMatrix())); | ||||||
|  |             ThreePidProviders.register(() -> new LdapThreePidProvider(cfg.getLdap(), cfg.getMatrix())); | ||||||
|  |             ProfileProviders.register(() -> new LdapProfileProvider(cfg.getLdap(), cfg.getMatrix())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -37,27 +37,20 @@ import org.apache.directory.api.ldap.model.message.SearchScope; | |||||||
| import org.apache.directory.ldap.client.api.LdapConnection; | import org.apache.directory.ldap.client.api.LdapConnection; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class LdapThreePidProvider extends LdapBackend implements IThreePidProvider { | public class LdapThreePidProvider extends LdapBackend implements IThreePidProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(LdapThreePidProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(LdapThreePidProvider.class); | ||||||
|  |  | ||||||
|     public LdapThreePidProvider(LdapConfig cfg, MatrixConfig mxCfg) { |     public LdapThreePidProvider(LdapConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg, mxCfg); |         super(cfg, mxCfg); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return getCfg().isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isLocal() { |     public boolean isLocal() { | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
| @@ -23,9 +23,7 @@ package io.kamax.mxisd.backend.ldap.netiq; | |||||||
| import io.kamax.mxisd.backend.ldap.LdapAuthProvider; | import io.kamax.mxisd.backend.ldap.LdapAuthProvider; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class NetIqLdapAuthProvider extends LdapAuthProvider { | public class NetIqLdapAuthProvider extends LdapAuthProvider { | ||||||
|  |  | ||||||
|     public NetIqLdapAuthProvider(NetIqLdapConfig cfg, MatrixConfig mxCfg) { |     public NetIqLdapAuthProvider(NetIqLdapConfig cfg, MatrixConfig mxCfg) { | ||||||
|   | |||||||
| @@ -23,9 +23,7 @@ package io.kamax.mxisd.backend.ldap.netiq; | |||||||
| import io.kamax.mxisd.backend.ldap.LdapDirectoryProvider; | import io.kamax.mxisd.backend.ldap.LdapDirectoryProvider; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class NetIqLdapDirectoryProvider extends LdapDirectoryProvider { | public class NetIqLdapDirectoryProvider extends LdapDirectoryProvider { | ||||||
|  |  | ||||||
|     public NetIqLdapDirectoryProvider(NetIqLdapConfig cfg, MatrixConfig mxCfg) { |     public NetIqLdapDirectoryProvider(NetIqLdapConfig cfg, MatrixConfig mxCfg) { | ||||||
|   | |||||||
| @@ -24,13 +24,9 @@ import io.kamax.matrix._MatrixID; | |||||||
| import io.kamax.mxisd.backend.ldap.LdapProfileProvider; | import io.kamax.mxisd.backend.ldap.LdapProfileProvider; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class NetIqLdapProfileProvider extends LdapProfileProvider { | public class NetIqLdapProfileProvider extends LdapProfileProvider { | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public NetIqLdapProfileProvider(NetIqLdapConfig cfg, MatrixConfig mxCfg) { |     public NetIqLdapProfileProvider(NetIqLdapConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg, mxCfg); |         super(cfg, mxCfg); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -0,0 +1,47 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend.ldap.netiq; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  | import io.kamax.mxisd.auth.AuthProviders; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  | import io.kamax.mxisd.profile.ProfileProviders; | ||||||
|  |  | ||||||
|  | public class NetIqLdapStoreSupplier implements IdentityStoreSupplier { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void accept(Mxisd mxisd) { | ||||||
|  |         accept(mxisd.getConfig()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void accept(MxisdConfig cfg) { | ||||||
|  |         if (cfg.getNetiq().isEnabled()) { | ||||||
|  |             AuthProviders.register(() -> new NetIqLdapAuthProvider(cfg.getNetiq(), cfg.getMatrix())); | ||||||
|  |             DirectoryProviders.register(() -> new NetIqLdapDirectoryProvider(cfg.getNetiq(), cfg.getMatrix())); | ||||||
|  |             ThreePidProviders.register(() -> new NetIqLdapThreePidProvider(cfg.getNetiq(), cfg.getMatrix())); | ||||||
|  |             ProfileProviders.register(() -> new NetIqLdapProfileProvider(cfg.getNetiq(), cfg.getMatrix())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -23,9 +23,7 @@ package io.kamax.mxisd.backend.ldap.netiq; | |||||||
| import io.kamax.mxisd.backend.ldap.LdapThreePidProvider; | import io.kamax.mxisd.backend.ldap.LdapThreePidProvider; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class NetIqLdapThreePidProvider extends LdapThreePidProvider { | public class NetIqLdapThreePidProvider extends LdapThreePidProvider { | ||||||
|  |  | ||||||
|     public NetIqLdapThreePidProvider(NetIqLdapConfig cfg, MatrixConfig mxCfg) { |     public NetIqLdapThreePidProvider(NetIqLdapConfig cfg, MatrixConfig mxCfg) { | ||||||
|   | |||||||
| @@ -31,8 +31,8 @@ import io.kamax.mxisd.config.MatrixConfig; | |||||||
| import io.kamax.mxisd.config.memory.MemoryIdentityConfig; | import io.kamax.mxisd.config.memory.MemoryIdentityConfig; | ||||||
| import io.kamax.mxisd.config.memory.MemoryStoreConfig; | import io.kamax.mxisd.config.memory.MemoryStoreConfig; | ||||||
| import io.kamax.mxisd.config.memory.MemoryThreePid; | import io.kamax.mxisd.config.memory.MemoryThreePid; | ||||||
| import io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchResult; | import io.kamax.mxisd.directory.DirectoryProvider; | ||||||
| import io.kamax.mxisd.directory.IDirectoryProvider; | import io.kamax.mxisd.http.io.UserDirectorySearchResult; | ||||||
| import io.kamax.mxisd.lookup.SingleLookupReply; | import io.kamax.mxisd.lookup.SingleLookupReply; | ||||||
| import io.kamax.mxisd.lookup.SingleLookupRequest; | import io.kamax.mxisd.lookup.SingleLookupRequest; | ||||||
| import io.kamax.mxisd.lookup.ThreePidMapping; | import io.kamax.mxisd.lookup.ThreePidMapping; | ||||||
| @@ -41,8 +41,6 @@ import io.kamax.mxisd.profile.ProfileProvider; | |||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| @@ -51,15 +49,13 @@ import java.util.Optional; | |||||||
| import java.util.function.Function; | import java.util.function.Function; | ||||||
| import java.util.function.Predicate; | import java.util.function.Predicate; | ||||||
|  |  | ||||||
| @Component | public class MemoryIdentityStore implements AuthenticatorProvider, DirectoryProvider, IThreePidProvider, ProfileProvider { | ||||||
| public class MemoryIdentityStore implements AuthenticatorProvider, IDirectoryProvider, IThreePidProvider, ProfileProvider { |  | ||||||
|  |  | ||||||
|     private final Logger logger = LoggerFactory.getLogger(MemoryIdentityStore.class); |     private transient final Logger logger = LoggerFactory.getLogger(MemoryIdentityStore.class); | ||||||
|  |  | ||||||
|     private final MatrixConfig mxCfg; |     private final MatrixConfig mxCfg; | ||||||
|     private final MemoryStoreConfig cfg; |     private final MemoryStoreConfig cfg; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public MemoryIdentityStore(MatrixConfig mxCfg, MemoryStoreConfig cfg) { |     public MemoryIdentityStore(MatrixConfig mxCfg, MemoryStoreConfig cfg) { | ||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
|         this.cfg = cfg; |         this.cfg = cfg; | ||||||
|   | |||||||
| @@ -0,0 +1,51 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend.memory; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  | import io.kamax.mxisd.auth.AuthProviders; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  | import io.kamax.mxisd.profile.ProfileProviders; | ||||||
|  |  | ||||||
|  | import java.util.function.Supplier; | ||||||
|  |  | ||||||
|  | public class MemoryIdentityStoreSupplier implements IdentityStoreSupplier { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void accept(Mxisd mxisd) { | ||||||
|  |         accept(mxisd.getConfig()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void accept(MxisdConfig cfg) { | ||||||
|  |         if (cfg.getMemory().isEnabled()) { | ||||||
|  |             Supplier<MemoryIdentityStore> supplier = () -> new MemoryIdentityStore(cfg.getMatrix(), cfg.getMemory()); | ||||||
|  |  | ||||||
|  |             AuthProviders.register(supplier); | ||||||
|  |             DirectoryProviders.register(supplier); | ||||||
|  |             ThreePidProviders.register(supplier); | ||||||
|  |             ProfileProviders.register(supplier); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -27,15 +27,11 @@ import io.kamax.mxisd.config.rest.RestBackendConfig; | |||||||
| import io.kamax.mxisd.util.RestClientUtils; | import io.kamax.mxisd.util.RestClientUtils; | ||||||
| import org.apache.http.client.methods.CloseableHttpResponse; | import org.apache.http.client.methods.CloseableHttpResponse; | ||||||
| import org.apache.http.client.methods.HttpUriRequest; | import org.apache.http.client.methods.HttpUriRequest; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class RestAuthProvider extends RestProvider implements AuthenticatorProvider { | public class RestAuthProvider extends RestProvider implements AuthenticatorProvider { | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public RestAuthProvider(RestBackendConfig cfg) { |     public RestAuthProvider(RestBackendConfig cfg) { | ||||||
|         super(cfg); |         super(cfg); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -23,21 +23,18 @@ package io.kamax.mxisd.backend.rest; | |||||||
| import io.kamax.matrix.MatrixID; | import io.kamax.matrix.MatrixID; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.rest.RestBackendConfig; | import io.kamax.mxisd.config.rest.RestBackendConfig; | ||||||
| import io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchRequest; | import io.kamax.mxisd.directory.DirectoryProvider; | ||||||
| import io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchResult; |  | ||||||
| import io.kamax.mxisd.directory.IDirectoryProvider; |  | ||||||
| import io.kamax.mxisd.exception.InternalServerError; | import io.kamax.mxisd.exception.InternalServerError; | ||||||
|  | import io.kamax.mxisd.http.io.UserDirectorySearchRequest; | ||||||
|  | import io.kamax.mxisd.http.io.UserDirectorySearchResult; | ||||||
| import io.kamax.mxisd.util.RestClientUtils; | import io.kamax.mxisd.util.RestClientUtils; | ||||||
| import org.apache.commons.io.IOUtils; | import org.apache.commons.io.IOUtils; | ||||||
| import org.apache.commons.lang.StringUtils; |  | ||||||
| import org.apache.http.client.methods.CloseableHttpResponse; | import org.apache.http.client.methods.CloseableHttpResponse; | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.nio.charset.StandardCharsets; | import java.nio.charset.StandardCharsets; | ||||||
|  |  | ||||||
| @Component | public class RestDirectoryProvider extends RestProvider implements DirectoryProvider { | ||||||
| public class RestDirectoryProvider extends RestProvider implements IDirectoryProvider { |  | ||||||
|  |  | ||||||
|     private MatrixConfig mxCfg; |     private MatrixConfig mxCfg; | ||||||
|  |  | ||||||
| @@ -46,11 +43,6 @@ public class RestDirectoryProvider extends RestProvider implements IDirectoryPro | |||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.isEnabled() && StringUtils.isNotBlank(cfg.getEndpoints().getDirectory()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private UserDirectorySearchResult search(String by, String query) { |     private UserDirectorySearchResult search(String by, String query) { | ||||||
|         UserDirectorySearchRequest request = new UserDirectorySearchRequest(query); |         UserDirectorySearchRequest request = new UserDirectorySearchRequest(query); | ||||||
|         request.setBy(by); |         request.setBy(by); | ||||||
|   | |||||||
| @@ -40,7 +40,6 @@ import org.apache.http.entity.ContentType; | |||||||
| import org.apache.http.entity.StringEntity; | import org.apache.http.entity.StringEntity; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.net.URISyntaxException; | import java.net.URISyntaxException; | ||||||
| @@ -48,20 +47,14 @@ import java.nio.charset.StandardCharsets; | |||||||
| import java.util.*; | import java.util.*; | ||||||
| import java.util.function.Function; | import java.util.function.Function; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class RestProfileProvider extends RestProvider implements ProfileProvider { | public class RestProfileProvider extends RestProvider implements ProfileProvider { | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(RestProfileProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(RestProfileProvider.class); | ||||||
|  |  | ||||||
|     public RestProfileProvider(RestBackendConfig cfg) { |     public RestProfileProvider(RestBackendConfig cfg) { | ||||||
|         super(cfg); |         super(cfg); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.isEnabled() && cfg.getEndpoints().getProfile().isPresent(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private <T> Optional<T> doRequest( |     private <T> Optional<T> doRequest( | ||||||
|             _MatrixID userId, |             _MatrixID userId, | ||||||
|             Function<RestBackendConfig.ProfileEndpoints, Optional<String>> endpoint, |             Function<RestBackendConfig.ProfileEndpoints, Optional<String>> endpoint, | ||||||
|   | |||||||
| @@ -0,0 +1,47 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend.rest; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  | import io.kamax.mxisd.auth.AuthProviders; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  | import io.kamax.mxisd.profile.ProfileProviders; | ||||||
|  |  | ||||||
|  | public class RestStoreSupplier implements IdentityStoreSupplier { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void accept(Mxisd mxisd) { | ||||||
|  |         accept(mxisd.getConfig()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void accept(MxisdConfig cfg) { | ||||||
|  |         if (cfg.getRest().isEnabled()) { | ||||||
|  |             AuthProviders.register(() -> new RestAuthProvider(cfg.getRest())); | ||||||
|  |             DirectoryProviders.register(() -> new RestDirectoryProvider(cfg.getRest(), cfg.getMatrix())); | ||||||
|  |             ThreePidProviders.register(() -> new RestThreePidProvider(cfg.getRest(), cfg.getMatrix())); | ||||||
|  |             ProfileProviders.register(() -> new RestProfileProvider(cfg.getRest())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -35,8 +35,6 @@ import org.apache.http.client.methods.CloseableHttpResponse; | |||||||
| import org.apache.http.client.methods.HttpUriRequest; | import org.apache.http.client.methods.HttpUriRequest; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| @@ -44,14 +42,12 @@ import java.util.List; | |||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class RestThreePidProvider extends RestProvider implements IThreePidProvider { | public class RestThreePidProvider extends RestProvider implements IThreePidProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(RestThreePidProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(RestThreePidProvider.class); | ||||||
|  |  | ||||||
|     private MatrixConfig mxCfg; // FIXME should be done in the lookup manager |     private MatrixConfig mxCfg; // FIXME should be done in the lookup manager | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public RestThreePidProvider(RestBackendConfig cfg, MatrixConfig mxCfg) { |     public RestThreePidProvider(RestBackendConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg); |         super(cfg); | ||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
| @@ -66,11 +62,6 @@ public class RestThreePidProvider extends RestProvider implements IThreePidProvi | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isLocal() { |     public boolean isLocal() { | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
| @@ -39,7 +39,7 @@ import java.util.Optional; | |||||||
|  |  | ||||||
| public abstract class SqlProfileProvider implements ProfileProvider { | public abstract class SqlProfileProvider implements ProfileProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(SqlProfileProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(SqlProfileProvider.class); | ||||||
|  |  | ||||||
|     private SqlConfig.Profile cfg; |     private SqlConfig.Profile cfg; | ||||||
|  |  | ||||||
| @@ -50,11 +50,6 @@ public abstract class SqlProfileProvider implements ProfileProvider { | |||||||
|         this.pool = new SqlConnectionPool(cfg); |         this.pool = new SqlConnectionPool(cfg); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Optional<String> getDisplayName(_MatrixID user) { |     public Optional<String> getDisplayName(_MatrixID user) { | ||||||
|         String stmtSql = cfg.getDisplayName().getQuery(); |         String stmtSql = cfg.getDisplayName().getQuery(); | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ import java.util.Optional; | |||||||
|  |  | ||||||
| public abstract class SqlThreePidProvider implements IThreePidProvider { | public abstract class SqlThreePidProvider implements IThreePidProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(SqlThreePidProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(SqlThreePidProvider.class); | ||||||
|  |  | ||||||
|     private SqlConfig cfg; |     private SqlConfig cfg; | ||||||
|     private MatrixConfig mxCfg; |     private MatrixConfig mxCfg; | ||||||
| @@ -54,11 +54,6 @@ public abstract class SqlThreePidProvider implements IThreePidProvider { | |||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isLocal() { |     public boolean isLocal() { | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
| @@ -27,20 +27,19 @@ import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | |||||||
| import io.kamax.mxisd.invitation.InvitationManager; | import io.kamax.mxisd.invitation.InvitationManager; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class GenericSqlAuthProvider implements AuthenticatorProvider { | public class GenericSqlAuthProvider implements AuthenticatorProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(GenericSqlAuthProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(GenericSqlAuthProvider.class); | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     private GenericSqlProviderConfig cfg; |     private GenericSqlProviderConfig cfg; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     private InvitationManager invMgr; |     private InvitationManager invMgr; | ||||||
|  |  | ||||||
|  |     public GenericSqlAuthProvider(GenericSqlProviderConfig cfg, InvitationManager invMgr) { | ||||||
|  |         this.cfg = cfg; | ||||||
|  |         this.invMgr = invMgr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isEnabled() { |     public boolean isEnabled() { | ||||||
|         return cfg.getAuth().isEnabled(); |         return cfg.getAuth().isEnabled(); | ||||||
|   | |||||||
| @@ -25,9 +25,9 @@ import io.kamax.mxisd.backend.sql.SqlConnectionPool; | |||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.sql.SqlConfig; | import io.kamax.mxisd.config.sql.SqlConfig; | ||||||
| import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | ||||||
| import io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchResult; | import io.kamax.mxisd.directory.DirectoryProvider; | ||||||
| import io.kamax.mxisd.directory.IDirectoryProvider; |  | ||||||
| import io.kamax.mxisd.exception.InternalServerError; | import io.kamax.mxisd.exception.InternalServerError; | ||||||
|  | import io.kamax.mxisd.http.io.UserDirectorySearchResult; | ||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| @@ -38,11 +38,11 @@ import java.sql.ResultSet; | |||||||
| import java.sql.SQLException; | import java.sql.SQLException; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
|  |  | ||||||
| import static io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchResult.Result; | import static io.kamax.mxisd.http.io.UserDirectorySearchResult.Result; | ||||||
|  |  | ||||||
| public abstract class GenericSqlDirectoryProvider implements IDirectoryProvider { | public class GenericSqlDirectoryProvider implements DirectoryProvider { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(GenericSqlDirectoryProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(GenericSqlDirectoryProvider.class); | ||||||
|  |  | ||||||
|     protected SqlConfig cfg; |     protected SqlConfig cfg; | ||||||
|     protected MatrixConfig mxCfg; |     protected MatrixConfig mxCfg; | ||||||
| @@ -55,11 +55,6 @@ public abstract class GenericSqlDirectoryProvider implements IDirectoryProvider | |||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return cfg.getDirectory().isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     protected void setParameters(PreparedStatement stmt, String searchTerm) throws SQLException { |     protected void setParameters(PreparedStatement stmt, String searchTerm) throws SQLException { | ||||||
|         for (int i = 1; i <= stmt.getParameterMetaData().getParameterCount(); i++) { |         for (int i = 1; i <= stmt.getParameterMetaData().getParameterCount(); i++) { | ||||||
|             stmt.setString(i, searchTerm); |             stmt.setString(i, searchTerm); | ||||||
|   | |||||||
| @@ -22,9 +22,7 @@ package io.kamax.mxisd.backend.sql.generic; | |||||||
|  |  | ||||||
| import io.kamax.mxisd.backend.sql.SqlProfileProvider; | import io.kamax.mxisd.backend.sql.SqlProfileProvider; | ||||||
| import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class GenericSqlProfileProvider extends SqlProfileProvider { | public class GenericSqlProfileProvider extends SqlProfileProvider { | ||||||
|  |  | ||||||
|     public GenericSqlProfileProvider(GenericSqlProviderConfig cfg) { |     public GenericSqlProfileProvider(GenericSqlProviderConfig cfg) { | ||||||
|   | |||||||
| @@ -0,0 +1,51 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend.sql.generic; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  | import io.kamax.mxisd.auth.AuthProviders; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  | import io.kamax.mxisd.profile.ProfileProviders; | ||||||
|  |  | ||||||
|  | public class GenericSqlStoreSupplier implements IdentityStoreSupplier { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void accept(Mxisd mxisd) { | ||||||
|  |         if (mxisd.getConfig().getSql().getAuth().isEnabled()) { | ||||||
|  |             AuthProviders.register(() -> new GenericSqlAuthProvider(mxisd.getConfig().getSql(), mxisd.getInvitationManager())); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (mxisd.getConfig().getSql().getDirectory().isEnabled()) { | ||||||
|  |             DirectoryProviders.register(() -> new GenericSqlDirectoryProvider(mxisd.getConfig().getSql(), mxisd.getConfig().getMatrix())); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (mxisd.getConfig().getSql().getIdentity().isEnabled()) { | ||||||
|  |             ThreePidProviders.register(() -> new GenericSqlThreePidProvider(mxisd.getConfig().getSql(), mxisd.getConfig().getMatrix())); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (mxisd.getConfig().getSql().getProfile().isEnabled()) { | ||||||
|  |             ProfileProviders.register(() -> new GenericSqlProfileProvider(mxisd.getConfig().getSql())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -23,13 +23,9 @@ package io.kamax.mxisd.backend.sql.generic; | |||||||
| import io.kamax.mxisd.backend.sql.SqlThreePidProvider; | import io.kamax.mxisd.backend.sql.SqlThreePidProvider; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class GenericSqlThreePidProvider extends SqlThreePidProvider { | public class GenericSqlThreePidProvider extends SqlThreePidProvider { | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public GenericSqlThreePidProvider(GenericSqlProviderConfig cfg, MatrixConfig mxCfg) { |     public GenericSqlThreePidProvider(GenericSqlProviderConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg, mxCfg); |         super(cfg, mxCfg); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -22,19 +22,15 @@ package io.kamax.mxisd.backend.sql.synapse; | |||||||
|  |  | ||||||
| import io.kamax.mxisd.backend.sql.SqlConnectionPool; | import io.kamax.mxisd.backend.sql.SqlConnectionPool; | ||||||
| import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.sql.PreparedStatement; | import java.sql.PreparedStatement; | ||||||
| import java.sql.ResultSet; | import java.sql.ResultSet; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class Synapse { | public class Synapse { | ||||||
|  |  | ||||||
|     private SqlConnectionPool pool; |     private SqlConnectionPool pool; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public Synapse(SynapseSqlProviderConfig sqlCfg) { |     public Synapse(SynapseSqlProviderConfig sqlCfg) { | ||||||
|         this.pool = new SqlConnectionPool(sqlCfg); |         this.pool = new SqlConnectionPool(sqlCfg); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -24,32 +24,15 @@ import io.kamax.mxisd.backend.sql.generic.GenericSqlDirectoryProvider; | |||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | ||||||
| import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
| import java.sql.PreparedStatement; | import java.sql.PreparedStatement; | ||||||
| import java.sql.SQLException; | import java.sql.SQLException; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class SynapseSqlDirectoryProvider extends GenericSqlDirectoryProvider { | public class SynapseSqlDirectoryProvider extends GenericSqlDirectoryProvider { | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public SynapseSqlDirectoryProvider(SynapseSqlProviderConfig cfg, MatrixConfig mxCfg) { |     public SynapseSqlDirectoryProvider(SynapseSqlProviderConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg, mxCfg); |         super(cfg, mxCfg); | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     protected void setParameters(PreparedStatement stmt, String searchTerm) throws SQLException { |  | ||||||
|         stmt.setString(1, "%" + searchTerm + "%"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |  | ||||||
|         if (!isEnabled()) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         GenericSqlProviderConfig.Type queries = cfg.getDirectory().getQuery(); |         GenericSqlProviderConfig.Type queries = cfg.getDirectory().getQuery(); | ||||||
|         if (Objects.isNull(queries.getName().getValue())) { |         if (Objects.isNull(queries.getName().getValue())) { | ||||||
| @@ -60,4 +43,9 @@ public class SynapseSqlDirectoryProvider extends GenericSqlDirectoryProvider { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     protected void setParameters(PreparedStatement stmt, String searchTerm) throws SQLException { | ||||||
|  |         stmt.setString(1, "%" + searchTerm + "%"); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -22,13 +22,9 @@ package io.kamax.mxisd.backend.sql.synapse; | |||||||
|  |  | ||||||
| import io.kamax.mxisd.backend.sql.SqlProfileProvider; | import io.kamax.mxisd.backend.sql.SqlProfileProvider; | ||||||
| import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class SynapseSqlProfileProvider extends SqlProfileProvider { | public class SynapseSqlProfileProvider extends SqlProfileProvider { | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public SynapseSqlProfileProvider(SynapseSqlProviderConfig cfg) { |     public SynapseSqlProfileProvider(SynapseSqlProviderConfig cfg) { | ||||||
|         super(cfg); |         super(cfg); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -0,0 +1,51 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend.sql.synapse; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.config.MxisdConfig; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  | import io.kamax.mxisd.profile.ProfileProviders; | ||||||
|  |  | ||||||
|  | public class SynapseSqlStoreSupplier implements IdentityStoreSupplier { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void accept(Mxisd mxisd) { | ||||||
|  |         accept(mxisd.getConfig()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void accept(MxisdConfig cfg) { | ||||||
|  |         if (cfg.getSynapseSql().getDirectory().isEnabled()) { | ||||||
|  |             DirectoryProviders.register(() -> new SynapseSqlDirectoryProvider(cfg.getSynapseSql(), cfg.getMatrix())); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (cfg.getSynapseSql().getIdentity().isEnabled()) { | ||||||
|  |             ThreePidProviders.register(() -> new SynapseSqlThreePidProvider(cfg.getSynapseSql(), cfg.getMatrix())); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (cfg.getSynapseSql().getProfile().isEnabled()) { | ||||||
|  |             ProfileProviders.register(() -> new SynapseSqlProfileProvider(cfg.getSynapseSql())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -23,13 +23,9 @@ package io.kamax.mxisd.backend.sql.synapse; | |||||||
| import io.kamax.mxisd.backend.sql.SqlThreePidProvider; | import io.kamax.mxisd.backend.sql.SqlThreePidProvider; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class SynapseSqlThreePidProvider extends SqlThreePidProvider { | public class SynapseSqlThreePidProvider extends SqlThreePidProvider { | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public SynapseSqlThreePidProvider(SynapseSqlProviderConfig cfg, MatrixConfig mxCfg) { |     public SynapseSqlThreePidProvider(SynapseSqlProviderConfig cfg, MatrixConfig mxCfg) { | ||||||
|         super(cfg, mxCfg); |         super(cfg, mxCfg); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -28,17 +28,13 @@ import io.kamax.mxisd.auth.provider.BackendAuthResult; | |||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class WordpressAuthProvider implements AuthenticatorProvider { | public class WordpressAuthProvider implements AuthenticatorProvider { | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(WordpressAuthProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(WordpressAuthProvider.class); | ||||||
|  |  | ||||||
|     private WordpressRestBackend wordpress; |     private WordpressRestBackend wordpress; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public WordpressAuthProvider(WordpressRestBackend wordpress) { |     public WordpressAuthProvider(WordpressRestBackend wordpress) { | ||||||
|         this.wordpress = wordpress; |         this.wordpress = wordpress; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -23,13 +23,11 @@ package io.kamax.mxisd.backend.wordpress; | |||||||
| import io.kamax.matrix.MatrixID; | import io.kamax.matrix.MatrixID; | ||||||
| import io.kamax.mxisd.config.MatrixConfig; | import io.kamax.mxisd.config.MatrixConfig; | ||||||
| import io.kamax.mxisd.config.wordpress.WordpressConfig; | import io.kamax.mxisd.config.wordpress.WordpressConfig; | ||||||
| import io.kamax.mxisd.controller.directory.v1.io.UserDirectorySearchResult; | import io.kamax.mxisd.directory.DirectoryProvider; | ||||||
| import io.kamax.mxisd.directory.IDirectoryProvider; |  | ||||||
| import io.kamax.mxisd.exception.InternalServerError; | import io.kamax.mxisd.exception.InternalServerError; | ||||||
|  | import io.kamax.mxisd.http.io.UserDirectorySearchResult; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.sql.Connection; | import java.sql.Connection; | ||||||
| import java.sql.PreparedStatement; | import java.sql.PreparedStatement; | ||||||
| @@ -37,27 +35,20 @@ import java.sql.ResultSet; | |||||||
| import java.sql.SQLException; | import java.sql.SQLException; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
|  |  | ||||||
| @Component | public class WordpressDirectoryProvider implements DirectoryProvider { | ||||||
| public class WordpressDirectoryProvider implements IDirectoryProvider { |  | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(WordpressDirectoryProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(WordpressDirectoryProvider.class); | ||||||
|  |  | ||||||
|     private WordpressConfig cfg; |     private WordpressConfig cfg; | ||||||
|     private WordressSqlBackend wordpress; |     private WordressSqlBackend wordpress; | ||||||
|     private MatrixConfig mxCfg; |     private MatrixConfig mxCfg; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public WordpressDirectoryProvider(WordpressConfig cfg, WordressSqlBackend wordpress, MatrixConfig mxCfg) { |     public WordpressDirectoryProvider(WordpressConfig cfg, WordressSqlBackend wordpress, MatrixConfig mxCfg) { | ||||||
|         this.cfg = cfg; |         this.cfg = cfg; | ||||||
|         this.wordpress = wordpress; |         this.wordpress = wordpress; | ||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return wordpress.isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     protected void setParameters(PreparedStatement stmt, String searchTerm) throws SQLException { |     protected void setParameters(PreparedStatement stmt, String searchTerm) throws SQLException { | ||||||
|         for (int i = 1; i <= stmt.getParameterMetaData().getParameterCount(); i++) { |         for (int i = 1; i <= stmt.getParameterMetaData().getParameterCount(); i++) { | ||||||
|             stmt.setString(i, "%" + searchTerm + "%"); |             stmt.setString(i, "%" + searchTerm + "%"); | ||||||
|   | |||||||
| @@ -34,15 +34,12 @@ import org.apache.http.impl.client.CloseableHttpClient; | |||||||
| import org.apache.http.util.EntityUtils; | import org.apache.http.util.EntityUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class WordpressRestBackend { | public class WordpressRestBackend { | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(WordpressRestBackend.class); |     private transient final Logger log = LoggerFactory.getLogger(WordpressRestBackend.class); | ||||||
|     private final String jsonPath = "/wp-json"; |     private final String jsonPath = "/wp-json"; | ||||||
|     private final String jwtPath = "/jwt-auth/v1"; |     private final String jwtPath = "/jwt-auth/v1"; | ||||||
|  |  | ||||||
| @@ -54,7 +51,6 @@ public class WordpressRestBackend { | |||||||
|  |  | ||||||
|     private String token; |     private String token; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public WordpressRestBackend(WordpressConfig cfg, CloseableHttpClient client) { |     public WordpressRestBackend(WordpressConfig cfg, CloseableHttpClient client) { | ||||||
|         this.cfg = cfg; |         this.cfg = cfg; | ||||||
|         this.client = client; |         this.client = client; | ||||||
|   | |||||||
| @@ -0,0 +1,48 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sarl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.backend.wordpress; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.Mxisd; | ||||||
|  | import io.kamax.mxisd.auth.AuthProviders; | ||||||
|  | import io.kamax.mxisd.backend.IdentityStoreSupplier; | ||||||
|  | import io.kamax.mxisd.config.MatrixConfig; | ||||||
|  | import io.kamax.mxisd.config.wordpress.WordpressConfig; | ||||||
|  | import io.kamax.mxisd.directory.DirectoryProviders; | ||||||
|  | import io.kamax.mxisd.lookup.ThreePidProviders; | ||||||
|  |  | ||||||
|  | public class WordpressStoreSupplier implements IdentityStoreSupplier { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void accept(Mxisd m) { | ||||||
|  |         WordpressConfig wpCfg = m.getConfig().getWordpress(); | ||||||
|  |         MatrixConfig mxCfg = m.getConfig().getMatrix(); | ||||||
|  |  | ||||||
|  |         if (m.getConfig().getWordpress().isEnabled()) { | ||||||
|  |             WordpressRestBackend restBackend = new WordpressRestBackend(wpCfg, m.getHttpClient()); | ||||||
|  |             WordressSqlBackend sqlBackend = new WordressSqlBackend(wpCfg); | ||||||
|  |  | ||||||
|  |             AuthProviders.register(() -> new WordpressAuthProvider(restBackend)); | ||||||
|  |             DirectoryProviders.register(() -> new WordpressDirectoryProvider(wpCfg, sqlBackend, mxCfg)); | ||||||
|  |             ThreePidProviders.register(() -> new WordpressThreePidProvider(mxCfg, wpCfg, sqlBackend)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -31,8 +31,6 @@ import io.kamax.mxisd.lookup.ThreePidMapping; | |||||||
| import io.kamax.mxisd.lookup.provider.IThreePidProvider; | import io.kamax.mxisd.lookup.provider.IThreePidProvider; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.sql.Connection; | import java.sql.Connection; | ||||||
| import java.sql.PreparedStatement; | import java.sql.PreparedStatement; | ||||||
| @@ -42,27 +40,20 @@ import java.util.List; | |||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class WordpressThreePidProvider implements IThreePidProvider { | public class WordpressThreePidProvider implements IThreePidProvider { | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(WordpressThreePidProvider.class); |     private transient final Logger log = LoggerFactory.getLogger(WordpressThreePidProvider.class); | ||||||
|  |  | ||||||
|     private MatrixConfig mxCfg; |     private MatrixConfig mxCfg; | ||||||
|     private WordpressConfig cfg; |     private WordpressConfig cfg; | ||||||
|     private WordressSqlBackend wordpress; |     private WordressSqlBackend wordpress; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public WordpressThreePidProvider(MatrixConfig mxCfg, WordpressConfig cfg, WordressSqlBackend wordpress) { |     public WordpressThreePidProvider(MatrixConfig mxCfg, WordpressConfig cfg, WordressSqlBackend wordpress) { | ||||||
|         this.mxCfg = mxCfg; |         this.mxCfg = mxCfg; | ||||||
|         this.cfg = cfg; |         this.cfg = cfg; | ||||||
|         this.wordpress = wordpress; |         this.wordpress = wordpress; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isEnabled() { |  | ||||||
|         return wordpress.isEnabled(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean isLocal() { |     public boolean isLocal() { | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
| @@ -24,22 +24,17 @@ import com.mchange.v2.c3p0.ComboPooledDataSource; | |||||||
| import io.kamax.mxisd.config.wordpress.WordpressConfig; | import io.kamax.mxisd.config.wordpress.WordpressConfig; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.stereotype.Component; |  | ||||||
|  |  | ||||||
| import java.sql.Connection; | import java.sql.Connection; | ||||||
| import java.sql.SQLException; | import java.sql.SQLException; | ||||||
|  |  | ||||||
| @Component |  | ||||||
| public class WordressSqlBackend { | public class WordressSqlBackend { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(WordressSqlBackend.class); |     private transient final Logger log = LoggerFactory.getLogger(WordressSqlBackend.class); | ||||||
|  |  | ||||||
|     private WordpressConfig cfg; |     private WordpressConfig cfg; | ||||||
|  |  | ||||||
|     private ComboPooledDataSource ds; |     private ComboPooledDataSource ds; | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public WordressSqlBackend(WordpressConfig cfg) { |     public WordressSqlBackend(WordpressConfig cfg) { | ||||||
|         this.cfg = cfg; |         this.cfg = cfg; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,16 +20,10 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.regex.Pattern; | import java.util.regex.Pattern; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties(prefix = "auth") |  | ||||||
| public class AuthenticationConfig { | public class AuthenticationConfig { | ||||||
|  |  | ||||||
|     public static class Rule { |     public static class Rule { | ||||||
| @@ -102,7 +96,6 @@ public class AuthenticationConfig { | |||||||
|         this.rewrite = rewrite; |         this.rewrite = rewrite; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         getRewrite().getUser().getRules().forEach(mapping -> mapping.setPattern(Pattern.compile(mapping.getRegex()))); |         getRewrite().getUser().getRules().forEach(mapping -> mapping.setPattern(Pattern.compile(mapping.getRegex()))); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -20,14 +20,8 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties(prefix = "lookup.bulk") |  | ||||||
| public class BulkLookupConfig { | public class BulkLookupConfig { | ||||||
|  |  | ||||||
|     private Boolean enabled; |     private Boolean enabled; | ||||||
| @@ -40,7 +34,6 @@ public class BulkLookupConfig { | |||||||
|         this.enabled = enabled; |         this.enabled = enabled; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         if (Objects.isNull(enabled)) { |         if (Objects.isNull(enabled)) { | ||||||
|             enabled = true; |             enabled = true; | ||||||
|   | |||||||
| @@ -22,16 +22,10 @@ package io.kamax.mxisd.config; | |||||||
|  |  | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("directory") |  | ||||||
| public class DirectoryConfig { | public class DirectoryConfig { | ||||||
|  |  | ||||||
|     private final transient Logger log = LoggerFactory.getLogger(DnsOverwriteConfig.class); |     private final static Logger log = LoggerFactory.getLogger(DirectoryConfig.class); | ||||||
|  |  | ||||||
|     public static class Exclude { |     public static class Exclude { | ||||||
|  |  | ||||||
| @@ -67,8 +61,7 @@ public class DirectoryConfig { | |||||||
|         this.exclude = exclude; |         this.exclude = exclude; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |     public void build() { | ||||||
|     public void buid() { |  | ||||||
|         log.info("--- Directory config ---"); |         log.info("--- Directory config ---"); | ||||||
|         log.info("Exclude:"); |         log.info("Exclude:"); | ||||||
|         log.info("\tHomeserver: {}", getExclude().getHomeserver()); |         log.info("\tHomeserver: {}", getExclude().getHomeserver()); | ||||||
|   | |||||||
| @@ -24,18 +24,13 @@ import com.google.gson.Gson; | |||||||
| import io.kamax.mxisd.util.GsonUtil; | import io.kamax.mxisd.util.GsonUtil; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("dns.overwrite") |  | ||||||
| public class DnsOverwriteConfig { | public class DnsOverwriteConfig { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(DnsOverwriteConfig.class); |     private transient final Logger log = LoggerFactory.getLogger(DnsOverwriteConfig.class); | ||||||
|  |  | ||||||
|     public static class Entry { |     public static class Entry { | ||||||
|  |  | ||||||
| @@ -93,7 +88,6 @@ public class DnsOverwriteConfig { | |||||||
|         this.homeserver = homeserver; |         this.homeserver = homeserver; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         Gson gson = GsonUtil.build(); |         Gson gson = GsonUtil.build(); | ||||||
|         log.info("--- DNS Overwrite config ---"); |         log.info("--- DNS Overwrite config ---"); | ||||||
|   | |||||||
| @@ -21,14 +21,9 @@ | |||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import org.apache.commons.lang3.StringUtils; | import org.apache.commons.lang3.StringUtils; | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
| import java.util.*; | import java.util.*; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("exec") |  | ||||||
| public class ExecConfig { | public class ExecConfig { | ||||||
|  |  | ||||||
|     public class IO { |     public class IO { | ||||||
| @@ -516,8 +511,7 @@ public class ExecConfig { | |||||||
|         this.profile = profile; |         this.profile = profile; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |     public ExecConfig build() { | ||||||
|     public ExecConfig compute() { |  | ||||||
|         if (Objects.isNull(getAuth().isEnabled())) { |         if (Objects.isNull(getAuth().isEnabled())) { | ||||||
|             getAuth().setEnabled(isEnabled()); |             getAuth().setEnabled(isEnabled()); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -20,27 +20,12 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import io.kamax.mxisd.auth.provider.AuthenticatorProvider; |  | ||||||
| import io.kamax.mxisd.backend.firebase.GoogleFirebaseAuthenticator; |  | ||||||
| import io.kamax.mxisd.backend.firebase.GoogleFirebaseProvider; |  | ||||||
| import io.kamax.mxisd.lookup.provider.IThreePidProvider; |  | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Bean; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("firebase") |  | ||||||
| public class FirebaseConfig { | public class FirebaseConfig { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(FirebaseConfig.class); |     private transient final Logger log = LoggerFactory.getLogger(FirebaseConfig.class); | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     private MatrixConfig mxCfg; |  | ||||||
|  |  | ||||||
|     private boolean enabled; |     private boolean enabled; | ||||||
|     private String credentials; |     private String credentials; | ||||||
| @@ -70,7 +55,6 @@ public class FirebaseConfig { | |||||||
|         this.database = database; |         this.database = database; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         log.info("--- Firebase configuration ---"); |         log.info("--- Firebase configuration ---"); | ||||||
|         log.info("Enabled: {}", isEnabled()); |         log.info("Enabled: {}", isEnabled()); | ||||||
| @@ -80,14 +64,4 @@ public class FirebaseConfig { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Bean |  | ||||||
|     public AuthenticatorProvider getAuthProvider() { |  | ||||||
|         return new GoogleFirebaseAuthenticator(enabled, credentials, database); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Bean |  | ||||||
|     public IThreePidProvider getLookupProvider() { |  | ||||||
|         return new GoogleFirebaseProvider(enabled, credentials, database, mxCfg.getDomain()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -20,14 +20,9 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties(prefix = "forward") |  | ||||||
| public class ForwardConfig { | public class ForwardConfig { | ||||||
|  |  | ||||||
|     private List<String> servers = new ArrayList<>(); |     private List<String> servers = new ArrayList<>(); | ||||||
| @@ -40,4 +35,8 @@ public class ForwardConfig { | |||||||
|         this.servers = servers; |         this.servers = servers; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public void build() { | ||||||
|  |         // no-op | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -23,21 +23,15 @@ package io.kamax.mxisd.config; | |||||||
| import io.kamax.mxisd.util.GsonUtil; | import io.kamax.mxisd.util.GsonUtil; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("invite") |  | ||||||
| public class InvitationConfig { | public class InvitationConfig { | ||||||
|  |  | ||||||
|     private final Logger log = LoggerFactory.getLogger(InvitationConfig.class); |     private transient final Logger log = LoggerFactory.getLogger(InvitationConfig.class); | ||||||
|  |  | ||||||
|     public static class Resolution { |     public static class Resolution { | ||||||
|  |  | ||||||
|         private boolean recursive; |         private boolean recursive = true; | ||||||
|         private long timer; |         private long timer = 1; | ||||||
|  |  | ||||||
|         public boolean isRecursive() { |         public boolean isRecursive() { | ||||||
|             return recursive; |             return recursive; | ||||||
| @@ -57,7 +51,7 @@ public class InvitationConfig { | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private Resolution resolution; |     private Resolution resolution = new Resolution(); | ||||||
|  |  | ||||||
|     public Resolution getResolution() { |     public Resolution getResolution() { | ||||||
|         return resolution; |         return resolution; | ||||||
| @@ -67,7 +61,6 @@ public class InvitationConfig { | |||||||
|         this.resolution = resolution; |         this.resolution = resolution; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         log.info("--- Invite config ---"); |         log.info("--- Invite config ---"); | ||||||
|         log.info("Resolution: {}", GsonUtil.build().toJson(resolution)); |         log.info("Resolution: {}", GsonUtil.build().toJson(resolution)); | ||||||
|   | |||||||
| @@ -22,13 +22,7 @@ package io.kamax.mxisd.config; | |||||||
|  |  | ||||||
| import io.kamax.mxisd.exception.ConfigurationException; | import io.kamax.mxisd.exception.ConfigurationException; | ||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties(prefix = "key") |  | ||||||
| public class KeyConfig { | public class KeyConfig { | ||||||
|  |  | ||||||
|     private String path; |     private String path; | ||||||
| @@ -41,7 +35,6 @@ public class KeyConfig { | |||||||
|         return path; |         return path; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         if (StringUtils.isBlank(getPath())) { |         if (StringUtils.isBlank(getPath())) { | ||||||
|             throw new ConfigurationException("key.path"); |             throw new ConfigurationException("key.path"); | ||||||
|   | |||||||
| @@ -20,16 +20,12 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.exception.ConfigurationException; | ||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
| import java.net.MalformedURLException; | import java.net.MalformedURLException; | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("matrix.listener") |  | ||||||
| public class ListenerConfig { | public class ListenerConfig { | ||||||
|  |  | ||||||
|     public static class Token { |     public static class Token { | ||||||
| @@ -84,8 +80,8 @@ public class ListenerConfig { | |||||||
|         this.token = token; |         this.token = token; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |     public void build() { | ||||||
|     public void build() throws MalformedURLException { |         try { | ||||||
|             if (StringUtils.isBlank(url)) { |             if (StringUtils.isBlank(url)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -103,6 +99,9 @@ public class ListenerConfig { | |||||||
|             if (StringUtils.isBlank(getToken().getHs())) { |             if (StringUtils.isBlank(getToken().getHs())) { | ||||||
|                 throw new IllegalArgumentException("HS token is not set"); |                 throw new IllegalArgumentException("HS token is not set"); | ||||||
|             } |             } | ||||||
|  |         } catch (MalformedURLException e) { | ||||||
|  |             throw new ConfigurationException(e); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -20,26 +20,27 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import com.google.gson.Gson; | import io.kamax.matrix.json.GsonUtil; | ||||||
| import io.kamax.mxisd.exception.ConfigurationException; | import io.kamax.mxisd.exception.ConfigurationException; | ||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; | import java.util.Collections; | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("matrix") |  | ||||||
| public class MatrixConfig { | public class MatrixConfig { | ||||||
|  |  | ||||||
|     public static class Identity { |     public static class Identity { | ||||||
|  |  | ||||||
|         private Map<String, List<String>> servers = new HashMap<>(); |         private Map<String, List<String>> servers = new HashMap<>(); | ||||||
|  |  | ||||||
|  |         public Identity() { | ||||||
|  |             servers.put("matrix-org", Collections.singletonList("https://matrix.org")); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         public Map<String, List<String>> getServers() { |         public Map<String, List<String>> getServers() { | ||||||
|             return servers; |             return servers; | ||||||
|         } |         } | ||||||
| @@ -55,12 +56,14 @@ public class MatrixConfig { | |||||||
|  |  | ||||||
|             return servers.get(label); |             return servers.get(label); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(MatrixConfig.class); |     private transient final Logger log = LoggerFactory.getLogger(MatrixConfig.class); | ||||||
|  |  | ||||||
|     private String domain; |     private String domain; | ||||||
|     private Identity identity = new Identity(); |     private Identity identity = new Identity(); | ||||||
|  |     private ListenerConfig listener = new ListenerConfig(); | ||||||
|  |  | ||||||
|     public String getDomain() { |     public String getDomain() { | ||||||
|         return domain; |         return domain; | ||||||
| @@ -78,7 +81,14 @@ public class MatrixConfig { | |||||||
|         this.identity = identity; |         this.identity = identity; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |     public ListenerConfig getListener() { | ||||||
|  |         return listener; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setListener(ListenerConfig listener) { | ||||||
|  |         this.listener = listener; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         log.info("--- Matrix config ---"); |         log.info("--- Matrix config ---"); | ||||||
|  |  | ||||||
| @@ -88,7 +98,9 @@ public class MatrixConfig { | |||||||
|  |  | ||||||
|         log.info("Domain: {}", getDomain()); |         log.info("Domain: {}", getDomain()); | ||||||
|         log.info("Identity:"); |         log.info("Identity:"); | ||||||
|         log.info("\tServers: {}", new Gson().toJson(identity.getServers())); |         log.info("\tServers: {}", GsonUtil.get().toJson(identity.getServers())); | ||||||
|  |  | ||||||
|  |         listener.build(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										326
									
								
								src/main/java/io/kamax/mxisd/config/MxisdConfig.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										326
									
								
								src/main/java/io/kamax/mxisd/config/MxisdConfig.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,326 @@ | |||||||
|  | /* | ||||||
|  |  * mxisd - Matrix Identity Server Daemon | ||||||
|  |  * Copyright (C) 2018 Kamax Sàrl | ||||||
|  |  * | ||||||
|  |  * https://www.kamax.io/ | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU Affero General Public License as | ||||||
|  |  * published by the Free Software Foundation, either version 3 of the | ||||||
|  |  * License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU Affero General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU Affero General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
|  | import io.kamax.mxisd.config.ldap.generic.GenericLdapConfig; | ||||||
|  | import io.kamax.mxisd.config.ldap.netiq.NetIqLdapConfig; | ||||||
|  | import io.kamax.mxisd.config.memory.MemoryStoreConfig; | ||||||
|  | import io.kamax.mxisd.config.rest.RestBackendConfig; | ||||||
|  | import io.kamax.mxisd.config.sql.generic.GenericSqlProviderConfig; | ||||||
|  | import io.kamax.mxisd.config.sql.synapse.SynapseSqlProviderConfig; | ||||||
|  | import io.kamax.mxisd.config.threepid.ThreePidConfig; | ||||||
|  | import io.kamax.mxisd.config.threepid.notification.NotificationConfig; | ||||||
|  | import io.kamax.mxisd.config.wordpress.WordpressConfig; | ||||||
|  | import org.apache.commons.lang.StringUtils; | ||||||
|  | import org.slf4j.Logger; | ||||||
|  | import org.slf4j.LoggerFactory; | ||||||
|  |  | ||||||
|  | public class MxisdConfig { | ||||||
|  |  | ||||||
|  |     private static final Logger log = LoggerFactory.getLogger(MxisdConfig.class); | ||||||
|  |  | ||||||
|  |     public static class Dns { | ||||||
|  |  | ||||||
|  |         private DnsOverwriteConfig overwrite = new DnsOverwriteConfig(); | ||||||
|  |  | ||||||
|  |         public DnsOverwriteConfig getOverwrite() { | ||||||
|  |             return overwrite; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public void setOverwrite(DnsOverwriteConfig overwrite) { | ||||||
|  |             this.overwrite = overwrite; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public void build() { | ||||||
|  |             overwrite.build(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static class Lookup { | ||||||
|  |  | ||||||
|  |         private BulkLookupConfig bulk = new BulkLookupConfig(); | ||||||
|  |         private RecursiveLookupConfig recursive = new RecursiveLookupConfig(); | ||||||
|  |  | ||||||
|  |         public BulkLookupConfig getBulk() { | ||||||
|  |             return bulk; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public void setBulk(BulkLookupConfig bulk) { | ||||||
|  |             this.bulk = bulk; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public RecursiveLookupConfig getRecursive() { | ||||||
|  |             return recursive; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public void setRecursive(RecursiveLookupConfig recursive) { | ||||||
|  |             this.recursive = recursive; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         public void build() { | ||||||
|  |             getBulk().build(); | ||||||
|  |             getRecursive().build(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private AuthenticationConfig auth = new AuthenticationConfig(); | ||||||
|  |     private DirectoryConfig directory = new DirectoryConfig(); | ||||||
|  |     private Dns dns = new Dns(); | ||||||
|  |     private ExecConfig exec = new ExecConfig(); | ||||||
|  |     private FirebaseConfig firebase = new FirebaseConfig(); | ||||||
|  |     private ForwardConfig forward = new ForwardConfig(); | ||||||
|  |     private InvitationConfig invite = new InvitationConfig(); | ||||||
|  |     private KeyConfig key = new KeyConfig(); | ||||||
|  |     private GenericLdapConfig ldap = new GenericLdapConfig(); | ||||||
|  |     private Lookup lookup = new Lookup(); | ||||||
|  |     private MatrixConfig matrix = new MatrixConfig(); | ||||||
|  |     private MemoryStoreConfig memory = new MemoryStoreConfig(); | ||||||
|  |     private NotificationConfig notification = new NotificationConfig(); | ||||||
|  |     private NetIqLdapConfig netiq = new NetIqLdapConfig(); | ||||||
|  |     private ServerConfig server = new ServerConfig(); | ||||||
|  |     private SessionConfig session = new SessionConfig(); | ||||||
|  |     private StorageConfig storage = new StorageConfig(); | ||||||
|  |     private RestBackendConfig rest = new RestBackendConfig(); | ||||||
|  |     private GenericSqlProviderConfig sql = new GenericSqlProviderConfig(); | ||||||
|  |     private SynapseSqlProviderConfig synapseSql = new SynapseSqlProviderConfig(); | ||||||
|  |     private ThreePidConfig threepid = new ThreePidConfig(); | ||||||
|  |     private ViewConfig view = new ViewConfig(); | ||||||
|  |     private WordpressConfig wordpress = new WordpressConfig(); | ||||||
|  |  | ||||||
|  |     public AuthenticationConfig getAuth() { | ||||||
|  |         return auth; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setAuth(AuthenticationConfig auth) { | ||||||
|  |         this.auth = auth; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public DirectoryConfig getDirectory() { | ||||||
|  |         return directory; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setDirectory(DirectoryConfig directory) { | ||||||
|  |         this.directory = directory; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Dns getDns() { | ||||||
|  |         return dns; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setDns(Dns dns) { | ||||||
|  |         this.dns = dns; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public ExecConfig getExec() { | ||||||
|  |         return exec; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setExec(ExecConfig exec) { | ||||||
|  |         this.exec = exec; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public FirebaseConfig getFirebase() { | ||||||
|  |         return firebase; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setFirebase(FirebaseConfig firebase) { | ||||||
|  |         this.firebase = firebase; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public ForwardConfig getForward() { | ||||||
|  |         return forward; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setForward(ForwardConfig forward) { | ||||||
|  |         this.forward = forward; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public InvitationConfig getInvite() { | ||||||
|  |         return invite; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setInvite(InvitationConfig invite) { | ||||||
|  |         this.invite = invite; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public KeyConfig getKey() { | ||||||
|  |         return key; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setKey(KeyConfig key) { | ||||||
|  |         this.key = key; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public GenericLdapConfig getLdap() { | ||||||
|  |         return ldap; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setLdap(GenericLdapConfig ldap) { | ||||||
|  |         this.ldap = ldap; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Lookup getLookup() { | ||||||
|  |         return lookup; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setLookup(Lookup lookup) { | ||||||
|  |         this.lookup = lookup; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public MatrixConfig getMatrix() { | ||||||
|  |         return matrix; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setMatrix(MatrixConfig matrix) { | ||||||
|  |         this.matrix = matrix; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public MemoryStoreConfig getMemory() { | ||||||
|  |         return memory; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setMemory(MemoryStoreConfig memory) { | ||||||
|  |         this.memory = memory; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public NotificationConfig getNotification() { | ||||||
|  |         return notification; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setNotification(NotificationConfig notification) { | ||||||
|  |         this.notification = notification; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public NetIqLdapConfig getNetiq() { | ||||||
|  |         return netiq; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setNetiq(NetIqLdapConfig netiq) { | ||||||
|  |         this.netiq = netiq; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public ServerConfig getServer() { | ||||||
|  |         return server; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setServer(ServerConfig server) { | ||||||
|  |         this.server = server; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public SessionConfig getSession() { | ||||||
|  |         return session; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setSession(SessionConfig session) { | ||||||
|  |         this.session = session; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public StorageConfig getStorage() { | ||||||
|  |         return storage; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setStorage(StorageConfig storage) { | ||||||
|  |         this.storage = storage; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public RestBackendConfig getRest() { | ||||||
|  |         return rest; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setRest(RestBackendConfig rest) { | ||||||
|  |         this.rest = rest; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public GenericSqlProviderConfig getSql() { | ||||||
|  |         return sql; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setSql(GenericSqlProviderConfig sql) { | ||||||
|  |         this.sql = sql; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public SynapseSqlProviderConfig getSynapseSql() { | ||||||
|  |         return synapseSql; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setSynapseSql(SynapseSqlProviderConfig synapseSql) { | ||||||
|  |         this.synapseSql = synapseSql; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public ThreePidConfig getThreepid() { | ||||||
|  |         return threepid; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setThreepid(ThreePidConfig threepid) { | ||||||
|  |         this.threepid = threepid; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public ViewConfig getView() { | ||||||
|  |         return view; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setView(ViewConfig view) { | ||||||
|  |         this.view = view; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public WordpressConfig getWordpress() { | ||||||
|  |         return wordpress; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setWordpress(WordpressConfig wordpress) { | ||||||
|  |         this.wordpress = wordpress; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public MxisdConfig build() { | ||||||
|  |         if (StringUtils.isBlank(getServer().getName())) { | ||||||
|  |             getServer().setName(getMatrix().getDomain()); | ||||||
|  |             log.debug("server.name is empty, using matrix.domain"); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         getAuth().build(); | ||||||
|  |         getDirectory().build(); | ||||||
|  |         getExec().build(); | ||||||
|  |         getFirebase().build(); | ||||||
|  |         getForward().build(); | ||||||
|  |         getInvite().build(); | ||||||
|  |         getKey().build(); | ||||||
|  |         getLdap().build(); | ||||||
|  |         getLookup().build(); | ||||||
|  |         getMatrix().build(); | ||||||
|  |         getMemory().build(); | ||||||
|  |         getNetiq().build(); | ||||||
|  |         getNotification().build(); | ||||||
|  |         getRest().build(); | ||||||
|  |         getSession().build(); | ||||||
|  |         getServer().build(); | ||||||
|  |         getSql().build(); | ||||||
|  |         getStorage().build(); | ||||||
|  |         getSynapseSql().build(); | ||||||
|  |         getThreepid().build(); | ||||||
|  |         getView().build(); | ||||||
|  |         getWordpress().build(); | ||||||
|  |  | ||||||
|  |         return this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -22,21 +22,16 @@ package io.kamax.mxisd.config; | |||||||
|  |  | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties(prefix = "lookup.recursive.bridge") |  | ||||||
| public class RecursiveLookupBridgeConfig { | public class RecursiveLookupBridgeConfig { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(RecursiveLookupBridgeConfig.class); |     private transient final Logger log = LoggerFactory.getLogger(RecursiveLookupBridgeConfig.class); | ||||||
|  |  | ||||||
|     private boolean enabled; |     private boolean enabled; | ||||||
|     private boolean recursiveOnly; |     private boolean recursiveOnly = true; | ||||||
|     private String server; |     private String server; | ||||||
|     private Map<String, String> mappings = new HashMap<>(); |     private Map<String, String> mappings = new HashMap<>(); | ||||||
|  |  | ||||||
| @@ -72,7 +67,6 @@ public class RecursiveLookupBridgeConfig { | |||||||
|         this.mappings = mappings; |         this.mappings = mappings; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         log.info("--- Bridge integration lookups config ---"); |         log.info("--- Bridge integration lookups config ---"); | ||||||
|         log.info("Enabled: {}", getEnabled()); |         log.info("Enabled: {}", getEnabled()); | ||||||
|   | |||||||
| @@ -20,18 +20,22 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; | import java.util.ArrayList; | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties(prefix = "lookup.recursive") |  | ||||||
| public class RecursiveLookupConfig { | public class RecursiveLookupConfig { | ||||||
|  |  | ||||||
|     private boolean enabled; |     private boolean enabled = true; | ||||||
|     private List<String> allowedCidr; |     private List<String> allowedCidr = new ArrayList<>(); | ||||||
|     private RecursiveLookupBridgeConfig bridge; |     private RecursiveLookupBridgeConfig bridge = new RecursiveLookupBridgeConfig(); | ||||||
|  |  | ||||||
|  |     public RecursiveLookupConfig() { | ||||||
|  |         allowedCidr.add("127.0.0.0/8"); | ||||||
|  |         allowedCidr.add("10.0.0.0/8"); | ||||||
|  |         allowedCidr.add("172.16.0.0/12"); | ||||||
|  |         allowedCidr.add("192.168.0.0/16"); | ||||||
|  |         allowedCidr.add("::1/128"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public boolean isEnabled() { |     public boolean isEnabled() { | ||||||
|         return enabled; |         return enabled; | ||||||
| @@ -57,4 +61,8 @@ public class RecursiveLookupConfig { | |||||||
|         this.bridge = bridge; |         this.bridge = bridge; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public void build() { | ||||||
|  |         bridge.build(); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -20,11 +20,6 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("storage.provider.sqlite") |  | ||||||
| public class SQLiteStorageConfig { | public class SQLiteStorageConfig { | ||||||
|  |  | ||||||
|     private String database; |     private String database; | ||||||
|   | |||||||
| @@ -23,25 +23,16 @@ package io.kamax.mxisd.config; | |||||||
| import org.apache.commons.lang.StringUtils; | import org.apache.commons.lang.StringUtils; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
| import java.net.MalformedURLException; | import java.net.MalformedURLException; | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties(prefix = "server") |  | ||||||
| public class ServerConfig { | public class ServerConfig { | ||||||
|  |  | ||||||
|     private Logger log = LoggerFactory.getLogger(ServerConfig.class); |     private transient final Logger log = LoggerFactory.getLogger(ServerConfig.class); | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     private MatrixConfig mxCfg; |  | ||||||
|  |  | ||||||
|     private String name; |     private String name; | ||||||
|     private int port; |     private int port = 8090; | ||||||
|     private String publicUrl; |     private String publicUrl; | ||||||
|  |  | ||||||
|     public String getName() { |     public String getName() { | ||||||
| @@ -68,15 +59,9 @@ public class ServerConfig { | |||||||
|         this.publicUrl = publicUrl; |         this.publicUrl = publicUrl; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         log.info("--- Server config ---"); |         log.info("--- Server config ---"); | ||||||
|  |  | ||||||
|         if (StringUtils.isBlank(getName())) { |  | ||||||
|             setName(mxCfg.getDomain()); |  | ||||||
|             log.debug("server.name is empty, using matrix.domain"); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if (StringUtils.isBlank(getPublicUrl())) { |         if (StringUtils.isBlank(getPublicUrl())) { | ||||||
|             setPublicUrl("https://" + getName()); |             setPublicUrl("https://" + getName()); | ||||||
|             log.debug("Public URL is empty, generating from name"); |             log.debug("Public URL is empty, generating from name"); | ||||||
|   | |||||||
| @@ -20,20 +20,13 @@ | |||||||
|  |  | ||||||
| package io.kamax.mxisd.config; | package io.kamax.mxisd.config; | ||||||
|  |  | ||||||
| import com.google.gson.Gson; | import io.kamax.matrix.json.GsonUtil; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.boot.context.properties.ConfigurationProperties; |  | ||||||
| import org.springframework.context.annotation.Configuration; |  | ||||||
|  |  | ||||||
| import javax.annotation.PostConstruct; |  | ||||||
|  |  | ||||||
| @Configuration |  | ||||||
| @ConfigurationProperties("session") |  | ||||||
| public class SessionConfig { | public class SessionConfig { | ||||||
|  |  | ||||||
|     private static Logger log = LoggerFactory.getLogger(SessionConfig.class); |     private transient final Logger log = LoggerFactory.getLogger(SessionConfig.class); | ||||||
|  |  | ||||||
|     public static class Policy { |     public static class Policy { | ||||||
|  |  | ||||||
| @@ -132,6 +125,19 @@ public class SessionConfig { | |||||||
|  |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         public Policy() { | ||||||
|  |             validation.enabled = true; | ||||||
|  |             validation.forLocal.enabled = true; | ||||||
|  |             validation.forLocal.toLocal = true; | ||||||
|  |             validation.forLocal.toRemote.enabled = true; | ||||||
|  |             validation.forLocal.toRemote.server = "matrix-org"; | ||||||
|  |  | ||||||
|  |             validation.forRemote.enabled = true; | ||||||
|  |             validation.forRemote.toLocal = false; | ||||||
|  |             validation.forRemote.toRemote.enabled = true; | ||||||
|  |             validation.forRemote.toRemote.server = "matrix-org"; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         private PolicyTemplate validation = new PolicyTemplate(); |         private PolicyTemplate validation = new PolicyTemplate(); | ||||||
|  |  | ||||||
|         public PolicyTemplate getValidation() { |         public PolicyTemplate getValidation() { | ||||||
| @@ -144,18 +150,8 @@ public class SessionConfig { | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private MatrixConfig mxCfg; |  | ||||||
|     private Policy policy = new Policy(); |     private Policy policy = new Policy(); | ||||||
|  |  | ||||||
|     @Autowired |  | ||||||
|     public SessionConfig(MatrixConfig mxCfg) { |  | ||||||
|         this.mxCfg = mxCfg; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public MatrixConfig getMatrixCfg() { |  | ||||||
|         return mxCfg; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public Policy getPolicy() { |     public Policy getPolicy() { | ||||||
|         return policy; |         return policy; | ||||||
|     } |     } | ||||||
| @@ -164,10 +160,9 @@ public class SessionConfig { | |||||||
|         this.policy = policy; |         this.policy = policy; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |  | ||||||
|     public void build() { |     public void build() { | ||||||
|         log.info("--- Session config ---"); |         log.info("--- Session config ---"); | ||||||
|         log.info("Global Policy: {}", new Gson().toJson(policy)); |         log.info("Global Policy: {}", GsonUtil.get().toJson(policy)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user