aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Auvolat <alex@adnab.me>2020-02-28 20:08:37 +0100
committerAlex Auvolat <alex@adnab.me>2020-02-28 20:08:37 +0100
commit155a9f7e4d96072c9a9afe35433b16156d5ddcb9 (patch)
treeb5423840771e869b8e9a97a6a014bfc59b53376c
parent52e6ba3c0036160ce9c419dd0188624cc55fa2b1 (diff)
downloadinfrastructure-155a9f7e4d96072c9a9afe35433b16156d5ddcb9.tar.gz
infrastructure-155a9f7e4d96072c9a9afe35433b16156d5ddcb9.zip
Initial Easybridge setup
-rw-r--r--consul/configuration/chat/easybridge/config.json.tpl13
-rw-r--r--consul/configuration/chat/easybridge/registration.yaml.tpl14
-rw-r--r--consul/configuration/chat/synapse/homeserver.yaml1
-rw-r--r--nomad/chat.hcl102
4 files changed, 130 insertions, 0 deletions
diff --git a/consul/configuration/chat/easybridge/config.json.tpl b/consul/configuration/chat/easybridge/config.json.tpl
new file mode 100644
index 0000000..39ac9ee
--- /dev/null
+++ b/consul/configuration/chat/easybridge/config.json.tpl
@@ -0,0 +1,13 @@
+{
+ "log_level": "debug",
+ "appservice_bind_addr": "0.0.0.0:8321",
+ "web_bind_addr": "0.0.0.0:8281",
+ "web_url": "https://easybridge.deuxfleurs.fr",
+ "easybridge_avatar": "/app/easybridge.jpg",
+ "registration": "/data/registration.yaml",
+ "homeserver_url": "https://im.deuxfleurs.fr",
+ "db_type": "postgres",
+ "db_path": "host=psql-proxy.service.2.cluster.deuxfleurs.fr port=5432 user={{ key "secrets/chat/easybridge/db_user" | trimSpace }} dbname=easybridge password={{ key "secrets/chat/easybridge/db_pass" | trimSpace }} sslmode=disable",
+ "matrix_domain": "deuxfleurs.fr",
+ "web_session_key": "{{ key "secrets/chat/easybridge/web_session_key" | trimSpace }}"
+}
diff --git a/consul/configuration/chat/easybridge/registration.yaml.tpl b/consul/configuration/chat/easybridge/registration.yaml.tpl
new file mode 100644
index 0000000..0123bc3
--- /dev/null
+++ b/consul/configuration/chat/easybridge/registration.yaml.tpl
@@ -0,0 +1,14 @@
+id: Easybridge
+url: http://easybridge.service.2.cluster.deuxfleurs.fr
+as_token: {{ key "secrets/chat/easybridge/as_token" | trimSpace }}
+hs_token: {{ key "secrets/chat/easybridge/hs_token" | trimSpace }}
+sender_localpart: _ezbr_
+rate_limited: false
+namespaces:
+ users:
+ - exclusive: true
+ regex: '@_ezbr_.*'
+ aliases:
+ - exclusive: true
+ regex: '#_ezbr_.*'
+ rooms: []
diff --git a/consul/configuration/chat/synapse/homeserver.yaml b/consul/configuration/chat/synapse/homeserver.yaml
index c54d4a0..87688a4 100644
--- a/consul/configuration/chat/synapse/homeserver.yaml
+++ b/consul/configuration/chat/synapse/homeserver.yaml
@@ -309,6 +309,7 @@ room_invite_state_types:
# A list of application service config file to use
app_service_config_files:
- "/etc/matrix-synapse/fb2mx_registration.yaml"
+ - "/etc/matrix-synapse/easybridge_registration.yaml"
# macaroon_secret_key: <PRIVATE STRING>
diff --git a/nomad/chat.hcl b/nomad/chat.hcl
index 70bacbf..83cc141 100644
--- a/nomad/chat.hcl
+++ b/nomad/chat.hcl
@@ -39,6 +39,16 @@ job "chat" {
}
artifact {
+ source = "http://127.0.0.1:8500/v1/kv/configuration/chat/easybridge/registration.yaml.tpl?raw"
+ destination = "secrets/tpl/easybridge_registration.yaml.tpl"
+ mode = "file"
+ }
+ template {
+ source = "secrets/tpl/easybridge_registration.yaml.tpl"
+ destination = "secrets/conf/easybridge_registration.yaml"
+ }
+
+ artifact {
source = "http://127.0.0.1:8500/v1/kv/configuration/chat/fb2mx/registration.yaml?raw"
destination = "secrets/tpl/fb2mx_registration.yaml.tpl"
mode = "file"
@@ -178,6 +188,98 @@ job "chat" {
}
}
*/
+
+
+ group "easybridge" {
+ count = 1
+ task "easybridge" {
+ driver = "docker"
+ config {
+ image = "lxpz/easybridge_amd64:5"
+ port_map {
+ api_port = 8321
+ web_port = 8281
+ }
+ volumes = [
+ "secrets/conf:/data"
+ ]
+ args = [ "-config", "/data/config.json" ]
+ }
+
+ artifact {
+ source = "http://127.0.0.1:8500/v1/kv/configuration/chat/easybridge/registration.yaml.tpl?raw"
+ destination = "secrets/tpl/registration.yaml.tpl"
+ mode = "file"
+ }
+ template {
+ source = "secrets/tpl/registration.yaml.tpl"
+ destination = "secrets/conf/registration.yaml"
+ }
+
+ artifact {
+ source = "http://127.0.0.1:8500/v1/kv/configuration/chat/easybridge/config.json.tpl?raw"
+ destination = "secrets/tpl/config.json.tpl"
+ mode = "file"
+ }
+ template {
+ source = "secrets/tpl/config.json.tpl"
+ destination = "secrets/conf/config.json"
+ }
+
+ resources {
+ memory = 50
+ network {
+ port "api_port" {
+ static = "8321"
+ }
+ port "web_port" {}
+ }
+ }
+
+ service {
+ name = "easybridge-api"
+ tags = ["easybridge-api"]
+ port = "api_port"
+ address_mode = "host"
+ check {
+ type = "tcp"
+ port = "api_port"
+ interval = "60s"
+ timeout = "5s"
+ check_restart {
+ limit = 3
+ grace = "90s"
+ ignore_warnings = false
+ }
+ }
+ }
+
+ service {
+ name = "easybridge-web"
+ tags = [
+ "easybridge-web",
+ "traefik.enable=true",
+ "traefik.frontend.entryPoints=https,http",
+ "traefik.frontend.rule=Host:easybridge.deuxfleurs.fr",
+ ]
+ port = "web_port"
+ address_mode = "host"
+ check {
+ type = "tcp"
+ port = "web_port"
+ interval = "60s"
+ timeout = "5s"
+ check_restart {
+ limit = 3
+ grace = "90s"
+ ignore_warnings = false
+ }
+ }
+ }
+ }
+ }
+
+
group "riotweb" {
count = 1