Matrix Docker Ansible eploy
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

371 lines
21 KiB

  1. ---
  2. # A bridge between Matrix and multiple project management services, such as GitHub, GitLab and JIRA.
  3. # Project source code URL: https://github.com/matrix-org/matrix-hookshot
  4. matrix_hookshot_enabled: true
  5. matrix_hookshot_identifier: matrix-hookshot
  6. matrix_hookshot_container_image_self_build: false
  7. matrix_hookshot_container_image_self_build_repo: "https://github.com/matrix-org/matrix-hookshot.git"
  8. matrix_hookshot_container_image_self_build_branch: "{{ 'main' if matrix_hookshot_version == 'latest' else matrix_hookshot_version }}"
  9. # Specifies additional networks for the Hookshot container to connect with
  10. matrix_hookshot_container_additional_networks: "{{ matrix_hookshot_container_additional_networks_auto + matrix_hookshot_container_additional_networks_custom }}"
  11. matrix_hookshot_container_additional_networks_auto: []
  12. matrix_hookshot_container_additional_networks_custom: []
  13. # renovate: datasource=docker depName=halfshot/matrix-hookshot
  14. matrix_hookshot_version: 6.0.1
  15. matrix_hookshot_docker_image: "{{ matrix_hookshot_docker_image_name_prefix }}matrix-org/matrix-hookshot:{{ matrix_hookshot_version }}"
  16. matrix_hookshot_docker_image_name_prefix: "{{ 'localhost/' if matrix_hookshot_container_image_self_build else 'ghcr.io/' }}"
  17. matrix_hookshot_docker_image_force_pull: "{{ matrix_hookshot_docker_image.endswith(':latest') }}"
  18. matrix_hookshot_base_path: "{{ matrix_base_data_path }}/hookshot"
  19. matrix_hookshot_docker_src_files_path: "{{ matrix_hookshot_base_path }}/docker-src"
  20. matrix_hookshot_homeserver_address: ""
  21. matrix_hookshot_container_url: 'matrix-hookshot'
  22. # Sets the localpart of the Matrix ID for the hookshot bot
  23. matrix_hookshot_bot_localpart: "hookshot"
  24. matrix_hookshot_public_scheme: https
  25. matrix_hookshot_public_hostname: "{{ matrix_server_fqn_matrix }}"
  26. matrix_hookshot_public_endpoint: /hookshot
  27. # This is the base URL prefix shared among all endpoints.
  28. #
  29. # It intentionally does not include the path prefix (`matrix_hookshot_public_endpoint`),
  30. # because of how it's used - it's concatenated with paths that already use matrix_hookshot_public_endpoint` within them.
  31. matrix_hookshot_urlprefix: "{{ matrix_hookshot_public_scheme }}://{{ matrix_hookshot_public_hostname }}"
  32. # There is no need to edit ports. use matrix_hookshot_container_http_host_bind_ports below to expose ports instead.
  33. matrix_hookshot_appservice_port: 9993
  34. matrix_hookshot_appservice_hostname: "{{ matrix_hookshot_public_hostname }}"
  35. matrix_hookshot_appservice_endpoint: "{{ matrix_hookshot_public_endpoint }}/_matrix/app"
  36. # The variables below control the Redis cache parameters.
  37. # Using caching is required when encryption is enabled (`matrix_hookshot_encryption_enabled`)
  38. # but may also speed up Hookshot startup, etc.
  39. matrix_hookshot_cache_redis_host: ''
  40. matrix_hookshot_cache_redis_port: "6379"
  41. matrix_hookshot_cache_redisUri: "{{ ('redis://' + matrix_hookshot_cache_redis_host + ':' + matrix_hookshot_cache_redis_port) if matrix_hookshot_cache_redis_host else '' }}" # noqa var-naming
  42. # Controls whether the end-to-bridge encryption support is enabled.
  43. # This requires that:
  44. # - support to also be enabled in the homeserver, see the documentation of Hookshot.
  45. # - Hookshot to be pointed at a Redis instance via the `matrix_hookshot_cache_redis*` variables.
  46. # See: https://matrix-org.github.io/matrix-hookshot/latest/advanced/encryption.html
  47. matrix_hookshot_encryption_enabled: false
  48. # Controls whether metrics are enabled in the bridge configuration.
  49. # Enabling them is usually enough for a local (in-container) Prometheus to consume them.
  50. # If metrics need to be consumed by another (external) Prometheus server, consider exposing them via `matrix_hookshot_metrics_proxying_enabled`.
  51. matrix_hookshot_metrics_enabled: false
  52. # Controls whether Hookshot metrics should be proxied (exposed) on a public URL.
  53. matrix_hookshot_metrics_proxying_enabled: false
  54. matrix_hookshot_metrics_proxying_hostname: ''
  55. matrix_hookshot_metrics_proxying_path_prefix: ''
  56. # There is no need to edit ports.
  57. # Read the documentation to learn about using Hookshot metrics with external Prometheus
  58. # If you still want something different, use matrix_hookshot_container_http_host_bind_ports below to expose ports instead.
  59. matrix_hookshot_metrics_port: 9001
  60. # There is no need to edit ports. use matrix_hookshot_container_http_host_bind_ports below to expose ports instead.
  61. matrix_hookshot_webhook_port: 9000
  62. matrix_hookshot_webhook_hostname: "{{ matrix_hookshot_public_hostname }}"
  63. matrix_hookshot_webhook_endpoint: "{{ matrix_hookshot_public_endpoint }}/webhooks"
  64. # You need to create a GitHub app to enable this and fill in the empty variables below
  65. # https://matrix-org.github.io/matrix-hookshot/setup/github.html
  66. matrix_hookshot_github_enabled: false
  67. matrix_hookshot_github_auth_id: ''
  68. # Set this variable to the contents of the generated and downloaded GitHub private key:
  69. # matrix_hookshot_github_private_key: |
  70. # -----BEGIN RSA PRIVATE KEY-----
  71. # 0123456789ABCDEF…
  72. # -----END RSA PRIVATE KEY-----
  73. # Alternatively, leave it empty and do it manually or use matrix-aux instead, see docs/matrix-bridge-hookshot.md for info.
  74. matrix_hookshot_github_private_key: ''
  75. matrix_hookshot_github_private_key_file: 'private-key.pem'
  76. matrix_hookshot_github_webhook_secret: '' # "Webhook secret" on the GitHub App page
  77. matrix_hookshot_github_oauth_enabled: false
  78. # You need to configure oauth settings only when you have enabled oauth (optional)
  79. matrix_hookshot_github_oauth_client_id: '' # "Client ID" on the GitHub App page
  80. matrix_hookshot_github_oauth_client_secret: '' # "Client Secret" on the GitHub App page
  81. # Default value of matrix_hookshot_github_oauth_endpoint: "/hookshot/webhooks/oauth"
  82. matrix_hookshot_github_oauth_endpoint: "{{ matrix_hookshot_webhook_endpoint }}/oauth"
  83. matrix_hookshot_github_oauth_redirect_uri: "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_github_oauth_endpoint }}"
  84. # 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
  85. matrix_hookshot_github_defaultOptions_ignoreHooks: {} # noqa var-naming
  86. matrix_hookshot_github_defaultOptions_commandPrefix: '!gh' # noqa var-naming
  87. matrix_hookshot_github_defaultOptions_showIssueRoomLink: false # noqa var-naming
  88. matrix_hookshot_github_defaultOptions_prDiff: # noqa var-naming
  89. enabled: false
  90. maxLines: 5
  91. matrix_hookshot_github_defaultOptions_includingLabels: '' # noqa var-naming
  92. matrix_hookshot_github_defaultOptions_excludingLabels: '' # noqa var-naming
  93. matrix_hookshot_github_defaultOptions_hotlinkIssues_prefix: "#" # noqa var-naming
  94. matrix_hookshot_gitlab_enabled: true
  95. # Optionally add your instances, e.g.
  96. # matrix_hookshot_gitlab_instances:
  97. # gitlab.com:
  98. # url: https://gitlab.com
  99. # mygitlab:
  100. # url: https://gitlab.example.org
  101. matrix_hookshot_gitlab_instances:
  102. gitlab.com:
  103. url: https://gitlab.com
  104. # This will be the "Secret token" you have to enter into all GitLab instances for authentication
  105. matrix_hookshot_gitlab_webhook_secret: ''
  106. matrix_hookshot_gitlab_webhook_publicUrl: "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_webhook_endpoint }}" # noqa var-naming
  107. matrix_hookshot_figma_enabled: false
  108. # Default value of matrix_hookshot_figma_endpoint: "/hookshot/webhooks/figma/webhook"
  109. matrix_hookshot_figma_endpoint: "{{ matrix_hookshot_webhook_endpoint }}/figma/webhook"
  110. matrix_hookshot_figma_publicUrl: "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_figma_endpoint }}" # noqa var-naming
  111. # To bridge figma webhooks, you need to configure one of multiple instances like this:
  112. # matrix_hookshot_figma_instances:
  113. # your-instance:
  114. # teamId: your-team-id
  115. # accessToken: your-personal-access-token
  116. # passcode: your-webhook-passcode
  117. matrix_hookshot_figma_instances: {}
  118. matrix_hookshot_jira_enabled: false
  119. # Get the these values from https://matrix-org.github.io/matrix-hookshot/setup/jira.html#jira-oauth
  120. matrix_hookshot_jira_webhook_secret: ''
  121. matrix_hookshot_jira_oauth_enabled: false
  122. matrix_hookshot_jira_oauth_client_id: ''
  123. matrix_hookshot_jira_oauth_client_secret: ''
  124. # Default value of matrix_hookshot_jira_oauth_endpoint: "/hookshot/webhooks/jira/oauth"
  125. matrix_hookshot_jira_oauth_endpoint: "{{ matrix_hookshot_webhook_endpoint }}/jira/oauth"
  126. matrix_hookshot_jira_oauth_redirect_uri: "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_jira_oauth_endpoint }}"
  127. # No need to change these
  128. matrix_hookshot_generic_enabled: true
  129. matrix_hookshot_generic_outbound: true
  130. matrix_hookshot_generic_enableHttpGet: false # noqa var-naming
  131. # Default value of matrix_hookshot_generic_endpoint: "/hookshot/webhooks"
  132. matrix_hookshot_generic_endpoint: "{{ matrix_hookshot_webhook_endpoint }}/webhook"
  133. # urlprefix gets updated with protocol & port in group_vars/matrix_servers
  134. matrix_hookshot_generic_urlPrefix: "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_generic_endpoint }}" # noqa var-naming
  135. # If you're also using matrix-appservice-webhooks, take care that these prefixes don't overlap
  136. matrix_hookshot_generic_userIdPrefix: '_webhooks_' # noqa var-naming
  137. matrix_hookshot_generic_allowJsTransformationFunctions: false # noqa var-naming
  138. matrix_hookshot_generic_waitForComplete: false # noqa var-naming
  139. matrix_hookshot_feeds_enabled: true
  140. matrix_hookshot_feeds_pollIntervalSeconds: 600 # noqa var-naming
  141. matrix_hookshot_feeds_pollTimeoutSeconds: 30 # noqa var-naming
  142. matrix_hookshot_provisioning_enabled: false
  143. # There is no need to edit ports. use matrix_hookshot_container_http_host_bind_ports below to expose ports instead.
  144. matrix_hookshot_provisioning_port: 9002
  145. matrix_hookshot_provisioning_secret: ''
  146. # Provisioning will be automatically enabled if dimension is enabled and you have provided a provisioning secret, unless you override it
  147. matrix_hookshot_provisioning_internal: "/v1"
  148. matrix_hookshot_provisioning_hostname: "{{ matrix_hookshot_public_hostname }}"
  149. matrix_hookshot_provisioning_endpoint: "{{ matrix_hookshot_public_endpoint }}{{ matrix_hookshot_provisioning_internal }}"
  150. # Valid logging levels are: debug, info, warn, error
  151. matrix_hookshot_logging_level: warn
  152. matrix_hookshot_widgets_enabled: true
  153. matrix_hookshot_widgets_port: 9003
  154. matrix_hookshot_widgets_addToAdminRooms: false # default off as it is a beta feature # noqa var-naming
  155. matrix_hookshot_widgets_roomSetupWidget_enabled: true # noqa var-naming
  156. matrix_hookshot_widgets_roomSetupWidget_addOnInvite: false # noqa var-naming
  157. # `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.
  158. # matrix_hookshot_widgets_disallowedIpRanges:
  159. # - 127.0.0.0/8
  160. # - 10.0.0.0/8
  161. # - 172.16.0.0/12
  162. # - 192.168.0.0/16
  163. # - 100.64.0.0/10
  164. # - 192.0.0.0/24
  165. # - 169.254.0.0/16
  166. # - 192.88.99.0/24
  167. # - 198.18.0.0/15
  168. # - 192.0.2.0/24
  169. # - 198.51.100.0/24
  170. # - 203.0.113.0/24
  171. # - 224.0.0.0/4
  172. # - ::1/128
  173. # - fe80::/10
  174. # - fc00::/7
  175. # - 2001:db8::/32
  176. # - ff00::/8
  177. # - fec0::/10
  178. matrix_hookshot_widgets_disallowedIpRanges: '' # noqa var-naming
  179. matrix_hookshot_widgets_internal: "/widgetapi"
  180. matrix_hookshot_widgets_hostname: "{{ matrix_hookshot_public_hostname }}"
  181. matrix_hookshot_widgets_endpoint: "{{ matrix_hookshot_public_endpoint }}{{ matrix_hookshot_widgets_internal }}"
  182. matrix_hookshot_widgets_publicUrl: "{{ matrix_hookshot_urlprefix }}{{ matrix_hookshot_widgets_endpoint }}/v1/static/" # noqa var-naming
  183. matrix_hookshot_widgets_branding_widgetTitle: "Hookshot Configuration" # noqa var-naming
  184. # You can configure access to the bridge as documented here https://matrix-org.github.io/matrix-hookshot/setup.html#permissions
  185. # When empty, the default permissions are applied.
  186. # Example:
  187. # matrix_hookshot_permissions:
  188. # - actor: *
  189. # services:
  190. # - service: *
  191. # level: commands
  192. # - actor: example.com
  193. # services:
  194. # - service: "*"
  195. # level: admin
  196. matrix_hookshot_permissions: []
  197. matrix_hookshot_bot_displayname: Hookshot Bot
  198. matrix_hookshot_bot_avatar: 'mxc://half-shot.uk/2876e89ccade4cb615e210c458e2a7a6883fe17d'
  199. matrix_hookshot_container_network: ""
  200. # A list of extra arguments to pass to the container
  201. matrix_hookshot_container_extra_arguments: []
  202. # matrix_hookshot_container_labels_traefik_enabled controls whether labels to assist a Traefik reverse-proxy will be attached to the container.
  203. # See `../templates/labels.j2` for details.
  204. #
  205. # To inject your own other container labels, see `matrix_hookshot_container_labels_additional_labels`.
  206. matrix_hookshot_container_labels_traefik_enabled: true
  207. matrix_hookshot_container_labels_traefik_docker_network: "{{ matrix_hookshot_container_network }}"
  208. matrix_hookshot_container_labels_traefik_entrypoints: web-secure
  209. matrix_hookshot_container_labels_traefik_tls_certResolver: default # noqa var-naming
  210. # Controls whether labels will be added that expose Hookshot's webhooks endpoint
  211. matrix_hookshot_container_labels_webhooks_enabled: true
  212. matrix_hookshot_container_labels_webhooks_traefik_rule: "Host(`{{ matrix_hookshot_webhook_hostname }}`) && PathPrefix(`{{ matrix_hookshot_webhook_endpoint }}`)"
  213. matrix_hookshot_container_labels_webhooks_traefik_priority: 0
  214. matrix_hookshot_container_labels_webhooks_traefik_entrypoints: "{{ matrix_hookshot_container_labels_traefik_entrypoints }}"
  215. matrix_hookshot_container_labels_webhooks_traefik_tls: "{{ matrix_hookshot_container_labels_webhooks_traefik_entrypoints != 'web' }}"
  216. matrix_hookshot_container_labels_webhooks_traefik_tls_certResolver: "{{ matrix_hookshot_container_labels_traefik_tls_certResolver }}" # noqa var-naming
  217. # Controls whether labels will be added that expose Hookshot's appservice endpoint
  218. matrix_hookshot_container_labels_appservice_enabled: true
  219. matrix_hookshot_container_labels_appservice_traefik_rule: "Host(`{{ matrix_hookshot_appservice_hostname }}`) && PathPrefix(`{{ matrix_hookshot_appservice_endpoint }}`)"
  220. matrix_hookshot_container_labels_appservice_traefik_priority: 0
  221. matrix_hookshot_container_labels_appservice_traefik_entrypoints: "{{ matrix_hookshot_container_labels_traefik_entrypoints }}"
  222. matrix_hookshot_container_labels_appservice_traefik_tls: "{{ matrix_hookshot_container_labels_appservice_traefik_entrypoints != 'web' }}"
  223. matrix_hookshot_container_labels_appservice_traefik_tls_certResolver: "{{ matrix_hookshot_container_labels_traefik_tls_certResolver }}" # noqa var-naming
  224. # Controls whether labels will be added that expose Hookshot's widgets endpoint
  225. matrix_hookshot_container_labels_widgets_enabled: "{{ matrix_hookshot_widgets_enabled }}"
  226. matrix_hookshot_container_labels_widgets_traefik_rule: "Host(`{{ matrix_hookshot_widgets_hostname }}`) && PathPrefix(`{{ matrix_hookshot_widgets_endpoint }}`)"
  227. matrix_hookshot_container_labels_widgets_traefik_priority: 0
  228. matrix_hookshot_container_labels_widgets_traefik_entrypoints: "{{ matrix_hookshot_container_labels_traefik_entrypoints }}"
  229. matrix_hookshot_container_labels_widgets_traefik_tls: "{{ matrix_hookshot_container_labels_widgets_traefik_entrypoints != 'web' }}"
  230. matrix_hookshot_container_labels_widgets_traefik_tls_certResolver: "{{ matrix_hookshot_container_labels_traefik_tls_certResolver }}" # noqa var-naming
  231. # Controls whether labels will be added that expose Hookshot's provisioning endpoint
  232. matrix_hookshot_container_labels_provisioning_enabled: "{{ matrix_hookshot_provisioning_enabled }}"
  233. matrix_hookshot_container_labels_provisioning_traefik_rule: "Host(`{{ matrix_hookshot_provisioning_hostname }}`) && PathPrefix(`{{ matrix_hookshot_provisioning_endpoint }}`)"
  234. matrix_hookshot_container_labels_provisioning_traefik_priority: 0
  235. matrix_hookshot_container_labels_provisioning_traefik_entrypoints: "{{ matrix_hookshot_container_labels_traefik_entrypoints }}"
  236. matrix_hookshot_container_labels_provisioning_traefik_tls: "{{ matrix_hookshot_container_labels_provisioning_traefik_entrypoints != 'web' }}"
  237. matrix_hookshot_container_labels_provisioning_traefik_tls_certResolver: "{{ matrix_hookshot_container_labels_traefik_tls_certResolver }}" # noqa var-naming
  238. # Controls whether labels will be added that expose Hookshot's provisioning endpoint
  239. matrix_hookshot_container_labels_metrics_enabled: "{{ matrix_hookshot_metrics_enabled and matrix_hookshot_metrics_proxying_enabled }}"
  240. matrix_hookshot_container_labels_metrics_traefik_rule: "Host(`{{ matrix_hookshot_metrics_proxying_hostname }}`) && PathPrefix(`{{ matrix_hookshot_metrics_proxying_path_prefix }}`)"
  241. matrix_hookshot_container_labels_metrics_traefik_priority: 0
  242. matrix_hookshot_container_labels_metrics_traefik_entrypoints: "{{ matrix_hookshot_container_labels_traefik_entrypoints }}"
  243. matrix_hookshot_container_labels_metrics_traefik_tls: "{{ matrix_hookshot_container_labels_metrics_traefik_entrypoints != 'web' }}"
  244. matrix_hookshot_container_labels_metrics_traefik_tls_certResolver: "{{ matrix_hookshot_container_labels_traefik_tls_certResolver }}" # noqa var-naming
  245. matrix_hookshot_container_labels_metrics_middleware_basic_auth_enabled: false
  246. # See: https://doc.traefik.io/traefik/middlewares/http/basicauth/#users
  247. matrix_hookshot_container_labels_metrics_middleware_basic_auth_users: ''
  248. # matrix_hookshot_container_labels_additional_labels contains a multiline string with additional labels to add to the container label file.
  249. # See `../templates/labels.j2` for details.
  250. #
  251. # Example:
  252. # matrix_hookshot_container_labels_additional_labels: |
  253. # my.label=1
  254. # another.label="here"
  255. matrix_hookshot_container_labels_additional_labels: ''
  256. # List of systemd services that service depends on.
  257. matrix_hookshot_systemd_required_services_list: "{{ matrix_hookshot_systemd_required_services_list_default + matrix_hookshot_systemd_required_services_list_auto + matrix_hookshot_systemd_required_services_list_custom }}"
  258. matrix_hookshot_systemd_required_services_list_default: "{{ [devture_systemd_docker_base_docker_service_name] if devture_systemd_docker_base_docker_service_name else [] }}"
  259. matrix_hookshot_systemd_required_services_list_auto: []
  260. matrix_hookshot_systemd_required_services_list_custom: []
  261. # List of systemd services that service wants
  262. matrix_hookshot_systemd_wanted_services_list: []
  263. # List of ports to bind to the host to expose them directly.
  264. # Supply docker port bind arguments in a list like this:
  265. #
  266. # matrix_hookshot_container_http_host_bind_ports:
  267. # - "127.0.0.1:9999:{{ matrix_hookshot_metrics_port }}"
  268. #
  269. # Above example will bind the metrics port in the container to port 9999 on localhost.
  270. matrix_hookshot_container_http_host_bind_ports: []
  271. # These tokens will be set automatically
  272. matrix_hookshot_appservice_token: ''
  273. matrix_hookshot_homeserver_token: ''
  274. # Default configuration template which covers the generic use case.
  275. # You can customize it by controlling the various variables inside it.
  276. #
  277. # For a more advanced customization, you can extend the default (see `matrixhookshot_configuration_extension_yaml`)
  278. # or completely replace this variable with your own template.
  279. matrix_hookshot_configuration_yaml: "{{ lookup('template', 'templates/config.yml.j2') }}"
  280. matrix_hookshot_configuration_extension_yaml: |
  281. # Your custom YAML configuration goes here.
  282. # This configuration extends the default starting configuration (`matrix_hookshot_configuration_yaml`).
  283. #
  284. # You can override individual variables from the default configuration, or introduce new ones.
  285. #
  286. # If you need something more special, you can take full control by
  287. # completely redefining `matrix_hookshot_configuration_yaml`.
  288. matrix_hookshot_configuration_extension: "{{ matrix_hookshot_configuration_extension_yaml | from_yaml if matrix_hookshot_configuration_extension_yaml | from_yaml is mapping else {} }}"
  289. # Holds the final configuration (a combination of the default and its extension).
  290. # You most likely don't need to touch this variable. Instead, see `matrix_hookshot_configuration_yaml`.
  291. matrix_hookshot_configuration: "{{ matrix_hookshot_configuration_yaml | from_yaml | combine(matrix_hookshot_configuration_extension, recursive=True) }}"
  292. # Default registration template which covers the generic use case.
  293. # You can customize it by controlling the various variables inside it.
  294. #
  295. # For a more advanced customization, you can extend the default (see `matrixhookshot_registration_extension_yaml`)
  296. # or completely replace this variable with your own template.
  297. matrix_hookshot_registration_yaml: "{{ lookup('template', 'templates/registration.yml.j2') }}"
  298. matrix_hookshot_registration_extension_yaml: |
  299. # Your custom YAML registration goes here.
  300. # This registration extends the default starting registration (`matrix_hookshot_registration_yaml`).
  301. #
  302. # You can override individual variables from the default registration, or introduce new ones.
  303. #
  304. # If you need something more special, you can take full control by
  305. # completely redefining `matrix_hookshot_registration_yaml`.
  306. matrix_hookshot_registration_extension: "{{ matrix_hookshot_registration_extension_yaml | from_yaml if matrix_hookshot_registration_extension_yaml | from_yaml is mapping else {} }}"
  307. # Holds the final registration (a combination of the default and its extension).
  308. # You most likely don't need to touch this variable. Instead, see `matrix_hookshot_registration_yaml`.
  309. matrix_hookshot_registration: "{{ matrix_hookshot_registration_yaml | from_yaml | combine(matrix_hookshot_registration_extension, recursive=True) }}"