No description
Find a file
2023-01-27 23:20:24 -05:00
.github Pin molecule-action to molecule 4.0.1 2022-11-23 22:53:07 +00:00
.vscode Useful Ansible snippets for Ansible-NAS 2022-09-11 17:17:01 +01:00
group_vars added code-server app 2022-08-21 22:07:39 +02:00
inventories/sample Start the move to pre-commit 2022-08-24 09:28:54 +01:00
misc Add logo 2018-12-24 13:43:37 +00:00
roles update vaultwarden image 2023-01-27 23:20:24 -05:00
tests Add samba_shares_root to base Molecule config 2022-09-12 23:36:14 +01:00
website jellyfin url changed 2022-12-27 23:16:34 +01:00
.ansible-lint Add start of molecule role testing 2022-09-09 23:52:17 +01:00
.drone.yml Fix yml indentation 2022-11-06 18:03:53 +00:00
.gitattributes Add .gitattributes 2018-12-23 22:17:14 +00:00
.gitignore Include downloaded roles into gitignore 2022-02-05 13:58:20 +00:00
.markdownlint.json Start the move to pre-commit 2022-08-24 09:28:54 +01:00
.markdownlintignore Start the move to pre-commit 2022-08-24 09:28:54 +01:00
.pre-commit-config.yaml Start the move to pre-commit 2022-08-24 09:28:54 +01:00
.woodpecker.yml More Woodpecker-CI CI-ing 2022-08-28 11:57:16 +01:00
.yamllint Update yamllint config 2022-08-23 22:29:10 +01:00
ansible.cfg Cache Ansible facts (speeds up reruns of the playbook) 2022-08-28 12:02:02 +01:00
CODE_OF_CONDUCT.md Update code of conduct 2022-09-12 10:07:07 +01:00
CONTRIBUTING.md Update contributing docs 2022-09-10 15:28:41 +01:00
LICENSE It's 2022... 2022-06-18 00:28:53 +01:00
mkdocs.yml It's 2022... 2022-06-18 00:28:53 +01:00
nas.yml Add Drone CI 2022-11-06 23:26:26 +00:00
permission_data.yml Yamllint FTW 2021-02-21 19:50:07 +00:00
README.md update vaultwarden image 2023-01-27 23:20:24 -05:00
requirements-dev.txt pytest and pytest-molecule for easy test kickoff 2022-09-11 17:22:03 +01:00
requirements.yml Upgrade to latest geerlingguy.docker role 2022-10-08 13:22:42 +01:00
Vagrantfile Vagrantfile: helpful VM name + fix ansible.inventory.path 2021-03-27 01:15:41 +00:00

Ansible NAS

CI Integration Gitter chat license Ko-fi

After getting burned by broken FreeNAS updates one too many times, I figured I could do a much better job myself using just a stock Ubuntu install, some clever Ansible config and a bunch of Docker containers.

What Ansible-NAS Does

You can configure Ansible-NAS to set up any (or all!) of the applications listed below on your home server.

If you have a spare domain name you can configure applications to be accessible externally to your home LAN too; they'll be configured with a sensible hostname and DNS gets updated accordingly if your home IP address changes.

Available Applications

  • Airsonic - catalog and stream music
  • Bazarr - companion to Radarr and Sonarr for downloading subtitles
  • Bitwarden - Password Manger (Technically Vaultwarden, a lightweight implementation in Rust)
  • Booksonic - The selfhosted audiobook server
  • Calibre-web - Provides a clean interface for browsing, reading and downloading eBooks using an existing Calibre database.
  • Code Server - Powerful IDE from Microsoft accessible through the browser
  • Cloud Commander - A dual panel file manager with integrated web console and text editor
  • Cloudflare DDNS - automatically update Cloudflare with your IP address
  • CouchPotato - for downloading and managing movies
  • Dashy - A self-hosted startpage for your server. Easy to use visual editor, status checking, widgets, themes and tons more!
  • Deluge - A lightweight, Free Software, cross-platform BitTorrent client.
  • DokuWiki - A simple to use and highly versatile Open Source wiki software that doesn't require a database.
  • Drone CI - A self-service Continuous Integration platform for busy development teams.
  • Duplicacy - A web UI for the Duplicacy cloud backup program, which provides lock-free deduplication backups to multiple providers
  • Duplicati - for backing up your stuff
  • Emby - Media streaming and management
  • ESPHome - ESP8266/ESP32 programming and management for home automation
  • Firefly III - Free and open source personal finance manager
  • Fresh RSS - Self-hosted RSS feed aggregator like Leed or Kriss Feed
  • get_iplayer - download programmes from BBC iplayer
  • Gitea - Simple self-hosted GitHub clone
  • GitLab - Self-hosted GitHub clone of the highest order
  • Glances - for seeing the state of your system via a web browser
  • Gotify - Self-hosted server for sending push notifications
  • Grafana - Query, visualize, alert on, and understand your data no matter where its stored (via stats role).
  • Guacamole - Web based remote desktop gateway, supports VNC, RDP and SSH
  • healthchecks.io - Ensure your NAS is online and get notified otherwise
  • Heimdall - Home server dashboard
  • Home Assistant - Open source home automation
  • Homebridge - Emulate the iOS HomeKit API
  • Jackett - API Support for your favorite torrent trackers
  • Jellyfin - The Free Software Media System
  • Joomla - Open source content management system
  • Komga - a media server for your comics, mangas, BDs and magazines
  • Krusader - Twin panel file management for your desktop
  • Lidarr - Music collection manager for Usenet and BitTorrent users
  • Mealie - A self-hosted recipe manager and meal planner
  • Minecraft Server - Server edition of the popular building and exploring game
  • MiniDLNA - simple media server which is fully compliant with DLNA/UPnP-AV clients
  • Miniflux - An RSS news reader
  • Mosquitto - An open source MQTT broker
  • Mylar - An automated Comic Book downloader (cbr/cbz) for use with SABnzbd, NZBGet and torrents
  • MyMediaForAlexa - Lets you stream your music collection to your alexa device
  • n8n - Nodemation, a node based workflow and automation service like IFTTT.
  • navidrome - Modern Music Server and Streamer compatible with Subsonic/Airsonic
  • netboot.xyz - a PXE boot server
  • Netdata - An extremely comprehensive system monitoring solution
  • Nextcloud - A self-hosted Dropbox alternative
  • Nomad - A simple and flexible scheduler and software orchestrator
  • NZBget - The most efficient usenet downloader
  • Octoprint - Control and monitor your 3D printer
  • Ombi - web application that automatically gives your users the ability to request content
  • openHAB - A vendor and technology agnostic open source automation software for your home
  • Organizr - ORGANIZR aims to be your one stop shop for your Servers Frontend.
  • overseerr - open source software application for managing requests for your media library
  • Paperless_ng - Scan, index and archive all your physical documents
  • Piwigo - Photo Gallery Software
  • Plex - Plex Media Server
  • Portainer - for managing Docker and running custom images
  • Prometheus - Time series database and monitoring system (via stats role).
  • Prowlarr - Indexer aggregator for Sonarr, Radarr, Lidarr, etc.
  • pyLoad - A download manager with a friendly web-interface
  • PyTivo - An HMO and GoBack server for TiVos.
  • Radarr - for organising and downloading movies
  • Route53 DDNS - Automatically update AWS Route53 with your IP address
  • RSS-Bridge - The RSS feed for websites missing it
  • Sabnzbd - A powerful usenet downloader that FreeNAS provides
  • Sickchill - for managing TV episodes
  • Sonarr - for downloading and managing TV episodes
  • Speedtest-Tracker - Continuously track your internet speed
  • Stats - Monitor and visualise metrics about your NAS and internet connection using Grafana, Prometheus, Telegraf and more.
  • Syncthing - sync directories with another device
  • Tautulli - Monitor Your Plex Media Server
  • The Lounge - Web based always-on IRC client
  • TiddlyWiki - A unique non-linear notebook/wiki for capturing, organizing, and sharing complex information
  • TimeMachine - Samba-based mac backup server
  • Traefik - Web proxy and SSL certificate manager
  • Transmission - BitTorrent client (with OpenVPN if you have a supported VPN provider)
  • Ubooquity - Book and comic server
  • uTorrent - The best torrent downloading app for beginners
  • Virtual Desktop - A virtual desktop running on your NAS.
  • Wallabag - Save and classify articles. Read them later.
  • Watchtower - Monitor your Docker containers and update them if a new version is available
  • Wireshark - the worlds foremost and widely-used network protocol analyzer.
  • Woodpecker-CI - a simple CI engine with great extensibility, forked from Drone.
  • YouTubeDL-Material - Self-hosted YouTube downloader built on Material Design
  • ZNC - IRC bouncer to stay connected to favourite IRC networks and channels

What This Could Do

Ansible-NAS can run anything that's in a Docker image, which is why Portainer is included. A NAS configuration is a pretty personal thing based on what you download, what media you view, how many photos you take...so it's difficult to please everyone.

That said, if specific functionality you want isn't included and you think others could benefit, add it and raise a PR!

What This Doesn't Do

Ansible NAS doesn't set up your disk partitions, primarily because getting it wrong can be incredibly destructive. That aside, configuring partitions is usually a one-time (or very infrequent) event, so there's not much to be gained by automating it. Check out the docs for recommended setups.

Installation

See Installation.

Documentation

You can read the docs here. PRs for more documentation always welcome!

Migrating from FreeNAS

Read the migrating from FreeNAS docs.

Requirements

  • Ansible NAS targets the latest Ubuntu LTS release, which is currently Ubuntu Server 22.04 LTS.
  • You can run Ansible-NAS on whatever hardware you like, read the docs for more info. I use an HP Microserver.

Getting Help

Getting help is easy! You can:

Contributing

Contributions are always welcome! Please read CONTRIBUTING.md first.

Support

If you've enjoyed Ansible-NAS as much as I do working on it, please consider buying me a coffee

Thanks

The awesome dudes at JetBrains for supplying core contributors with JetBrains Open Source licenses!

All of the awesome contributors to Ansible-NAS!