mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2025-01-01 16:34:15 +03:00
123dd9f4e7
Offline mode: When adding a lot of data, start this service. It will will not flood the DHT since it only exposes the API. When you are done simply reverse the process.
177 lines
4.1 KiB
Nix
177 lines
4.1 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
inherit (pkgs) ipfs;
|
|
|
|
cfg = config.services.ipfs;
|
|
|
|
ipfsFlags = ''${if cfg.autoMigrate then "--migrate" else ""} ${if cfg.enableGC then "--enable-gc" else ""} ${toString cfg.extraFlags}'';
|
|
|
|
in
|
|
|
|
{
|
|
|
|
###### interface
|
|
|
|
options = {
|
|
|
|
services.ipfs = {
|
|
|
|
enable = mkEnableOption "Interplanetary File System";
|
|
|
|
user = mkOption {
|
|
type = types.str;
|
|
default = "ipfs";
|
|
description = "User under which the IPFS daemon runs";
|
|
};
|
|
|
|
group = mkOption {
|
|
type = types.str;
|
|
default = "ipfs";
|
|
description = "Group under which the IPFS daemon runs";
|
|
};
|
|
|
|
dataDir = mkOption {
|
|
type = types.str;
|
|
default = "/var/lib/ipfs";
|
|
description = "The data dir for IPFS";
|
|
};
|
|
|
|
autoMigrate = mkOption {
|
|
type = types.bool;
|
|
default = false;
|
|
description = ''
|
|
Whether IPFS should try to migrate the file system automatically.
|
|
'';
|
|
};
|
|
|
|
gatewayAddress = mkOption {
|
|
type = types.str;
|
|
default = "/ip4/127.0.0.1/tcp/8080";
|
|
description = "Where the IPFS Gateway can be reached";
|
|
};
|
|
|
|
apiAddress = mkOption {
|
|
type = types.str;
|
|
default = "/ip4/127.0.0.1/tcp/5001";
|
|
description = "Where IPFS exposes its API to";
|
|
};
|
|
|
|
enableGC = mkOption {
|
|
type = types.bool;
|
|
default = false;
|
|
description = ''
|
|
Whether to enable automatic garbage collection.
|
|
'';
|
|
};
|
|
|
|
emptyRepo = mkOption {
|
|
type = types.bool;
|
|
default = false;
|
|
description = ''
|
|
If set to true, the repo won't be initialized with help files
|
|
'';
|
|
};
|
|
|
|
extraFlags = mkOption {
|
|
type = types.listOf types.str;
|
|
description = "Extra flags passed to the IPFS daemon";
|
|
default = [];
|
|
};
|
|
};
|
|
};
|
|
|
|
###### implementation
|
|
|
|
config = mkIf cfg.enable {
|
|
environment.systemPackages = [ pkgs.ipfs ];
|
|
|
|
users.extraUsers = mkIf (cfg.user == "ipfs") {
|
|
ipfs = {
|
|
group = cfg.group;
|
|
home = cfg.dataDir;
|
|
createHome = false;
|
|
uid = config.ids.uids.ipfs;
|
|
description = "IPFS daemon user";
|
|
};
|
|
};
|
|
|
|
users.extraGroups = mkIf (cfg.group == "ipfs") {
|
|
ipfs = {
|
|
gid = config.ids.gids.ipfs;
|
|
};
|
|
};
|
|
|
|
systemd.services.ipfs-init = {
|
|
description = "IPFS Initializer";
|
|
|
|
after = [ "local-fs.target" ];
|
|
before = [ "ipfs.service" "ipfs-offline.service" ];
|
|
|
|
path = [ pkgs.ipfs pkgs.su pkgs.bash ];
|
|
|
|
preStart = ''
|
|
install -m 0755 -o ${cfg.user} -g ${cfg.group} -d ${cfg.dataDir}
|
|
'';
|
|
|
|
script = ''
|
|
if [[ ! -d ${cfg.dataDir}/.ipfs ]]; then
|
|
cd ${cfg.dataDir}
|
|
${ipfs}/bin/ipfs init ${optionalString cfg.emptyRepo "-e"}
|
|
fi
|
|
${ipfs}/bin/ipfs --local config Addresses.API ${cfg.apiAddress}
|
|
${ipfs}/bin/ipfs --local config Addresses.Gateway ${cfg.gatewayAddress}
|
|
'';
|
|
|
|
serviceConfig = {
|
|
User = cfg.user;
|
|
Group = cfg.group;
|
|
Type = "oneshot";
|
|
RemainAfterExit = true;
|
|
PermissionsStartOnly = true;
|
|
};
|
|
};
|
|
|
|
systemd.services.ipfs = {
|
|
description = "IPFS Daemon";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
after = [ "network.target" "local-fs.target" "ipfs-init.service" ];
|
|
|
|
conflicts = [ "ipfs-offline.service" ];
|
|
wants = [ "ipfs-init.service" ];
|
|
|
|
path = [ pkgs.ipfs ];
|
|
|
|
serviceConfig = {
|
|
ExecStart = "${ipfs}/bin/ipfs daemon ${ipfsFlags}";
|
|
User = cfg.user;
|
|
Group = cfg.group;
|
|
Restart = "on-failure";
|
|
RestartSec = 1;
|
|
};
|
|
};
|
|
|
|
systemd.services.ipfs-offline = {
|
|
description = "IPFS Daemon (offline mode)";
|
|
|
|
after = [ "local-fs.target" "ipfs-init.service" ];
|
|
|
|
conflicts = [ "ipfs.service" ];
|
|
wants = [ "ipfs-init.service" ];
|
|
|
|
path = [ pkgs.ipfs ];
|
|
|
|
serviceConfig = {
|
|
ExecStart = "${ipfs}/bin/ipfs daemon ${ipfsFlags} --offline";
|
|
User = cfg.user;
|
|
Group = cfg.group;
|
|
Restart = "on-failure";
|
|
RestartSec = 1;
|
|
};
|
|
};
|
|
};
|
|
}
|