Skip to content

🏑 Turning an old computer into a homelab

License

Notifications You must be signed in to change notification settings

theobori/homelab

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ef5718c Β· Jun 12, 2024

History

25 Commits
Apr 29, 2024
May 9, 2024
May 14, 2024
Apr 29, 2024
May 8, 2024
Apr 27, 2024
Apr 27, 2024
Jun 12, 2024
Apr 27, 2024
Jun 12, 2024
Apr 27, 2024

Repository files navigation

🏑 homelab

ansible-lint

The aim is to use my old laptop as a homelab with a Debian system. All automations and configurations used are declared in this repository and are managed by Ansible playbook.

πŸ“– How to build and run ?

  1. Install the dependencies
    • ansible
    • ansible galaxy dependencies
ansible-galaxy install -r requirements.yml
  1. Configure a vault password (a filepass is better)
  2. Configure an inventory
  3. Configure a playbook
    1. Inventory (if needed)
    2. Replace variables
    3. Encrypt the needed ones
  4. Run the playbook

ℹ️ Roles and variables

Roles

  • nickjj.docker: Setup and configure Docker + docker-compose.
  • weareinteractive.ufw: Setup the network firewall and configure it.
  • shell: Setup a shell environment with fish + tmux.
  • base: Install basics needed packages for the other roles.
  • profile: Setup some default configuration for new users.
  • security: Setup system security tools/services like ssh, knockd, etc.
  • services: Create the Docker resources (containers, volumes, network, etc..).

Variables

SSH

  • ssh_identity_key_path: SSH public key used to auth.
  • ssh_port: Change the default SSH port.

Domain

  • domain: The server domain, must be formatted as "domain.tld".

Authentik

  • authentik_pg_db: Authentik PosgreSQL database.
  • authentik_pg_user: Authentik PosgreSQL username.
  • authentik_pg_password: Authentik PosgreSQL password.
  • authentik_secret_key: Authentik secret key.

DuckDNS

  • duckdns_token: DuckDNS token.

Let"s Encrypt

  • letsencrypt_acme_email: Let"s Encrypt email address.

Directory

  • base_dir: Base directory.
  • docker_dir: Docker directory.

Nextcloud

  • nextcloud_db_name:: Nextcloud database name.
  • nextcloud_db_username:: Nextcloud database username.
  • nextcloud_db_password:: Nextcloud database password.
  • nextcloud_db_root_password:: Nextcloud database root password.

Owncloud (Disabled by default)

  • owncloud_mysql_database: owncloud mysql database.
  • owncloud_mysql_user: owncloud mysql user.
  • owncloud_mysql_password: owncloud mysql password.
  • owncloud_mysql_root_password: owncloud mysql root password.
  • owncloud_admin_username: owncloud admin username.
  • owncloud_admin_password: owncloud admin password.

Wireguard

  • wg_password: Wireguard web admin panel password.
  • wg_host: Wireguard public IP address.

LibreSpeed

  • librespeed_password: LibreSpeed password.

Mailer

  • mailer_smtp_host: Mailer SMTP host.
  • mailer_smtp_from: Mailer SMTP email address.
  • mailer_smtp_port: Mailer SMTP port.
  • mailer_smtp_security: Mailer SMTP, force_tls or start_tls.
  • mailer_smtp_username: Mailer SMTP username.
  • mailer_smtp_password: Mailer SMTP password.

Vaultwarden

  • vaultwarden_admin_token: Vaultwarden admin token.

About

🏑 Turning an old computer into a homelab

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published