diff --git a/ansible/overcloud-deprovision.yml b/ansible/overcloud-deprovision.yml index 76bd3445963c39f13809feb05916eb8f12edb4a3..824f8ccbba5a869d4885dcb5f08a54b0c1317d96 100644 --- a/ansible/overcloud-deprovision.yml +++ b/ansible/overcloud-deprovision.yml @@ -29,8 +29,23 @@ ironic_retries: 6 ironic_retry_interval: 5 seed_host: "{{ groups['seed'][0] }}" + vars_prompt: + - name: confirm_deprovision + prompt: | + The following hosts will be deprovisioned: + {{ play_hosts | join(', ') }} + If you want to proceed type: yes + default: "no" + private: false gather_facts: no tasks: + - name: Fail if deprovision is not confirmed + assert: + that: confirm_deprovision == 'yes' + msg: > + Deprovision has not been confirmed. You must either type 'yes' when + prompted, or set ``confirm_deprovision=yes``. + - name: Check the ironic node's initial provision state command: > docker exec bifrost_deploy diff --git a/doc/source/administration/overcloud.rst b/doc/source/administration/overcloud.rst index 38065923bcf208e3fa5346e2f83f48234a2d572e..e576a810b2ade9dcc1d3bd8f4bf9ceaa6bdaa6dd 100644 --- a/doc/source/administration/overcloud.rst +++ b/doc/source/administration/overcloud.rst @@ -181,7 +181,9 @@ Deprovisioning The Cloud .. note:: This step will power down the overcloud hosts and delete their nodes' - instance state from the seed's ironic service. + instance state from the seed's ironic service. This command will print a + list of hosts which will be deprovisioned, you must type ``yes`` to confirm. + To automatically confirm, pass the variable ``-e confirm_deprovision=yes``. To deprovision the overcloud:: diff --git a/releasenotes/notes/confirm-before-overcloud-deprovision-6976c8b3c043bc99.yaml b/releasenotes/notes/confirm-before-overcloud-deprovision-6976c8b3c043bc99.yaml new file mode 100644 index 0000000000000000000000000000000000000000..12d93e147b2a2791820039f728276420585c9084 --- /dev/null +++ b/releasenotes/notes/confirm-before-overcloud-deprovision-6976c8b3c043bc99.yaml @@ -0,0 +1,11 @@ +--- +features: + - | + ``kayobe overcloud deprovision`` now requires confirmation before any hosts + are deprovisioned. Automatic confirmation can still be achieved by setting + ``confirm_deprovision`` to ``yes``. +upgrade: + - | + ``kayobe overcloud deprovision`` now requires confirmation before any hosts + are deprovisioned. Automatic confirmation can still be achieved by setting + ``confirm_deprovision`` to ``yes``.