-
Notifications
You must be signed in to change notification settings - Fork 144
Network: Meraki
- Ansible v2.7 now ships with 11 Meraki modules !
- Feedback is very much appreciated.
- Kevin Breit (@kbreit)
- Dag Wieers (@dagwieers)
I am very much looking for feedback on how you use, or would use, these modules. Please submit issues on the Ansible New Issues page if you would like to see functionality changed or enhanced.
- Modules do not respect Meraki’s rate limiting of 5 requests per second, per organization
- Using HTTP (no SSL) turns PUT/POST/DELETE in to GET requests (on purpose?)
- API does not enforce Organizations to have unique names
- API idempotency issues
- Requires POST for creating and PUT (id) for updating
- DELETE is not idempotent, only works when exists
- VLANs are not enabled by default on a network. Ansible 2.8 or 2.9 will have support for enabling and disabling VLANs via the API. In the meantime, a network must have VLANs enabled via the Dashboard web interface.
- Develop Meraki connection plugin (uncertain)
- Create modules for the following categories:
- Clients
- MX VPN firewall
- MX cellular firewall
- Network VPN settings
- Wireless health facts
- Syslog server configuration
- BLE
- Webhook HTTP configuration
- Service access controls
- Add support for new features
- Network alert configuration
- Enable/disable VLANs on network
Each Meraki module includes a suite of integration tests which help validate module functionality. Running the test is easy once you do a couple of setup steps.
- Setup your development environment as described at the Ansible Module Development web page. If you've already done this, run
$ . venv/bin/activate && . hacking/env-setup
from the root directory of the Ansible code base. - Rename the template file located at
/test/integration/inventory.networking.template
to/test/integration/inventory.networking
. - Edit the
inventory.networking
file with the following variables:
-
auth_key
- Authentication key as provided by the Meraki Dashboard. Required for all modules. -
test_org_name
- Name of organization which your tests will be conducted in. Required for most modules. -
test_org_id
- ID number of the organization which your tests will be conducted in. Required for some modules. Use the meraki_organization module to find the ID for the organization as this information isn't available in the dashboard. -
test_net_name
- Name of the network which your tests will be conducted in. Required for most modules. -
test_net_id
- ID number of the network which your tests will be conducted in. Required for some modules. Use the meraki_network module to find the ID of the network as this information isn't available in the dashboard.
This Wiki is used for quick notes, not for support or documentation.
Working groups are now in the Ansible forum
Ansible project:
Community,
Contributor Experience,
Docs,
News,
Outreach,
RelEng,
Testing
Cloud:
AWS,
Azure,
CloudStack,
Container,
DigitalOcean,
Docker,
hcloud,
Kubernetes,
Linode,
OpenStack,
oVirt,
Virt,
VMware
Networking:
ACI,
AVI,
F5,
Meraki,
Network,
NXOS
Ansible Developer Tools:
Ansible-developer-tools
Software:
Crypto,
Foreman,
GDrive,
GitLab,
Grafana,
IPA,
JBoss,
MongoDB,
MySQL,
PostgreSQL,
RabbitMQ,
Zabbix
System:
AIX,
BSD,
HP-UX,
macOS,
Remote Management,
Solaris,
Windows
Security:
Security-Automation,
Lockdown
Tooling:
AWX,
Galaxy,
Molecule
Plugins:
httpapi