core.objectchange:2304
| Time |
2026-05-31 20:34:18
|
|---|---|
| User |
York-Simon Johannsen (YoSiJo)
|
| Action |
Updated
|
| Object type |
Extras | webhook
|
| Object | |
| Message |
—
|
| Request ID |
{
"body_template": "{%- set ns = namespace(has_failures=false, body=\"\") -%}\r\n\r\n{# Titel und Einleitung #}\r\n{%- set report_name = data.name | default(\"PlatformReport\") -%}\r\n{%- set ns.body = \"# ❌ NetBox Report: Fehlgeschlagene Checks in \" ~ report_name ~ \"[BR]## Der Report \" ~ report_name ~ \" wurde von \" ~ (username | default('YoSiJo')) ~ \" ausgefuehrt.[BR]### Log:\" -%}\r\n\r\n{# 1. NetBox v4 Report-Tests durchlaufen #}\r\n{%- if data is defined and data.tests is defined -%}\r\n {%- for test_name, test_results in data.tests.items() -%}\r\n {%- if test_results.failure and test_results.log -%}\r\n \r\n {# 1a. Einzigartige Fehlermeldungen fuer diesen Test sammeln #}\r\n {%- set unique_messages = [] -%}\r\n {%- for log_entry in test_results.log -%}\r\n {%- if log_entry == 'failure' or log_entry == 'failed' -%}\r\n {%- set msg_text = log_entry -%}\r\n {%- if msg_text not in unique_messages -%}\r\n {%- set unique_messages = unique_messages + [msg_text] -%}\r\n {%- set ns.has_failures = true -%}\r\n {%- endif -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n\r\n {# 1b. Wenn Fehler existieren, strukturiert ausgeben #}\r\n {%- if unique_messages | length > 0 -%}\r\n {%- set ns.body = ns.body ~ \"[BR][BR]#### \" ~ test_name -%}\r\n \r\n {# Fuer jede einzigartige Meldung eine eigene Gruppe erstellen #}\r\n {%- for current_msg in unique_messages -%}\r\n {%- set ns.body = ns.body ~ \"[BR][BR]##### \" ~ current_msg -%}\r\n \r\n {# Alle Objekte heraussuchen, die genau diese Meldung haben #}\r\n {%- for log_entry in test_results.log -%}\r\n {%- if (log_entry == 'failure' or log_entry == 'failed') and log_entry == current_msg -%}\r\n {%- set clean_path = log_entry if log_entry.startswith('/') else '/' ~ log_entry -%}\r\n {%- set target_url = \"https://anoxinon.de\" ~ clean_path -%}\r\n {%- set ns.body = ns.body ~ \"[BR]- Name: \" ~ log_entry ~ \"[BR] URL: \" ~ target_url -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n \r\n {%- endfor -%}(1.3.2)\r\n {%- endif -%}\r\n\r\n {%- endif -%}\r\n {%- endfor -%}\r\n{%- endif -%}\r\n\r\n{# 2. Fallback für klassische Script-Logs #}\r\n{%- if data is defined and data.result is defined and data.result.log is defined -%}\r\n {%- set unique_script_messages = [] -%}\r\n {%- for log in data.result.log -%}\r\n {%- if log.status == 'failure' or log.status == 'failed' -%}\r\n {%- if log.message not in unique_script_messages -%}\r\n {%- set unique_script_messages = unique_script_messages + [log.message] -%}\r\n {%- set ns.has_failures = true -%}\r\n {%- endif -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n\r\n {%- if unique_script_messages | length > 0 -%}\r\n {%- set ns.body = ns.body ~ \"[BR][BR]#### Allgemeines Script Log\" -%}\r\n {%- for current_msg in unique_script_messages -%}\r\n {%- set ns.body = ns.body ~ \"[BR][BR]##### \" ~ current_msg -%}\r\n {%- for log in data.result.log -%}\r\n {%- if (log.status == 'failure' or log.status == 'failed') and log.message == current_msg -%}\r\n {%- set clean_path = log.obj.get_absolute_url() if log.obj else '' -%}\r\n {%- set target_url = \"https://anoxinon.de\" ~ clean_path if clean_path else \"https://anoxinon.de\" -%}\r\n {%- set ns.body = ns.body ~ \"[BR]- Name: \" ~ (log.obj.name | default('Allgemein')) ~ \"[BR] URL: \" ~ target_url -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n {%- endfor -%}\r\n {%- endif -%}\r\n{%- endif -%}\r\n\r\n{\r\n \"urls\": \"{%- if ns.has_failures -%}xmpps://netbox:{{ '' | xmpp_apprise_password }}@anoxinon.me/yosijo{%- endif -%}\",\r\n \"title\": \"❌ NetBox Report: Fehlgeschlagene Checks in {{ report_name }}\",\r\n \"body\": \"{{ ns.body.replace('[BR]', '\\\\n') }}\"\r\n}"
}
{
"body_template": "{%- set ns = namespace(has_failures=false, body=\"\") -%}\r\n\r\n{# Titel und Einleitung #}\r\n{%- set report_name = data.name | default(\"PlatformReport\") -%}\r\n{%- set ns.body = \"# ❌ NetBox Report: Fehlgeschlagene Checks in \" ~ report_name ~ \"\\n## Der Report \" ~ report_name ~ \" wurde von \" ~ (username | default('YoSiJo')) ~ \" ausgefuehrt.\\n### Log:\" -%}\r\n\r\n{# 1. NetBox v4 Report-Tests durchlaufen #}\r\n{%- if data is defined and data.tests is defined -%}\r\n {%- for test_name, test_results in data.tests.items() -%}\r\n {%- if test_results.failure and test_results.log -%}\r\n \r\n {# 1a. Einzigartige Fehlermeldungen fuer diesen Test sammeln #}\r\n {%- set unique_messages = [] -%}\r\n {%- for log_entry in test_results.log -%}\r\n {%- if log_entry[1] == 'failure' or log_entry[1] == 'failed' -%}\r\n {%- set msg_text = log_entry[4] -%}\r\n {%- if msg_text not in unique_messages -%}\r\n {%- set unique_messages = unique_messages + [msg_text] -%}\r\n {%- set ns.has_failures = true -%}\r\n {%- endif -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n\r\n {# 1b. Wenn Fehler existieren, strukturiert ausgeben #}\r\n {%- if unique_messages | length > 0 -%}\r\n {%- set ns.body = ns.body ~ \"\\n\\n#### \" ~ test_name -%}\r\n \r\n {# Fuer jede einzigartige Meldung eine eigene Gruppe erstellen #}\r\n {%- for current_msg in unique_messages -%}\r\n {%- set ns.body = ns.body ~ \"\\n\\n##### \" ~ current_msg -%}\r\n \r\n {# Alle Objekte heraussuchen, die genau diese Meldung haben #}\r\n {%- for log_entry in test_results.log -%}\r\n {%- if (log_entry[1] == 'failure' or log_entry[1] == 'failed') and log_entry[4] == current_msg -%}\r\n {%- set clean_path = log_entry[3] if log_entry[3].startswith('/') else '/' ~ log_entry[3] -%}\r\n {%- set target_url = \"https://anoxinon.de\" ~ clean_path -%}\r\n {%- set ns.body = ns.body ~ \"\\n- Name: \" ~ log_entry[2] ~ \"\\n URL: \" ~ target_url -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n \r\n {%- endfor -%}\r\n {%- endif -%}\r\n\r\n {%- endif -%}\r\n {%- endfor -%}\r\n{%- endif -%}\r\n\r\n{# 2. Fallback für klassische Script-Logs #}\r\n{%- if data is defined and data.result is defined and data.result.log is defined -%}\r\n {%- set unique_script_messages = [] -%}\r\n {%- for log in data.result.log -%}\r\n {%- if log.status == 'failure' or log.status == 'failed' -%}\r\n {%- if log.message not in unique_script_messages -%}\r\n {%- set unique_script_messages = unique_script_messages + [log.message] -%}\r\n {%- set ns.has_failures = true -%}\r\n {%- endif -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n\r\n {%- if unique_script_messages | length > 0 -%}\r\n {%- set ns.body = ns.body ~ \"\\n\\n#### Allgemeines Script Log\" -%}\r\n {%- for current_msg in unique_script_messages -%}\r\n {%- set ns.body = ns.body ~ \"\\n\\n##### \" ~ current_msg -%}\r\n {%- for log in data.result.log -%}\r\n {%- if (log.status == 'failure' or log.status == 'failed') and log.message == current_msg -%}\r\n {%- set clean_path = log.obj.get_absolute_url() if log.obj else '' -%}\r\n {%- set target_url = \"https://anoxinon.de\" ~ clean_path if clean_path else \"https://anoxinon.de\" -%}\r\n {%- set ns.body = ns.body ~ \"\\n- Name: \" ~ (log.obj.name | default('Allgemein')) ~ \"\\n URL: \" ~ target_url -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n {%- endfor -%}\r\n {%- endif -%}\r\n{%- endif -%}\r\n\r\n{\r\n \"urls\": \"{%- if ns.has_failures -%}xmpps://netbox:{{ '' | xmpp_apprise_password }}@anoxinon.me/yosijo{%- endif -%}\",\r\n \"title\": \"❌ NetBox Report: Fehlgeschlagene Checks in {{ report_name }}\",\r\n \"body\": {{ ns.body | dump }}\r\n}"
}
name: "XMPP YoSiJo - Reports"tags: []owner: 1secret: ""description: "xmpps://netbox@anoxinon.me/yosijo"http_method: "POST"payload_url: "https://apprise-api.stage.anoxinon.de/notify/"ca_file_path: nullbody_template: "{%- set ns = namespace(has_failures=false, body=\"\") -%}\r\n\r\n{# Titel und Einleitung #}\r\n{%- set report_name = data.name | default(\"PlatformReport\") -%}\r\n{%- set ns.body = \"# ❌ NetBox Report: Fehlgeschlagene Checks in \" ~ report_name ~ \"[BR]## Der Report \" ~ report_name ~ \" wurde von \" ~ (username | default('YoSiJo')) ~ \" ausgefuehrt.[BR]### Log:\" -%}\r\n\r\n{# 1. NetBox v4 Report-Tests durchlaufen #}\r\n{%- if data is defined and data.tests is defined -%}\r\n {%- for test_name, test_results in data.tests.items() -%}\r\n {%- if test_results.failure and test_results.log -%}\r\n \r\n {# 1a. Einzigartige Fehlermeldungen fuer diesen Test sammeln #}\r\n {%- set unique_messages = [] -%}\r\n {%- for log_entry in test_results.log -%}\r\n {%- if log_entry == 'failure' or log_entry == 'failed' -%}\r\n {%- set msg_text = log_entry -%}\r\n {%- if msg_text not in unique_messages -%}\r\n {%- set unique_messages = unique_messages + [msg_text] -%}\r\n {%- set ns.has_failures = true -%}\r\n {%- endif -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n\r\n {# 1b. Wenn Fehler existieren, strukturiert ausgeben #}\r\n {%- if unique_messages | length > 0 -%}\r\n {%- set ns.body = ns.body ~ \"[BR][BR]#### \" ~ test_name -%}\r\n \r\n {# Fuer jede einzigartige Meldung eine eigene Gruppe erstellen #}\r\n {%- for current_msg in unique_messages -%}\r\n {%- set ns.body = ns.body ~ \"[BR][BR]##### \" ~ current_msg -%}\r\n \r\n {# Alle Objekte heraussuchen, die genau diese Meldung haben #}\r\n {%- for log_entry in test_results.log -%}\r\n {%- if (log_entry == 'failure' or log_entry == 'failed') and log_entry == current_msg -%}\r\n {%- set clean_path = log_entry if log_entry.startswith('/') else '/' ~ log_entry -%}\r\n {%- set target_url = \"https://anoxinon.de\" ~ clean_path -%}\r\n {%- set ns.body = ns.body ~ \"[BR]- Name: \" ~ log_entry ~ \"[BR] URL: \" ~ target_url -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n \r\n {%- endfor -%}(1.3.2)\r\n {%- endif -%}\r\n\r\n {%- endif -%}\r\n {%- endfor -%}\r\n{%- endif -%}\r\n\r\n{# 2. Fallback für klassische Script-Logs #}\r\n{%- if data is defined and data.result is defined and data.result.log is defined -%}\r\n {%- set unique_script_messages = [] -%}\r\n {%- for log in data.result.log -%}\r\n {%- if log.status == 'failure' or log.status == 'failed' -%}\r\n {%- if log.message not in unique_script_messages -%}\r\n {%- set unique_script_messages = unique_script_messages + [log.message] -%}\r\n {%- set ns.has_failures = true -%}\r\n {%- endif -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n\r\n {%- if unique_script_messages | length > 0 -%}\r\n {%- set ns.body = ns.body ~ \"[BR][BR]#### Allgemeines Script Log\" -%}\r\n {%- for current_msg in unique_script_messages -%}\r\n {%- set ns.body = ns.body ~ \"[BR][BR]##### \" ~ current_msg -%}\r\n {%- for log in data.result.log -%}\r\n {%- if (log.status == 'failure' or log.status == 'failed') and log.message == current_msg -%}\r\n {%- set clean_path = log.obj.get_absolute_url() if log.obj else '' -%}\r\n {%- set target_url = \"https://anoxinon.de\" ~ clean_path if clean_path else \"https://anoxinon.de\" -%}\r\n {%- set ns.body = ns.body ~ \"[BR]- Name: \" ~ (log.obj.name | default('Allgemein')) ~ \"[BR] URL: \" ~ target_url -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n {%- endfor -%}\r\n {%- endif -%}\r\n{%- endif -%}\r\n\r\n{\r\n \"urls\": \"{%- if ns.has_failures -%}xmpps://netbox:{{ '' | xmpp_apprise_password }}@anoxinon.me/yosijo{%- endif -%}\",\r\n \"title\": \"❌ NetBox Report: Fehlgeschlagene Checks in {{ report_name }}\",\r\n \"body\": \"{{ ns.body.replace('[BR]', '\\\\n') }}\"\r\n}"custom_fields: {}ssl_verification: truehttp_content_type: "application/json"additional_headers: ""
name: "XMPP YoSiJo - Reports"tags: []owner: 1secret: ""description: "xmpps://netbox@anoxinon.me/yosijo"http_method: "POST"payload_url: "https://apprise-api.stage.anoxinon.de/notify/"ca_file_path: nullbody_template: "{%- set ns = namespace(has_failures=false, body=\"\") -%}\r\n\r\n{# Titel und Einleitung #}\r\n{%- set report_name = data.name | default(\"PlatformReport\") -%}\r\n{%- set ns.body = \"# ❌ NetBox Report: Fehlgeschlagene Checks in \" ~ report_name ~ \"\\n## Der Report \" ~ report_name ~ \" wurde von \" ~ (username | default('YoSiJo')) ~ \" ausgefuehrt.\\n### Log:\" -%}\r\n\r\n{# 1. NetBox v4 Report-Tests durchlaufen #}\r\n{%- if data is defined and data.tests is defined -%}\r\n {%- for test_name, test_results in data.tests.items() -%}\r\n {%- if test_results.failure and test_results.log -%}\r\n \r\n {# 1a. Einzigartige Fehlermeldungen fuer diesen Test sammeln #}\r\n {%- set unique_messages = [] -%}\r\n {%- for log_entry in test_results.log -%}\r\n {%- if log_entry[1] == 'failure' or log_entry[1] == 'failed' -%}\r\n {%- set msg_text = log_entry[4] -%}\r\n {%- if msg_text not in unique_messages -%}\r\n {%- set unique_messages = unique_messages + [msg_text] -%}\r\n {%- set ns.has_failures = true -%}\r\n {%- endif -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n\r\n {# 1b. Wenn Fehler existieren, strukturiert ausgeben #}\r\n {%- if unique_messages | length > 0 -%}\r\n {%- set ns.body = ns.body ~ \"\\n\\n#### \" ~ test_name -%}\r\n \r\n {# Fuer jede einzigartige Meldung eine eigene Gruppe erstellen #}\r\n {%- for current_msg in unique_messages -%}\r\n {%- set ns.body = ns.body ~ \"\\n\\n##### \" ~ current_msg -%}\r\n \r\n {# Alle Objekte heraussuchen, die genau diese Meldung haben #}\r\n {%- for log_entry in test_results.log -%}\r\n {%- if (log_entry[1] == 'failure' or log_entry[1] == 'failed') and log_entry[4] == current_msg -%}\r\n {%- set clean_path = log_entry[3] if log_entry[3].startswith('/') else '/' ~ log_entry[3] -%}\r\n {%- set target_url = \"https://anoxinon.de\" ~ clean_path -%}\r\n {%- set ns.body = ns.body ~ \"\\n- Name: \" ~ log_entry[2] ~ \"\\n URL: \" ~ target_url -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n \r\n {%- endfor -%}\r\n {%- endif -%}\r\n\r\n {%- endif -%}\r\n {%- endfor -%}\r\n{%- endif -%}\r\n\r\n{# 2. Fallback für klassische Script-Logs #}\r\n{%- if data is defined and data.result is defined and data.result.log is defined -%}\r\n {%- set unique_script_messages = [] -%}\r\n {%- for log in data.result.log -%}\r\n {%- if log.status == 'failure' or log.status == 'failed' -%}\r\n {%- if log.message not in unique_script_messages -%}\r\n {%- set unique_script_messages = unique_script_messages + [log.message] -%}\r\n {%- set ns.has_failures = true -%}\r\n {%- endif -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n\r\n {%- if unique_script_messages | length > 0 -%}\r\n {%- set ns.body = ns.body ~ \"\\n\\n#### Allgemeines Script Log\" -%}\r\n {%- for current_msg in unique_script_messages -%}\r\n {%- set ns.body = ns.body ~ \"\\n\\n##### \" ~ current_msg -%}\r\n {%- for log in data.result.log -%}\r\n {%- if (log.status == 'failure' or log.status == 'failed') and log.message == current_msg -%}\r\n {%- set clean_path = log.obj.get_absolute_url() if log.obj else '' -%}\r\n {%- set target_url = \"https://anoxinon.de\" ~ clean_path if clean_path else \"https://anoxinon.de\" -%}\r\n {%- set ns.body = ns.body ~ \"\\n- Name: \" ~ (log.obj.name | default('Allgemein')) ~ \"\\n URL: \" ~ target_url -%}\r\n {%- endif -%}\r\n {%- endfor -%}\r\n {%- endfor -%}\r\n {%- endif -%}\r\n{%- endif -%}\r\n\r\n{\r\n \"urls\": \"{%- if ns.has_failures -%}xmpps://netbox:{{ '' | xmpp_apprise_password }}@anoxinon.me/yosijo{%- endif -%}\",\r\n \"title\": \"❌ NetBox Report: Fehlgeschlagene Checks in {{ report_name }}\",\r\n \"body\": {{ ns.body | dump }}\r\n}"custom_fields: {}ssl_verification: truehttp_content_type: "application/json"additional_headers: ""