| .. | ||
| changelogs | ||
| meta | ||
| plugins | ||
| CHANGELOG.rst | ||
| CODE_OF_CONDUCT.md | ||
| CONTRIBUTING.md | ||
| FILES.json | ||
| galaxy-importer.cfg | ||
| LICENSE | ||
| MANIFEST.json | ||
| README.md | ||
| RELEASE_POLICY.md | ||
| requirements-dev.txt | ||
Ansible Cisco Small Bussiness Switches (SMB) module
Ansible Galaxy module for Cisco SMB switches - SG250, SG300, SG500, SG350, SG550, CBS350
Install
ansible-galaxy collection install community.ciscosmb
Usage examples
Tested on devices:
- SG250-10P
- SG350-10-K9
- SG350-28-K9
- SG500-52-K9
- SG550X-24MP-K9
- CBS350-24P-4G
- SG550X-48 stack
Required device configuration
Access setup
! you should set enable password
enable password level 15
! on user you have two choices
! use unpriviledged user (for example priv. 7) and "become mode"
username user1 privilege 7
! or user with full privileges (priv 15)
username user2 privelege 15
Cisco's SSH server setup
! you have to enable SSH server
ip ssh server
! enable password and/or key
ip ssh password-auth      
ip ssh pubkey-auth auto-login
! generate switch ssh key pair if you did not before
crypto key generate rsa
! if you use public keys for users login configure that keys
crypto key pubkey-chain ssh
user-key user2 rsa
key-string AAAAB3NzaC1......XYZ==
exit
Python versions
Tested on Python versions:
- 3.6
- 3.7
- 3.8
- 3.9
- 3.10
- 3.11
- 3.12
Running examples
For your tests or quick startup use files form repository: cismosmb_inventory_template.yml, cismosmb_gather_facts.yml, cismosmb_commands.yml .
Prepare your inventory file - copy file cismosmb_inventory_template.yml to cismosmb_inventory.yml and make your changes.
Then you can run
ansible-playbook -i ciscosmb_inventory.yml cismosmb_gather_facts.yml
or
ansible-playbook -i ciscosmb_inventory.yml cismosmb_commands.yml
Developement
Setup environment
git clone https://github.com/ansible-collections/community.ciscosmb ansible_collections/community/ciscosmb
git clone --depth=1 --single-branch https://github.com/ansible-collections/ansible.netcommon.git ansible_collections/ansible/netcommon
cd ansible_collections/community/ciscosmb
python3 -m venv .venv
. .venv/bin/activate
pip install ansible
pip install -r requirements-dev.txt
pip install -r tests/unit/requirements.txt
Develop
cd ansible_collections/community/ciscosmb
git pull
. .venv/bin/activate
# edit files
vim file
cp changelogs/fragments/.keep changelogs/fragments/featureXYZ.yml
vim changelogs/fragments/featureXYZ.yml
# test your changes see "Testing"
git commit -m "xxx" file
Testing
cd ansible_collections/community/ciscosmb
. .venv/bin/activate
# PY="--python 3.8" # set your version or unset
METHOD="--docker" # or --local if you have no Docker installed
ansible-test sanity ${METHOD} ${PY}  \
    && ansible-test units  ${METHOD} ${PY} \
    && rm -f ./community-ciscosmb-*.tar.gz  \
    && ansible-galaxy collection build -v --force  \
    && export GALAXY_IMPORTER_CONFIG=./galaxy-importer.cfg  \
    && python3 -m galaxy_importer.main ./community-ciscosmb-*.tar.gz  \
    && rm -f ./community-ciscosmb-*.tar.gz
Release
cd ansible_collections/community/ciscosmb
git pull
. .venv/bin/activate
# edit version x.y.z. in galaxy.yml
vim galaxy.yml
# edit changelog fragments (template in changelogs/fragments/.keep)
cp changelogs/fragments/.keep changelogs/fragments/release-x.y.z.yml
vim changelogs/fragments/release-x.y.z.yml
# change and generate CHANGELOG.rst
antsibull-changelog lint -v
antsibull-changelog release -v
git commit -m "version bump to x.y.z" .
git tag x.y.z
git push 
Releasing, Versioning and Deprecation
Code of Conduct
Contributing
See CONTRIBUTING.md
