--- # Harmonize systems rather than doing everything manually. :) # Setup of any device connected to this repo. - name: Main | Default Setup hosts: localhost connection: local become: true tasks: - include_tasks: facts/general/gather.yml - include_tasks: tasks/general/acct_mgmt/provision_config.yml - include_tasks: facts/general/system.yml - include_tasks: facts/general/package.yml - include_tasks: facts/general/service.yml - include_tasks: facts/general/user.yml - include_tasks: tasks/general/software/packages.yml - include_tasks: tasks/general/software/services.yml - include_tasks: tasks/general/software/sendmail.yml when: ansible_system == "FreeBSD" - include_tasks: facts/general/gather.yml - include_tasks: tasks/general/acct_mgmt/groups.yml - include_tasks: tasks/general/acct_mgmt/users.yml - include_tasks: tasks/general/acct_mgmt/sudo.yml - include_tasks: tasks/general/acct_mgmt/doas.yml - include_tasks: tasks/general/scripts/root.yml - include_tasks: tasks/general/scripts/user.yml - include_tasks: tasks/general/cron/ansible.yml # TODO Need to refactor. Maybe tasks/general/cron/freebsd.yml - include_tasks: tasks/workstation/freebsd/cron/ansible.yml when: ansible_system == "FreeBSD" - include_tasks: tasks/general/software/metasploit.yml when: pentesting == true ####### Workstations ####### # Additional setup for systems with GUI. - name: Main | Workstation Setup block: - include_tasks: facts/workstation/package.yml # Set Up Desktop Environments # - include_tasks: tasks/workstation/freebsd/software/gpu.yml when: ansible_system == "FreeBSD" and bsd_gpu == true - include_tasks: tasks/workstation/freebsd/software/gnome.yml when: ansible_system == "FreeBSD" - include_tasks: tasks/workstation/linux/software/gnome.yml when: ansible_system == "Linux" - include_tasks: tasks/workstation/shared/software/dwm.yml # Software Tasks # - include_tasks: tasks/workstation/linux/software/flatpaks.yml when: ansible_system == "Linux" and flatpak_distro - include_tasks: tasks/workstation/linux/software/brave.yml when: ansible_pkg_mgr in ("apt", "dnf", "zypper") and not mobile - include_tasks: tasks/workstation/freebsd/software/packages.yml when: ansible_system == "FreeBSD" - include_tasks: tasks/workstation/mac-os/software/brew.yml when: ansible_system == "Darwin" # Configuration Tasks # - include_tasks: tasks/workstation/shared/settings/gnome.yml when: not mobile - include_tasks: tasks/workstation/linux/cron/ansible.yml when: ansible_system == "Linux" and not mobile - include_tasks: tasks/workstation/shared/settings/nfs.yml - include_tasks: tasks/workstation/shared/settings/rdp.yml when: rdp == true - include_tasks: tasks/workstation/shared/settings/vnc.yml when: vnc == true - include_tasks: tasks/workstation/shared/settings/services.yml when: workstation == true # No longer mining, this is now considered deprecated. # ####### Miners ####### # # # Additional setup for miners. # - name: Main | Miner Setup # block: # # ##### Setup ##### # - include_tasks: tasks/miner/debug.yml # # - include_tasks: tasks/miner/acct_mgmt/users.yml # # - include_tasks: facts/miner/system.yml # - include_tasks: facts/miner/config.yml # - include_tasks: facts/miner/pool.yml # # ##### Installations ##### # ### CPU SECTION ### # # Monero # # - include_tasks: tasks/miner/software/xmr-stak-cpu.yml # when: xmr_stak_cpu is defined # # ### GPU Section ### # ## Drivers ## # - include_tasks: tasks/miner/drivers/amdgpu.yml # when: ansible_distribution == "Ubuntu" and amdgpu == true # # # Ethereum # # - include_tasks: tasks/miner/software/ethminer.yml # when: ethminer == true # # - include_tasks: tasks/miner/software/nanominer.yml # when: nanominer == true # # ##### Scheduling ##### # - include_tasks: tasks/miner/cron/ansible.yml # - include_tasks: tasks/miner/cron/mfn.yml # # when: miner == true ####### Servers ####### # Easy to deploy server configurations. - name: Main | Server Setup block: - include_tasks: tasks/server/software/services.yml - include_tasks: tasks/server/software/certbot.yml when: certbot == true - include_tasks: tasks/server/cron/certbot.yml when: certbot == true - include_tasks: tasks/server/software/onlyoffice.yml when: onlyoffice == true and ansible_pkg_mgr == "apt" - include_tasks: tasks/server/software/influxdb1.yml when: influxdb1 == true and ansible_pkg_mgr == "apt" - include_tasks: tasks/server/software/influxdb2.yml when: influxdb2 == true and ansible_pkg_mgr == "apt" - include_tasks: tasks/server/software/grafana.yml when: grafana == true and ansible_pkg_mgr == "apt" - include_tasks: tasks/server/software/hugo.yml when: hugo == true - include_tasks: tasks/server/software/gitlab.yml when: gitlab and ansible_pkg_mgr in ("apt", "dnf") and ansible_distribution not in ("Fedora") - include_tasks: tasks/server/software/git.yml when: git and ansible_pkg_mgr in ("apt") when: server == true ####### Reporting ####### # Provide information for analysis. - include_tasks: tasks/general/software/telegraf.yml - include_tasks: tasks/general/tests/lynis.yml - include_tasks: tasks/general/tests/nmap.yml