openstack-ansible/rpc_deployment/roles/maas_local/tasks/main.yml
Andy McCrae 4085c5342d Allow an fqdn extension to be specified for MaaS purposes
This allows the inventory_hostname to be specified as the shortname, and
a common fqdn to applied. E.g. infra01 with an fqdn of .test.com would
count towards a MaaS entity of infra01.test.com whilst the inventory for
ansible would still see it as "infra01".
2014-09-15 14:39:35 +01:00

52 lines
2.4 KiB
YAML

---
# Copyright 2014, Rackspace US, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
- name: Get entity ID for physical_host
shell: raxmon-entities-list | grep "label={{ physical_host|quote }}{{ maas_fqdn_extension|default('') }} " | sed -e 's/^.* id=\(.*\) label=.*$/\1/g'
register: entity_id
delegate_to: "{{ physical_host }}"
- name: Validate if check exists
shell: raxmon-checks-list --entity-id {{ entity_id.stdout|quote }} | grep "label={{ check_name|quote }}--{{ ansible_hostname|quote }}"
register: check_exists
ignore_errors: True
delegate_to: "{{ physical_host }}"
- name: Create check if it does not exist
command: raxmon-checks-create --entity-id {{ entity_id.stdout }} --type agent.plugin --label {{ check_name }}--{{ ansible_hostname }} --details {{ check_details }} --period {{ check_period }} --timeout {{ check_timeout }}
when: check_exists|failed
delegate_to: "{{ physical_host }}"
- name: Get check ID for newly created check
shell: raxmon-checks-list --entity-id {{ entity_id.stdout|quote }} | grep "label={{ check_name|quote }}--{{ ansible_hostname|quote }}" | sed -e 's/^.* id=\(.*\) label=.*$/\1/g'
register: check_id
delegate_to: "{{ physical_host }}"
- name: Validate if alarm exists
shell: raxmon-alarms-list --entity-id {{ entity_id.stdout|quote }} | grep "label={{ item.name|quote }}--{{ ansible_hostname|quote }}"
register: alarm_exists
ignore_errors: True
delegate_to: "{{ physical_host }}"
when: alarms is defined
with_items: alarms
- name: Create alarm if it does not exist
shell: raxmon-alarms-create --entity-id {{ entity_id.stdout|quote }} --check-id {{ check_id.stdout|quote }} --notification-plan {{ maas_notification_plan }} --label {{ item[1].name|quote }}--{{ ansible_hostname|quote }} --criteria {{ item[1].criteria|quote }}
delegate_to: "{{ physical_host }}"
when: item[0]|failed and alarms is defined
with_together:
- alarm_exists.results
- alarms