ipfs: autoMount working without root
This commit is contained in:
parent
6324317c76
commit
1a15c5d8c6
|
@ -6,7 +6,7 @@ let
|
||||||
cfg = config.services.ipfs;
|
cfg = config.services.ipfs;
|
||||||
|
|
||||||
ipfsFlags = toString ([
|
ipfsFlags = toString ([
|
||||||
#(optionalString cfg.autoMount "--mount")
|
(optionalString cfg.autoMount "--mount")
|
||||||
(optionalString cfg.autoMigrate "--migrate")
|
(optionalString cfg.autoMigrate "--migrate")
|
||||||
(optionalString cfg.enableGC "--enable-gc")
|
(optionalString cfg.enableGC "--enable-gc")
|
||||||
(optionalString (cfg.serviceFdlimit != null) "--manage-fdlimit=false")
|
(optionalString (cfg.serviceFdlimit != null) "--manage-fdlimit=false")
|
||||||
|
@ -40,7 +40,7 @@ let
|
||||||
ipfs repo fsck # workaround for BUG #4212 (https://github.com/ipfs/go-ipfs/issues/4214)
|
ipfs repo fsck # workaround for BUG #4212 (https://github.com/ipfs/go-ipfs/issues/4214)
|
||||||
ipfs --local config Addresses.API ${cfg.apiAddress}
|
ipfs --local config Addresses.API ${cfg.apiAddress}
|
||||||
ipfs --local config Addresses.Gateway ${cfg.gatewayAddress}
|
ipfs --local config Addresses.Gateway ${cfg.gatewayAddress}
|
||||||
'' + optionalString false/*cfg.autoMount*/ ''
|
'' + optionalString cfg.autoMount ''
|
||||||
ipfs --local config Mounts.FuseAllowOther --json true
|
ipfs --local config Mounts.FuseAllowOther --json true
|
||||||
ipfs --local config Mounts.IPFS ${cfg.ipfsMountDir}
|
ipfs --local config Mounts.IPFS ${cfg.ipfsMountDir}
|
||||||
ipfs --local config Mounts.IPNS ${cfg.ipnsMountDir}
|
ipfs --local config Mounts.IPNS ${cfg.ipnsMountDir}
|
||||||
|
@ -103,11 +103,11 @@ in {
|
||||||
description = "Whether IPFS should try to migrate the file system automatically";
|
description = "Whether IPFS should try to migrate the file system automatically";
|
||||||
};
|
};
|
||||||
|
|
||||||
#autoMount = mkOption {
|
autoMount = mkOption {
|
||||||
# type = types.bool;
|
type = types.bool;
|
||||||
# default = false;
|
default = false;
|
||||||
# description = "Whether IPFS should try to mount /ipfs and /ipns at startup.";
|
description = "Whether IPFS should try to mount /ipfs and /ipns at startup.";
|
||||||
#};
|
};
|
||||||
|
|
||||||
ipfsMountDir = mkOption {
|
ipfsMountDir = mkOption {
|
||||||
type = types.str;
|
type = types.str;
|
||||||
|
@ -185,6 +185,9 @@ in {
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
environment.systemPackages = [ wrapped ];
|
environment.systemPackages = [ wrapped ];
|
||||||
|
environment.etc."fuse.conf" = mkIf cfg.autoMount { text = ''
|
||||||
|
user_allow_other
|
||||||
|
''; };
|
||||||
|
|
||||||
users.extraUsers = mkIf (cfg.user == "ipfs") {
|
users.extraUsers = mkIf (cfg.user == "ipfs") {
|
||||||
ipfs = {
|
ipfs = {
|
||||||
|
@ -208,7 +211,7 @@ in {
|
||||||
|
|
||||||
preStart = ''
|
preStart = ''
|
||||||
install -m 0755 -o ${cfg.user} -g ${cfg.group} -d ${cfg.dataDir}
|
install -m 0755 -o ${cfg.user} -g ${cfg.group} -d ${cfg.dataDir}
|
||||||
'' + optionalString false/*cfg.autoMount*/ ''
|
'' + optionalString cfg.autoMount ''
|
||||||
install -m 0755 -o ${cfg.user} -g ${cfg.group} -d ${cfg.ipfsMountDir}
|
install -m 0755 -o ${cfg.user} -g ${cfg.group} -d ${cfg.ipfsMountDir}
|
||||||
install -m 0755 -o ${cfg.user} -g ${cfg.group} -d ${cfg.ipnsMountDir}
|
install -m 0755 -o ${cfg.user} -g ${cfg.group} -d ${cfg.ipnsMountDir}
|
||||||
'';
|
'';
|
||||||
|
|
Loading…
Reference in New Issue