# SPDX-FileCopyrightText: 2024 Slavi Pantaleev # SPDX-FileCopyrightText: 2025 Suguru Hirahara # # SPDX-License-Identifier: AGPL-3.0-or-later --- - name: Fail if required baibot settings not defined ansible.builtin.fail: msg: >- You need to define a required configuration setting (`{{ item.name }}`). when: "item.when | bool and lookup('vars', item.name, default='') | string | length == 0" with_items: - {'name': 'matrix_bot_baibot_config_user_mxid_localpart', when: true} - {'name': 'matrix_bot_baibot_container_network', when: true} - {'name': 'matrix_bot_baibot_config_homeserver_url', when: true} - {'name': 'matrix_bot_baibot_config_agents_static_definitions_anthropic_config_api_key', when: "{{ matrix_bot_baibot_config_agents_static_definitions_anthropic_enabled }}"} - {'name': 'matrix_bot_baibot_config_agents_static_definitions_groq_config_api_key', when: "{{ matrix_bot_baibot_config_agents_static_definitions_groq_enabled }}"} - {'name': 'matrix_bot_baibot_config_agents_static_definitions_groq_config_text_generation_model_id', when: "{{ matrix_bot_baibot_config_agents_static_definitions_groq_enabled and matrix_bot_baibot_config_agents_static_definitions_groq_config_text_generation_enabled }}"} - {'name': 'matrix_bot_baibot_config_agents_static_definitions_mistral_config_api_key', when: "{{ matrix_bot_baibot_config_agents_static_definitions_mistral_enabled }}"} - {'name': 'matrix_bot_baibot_config_agents_static_definitions_mistral_config_text_generation_model_id', when: "{{ matrix_bot_baibot_config_agents_static_definitions_mistral_enabled and matrix_bot_baibot_config_agents_static_definitions_mistral_config_text_generation_enabled }}"} - {'name': 'matrix_bot_baibot_config_agents_static_definitions_openai_config_api_key', when: "{{ matrix_bot_baibot_config_agents_static_definitions_openai_enabled }}"} - name: Fail if baibot authentication mode is not configured ansible.builtin.fail: msg: >- You need to configure one baibot authentication mode: either `matrix_bot_baibot_config_user_password` or (`matrix_bot_baibot_config_user_access_token` + `matrix_bot_baibot_config_user_device_id`). when: >- ( matrix_bot_baibot_config_user_password | default('', true) | string | length == 0 ) and ( matrix_bot_baibot_config_user_access_token | default('', true) | string | length == 0 and matrix_bot_baibot_config_user_device_id | default('', true) | string | length == 0 ) - name: Fail if baibot authentication mode is configured ambiguously ansible.builtin.fail: msg: >- You need to configure exactly one baibot authentication mode. Set either `matrix_bot_baibot_config_user_password`, or (`matrix_bot_baibot_config_user_access_token` + `matrix_bot_baibot_config_user_device_id`) but not both. when: >- ( matrix_bot_baibot_config_user_password | default('', true) | string | length > 0 ) and ( matrix_bot_baibot_config_user_access_token | default('', true) | string | length > 0 or matrix_bot_baibot_config_user_device_id | default('', true) | string | length > 0 ) - name: Fail if baibot access token authentication is incomplete ansible.builtin.fail: msg: >- Access-token authentication requires both `matrix_bot_baibot_config_user_access_token` and `matrix_bot_baibot_config_user_device_id`. when: >- ( matrix_bot_baibot_config_user_password | default('', true) | string | length == 0 ) and ( matrix_bot_baibot_config_user_access_token | default('', true) | string | length > 0 or matrix_bot_baibot_config_user_device_id | default('', true) | string | length > 0 ) and ( matrix_bot_baibot_config_user_access_token | default('', true) | string | length == 0 or matrix_bot_baibot_config_user_device_id | default('', true) | string | length == 0 ) - name: Fail if admin patterns list is empty ansible.builtin.fail: msg: >- You need to define a required configuration setting (`matrix_bot_baibot_config_access_admin_patterns`) to specify which users are bot administrators. when: "matrix_bot_baibot_config_access_admin_patterns | length == 0" - name: (Deprecation) Catch and report renamed baibot settings ansible.builtin.fail: msg: >- Your configuration contains a variable, which now has a different name. Please rename the variable (`{{ item.old }}` -> `{{ item.new }}`) on your configuration file (vars.yml). when: "lookup('ansible.builtin.varnames', ('^' + item.old + '$'), wantlist=True) | length > 0" with_items: - {'old': 'matrix_bot_baibot_container_image_name_prefix', 'new': 'matrix_bot_baibot_container_image_registry_prefix'}