aruba / aruba-ansible-modules

Aruba Ansible Modules
Apache License 2.0
80 stars 36 forks source link
ansible ansible-modules aruba aruba-ansible-modules arubaos-cx arubaos-switch

:warning: :warning: :warning: :warning: :warning:

This repository is deprecated.

For all Aruba created Ansible content visit ArubaNetworks on Galaxy.

_For official AOS-Switch Ansible Collection._

_For official Central Ansible Role._

_For official WLAN Ansible Role._

For official AOS-CX automation with Ansible guides and workflows visit Aruba's Developer Hub.

:warning: :warning: :warning: :warning: :warning:

aruba-ansible-modules

All Ansible modules, module installer, and example playbooks for AOS-Switch and WLAN products. For AOS-CX modules please see our AOS-CX Ansible Role in Ansible's Galaxy.

Structure

How to Install Modules

The aruba_module_installer.py tool installs all files/directories required by Ansible for AOS-Switch and WLAN integration.

Requirements

How to run this code

Clone this repository onto your Linux machine:

$ git clone https://github.com/aruba/aruba-ansible-modules.git

Enter the cloned directory and execute the python installer:

$ cd aruba-ansible-modules
$ python aruba_module_installer/aruba_module_installer.py

If you receive a permission error, use 'sudo':

$ sudo python aruba_module_installer/aruba_module_installer.py

In order to run these scripts, please complete the steps below:

  1. Install Python version 2.7 or 3.5+ on the system.

  2. Install Ansible 2.5 or later (refer https://docs.ansible.com/ansible/latest/installation_guide/intro_installation.html).

How to install updates or new modules

Enter the cloned directory and pull any updates from the repository:

$ cd aruba-ansible-modules
$ git pull

Run the python installer with the --reinstall option, remember to use sudo if you receive a permission error:

$ sudo python aruba_module_installer/aruba_module_installer.py --reinstall

Optional Arguments

optional arguments:
  -h, --help    show this help message and exit
  -r, --remove  remove all files & directories installed by this script.
  --reinstall   remove all files & directories installed by this script. Then
                re-install.
  --switch      only install files/directories required for AOS-Switch.

How to Run a Playbook on AOS-Switch

Prerequisites

Follow the above steps to install the AOS-Switch Ansible modules.

  1. Assign an IP address to the management interface of your Switch device. Ensure that the IP address is reachable from your Ansible control machine.
  2. Enable REST on your Switch device with the following commands:
    switch(config)# web-management ssl
    switch(config)# rest-interface
  3. Modify the IP address in the hosts file example_playbooks/arubaoss/switch_hosts.yml to match the IP of your Switch device.
  4. Modify the ansible_user and ansible_password in the hosts file example_playbooks/arubaoss/switch_hosts.yml to match the login information of your Switch device.

SSH/CLI Modules

Inventory Variables

The variables that should be defined in your inventory for your AOS-Switch host are:

Using Both REST API and SSH/CLI Modules on a Host

To use both REST API and SSH/CLI modules on the same host, you must create separate plays such that each play uses either only REST API modules or only SSH/CLI modules. A play cannot mix and match REST API and SSH/CLI module calls. In each play, ansible_connection must possess the appropriate value according to the modules used. If the play uses REST API modules, the value should be local. If the play uses SSH/CLI modules, the value should be network_cli.

A recommended approach to successfully using both types of modules for a host is as follows:

  1. Set the host variables such that Ansible will connect to the host using REST API.
  2. In the playbook, in each play wherein the SSH/CLI modules are used, set the ansible_connection to network_cli.

The inventory should look something like this:

all:
  hosts:
    switch1:
      ansible_host: 10.0.0.1
      ansible_user: admin
      ansible_password: password
      ansible_network_os: arubaoss
      ansible_connection: local  # REST API connection method

and the playbook like this (note how the second play, which uses the SSH/CLI module arubaoss_command, sets the ansible_connection value accordingly):

- hosts: all
  tasks:
    - name: Create VLAN 200
      arubaoss_vlan:
        vlan_id: 300
        name: "vlan300"
        config: "create"
        command: config_vlan

- hosts: all
  vars:
    ansible_connection: network_cli
  tasks:
    - name: Execute show run on the switch
      arubaoss_command:
        commands: ['show run']
all:
  hosts:
    switch1:
      ansible_host: 10.0.0.1
      ansible_user: admin
      ansible_password: password
      ansible_network_os: arubaoss
      ansible_connection: local  # REST API connection method

How to Run a Playbook on ArubaOS Controller

Follow the above steps to install the Aruba's Ansible modules.

Prerequisites

  1. Install python request module "pip install requests".
  2. Ensure that the IP address of the Aruba controllers are reachable from your Ansible machine.
  3. Update variables.yml file with required variables like username, IP address and password.
  4. Refer to the module_documentation folder for description of module arguments and example playbooks.

Contribution

If you're interested in contributing please read and follow our contribution documentation.

License

Apache 2.0