{"id":20179432,"url":"https://github.com/wunderio/wunderfleet","last_synced_at":"2026-05-08T20:31:57.205Z","repository":{"id":137832477,"uuid":"99782735","full_name":"wunderio/WunderFleet","owner":"wunderio","description":"Tools to manage all our servers at once with ansible and dynamic inventory","archived":false,"fork":false,"pushed_at":"2018-10-17T07:11:18.000Z","size":18,"stargazers_count":0,"open_issues_count":1,"forks_count":0,"subscribers_count":3,"default_branch":"master","last_synced_at":"2025-03-03T05:42:04.546Z","etag":null,"topics":["ansible","upcloud"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/wunderio.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2017-08-09T08:17:05.000Z","updated_at":"2018-10-17T07:11:19.000Z","dependencies_parsed_at":null,"dependency_job_id":"f920ef8c-f0ae-4358-8902-fa1a6808c417","html_url":"https://github.com/wunderio/WunderFleet","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/wunderio/WunderFleet","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wunderio%2FWunderFleet","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wunderio%2FWunderFleet/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wunderio%2FWunderFleet/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wunderio%2FWunderFleet/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/wunderio","download_url":"https://codeload.github.com/wunderio/WunderFleet/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wunderio%2FWunderFleet/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32795874,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-08T08:22:46.396Z","status":"ssl_error","status_checked_at":"2026-05-08T08:22:45.650Z","response_time":54,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["ansible","upcloud"],"created_at":"2024-11-14T02:26:36.269Z","updated_at":"2026-05-08T20:31:57.189Z","avatar_url":"https://github.com/wunderio.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# WunderFleet\n\nThis project can be used to update all of our UpCloud servers simultaneously.\n\nIt uses UpCloud dynamic inventory from [upcloud-ansible](https://github.com/UpCloudLtd/upcloud-ansible/blob/master/inventory/upcloud.py).\n\n## Setup\n\nThe `provision.sh` doesn't act like the one in WunderTools. This just makes sure that that virtualenv is used and WunderSecrets and WunderMachina is installed.\n\nAll flags are then passed into `ansible-playbook` command.\n\n### UpCloud specific settings\n\nYou need to provide your UpCloud credentials as environmental variables:\n\n```\nexport UPCLOUD_API_USER='upcloud-username' UPCLOUD_API_PASSWD='password-for-upcloud-user'\n```\n\n## Usage examples\n\n### Ping all machines\n\nThis pings all machines in the inventory\n```\n$ ./provision.sh -i environments/upcloud playbooks/ping.yml\n```\n\n### Install updates for yum packages like nginx, mariadb and openssl\n\nThis updates many installed packages and restarts the related services\n```\n$ ./provision.sh -i environments/upcloud playbooks/update-packages.yml\n```\n\n**Note:** You should add more services into the included list:\n```yml\nupgradeable_packages:\n  - package: nginx\n    service: nginx\n  - package: MariaDB-server\n    service: mysql\n  - package: openssl \n    service: sshd\n```\n\n### Update UpCloud firewall rules\n\nThis updates the default upcloud firewall rules for all machines:\n```\n$ ./provision.sh -i environments/upcloud playbooks/update-firewalls.yml\n```\n\n**Notes:**\n* This doesn't alter the web ports in any way, You should enable them separately inside the project configs.\n* This doesn't remove any custom firewall rules you have added into the the project configs.\n* The list of all allowed ssh ports come from private repo: [WunderSecrets](https://github.com/wunderio/wundersecrets).\n* The default security rules come from [WunderMachina upcloud-firewall role](https://github.com/wunderio/WunderMachina/blob/master/playbook/roles/upcloud-firewall/defaults/main.yml) from variable `upcloud_default_firewall_rules`.\n\n## Notes\n* `root` user is used to access the servers\n* Initial inventory loading takes few minutes so just wait for a moment.\n\n## License\nMIT","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwunderio%2Fwunderfleet","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fwunderio%2Fwunderfleet","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwunderio%2Fwunderfleet/lists"}