17 Commits

Author SHA1 Message Date
824a2ec1ec Merge pull request '1.0.34' (#21) from testing into main
Reviewed-on: #21
2024-03-21 11:44:03 -04:00
9c66f1952b Merge pull request '1.0.33' (#20) from testing into main
Reviewed-on: #20
2024-03-21 10:32:11 -04:00
aadb25069d Merge pull request '1.0.32' (#19) from testing into main
Reviewed-on: #19
2024-03-12 15:30:43 -04:00
7734a8c457 Merge pull request '1.0.31' (#18) from testing into main
Reviewed-on: #18
2024-03-03 20:34:10 -05:00
63ac9d6e4f 1.0.30
Reviewed-on: #17
2024-03-03 19:55:22 -05:00
584a33172c Merge pull request '1.0.29' (#16) from testing into main
Reviewed-on: #16
2024-03-02 16:31:36 -05:00
3cc31ecb40 v1.0.28
Reviewed-on: #15
2024-03-01 17:00:33 -05:00
665560250f Merge pull request '1.0.27' (#14) from testing into main
Reviewed-on: #14
2024-03-01 10:47:12 -05:00
d25730cb74 Merge pull request '1.0.26' (#13) from testing into main
Reviewed-on: #13
2024-03-01 09:27:34 -05:00
1ad31b8305 Merge pull request 'v1.0.26' (#12) from testing into main
Reviewed-on: #12
2024-03-01 09:26:38 -05:00
bdfa48f95d Merge pull request 'v1.0.25' (#11) from testing into main
Reviewed-on: #11
2024-03-01 08:59:52 -05:00
a29281515b Merge pull request 'v1.0.24' (#10) from testing into main
Reviewed-on: #10
2024-02-29 18:29:44 -05:00
152e7e3815 Merge pull request 'v1.0.23' (#9) from testing into main
Reviewed-on: #9
2024-02-29 18:04:27 -05:00
028bde883e Merge pull request 'Update galaxy.yml for 1.0.22 release' (#8) from testing into main
Reviewed-on: #8
2024-02-29 12:21:18 -05:00
bae88f96a7 Merge pull request 'Add node_status role' (#7) from testing into main
Reviewed-on: #7
2024-02-29 12:20:14 -05:00
d752b8064b Merge pull request 'BaseOS v1.0.21' (#6) from testing into main
Reviewed-on: #6
2024-02-28 20:05:59 -05:00
7d3a8d8f77 Merge pull request 'Initial release version to AAP' (#5) from testing into main
Reviewed-on: #5
2024-02-28 16:47:03 -05:00
14 changed files with 164 additions and 48 deletions

View File

111
.drone.yml Normal file
View File

@ -0,0 +1,111 @@
---
kind: pipeline
type: docker
name: CentOS_9-Ansible-Pipeline
trigger:
branch:
exclude:
- main
event: [push]
steps:
- name: ansible_environment_verify
image: gitea.thezengarden.net/podman/ansible-dev/centos9:release
commands:
- . ./.drone.env
- env
- git log -1
- ansible --version
- ansible-lint --version
- name: ansible_lint
image: gitea.thezengarden.net/podman/ansible-dev/centos9:release
commands:
- . ./.drone.env
- ansible-lint --offline --nocolor $ANSIBLE_LINT_EXCLUSION
---
kind: pipeline
type: docker
name: Fedora_39-Ansible-Pipeline
trigger:
branch:
exclude:
- main
event: [push]
steps:
- name: ansible_environment_verify
image: gitea.thezengarden.net/podman/ansible-dev/fedora39:release
commands:
- . ./.drone.env
- env
- git log -1
- ansible --version
- ansible-lint --version
- name: ansible_lint
image: gitea.thezengarden.net/podman/ansible-dev/fedora39:release
commands:
- . ./.drone.env
- ansible-lint --offline --nocolor $ANSIBLE_LINT_EXCLUSION
---
kind: pipeline
type: docker
name: Debian_11-Ansible-Pipeline
trigger:
branch:
exclude:
- main
event: [push]
steps:
- name: ansible_environment_verify
image: gitea.thezengarden.net/podman/ansible-dev/debian11:release
commands:
- . ./.drone.env
- env
- git log -1
- ansible --version
- ansible-lint --version
- name: ansible_lint
image: gitea.thezengarden.net/podman/ansible-dev/debian11:release
commands:
- . ./.drone.env
- ansible-lint --offline --nocolor $ANSIBLE_LINT_EXCLUSION
---
kind: pipeline
type: docker
name: Debian_12-Ansible-Pipeline
trigger:
branch:
exclude:
- main
event: [push]
steps:
- name: ansible_environment_verify
image: gitea.thezengarden.net/podman/ansible-dev/debian12:release
commands:
- . ./.drone.env
- env
- git log -1
- ansible --version
- ansible-lint --version
- name: ansible_lint
image: gitea.thezengarden.net/podman/ansible-dev/debian12:release
commands:
- . ./.drone.env
- ansible-lint --offline --nocolor $ANSIBLE_LINT_EXCLUSION

View File

@ -7,7 +7,10 @@ on:
jobs:
Ansible-Development-Pipeline:
runs-on: ansible-dev-centos
strategy:
matrix:
os: [ ansible-dev-centos9, ansible-dev-fedora39, ansible-dev-debian11, ansible-dev-debian12 ]
runs-on: ${{ matrix.os }}
steps:
- name: Clone repository
@ -15,18 +18,13 @@ jobs:
- name: Ansible Environment Verify
run: |
echo "BUILD HOST: $(cat /etc/hostname)" && echo
echo "BUILD USER: $(whoami)" && echo
echo "PWD: $(pwd)" && echo
lscpu && echo
. ./.ci.env && echo
env && echo
git log -1 && echo
ansible --version && echo
ansible-lint --version --offline && echo
. ./.drone.env
env
git log -1
ansible --version
ansible-lint --version
- name: Run Ansible-Lint
run: |
. ./.ci.env
. ./.drone.env
ansible-lint --offline --nocolor $ANSIBLE_LINT_EXCLUSION

View File

@ -8,7 +8,7 @@ namespace: jchristianh
name: baseos
# The version of the collection. Must be compatible with semantic versioning
version: 1.0.36
version: 1.0.34
# The path to the Markdown (.md) readme file. This path is relative to the root of the collection
readme: README.md

View File

@ -1,2 +1,2 @@
---
requires_ansible: ">=2.15.0"
requires_ansible: ">=2.14.0"

View File

@ -3,7 +3,7 @@
ansible.builtin.set_fact:
etc_hosts_etc_hosts_file: "{{ etc_hosts_etc_hosts_file }}.docker"
when:
- ansible_virtualization_type is search("docker|podman|container")
- ansible_virtualization_type | regex_search("docker|podman|container")
- name: Deploy {{ etc_hosts_etc_hosts_file }}

View File

@ -2,7 +2,7 @@
- name: Use hostname module to set hostname, or failback to command module
when:
- not ansible_virtualization_type is search("docker|podman|container")
- not ansible_virtualization_type | regex_search("docker|podman|container")
block:
- name: Set hostname for host using hostname module
ansible.builtin.hostname:

View File

@ -1,13 +1,13 @@
---
motd_motd_file: /etc/motd
motd_host_ip: "{{ ansible_default_ipv4.address | default('127.0.0.1') }}"
motd_host_uptime: "{{ now().replace(microsecond=0) - now().fromtimestamp(now(fmt='%s') | int - ansible_uptime_seconds) }}"
motd_host_ip : "{{ ansible_default_ipv4.address | default('127.0.0.1') }}"
motd_host_uptime : "{{ now().replace(microsecond=0) - now().fromtimestamp(now(fmt='%s') | int - ansible_uptime_seconds) }}"
motd_day_filter: "(.* day[s]?),\\s+(\\d+):(\\d+):(\\d+)"
motd_nonday_filter: "(\\d+):(\\d+):(\\d+)"
motd_day_filter : "(.* day[s]?),\\s+(\\d+):(\\d+):(\\d+)"
motd_nonday_filter : "(\\d+):(\\d+):(\\d+)"
motd_day_filter_repl: "\\1 \\2 hours \\3 minutes"
motd_day_filter_repl : "\\1 \\2 hours \\3 minutes"
motd_nonday_filter_repl : "\\1 hours \\2 minutes \\3 seconds"
...

View File

@ -1,16 +1,20 @@
---
- name: Format uptime using Jinja
ansible.builtin.set_fact:
motd_uptime_formatted: |
uptime_formatted: |
{% if 'day' in motd_host_uptime %}
{{ motd_host_uptime | regex_replace(motd_day_filter, motd_day_filter_repl) }}
{% else %}
{{ motd_host_uptime | regex_replace(motd_nonday_filter, motd_nonday_filter_repl) }}
{% endif %}
- name: Update MOTD
ansible.builtin.template:
src: templates/motd.j2
dest: "{{ motd_motd_file }}"
mode: "0644"
changed_when: false
src : templates/motd.j2
dest : "{{ motd_motd_file }}"
mode : "0644"
changed_when : false
...

View File

@ -19,6 +19,6 @@ IP : {{ motd_host_ip }}
CPU : {{ ansible_processor_vcpus }} x {{ ansible_processor[2] | regex_replace('\\s+', ' ') }}
Memory : {{ "{0:0.2f}".format(ansible_memfree_mb/1024) }} GB free of {{ (ansible_memtotal_mb/1024)|round}} GB
Platform : {{ ansible_distribution }} {{ ansible_distribution_version }} {{ ansible_kernel }}
Up : {{ motd_uptime_formatted | trim }}
Up : {{ uptime_formatted | trim }}

View File

@ -1,31 +1,33 @@
---
- name: Update node status when not running in a container
when: not ansible_virtualization_type is search("docker|podman|container")
when: not ansible_virtualization_type | regex_search("docker|podman|container")
block:
- name: Create directory {{ node_status_dir }}
ansible.builtin.file:
path: "{{ node_status_dir }}"
state: directory
mode: '0755'
become: false
run_once: true
delegate_to: "{{ node_status_host }}"
path : "{{ node_status_dir }}"
state : directory
mode : '0755'
become : false
run_once : true
delegate_to : "{{ node_status_host }}"
- name: Capture system uptime
ansible.builtin.command : uptime
register: node_status_sys_uptime
register : r_node_status_uptime
changed_when: false
- name: Log node status
ansible.builtin.lineinfile:
path: "{{ node_status_dir }}/{{ node_status_file }}"
state: present
regexp: "{{ inventory_hostname }}"
line: "{{ ansible_date_time.epoch }},,{{ inventory_hostname }},,{{ ansible_distribution }} {{ ansible_distribution_version }},,{{ node_status_sys_uptime.stdout }}"
create: true
mode: '0644'
owner: "{{ node_status_user }}"
group: "{{ node_status_group }}"
delegate_to: "{{ node_status_host }}"
throttle: 1
path : "{{ node_status_dir }}/{{ node_status_file }}"
state : present
regexp : "{{ inventory_hostname }}"
line : "{{ ansible_date_time.epoch }},,{{ inventory_hostname }},,{{ ansible_distribution }} {{ ansible_distribution_version }},,{{ r_node_status_uptime.stdout }}"
create : true
mode : '0644'
owner : "{{ node_status_user }}"
group : "{{ node_status_group }}"
delegate_to : "{{ node_status_host }}"
throttle : 1

View File

@ -3,7 +3,7 @@
ansible.builtin.set_fact:
resolv_conf_resolv_conf_file: "{{ resolv_conf_resolv_conf_file }}.container"
when:
- ansible_virtualization_type is search("docker|podman|container")
- ansible_virtualization_type | regex_search("docker|podman|container")
- name: Deploy {{ resolv_conf_resolv_conf_file }}

View File

@ -4,4 +4,4 @@
name : snmpd
state: restarted
when:
- not ansible_virtualization_type is search("docker|podman|container")
- not ansible_virtualization_type | regex_search("docker|podman|container")

View File

@ -1,11 +1,12 @@
---
- name: Deploy and configure SNMP
block:
- name: Set package name for Debian
- name: Set package name for Debian 12
ansible.builtin.set_fact:
snmpd_conf_snmp_pkg: snmpd
when:
- ansible_distribution | lower == 'debian'
- ansible_distribution_major_version == '12'
- name: Install SNMP
ansible.builtin.package: