commit de635c08475cd1b7fae157ab627d49c7d3898917 Author: decentral1se Date: Mon May 30 13:17:10 2022 +0200 init diff --git a/.ansible-lint.yml b/.ansible-lint.yml new file mode 100644 index 0000000..774ef1f --- /dev/null +++ b/.ansible-lint.yml @@ -0,0 +1,5 @@ +--- +skip_list: + - fqcn-builtins + - experimental + - yaml diff --git a/.drone.yml b/.drone.yml new file mode 100644 index 0000000..41ffc1c --- /dev/null +++ b/.drone.yml @@ -0,0 +1,16 @@ +---- +kind: pipeline +name: default +steps: + - name: integration test + image: python:3.9-buster + environment: + REMOTE_USER: molecule + HCLOUD_TOKEN: + from_secret: HCLOUD_TOKEN + commands: + - apt update && apt install -y pwgen + - mkdir -p /root/.ansible/roles && ln -sr . /root/.ansible/roles/autonomic.packages + - export INSTANCE_UUID=$(pwgen 8 1) + - pip install -r requirements.txt + - molecule test diff --git a/.envrc.sample b/.envrc.sample new file mode 100644 index 0000000..8a266bf --- /dev/null +++ b/.envrc.sample @@ -0,0 +1,18 @@ +# Your username that you use for accounts on our machines. +export REMOTE_USER= +export ANSIBLE_USER=$REMOTE_USER + +# The path to our pass credentials store +export PASSWORD_STORE_DIR= + +# The Hetzner Cloud API token for managing our instances +# Uncomment the prod/test line below depending on what you're doing +# export HCLOUD_TOKEN=$(pass show logins/hetzner/prod/api_key) +# export HCLOUD_TOKEN=$(pass show logins/hetzner/test/api_key) +export HCLOUD_TOKEN=$(pass show logins/hetzner/cicd/api_key) + +# For molecule role testing +export INSTANCE_UUID=$RANDOM + +# So molecule will show credentials in the logs +export MOLECULE_NO_LOG=False diff --git a/.yamllint.yml b/.yamllint.yml new file mode 100755 index 0000000..07bf509 --- /dev/null +++ b/.yamllint.yml @@ -0,0 +1,17 @@ +--- +extends: default + +yaml-files: + - "*.yaml" + - "*.yml" + +ignore: | + .venv + .drone.yml + +rules: + line-length: disable + braces: + max-spaces-inside: 1 + level: error + comments-indentation: disable diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..a9c3d25 --- /dev/null +++ b/LICENSE @@ -0,0 +1,15 @@ +autonomic.packages: Installs a number of packages that Autonomic members find useful +Copyright (C) 2022 Autonomic Co-operative + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation, either version 3 of the License, or +(at your option) any later version. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program. If not, see . diff --git a/README.md b/README.md new file mode 100644 index 0000000..ffc55c8 --- /dev/null +++ b/README.md @@ -0,0 +1,3 @@ +# autonomic.packages + +[![Build Status](https://drone.autonomic.zone/api/badges/autonomic-cooperative/autonomic.packages/status.svg?ref=refs/heads/main)](https://drone.autonomic.zone/autonomic-cooperative/autonomic.packages) diff --git a/defaults/main.yml b/defaults/main.yml new file mode 100644 index 0000000..34b3ab1 --- /dev/null +++ b/defaults/main.yml @@ -0,0 +1,32 @@ +--- +packages_list: + # Access + - sudo + + # Utilities + - git + - tmux + - unzip + - zip + - needrestart + + # Alternate shells + - fish + - zsh + + # Text editors + - neovim + - nano + + # Monitoring + - htop + # - ctop + - ncdu + + # Security + - lynis + - rkhunter + + # Web + - curl + - wget diff --git a/meta/main.yml b/meta/main.yml new file mode 100644 index 0000000..e2440b8 --- /dev/null +++ b/meta/main.yml @@ -0,0 +1,17 @@ +--- +dependencies: [] +galaxy_info: + role_name: packages + namespace: autonomic + author: autonomic + description: | + Installs a number of packages that Autonomic membership find useful and + necessary for getting work done. Includes text editors, terminal + multiplexers and file system monitoring tools. + company: Autonomic + license: GPLv3 + min_ansible_version: 2.9 + platforms: + - name: Debian + versions: + - buster diff --git a/molecule/default/converge.yml b/molecule/default/converge.yml new file mode 100644 index 0000000..25daa0c --- /dev/null +++ b/molecule/default/converge.yml @@ -0,0 +1,5 @@ +--- +- name: Converge + hosts: all + roles: + - role: autonomic.packages diff --git a/molecule/default/molecule.yml b/molecule/default/molecule.yml new file mode 100644 index 0000000..eb7966a --- /dev/null +++ b/molecule/default/molecule.yml @@ -0,0 +1,19 @@ +--- +dependency: + name: galaxy + +driver: + name: hetznercloud + +platforms: + - name: "autonomic.packages-${INSTANCE_UUID}" + server_type: cx11 + image: debian-10 + +provisioner: + name: ansible + +lint: | + set -e + yamllint -c .yamllint.yml . + ansible-lint --exclude .drone.yml -c .ansible-lint.yml . diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 0000000..7d6c96a --- /dev/null +++ b/requirements.txt @@ -0,0 +1,4 @@ +ansible-lint==6.0.0 +ansible==5.4.0 +molecule-hetznercloud==1.3.0 +molecule==3.6.1 diff --git a/tasks/main.yml b/tasks/main.yml new file mode 100644 index 0000000..1bae720 --- /dev/null +++ b/tasks/main.yml @@ -0,0 +1,15 @@ +--- +- name: Update the package cache + apt: + update_cache: true + cache_valid_time: 3600 + +- name: Update all packages + apt: + name: "*" + state: present + +- name: Install basic packages + apt: + name: "{{ packages_list }}" + state: present