job "lidarr" {
  schedule = "@daily"

  config {
    repo = "rclone::ftp,env_auth:/nomad/lidarr"
    passphrase = env("BACKUP_PASSPHRASE")
  }

  task "Backup main database" {
    postgres "Backup database" {
      hostname       = env("MYSQL_HOST")
      port           = env("MYSQL_PORT")
      username       = env("MYSQL_USER")
      password       = env("MYSQL_PASSWORD")
      database       = "lidarr"
      no_tablespaces = true
      dump_to        = "/data/nas-container/lidarr/Backups/dump-lidarr.sql"
    }
  }

  task "Backup logs database" {
    postgres "Backup database" {
      hostname       = env("MYSQL_HOST")
      port           = env("MYSQL_PORT")
      username       = env("MYSQL_USER")
      password       = env("MYSQL_PASSWORD")
      database       = "lidarr-logs"
      no_tablespaces = true
      dump_to        = "/data/nas-container/lidarr/Backups/dump-lidarr-logs.sql"
    }
  }

  backup {
    paths = ["/data/nas-container/lidarr"]

    backup_opts {
      Exclude = ["lidarr_backup_*.zip"]
      Host = "nomad"
    }

    restore_opts {
      Host = ["nomad"]
      # Because path is absolute
      Target = "/"
    }
  }

  forget {
    KeepLast = 2
    KeepDaily = 30
    KeepWeekly = 8
    KeepMonthly = 6
    KeepYearly = 2
    Prune = true
  }
}