87 lines
2.2 KiB
Nix
87 lines
2.2 KiB
Nix
{
|
|
config,
|
|
inputs,
|
|
lib,
|
|
...
|
|
}:
|
|
let
|
|
cfg = config.services.az-gitea;
|
|
volumePath = "/mnt/server-data/gitea";
|
|
in
|
|
{
|
|
options = {
|
|
services.az-gitea.enable = lib.mkEnableOption "Enable Gitea in Docker.";
|
|
services.az-gitea.domain = lib.mkOption {
|
|
type = lib.types.str;
|
|
description = "The domain Gitea is being run from.";
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
age.secrets.giteaEnv.file = "${inputs.self}/scrts/gitea_env.age";
|
|
|
|
fileSystems."${volumePath}" = {
|
|
device = "10.7.89.108:server_data/gitea/data";
|
|
fsType = "nfs";
|
|
options = [
|
|
"hard"
|
|
"noatime"
|
|
"rw"
|
|
];
|
|
};
|
|
services = {
|
|
az-docker.enable = true;
|
|
az-mariadb-for-containers.enable = true;
|
|
mysql.settings = {
|
|
mysql = {
|
|
default-character-set = "utf8mb4";
|
|
};
|
|
mysqld = {
|
|
collation-server = "utf8mb4_unicode_ci";
|
|
init-connect = "SET NAMES utf8mb4";
|
|
character-set-server = "utf8mb4";
|
|
innodb_file_per_table = 1;
|
|
innodb_buffer_pool_size = "2G";
|
|
read_rnd_buffer_size = "4M";
|
|
sort_buffer_size = "4M";
|
|
};
|
|
};
|
|
};
|
|
|
|
virtualisation.oci-containers = {
|
|
backend = "docker";
|
|
containers."gitea" = {
|
|
# https://blog.gitea.io/
|
|
# https://hub.docker.com/r/gitea/gitea/tags
|
|
image = "gitea/gitea:1.21.10";
|
|
autoStart = true;
|
|
environment = {
|
|
PUID = "1000";
|
|
PGID = "100";
|
|
DB_TYPE = "mysql";
|
|
DB_HOST = "host.docker.internal:3306";
|
|
DB_NAME = "giteadb";
|
|
DB_USER = "gitea";
|
|
ROOT_URL = "${cfg.domain}";
|
|
INSTALL_LOCK = "true";
|
|
DISABLE_REGISTRATION = "true";
|
|
};
|
|
environmentFiles = [ config.age.secrets.giteaEnv.path ];
|
|
ports = [
|
|
"2222:22"
|
|
"8080:3000"
|
|
];
|
|
volumes = [
|
|
"/etc/timezone:/etc/timezone:ro"
|
|
"/etc/localtime:/etc/localtime:ro"
|
|
"${volumePath}:/data"
|
|
];
|
|
extraOptions = [
|
|
"--add-host=host.docker.internal:host-gateway"
|
|
"--log-opt=tag='gitea'"
|
|
];
|
|
};
|
|
};
|
|
};
|
|
}
|