diff --git a/roles/custom/matrix-element-call/templates/element-call-labels.j2-new b/roles/custom/matrix-element-call/templates/element-call-labels.j2-new index a31c6ea6b..0428d056a 100644 --- a/roles/custom/matrix-element-call/templates/element-call-labels.j2-new +++ b/roles/custom/matrix-element-call/templates/element-call-labels.j2-new @@ -1,19 +1,20 @@ {% if matrix_element_call_container_labels_traefik_enabled %} traefik.enable=true +# Network configuration for Traefik {% if matrix_element_call_container_labels_traefik_docker_network %} traefik.docker.network={{ matrix_element_call_container_labels_traefik_docker_network }} {% endif %} -# Define the Traefik router rule -traefik.http.routers.element-call-router.rule={{ matrix_element_call_container_labels_traefik_rule }} +# Traefik Router and Service configuration for Element Call +traefik.http.routers.element-call-router.rule=Host(`{{ matrix_element_call_container_labels_traefik_hostname }}`) traefik.http.routers.element-call-router.entrypoints={{ matrix_element_call_container_labels_traefik_entrypoints }} traefik.http.routers.element-call-router.tls.certresolver={{ matrix_element_call_container_labels_traefik_tls_certResolver }} traefik.http.services.element-call-service.loadbalancer.server.port=8080 {% set middlewares = [] %} -# Define any path prefix redirection or stripping middleware +# Path prefix handling for Element Call {% if matrix_element_call_container_labels_traefik_path_prefix != '/' %} traefik.http.middlewares.element-call-slashless-redirect.redirectregex.regex=({{ matrix_element_call_container_labels_traefik_path_prefix | quote }})$ traefik.http.middlewares.element-call-slashless-redirect.redirectregex.replacement=${1}/ @@ -23,17 +24,24 @@ traefik.http.middlewares.element-call-strip-prefix.stripprefix.prefixes={{ matri {% set middlewares = middlewares + ['element-call-strip-prefix'] %} {% endif %} -# Apply any additional response headers if provided -{% if matrix_element_call_container_labels_traefik_additional_response_headers.keys() | length > 0 %} +# Additional response headers for Element Call +{% if matrix_element_call_container_labels_traefik_additional_response_headers is defined and matrix_element_call_container_labels_traefik_additional_response_headers | length > 0 %} {% for name, value in matrix_element_call_container_labels_traefik_additional_response_headers.items() %} traefik.http.middlewares.element-call-add-headers.headers.customresponseheaders.{{ name }}={{ value }} {% endfor %} {% set middlewares = middlewares + ['element-call-add-headers'] %} {% endif %} -# Add middlewares to the router +# Apply middlewares to the Element Call router {% if middlewares | length > 0 %} traefik.http.routers.element-call-router.middlewares={{ middlewares | join(',') }} {% endif %} {% endif %} + +# Additional labels (if any) specified by the user +{% if matrix_element_call_container_extra_arguments is defined and matrix_element_call_container_extra_arguments | length > 0 %} +{% for key, value in matrix_element_call_container_extra_arguments.items() %} +{{ key }}={{ value }} +{% endfor %} +{% endif %}