2022-02-05 21:32:54 +01:00
---
2022-01-03 21:22:42 +01:00
# A bridge between Matrix and multiple project management services, such as GitHub, GitLab and JIRA.
2022-07-16 23:59:21 +03:00
# Project source code URL: https://github.com/matrix-org/matrix-hookshot
2022-01-03 21:22:42 +01:00
matrix_hookshot_enabled : true
2022-04-03 17:10:46 +07:00
matrix_hookshot_container_image_self_build : false
matrix_hookshot_container_image_self_build_repo : "https://github.com/matrix-org/matrix-hookshot.git"
matrix_hookshot_container_image_self_build_branch : "{{ 'main' if matrix_hookshot_version == 'latest' else matrix_hookshot_version }}"
2023-07-31 18:41:25 +03:00
matrix_hookshot_version : 4.4 .1
2022-04-03 17:10:46 +07:00
2022-04-05 12:42:38 +00:00
matrix_hookshot_docker_image : "{{ matrix_hookshot_docker_image_name_prefix }}halfshot/matrix-hookshot:{{ matrix_hookshot_version }}"
2022-04-03 17:10:46 +07:00
matrix_hookshot_docker_image_name_prefix : "{{ 'localhost/' if matrix_hookshot_container_image_self_build else matrix_container_global_registry_prefix }}"
2022-01-03 21:22:42 +01:00
matrix_hookshot_docker_image_force_pull : "{{ matrix_hookshot_docker_image.endswith(':latest') }}"
matrix_hookshot_base_path : "{{ matrix_base_data_path }}/hookshot"
2022-04-03 17:10:46 +07:00
matrix_hookshot_docker_src_files_path : "{{ matrix_hookshot_base_path }}/docker-src"
2022-01-03 21:22:42 +01:00
matrix_hookshot_homeserver_address : "{{ matrix_homeserver_container_url }}"
2022-01-08 16:51:52 +01:00
matrix_hookshot_container_url : 'matrix-hookshot'
2022-01-03 21:22:42 +01:00
matrix_hookshot_public_endpoint : /hookshot
2022-01-30 19:05:49 +01:00
# There is no need to edit ports. use matrix_hookshot_container_http_host_bind_ports below to expose ports instead.
2022-01-06 18:55:36 +01:00
matrix_hookshot_appservice_port : 9993
matrix_hookshot_appservice_endpoint : "{{ matrix_hookshot_public_endpoint }}/_matrix/app"
2022-06-23 17:44:11 +03:00
# Controls whether metrics are enabled in the bridge configuration.
# Enabling them is usually enough for a local (in-container) Prometheus to consume them.
# If metrics need to be consumed by another (external) Prometheus server, consider exposing them via `matrix_hookshot_metrics_proxying_enabled`.
matrix_hookshot_metrics_enabled : false
# Controls whether Hookshot metrics should be proxied (exposed) on `matrix.DOMAIN/metrics/hookshot`.
# This will only work take effect if `matrix_nginx_proxy_proxy_matrix_metrics_enabled: true`.
# See the `matrix-nginx-proxy` role for details about enabling `matrix_nginx_proxy_proxy_matrix_metrics_enabled`.
matrix_hookshot_metrics_proxying_enabled : false
2022-01-30 19:05:49 +01:00
# There is no need to edit ports.
# Read the documentation to learn about using hookshot metrics with external Prometheus
# If you still want something different, use matrix_hookshot_container_http_host_bind_ports below to expose ports instead.
2022-01-03 21:22:42 +01:00
matrix_hookshot_metrics_port : 9001
2022-01-30 19:05:49 +01:00
# There is no need to edit ports. use matrix_hookshot_container_http_host_bind_ports below to expose ports instead.
2022-01-03 21:22:42 +01:00
matrix_hookshot_webhook_port : 9000
2022-01-06 18:55:36 +01:00
matrix_hookshot_webhook_endpoint : "{{ matrix_hookshot_public_endpoint }}/webhooks"
2022-01-03 21:22:42 +01:00
2022-01-11 00:19:29 +01:00
2022-01-30 19:05:49 +01:00
# You need to create a GitHub app to enable this and fill in the empty variables below
2022-03-02 20:58:11 +01:00
# https://matrix-org.github.io/matrix-hookshot/setup/github.html
2022-01-06 18:55:36 +01:00
matrix_hookshot_github_enabled : false
2022-11-30 08:13:39 +02:00
matrix_hookshot_github_auth_id : ''
2022-01-30 19:05:49 +01:00
# Set this variable to the contents of the generated and downloaded GitHub private key:
2022-01-23 16:10:25 +01:00
# matrix_hookshot_github_private_key: |
# -----BEGIN RSA PRIVATE KEY-----
# 0123456789ABCDEF...
# -----END RSA PRIVATE KEY-----
2022-01-30 19:05:49 +01:00
# Alternatively, leave it empty and do it manually or use matrix-aux instead, see docs/matrix-bridge-hookshot.md for info.
2022-01-23 16:10:25 +01:00
matrix_hookshot_github_private_key : ''
matrix_hookshot_github_private_key_file : 'private-key.pem'
2022-11-30 08:13:39 +02:00
matrix_hookshot_github_webhook_secret : '' # "Webhook secret" on the GitHub App page
2022-01-06 18:55:36 +01:00
matrix_hookshot_github_oauth_enabled : false
2022-01-30 19:05:49 +01:00
# You need to configure oauth settings only when you have enabled oauth (optional)
2022-11-30 11:55:23 +02:00
matrix_hookshot_github_oauth_client_id : '' # "Client ID" on the GitHub App page
matrix_hookshot_github_oauth_client_secret : '' # "Client Secret" on the GitHub App page
2022-01-30 19:05:49 +01:00
# Default value of matrix_hookshot_github_oauth_endpoint: "/hookshot/webhooks/oauth"
2022-01-06 18:55:36 +01:00
matrix_hookshot_github_oauth_endpoint : "{{ matrix_hookshot_webhook_endpoint }}/oauth"
2022-11-30 11:55:23 +02:00
matrix_hookshot_github_oauth_redirect_uri : "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_github_oauth_endpoint }}"
2022-11-30 08:13:39 +02:00
2022-03-02 20:58:11 +01:00
# These are the default settings mentioned here and don't need to be modified: https://matrix-org.github.io/matrix-hookshot/usage/room_configuration/github_repo.html#configuration
2022-11-30 08:13:39 +02:00
matrix_hookshot_github_defaultOptions_ignoreHooks : {} # noqa var-naming
matrix_hookshot_github_defaultOptions_commandPrefix : '!gh' # noqa var-naming
matrix_hookshot_github_defaultOptions_showIssueRoomLink : false # noqa var-naming
matrix_hookshot_github_defaultOptions_prDiff : # noqa var-naming
enabled : false
maxLines : 5
matrix_hookshot_github_defaultOptions_includingLabels : '' # noqa var-naming
matrix_hookshot_github_defaultOptions_excludingLabels : '' # noqa var-naming
matrix_hookshot_github_defaultOptions_hotlinkIssues_prefix : "#" # noqa var-naming
2022-01-03 21:22:42 +01:00
2022-01-11 00:19:29 +01:00
2022-01-03 21:22:42 +01:00
matrix_hookshot_gitlab_enabled : true
2022-01-30 19:05:49 +01:00
# Optionally add your instances, e.g.
2022-01-11 00:19:29 +01:00
# matrix_hookshot_gitlab_instances:
# gitlab.com:
# url: https://gitlab.com
# mygitlab:
# url: https://gitlab.example.org
2022-01-03 21:22:42 +01:00
matrix_hookshot_gitlab_instances :
gitlab.com :
url : https://gitlab.com
2022-01-30 19:05:49 +01:00
# This will be the "Secret token" you have to enter into all GitLab instances for authentication
2022-11-30 08:13:39 +02:00
matrix_hookshot_gitlab_webhook_secret : ''
2022-01-03 21:22:42 +01:00
2022-01-11 00:19:29 +01:00
2022-04-11 16:45:33 +02:00
matrix_hookshot_figma_enabled : false
# Default value of matrix_hookshot_figma_endpoint: "/hookshot/webhooks/figma/webhook"
matrix_hookshot_figma_endpoint : "{{ matrix_hookshot_webhook_endpoint }}/figma/webhook"
2022-07-18 16:43:12 +03:00
matrix_hookshot_figma_publicUrl : "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_figma_endpoint }}" # noqa var-naming
2022-04-11 16:45:33 +02:00
# To bridge figma webhooks, you need to configure one of multiple instances like this:
# matrix_hookshot_figma_instances:
# your-instance:
# teamId: your-team-id
# accessToken: your-personal-access-token
# passcode: your-webhook-passcode
2022-11-30 08:13:39 +02:00
matrix_hookshot_figma_instances : {}
2022-04-11 16:45:33 +02:00
2022-01-06 18:55:36 +01:00
matrix_hookshot_jira_enabled : false
2022-03-02 20:58:11 +01:00
# Get the these values from https://matrix-org.github.io/matrix-hookshot/setup/jira.html#jira-oauth
2022-11-30 08:13:39 +02:00
matrix_hookshot_jira_webhook_secret : ''
2022-01-11 00:19:29 +01:00
matrix_hookshot_jira_oauth_enabled : false
2022-11-30 08:13:39 +02:00
matrix_hookshot_jira_oauth_client_id : ''
matrix_hookshot_jira_oauth_client_secret : ''
2022-01-30 19:05:49 +01:00
# Default value of matrix_hookshot_jira_oauth_endpoint: "/hookshot/webhooks/jira/oauth"
2022-01-06 18:55:36 +01:00
matrix_hookshot_jira_oauth_endpoint : "{{ matrix_hookshot_webhook_endpoint }}/jira/oauth"
2022-11-30 08:13:39 +02:00
matrix_hookshot_jira_oauth_redirect_uri : "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_jira_oauth_endpoint }}"
2022-01-03 21:22:42 +01:00
2022-01-11 00:19:29 +01:00
2022-01-30 19:05:49 +01:00
# No need to change these
2022-01-03 21:22:42 +01:00
matrix_hookshot_generic_enabled : true
2023-03-07 17:28:10 +02:00
matrix_hookshot_generic_enableHttpGet : false # noqa var-naming
2022-01-30 19:05:49 +01:00
# Default value of matrix_hookshot_generic_endpoint: "/hookshot/webhooks"
2022-01-06 18:55:36 +01:00
matrix_hookshot_generic_endpoint : "{{ matrix_hookshot_webhook_endpoint }}"
2022-02-16 19:51:00 +01:00
# urlprefix gets updated with protocol & port in group_vars/matrix_servers
2023-03-07 17:28:10 +02:00
matrix_hookshot_generic_urlPrefix : "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_generic_endpoint }}" # noqa var-naming
2022-01-30 19:05:49 +01:00
# If you're also using matrix-appservice-webhooks, take care that these prefixes don't overlap
2023-03-07 17:28:10 +02:00
matrix_hookshot_generic_userIdPrefix : '_webhooks_' # noqa var-naming
matrix_hookshot_generic_allowJsTransformationFunctions : false # noqa var-naming
matrix_hookshot_generic_waitForComplete : false # noqa var-naming
2022-01-03 21:22:42 +01:00
2022-01-11 00:19:29 +01:00
2022-10-11 06:00:49 +00:00
matrix_hookshot_feeds_enabled : true
2022-11-04 14:58:28 +02:00
matrix_hookshot_feeds_pollIntervalSeconds : 600 # noqa var-naming
2022-12-02 19:14:29 +02:00
matrix_hookshot_feeds_pollTimeoutSeconds : 30 # noqa var-naming
2022-05-07 18:42:15 +02:00
2022-01-30 19:05:49 +01:00
# There is no need to edit ports. use matrix_hookshot_container_http_host_bind_ports below to expose ports instead.
2022-01-06 18:55:36 +01:00
matrix_hookshot_provisioning_port : 9002
2022-01-03 21:22:42 +01:00
matrix_hookshot_provisioning_secret : ''
2022-01-30 19:05:49 +01:00
# Provisioning will be automatically enabled if dimension is enabled and you have provided a provisioning secret, unless you override it
2022-01-11 00:19:29 +01:00
matrix_hookshot_provisioning_enabled : false
2022-04-11 16:45:33 +02:00
matrix_hookshot_provisioning_internal : "/v1"
matrix_hookshot_provisioning_endpoint : "{{ matrix_hookshot_public_endpoint }}{{ matrix_hookshot_provisioning_internal }}"
2022-01-06 18:55:36 +01:00
2022-11-30 08:18:41 +02:00
# Valid logging levels are: debug, info, warn, error
matrix_hookshot_logging_level : warn
2022-04-11 16:48:50 +02:00
matrix_hookshot_widgets_enabled : true
matrix_hookshot_widgets_port : 9003
2022-07-18 16:43:12 +03:00
matrix_hookshot_widgets_addToAdminRooms : false # default off as it is a beta feature # noqa var-naming
matrix_hookshot_widgets_roomSetupWidget_enabled : true # noqa var-naming
matrix_hookshot_widgets_roomSetupWidget_addOnInvite : false # noqa var-naming
2022-04-11 16:48:50 +02:00
# `disallowedIpRanges` describes which IP ranges should be disallowed when resolving homeserver IP addresses (for security reasons). Unless you know what you are doing, it is recommended to not include this key. The following IPs are blocked by default, unless you supply another list.
# matrix_hookshot_widgets_disallowedIpRanges:
# - 127.0.0.0/8
# - 10.0.0.0/8
# - 172.16.0.0/12
# - 192.168.0.0/16
# - 100.64.0.0/10
# - 192.0.0.0/24
# - 169.254.0.0/16
# - 192.88.99.0/24
# - 198.18.0.0/15
# - 192.0.2.0/24
# - 198.51.100.0/24
# - 203.0.113.0/24
# - 224.0.0.0/4
# - ::1/128
# - fe80::/10
# - fc00::/7
# - 2001:db8::/32
# - ff00::/8
# - fec0::/10
2022-07-18 16:43:12 +03:00
matrix_hookshot_widgets_disallowedIpRanges : '' # noqa var-naming
2022-04-11 16:48:50 +02:00
matrix_hookshot_widgets_internal : "/widgetapi"
# Default value of matrix_hookshot_widgets_endpoint: "/hookshot/widgetapi"
matrix_hookshot_widgets_endpoint : "{{ matrix_hookshot_public_endpoint }}{{ matrix_hookshot_widgets_internal }}"
2022-07-18 16:43:12 +03:00
matrix_hookshot_widgets_publicUrl : "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_widgets_endpoint }}/v1/static" # noqa var-naming
matrix_hookshot_widgets_branding_widgetTitle : "Hookshot Configuration" # noqa var-naming
2022-04-11 16:48:50 +02:00
2022-03-02 20:58:11 +01:00
# You can configure access to the bridge as documented here https://matrix-org.github.io/matrix-hookshot/setup.html#permissions
2022-01-14 19:21:05 +01:00
# When empty, the default permissions are applied.
# Example:
# matrix_hookshot_permissions:
# - actor: *
# services:
# - service: *
# level: commands
# - actor: example.com
# services:
# - service: "*"
# level: admin
matrix_hookshot_permissions : [ ]
2022-01-11 00:19:29 +01:00
2022-01-06 18:55:36 +01:00
matrix_hookshot_bot_displayname : Hookshot Bot
matrix_hookshot_bot_avatar : 'mxc://half-shot.uk/2876e89ccade4cb615e210c458e2a7a6883fe17d'
2022-01-03 21:22:42 +01:00
2023-03-20 17:03:19 +02:00
matrix_hookshot_container_network : "{{ matrix_docker_network }}"
2022-01-03 21:22:42 +01:00
# A list of extra arguments to pass to the container
matrix_hookshot_container_extra_arguments : [ ]
# List of systemd services that service depends on.
matrix_hookshot_systemd_required_services_list : [ 'docker.service' ]
# List of systemd services that service wants
matrix_hookshot_systemd_wanted_services_list : [ ]
2022-01-06 18:55:36 +01:00
# List of ports to bind to the host to expose them directly.
# Ports will automatically be bound to localhost if matrix_nginx_proxy_enabled is false.
# Setting this variable will override that behaviour in either case.
# Supply docker port bind arguments in a list like this:
#
# matrix_hookshot_container_http_host_bind_ports:
# - "127.0.0.1:9999:{{ matrix_hookshot_metrics_port }}"
#
# Above example will bind the metrics port in the container to port 9999 on localhost.
matrix_hookshot_container_http_host_bind_ports : [ ]
2022-01-30 19:05:49 +01:00
# These tokens will be set automatically
2022-01-03 21:22:42 +01:00
matrix_hookshot_appservice_token : ''
matrix_hookshot_homeserver_token : ''
# Default configuration template which covers the generic use case.
# You can customize it by controlling the various variables inside it.
#
# For a more advanced customization, you can extend the default (see `matrixhookshot_configuration_extension_yaml`)
# or completely replace this variable with your own template.
matrix_hookshot_configuration_yaml : "{{ lookup('template', 'templates/config.yml.j2') }}"
matrix_hookshot_configuration_extension_yaml : |
# Your custom YAML configuration goes here.
# This configuration extends the default starting configuration (`matrix_hookshot_configuration_yaml`).
#
# You can override individual variables from the default configuration, or introduce new ones.
#
# If you need something more special, you can take full control by
# completely redefining `matrix_hookshot_configuration_yaml`.
2022-07-18 11:22:05 +03:00
matrix_hookshot_configuration_extension : "{{ matrix_hookshot_configuration_extension_yaml | from_yaml if matrix_hookshot_configuration_extension_yaml | from_yaml is mapping else {} }}"
2022-01-03 21:22:42 +01:00
# Holds the final configuration (a combination of the default and its extension).
# You most likely don't need to touch this variable. Instead, see `matrix_hookshot_configuration_yaml`.
2022-07-18 12:28:39 +03:00
matrix_hookshot_configuration : "{{ matrix_hookshot_configuration_yaml | from_yaml | combine(matrix_hookshot_configuration_extension, recursive=True) }}"
2022-01-03 21:22:42 +01:00
# Default registration template which covers the generic use case.
# You can customize it by controlling the various variables inside it.
#
# For a more advanced customization, you can extend the default (see `matrixhookshot_registration_extension_yaml`)
# or completely replace this variable with your own template.
matrix_hookshot_registration_yaml : "{{ lookup('template', 'templates/registration.yml.j2') }}"
matrix_hookshot_registration_extension_yaml : |
# Your custom YAML registration goes here.
# This registration extends the default starting registration (`matrix_hookshot_registration_yaml`).
#
# You can override individual variables from the default registration, or introduce new ones.
#
# If you need something more special, you can take full control by
# completely redefining `matrix_hookshot_registration_yaml`.
2022-07-18 11:22:05 +03:00
matrix_hookshot_registration_extension : "{{ matrix_hookshot_registration_extension_yaml | from_yaml if matrix_hookshot_registration_extension_yaml | from_yaml is mapping else {} }}"
2022-01-03 21:22:42 +01:00
# Holds the final registration (a combination of the default and its extension).
# You most likely don't need to touch this variable. Instead, see `matrix_hookshot_registration_yaml`.
2022-07-18 12:28:39 +03:00
matrix_hookshot_registration : "{{ matrix_hookshot_registration_yaml | from_yaml | combine(matrix_hookshot_registration_extension, recursive=True) }}"