 
    CNOS supports Enable Mode (Privilege Escalation). This page offers details on how to use Enable Mode on CNOS in Ansible.
Topics
| CLI | |
|---|---|
| Protocol | SSH | 
| Credentials | uses SSH keys / SSH-agent if present accepts  -u myuser -kif using password | 
| Indirect Access | via a bastion (jump host) | 
| Connection Settings | ansible_connection: network_cli | 
| Enable Mode (Privilege Escalation) | supported - use  ansible_become: yeswith  ansible_become_method: enableand  ansible_become_password: | 
| Returned Data Format | stdout[0]. | 
For legacy playbooks, CNOS still supports ansible_connection: local. We recommend modernizing to use ansible_connection: network_cli as soon as possible.
group_vars/cnos.yml¶ansible_connection: network_cli
ansible_network_os: cnos
ansible_user: myuser
ansible_password: !vault...
ansible_become: yes
ansible_become_method: enable
ansible_become_password: !vault...
ansible_ssh_common_args: '-o ProxyCommand="ssh -W %h:%p -q bastion01"'
ansible_password configuration.ansible_ssh_common_args configuration.ProxyCommand directive. To prevent secrets from leaking out (for example in ps output), SSH does not support providing passwords via environment variables.- name: Retreive CNOS OS version
  cnos_command:
    commands: show version
  when: ansible_network_os == 'cnos'
Warning
Never store passwords in plain text. We recommend using SSH keys to authenticate SSH connections. Ansible supports ssh-agent to manage your SSH keys. If you must use passwords to authenticate SSH connections, we recommend encrypting them with Ansible Vault.