Merge staging-next into staging
This commit is contained in:
		
						commit
						377242d587
					
				| @ -436,6 +436,12 @@ lib.mapAttrs (n: v: v // { shortName = n; }) { | |||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   # Proprietary binaries; free to redistribute without modification. |   # Proprietary binaries; free to redistribute without modification. | ||||||
|  |   databricks = { | ||||||
|  |     fullName = "Databricks Proprietary License"; | ||||||
|  |     url = "https://pypi.org/project/databricks-connect"; | ||||||
|  |     free = false; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|   issl = { |   issl = { | ||||||
|     fullName = "Intel Simplified Software License"; |     fullName = "Intel Simplified Software License"; | ||||||
|     url = "https://software.intel.com/en-us/license/intel-simplified-software-license"; |     url = "https://software.intel.com/en-us/license/intel-simplified-software-license"; | ||||||
|  | |||||||
| @ -613,7 +613,6 @@ rec { | |||||||
|         if tp.name == "option set" || tp.name == "submodule" then |         if tp.name == "option set" || tp.name == "submodule" then | ||||||
|           throw "The option ${showOption loc} uses submodules without a wrapping type, in ${showFiles opt.declarations}." |           throw "The option ${showOption loc} uses submodules without a wrapping type, in ${showFiles opt.declarations}." | ||||||
|         else if optionSetIn "attrsOf" then types.attrsOf (types.submodule options) |         else if optionSetIn "attrsOf" then types.attrsOf (types.submodule options) | ||||||
|         else if optionSetIn "loaOf"   then types.loaOf   (types.submodule options) |  | ||||||
|         else if optionSetIn "listOf"  then types.listOf  (types.submodule options) |         else if optionSetIn "listOf"  then types.listOf  (types.submodule options) | ||||||
|         else if optionSetIn "nullOr"  then types.nullOr  (types.submodule options) |         else if optionSetIn "nullOr"  then types.nullOr  (types.submodule options) | ||||||
|         else tp; |         else tp; | ||||||
|  | |||||||
							
								
								
									
										77
									
								
								lib/systems/architectures.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								lib/systems/architectures.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,77 @@ | |||||||
|  | { lib }: | ||||||
|  | 
 | ||||||
|  | rec { | ||||||
|  |   # platform.gcc.arch to its features (as in /proc/cpuinfo) | ||||||
|  |   features = { | ||||||
|  |     default        = [ ]; | ||||||
|  |     # x86_64 Intel | ||||||
|  |     westmere       = [ "sse3" "ssse3" "sse4_1" "sse4_2"         "aes"                                    ]; | ||||||
|  |     sandybridge    = [ "sse3" "ssse3" "sse4_1" "sse4_2"         "aes" "avx"                              ]; | ||||||
|  |     ivybridge      = [ "sse3" "ssse3" "sse4_1" "sse4_2"         "aes" "avx"                              ]; | ||||||
|  |     haswell        = [ "sse3" "ssse3" "sse4_1" "sse4_2"         "aes" "avx" "avx2"          "fma"        ]; | ||||||
|  |     broadwell      = [ "sse3" "ssse3" "sse4_1" "sse4_2"         "aes" "avx" "avx2"          "fma"        ]; | ||||||
|  |     skylake        = [ "sse3" "ssse3" "sse4_1" "sse4_2"         "aes" "avx" "avx2"          "fma"        ]; | ||||||
|  |     skylake-avx512 = [ "sse3" "ssse3" "sse4_1" "sse4_2"         "aes" "avx" "avx2" "avx512" "fma"        ]; | ||||||
|  |     # x86_64 AMD | ||||||
|  |     btver1         = [ "sse3" "ssse3" "sse4_1" "sse4_2"                                                  ]; | ||||||
|  |     btver2         = [ "sse3" "ssse3" "sse4_1" "sse4_2"         "aes" "avx"                              ]; | ||||||
|  |     bdver1         = [ "sse3" "ssse3" "sse4_1" "sse4_2" "sse4a" "aes" "avx"                 "fma" "fma4" ]; | ||||||
|  |     bdver2         = [ "sse3" "ssse3" "sse4_1" "sse4_2" "sse4a" "aes" "avx"                 "fma" "fma4" ]; | ||||||
|  |     bdver3         = [ "sse3" "ssse3" "sse4_1" "sse4_2" "sse4a" "aes" "avx"                 "fma" "fma4" ]; | ||||||
|  |     bdver4         = [ "sse3" "ssse3" "sse4_1" "sse4_2" "sse4a" "aes" "avx" "avx2"          "fma" "fma4" ]; | ||||||
|  |     znver1         = [ "sse3" "ssse3" "sse4_1" "sse4_2" "sse4a" "aes" "avx" "avx2"          "fma"        ]; | ||||||
|  |     znver2         = [ "sse3" "ssse3" "sse4_1" "sse4_2" "sse4a" "aes" "avx" "avx2"          "fma"        ]; | ||||||
|  |     # other | ||||||
|  |     armv5te        = [ ]; | ||||||
|  |     armv6          = [ ]; | ||||||
|  |     armv7-a        = [ ]; | ||||||
|  |     armv8-a        = [ ]; | ||||||
|  |     mips32         = [ ]; | ||||||
|  |     loongson2f     = [ ]; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   # a superior CPU has all the features of an inferior and is able to build and test code for it | ||||||
|  |   inferiors = { | ||||||
|  |     # x86_64 Intel | ||||||
|  |     default        = [ ]; | ||||||
|  |     westmere       = [ ]; | ||||||
|  |     sandybridge    = [ "westmere"    ] ++ inferiors.westmere; | ||||||
|  |     ivybridge      = [ "sandybridge" ] ++ inferiors.sandybridge; | ||||||
|  |     haswell        = [ "ivybridge"   ] ++ inferiors.ivybridge; | ||||||
|  |     broadwell      = [ "haswell"     ] ++ inferiors.haswell; | ||||||
|  |     skylake        = [ "broadwell"   ] ++ inferiors.broadwell; | ||||||
|  |     skylake-avx512 = [ "skylake"     ] ++ inferiors.skylake; | ||||||
|  |     # x86_64 AMD | ||||||
|  |     btver1         = [ ]; | ||||||
|  |     btver2         = [ ]; # TODO: fill this (need testing) | ||||||
|  |     bdver1         = [ ]; # TODO: fill this (need testing) | ||||||
|  |     bdver2         = [ ]; # TODO: fill this (need testing) | ||||||
|  |     bdver3         = [ ]; # TODO: fill this (need testing) | ||||||
|  |     bdver4         = [ ]; # TODO: fill this (need testing) | ||||||
|  |     znver1         = [ ]; # TODO: fill this (need testing) | ||||||
|  |     znver2         = [ ]; # TODO: fill this (need testing) | ||||||
|  |     # other | ||||||
|  |     armv5te        = [ ]; | ||||||
|  |     armv6          = [ ]; | ||||||
|  |     armv7-a        = [ ]; | ||||||
|  |     armv8-a        = [ ]; | ||||||
|  |     mips32         = [ ]; | ||||||
|  |     loongson2f     = [ ]; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   predicates = let | ||||||
|  |     featureSupport = feature: x: builtins.elem feature features.${x}; | ||||||
|  |   in { | ||||||
|  |     sse3Support    = featureSupport "sse3"; | ||||||
|  |     ssse3Support   = featureSupport "ssse3"; | ||||||
|  |     sse4_1Support  = featureSupport "sse4_1"; | ||||||
|  |     sse4_2Support  = featureSupport "sse4_2"; | ||||||
|  |     sse4_aSupport  = featureSupport "sse4a"; | ||||||
|  |     avxSupport     = featureSupport "avx"; | ||||||
|  |     avx2Support    = featureSupport "avx2"; | ||||||
|  |     avx512Support  = featureSupport "avx512"; | ||||||
|  |     aesSupport     = featureSupport "aes"; | ||||||
|  |     fmaSupport     = featureSupport "fma"; | ||||||
|  |     fma4Support    = featureSupport "fma4"; | ||||||
|  |   }; | ||||||
|  | } | ||||||
| @ -7,6 +7,7 @@ rec { | |||||||
|   inspect = import ./inspect.nix { inherit lib; }; |   inspect = import ./inspect.nix { inherit lib; }; | ||||||
|   platforms = import ./platforms.nix { inherit lib; }; |   platforms = import ./platforms.nix { inherit lib; }; | ||||||
|   examples = import ./examples.nix { inherit lib; }; |   examples = import ./examples.nix { inherit lib; }; | ||||||
|  |   architectures = import ./architectures.nix { inherit lib; }; | ||||||
| 
 | 
 | ||||||
|   # Elaborate a `localSystem` or `crossSystem` so that it contains everything |   # Elaborate a `localSystem` or `crossSystem` so that it contains everything | ||||||
|   # necessary. |   # necessary. | ||||||
| @ -76,6 +77,7 @@ rec { | |||||||
|          # uname -r |          # uname -r | ||||||
|          release = null; |          release = null; | ||||||
|       }; |       }; | ||||||
|  |       isStatic = final.isWasm || final.isRedox; | ||||||
| 
 | 
 | ||||||
|       kernelArch = |       kernelArch = | ||||||
|         if final.isAarch32 then "arm" |         if final.isAarch32 then "arm" | ||||||
| @ -125,6 +127,7 @@ rec { | |||||||
|         else throw "Don't know how to run ${final.config} executables."; |         else throw "Don't know how to run ${final.config} executables."; | ||||||
| 
 | 
 | ||||||
|     } // mapAttrs (n: v: v final.parsed) inspect.predicates |     } // mapAttrs (n: v: v final.parsed) inspect.predicates | ||||||
|  |       // mapAttrs (n: v: v final.platform.gcc.arch or "default") architectures.predicates | ||||||
|       // args; |       // args; | ||||||
|   in assert final.useAndroidPrebuilt -> final.isAndroid; |   in assert final.useAndroidPrebuilt -> final.isAndroid; | ||||||
|      assert lib.foldl |      assert lib.foldl | ||||||
|  | |||||||
							
								
								
									
										115
									
								
								lib/types.nix
									
									
									
									
									
								
							
							
						
						
									
										115
									
								
								lib/types.nix
									
									
									
									
									
								
							| @ -252,8 +252,8 @@ rec { | |||||||
|       merge = mergeEqualOption; |       merge = mergeEqualOption; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     # drop this in the future: |     # TODO: drop this in the future: | ||||||
|     list = builtins.trace "`types.list` is deprecated; use `types.listOf` instead" types.listOf; |     list = builtins.trace "`types.list` has been removed; please use `types.listOf` instead" types.listOf; | ||||||
| 
 | 
 | ||||||
|     listOf = elemType: mkOptionType rec { |     listOf = elemType: mkOptionType rec { | ||||||
|       name = "listOf"; |       name = "listOf"; | ||||||
| @ -326,110 +326,15 @@ rec { | |||||||
|       functor = (defaultFunctor name) // { wrapped = elemType; }; |       functor = (defaultFunctor name) // { wrapped = elemType; }; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     # List or attribute set of ... |     # TODO: drop this in the future: | ||||||
|     loaOf = elemType: |     loaOf = | ||||||
|       let |       let msg = | ||||||
|         convertAllLists = loc: defs: |         '' | ||||||
|           let |           `types.loaOf` has been removed and mixing lists with attribute values | ||||||
|             padWidth = stringLength (toString (length defs)); |           is no longer possible; please use `types.attrsOf` instead. | ||||||
|             unnamedPrefix = i: "unnamed-" + fixedWidthNumber padWidth i + "."; |           See https://github.com/NixOS/nixpkgs/issues/1800 for the motivation. | ||||||
|           in |  | ||||||
|             imap1 (i: convertIfList loc (unnamedPrefix i)) defs; |  | ||||||
|         convertIfList = loc: unnamedPrefix: def: |  | ||||||
|           if isList def.value then |  | ||||||
|             let |  | ||||||
|               padWidth = stringLength (toString (length def.value)); |  | ||||||
|               unnamed = i: unnamedPrefix + fixedWidthNumber padWidth i; |  | ||||||
|               anyString = placeholder "name"; |  | ||||||
|               nameAttrs = [ |  | ||||||
|                 { path = [ "environment" "etc" ]; |  | ||||||
|                   name = "target"; |  | ||||||
|                 } |  | ||||||
|                 { path = [ "containers" anyString "bindMounts" ]; |  | ||||||
|                   name = "mountPoint"; |  | ||||||
|                 } |  | ||||||
|                 { path = [ "programs" "ssh" "knownHosts" ]; |  | ||||||
|                   # hostNames is actually a list so we would need to handle it only when singleton |  | ||||||
|                   name = "hostNames"; |  | ||||||
|                 } |  | ||||||
|                 { path = [ "fileSystems" ]; |  | ||||||
|                   name = "mountPoint"; |  | ||||||
|                 } |  | ||||||
|                 { path = [ "boot" "specialFileSystems" ]; |  | ||||||
|                   name = "mountPoint"; |  | ||||||
|                 } |  | ||||||
|                 { path = [ "services" "znapzend" "zetup" ]; |  | ||||||
|                   name = "dataset"; |  | ||||||
|                 } |  | ||||||
|                 { path = [ "services" "znapzend" "zetup" anyString "destinations" ]; |  | ||||||
|                   name = "label"; |  | ||||||
|                 } |  | ||||||
|                 { path = [ "services" "geoclue2" "appConfig" ]; |  | ||||||
|                   name = "desktopID"; |  | ||||||
|                 } |  | ||||||
|               ]; |  | ||||||
|               matched = let |  | ||||||
|                 equals = a: b: b == anyString || a == b; |  | ||||||
|                 fallback = { name = "name"; }; |  | ||||||
|               in findFirst ({ path, ... }: all (v: v == true) (zipListsWith equals loc path)) fallback nameAttrs; |  | ||||||
|               nameAttr = matched.name; |  | ||||||
|               nameValueOld = value: |  | ||||||
|                 if isList value then |  | ||||||
|                   if length value > 0 then |  | ||||||
|                     "[ " + concatMapStringsSep " " escapeNixString value + " ]" |  | ||||||
|                   else |  | ||||||
|                     "[ ]" |  | ||||||
|                 else |  | ||||||
|                   escapeNixString value; |  | ||||||
|               nameValueNew = value: unnamed: |  | ||||||
|                 if isList value then |  | ||||||
|                   if length value > 0 then |  | ||||||
|                     head value |  | ||||||
|                   else |  | ||||||
|                     unnamed |  | ||||||
|                 else |  | ||||||
|                   value; |  | ||||||
|               res = |  | ||||||
|                 { inherit (def) file; |  | ||||||
|                   value = listToAttrs ( |  | ||||||
|                     imap1 (elemIdx: elem: |  | ||||||
|                       { name  = nameValueNew (elem.${nameAttr} or (unnamed elemIdx)) (unnamed elemIdx); |  | ||||||
|                         value = elem; |  | ||||||
|                       }) def.value); |  | ||||||
|                 }; |  | ||||||
|               option = concatStringsSep "." loc; |  | ||||||
|               sample = take 3 def.value; |  | ||||||
|               more = lib.optionalString (length def.value > 3) "... "; |  | ||||||
|               list = concatMapStrings (x: ''{ ${nameAttr} = ${nameValueOld (x.${nameAttr} or "unnamed")}; ...} '') sample; |  | ||||||
|               set = concatMapStrings (x: ''${nameValueNew (x.${nameAttr} or "unnamed") "unnamed"} = {...}; '') sample; |  | ||||||
|               msg = '' |  | ||||||
|                 In file ${def.file} |  | ||||||
|                 a list is being assigned to the option config.${option}. |  | ||||||
|                 This will soon be an error as type loaOf is deprecated. |  | ||||||
|                 See https://github.com/NixOS/nixpkgs/pull/63103 for more information. |  | ||||||
|                 Do |  | ||||||
|                   ${option} = |  | ||||||
|                     { ${set}${more}} |  | ||||||
|                 instead of |  | ||||||
|                   ${option} = |  | ||||||
|                     [ ${list}${more}] |  | ||||||
|         ''; |         ''; | ||||||
|             in |       in builtins.trace msg types.attrsOf; | ||||||
|               lib.warn msg res |  | ||||||
|           else |  | ||||||
|             def; |  | ||||||
|         attrOnly = attrsOf elemType; |  | ||||||
|       in mkOptionType rec { |  | ||||||
|         name = "loaOf"; |  | ||||||
|         description = "list or attribute set of ${elemType.description}s"; |  | ||||||
|         check = x: isList x || isAttrs x; |  | ||||||
|         merge = loc: defs: attrOnly.merge loc (convertAllLists loc defs); |  | ||||||
|         emptyValue = { value = {}; }; |  | ||||||
|         getSubOptions = prefix: elemType.getSubOptions (prefix ++ ["<name?>"]); |  | ||||||
|         getSubModules = elemType.getSubModules; |  | ||||||
|         substSubModules = m: loaOf (elemType.substSubModules m); |  | ||||||
|         functor = (defaultFunctor name) // { wrapped = elemType; }; |  | ||||||
|       }; |  | ||||||
| 
 | 
 | ||||||
|     # Value of given type but with no merging (i.e. `uniq list`s are not concatenated). |     # Value of given type but with no merging (i.e. `uniq list`s are not concatenated). | ||||||
|     uniq = elemType: mkOptionType rec { |     uniq = elemType: mkOptionType rec { | ||||||
|  | |||||||
| @ -4310,6 +4310,12 @@ | |||||||
|     githubId = 494012; |     githubId = 494012; | ||||||
|     name = "Kevin Cox"; |     name = "Kevin Cox"; | ||||||
|   }; |   }; | ||||||
|  |   kfollesdal = { | ||||||
|  |     email = "kfollesdal@gmail.com"; | ||||||
|  |     github = "kfollesdal"; | ||||||
|  |     githubId = 546087; | ||||||
|  |     name = "Kristoffer K. Føllesdal"; | ||||||
|  |   }; | ||||||
|   khumba = { |   khumba = { | ||||||
|     email = "bog@khumba.net"; |     email = "bog@khumba.net"; | ||||||
|     github = "khumba"; |     github = "khumba"; | ||||||
| @ -7175,6 +7181,16 @@ | |||||||
|     githubId = 3621083; |     githubId = 3621083; | ||||||
|     name = "Roosembert (Roosemberth) Palacios"; |     name = "Roosembert (Roosemberth) Palacios"; | ||||||
|   }; |   }; | ||||||
|  |   rople380 = { | ||||||
|  |     name = "rople380"; | ||||||
|  |     email = "55679162+rople380@users.noreply.github.com"; | ||||||
|  |     github = "rople380"; | ||||||
|  |     githubId = 55679162; | ||||||
|  |     keys = [{ | ||||||
|  |       longkeyid = "rsa2048/0x8526B7574A536236"; | ||||||
|  |       fingerprint = "1401 1B63 393D 16C1 AA9C  C521 8526 B757 4A53 6236"; | ||||||
|  |     }]; | ||||||
|  |   }; | ||||||
|   royneary = { |   royneary = { | ||||||
|     email = "christian@ulrich.earth"; |     email = "christian@ulrich.earth"; | ||||||
|     github = "royneary"; |     github = "royneary"; | ||||||
|  | |||||||
| @ -58,9 +58,9 @@ | |||||||
|       Like <literal>boot.debug1</literal> or |       Like <literal>boot.debug1</literal> or | ||||||
|       <literal>boot.debug1devices</literal>, but runs stage1 until all |       <literal>boot.debug1devices</literal>, but runs stage1 until all | ||||||
|       filesystems that are mounted during initrd are mounted (see |       filesystems that are mounted during initrd are mounted (see | ||||||
|       <option><link linkend="opt-fileSystems._name__.neededForBoot">neededForBoot</link></option> |       <option><link linkend="opt-fileSystems._name_.neededForBoot">neededForBoot</link></option> | ||||||
|       ). As a motivating example, this could be useful if you've forgotten to set |       ). As a motivating example, this could be useful if you've forgotten to set | ||||||
|       <option><link linkend="opt-fileSystems._name__.neededForBoot">neededForBoot</link></option> |       <option><link linkend="opt-fileSystems._name_.neededForBoot">neededForBoot</link></option> | ||||||
|       on a file system. |       on a file system. | ||||||
|      </para> |      </para> | ||||||
|     </listitem> |     </listitem> | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ | |||||||
| <screen> | <screen> | ||||||
| # nixos-container create foo --config ' | # nixos-container create foo --config ' | ||||||
|   <xref linkend="opt-services.openssh.enable"/> = true; |   <xref linkend="opt-services.openssh.enable"/> = true; | ||||||
|   <link linkend="opt-users.users._name__.openssh.authorizedKeys.keys">users.users.root.openssh.authorizedKeys.keys</link> = ["ssh-dss AAAAB3N…"]; |   <link linkend="opt-users.users._name_.openssh.authorizedKeys.keys">users.users.root.openssh.authorizedKeys.keys</link> = ["ssh-dss AAAAB3N…"]; | ||||||
| ' | ' | ||||||
| </screen> | </screen> | ||||||
|   By default the next free address in the <literal>10.233.0.0/16</literal> subnet will be chosen |   By default the next free address in the <literal>10.233.0.0/16</literal> subnet will be chosen | ||||||
|  | |||||||
| @ -23,12 +23,12 @@ | |||||||
|   <link xlink:href="https://www.freedesktop.org/software/systemd/man/systemd-fstab-generator.html">systemd-fstab-generator</link>. |   <link xlink:href="https://www.freedesktop.org/software/systemd/man/systemd-fstab-generator.html">systemd-fstab-generator</link>. | ||||||
|   The filesystem will be mounted automatically unless |   The filesystem will be mounted automatically unless | ||||||
|   <literal>"noauto"</literal> is present in <link |   <literal>"noauto"</literal> is present in <link | ||||||
|   linkend="opt-fileSystems._name__.options">options</link>. |   linkend="opt-fileSystems._name_.options">options</link>. | ||||||
|   <literal>"noauto"</literal> filesystems can be mounted explicitly using |   <literal>"noauto"</literal> filesystems can be mounted explicitly using | ||||||
|   <command>systemctl</command> e.g. <command>systemctl start |   <command>systemctl</command> e.g. <command>systemctl start | ||||||
|   data.mount</command>. |   data.mount</command>. | ||||||
|   Mount points are created automatically if they don’t already exist. For |   Mount points are created automatically if they don’t already exist. For | ||||||
|   <option><link linkend="opt-fileSystems._name__.device">device</link></option>, |   <option><link linkend="opt-fileSystems._name_.device">device</link></option>, | ||||||
|   it’s best to use the topology-independent device aliases in |   it’s best to use the topology-independent device aliases in | ||||||
|   <filename>/dev/disk/by-label</filename> and |   <filename>/dev/disk/by-label</filename> and | ||||||
|   <filename>/dev/disk/by-uuid</filename>, as these don’t change if the |   <filename>/dev/disk/by-uuid</filename>, as these don’t change if the | ||||||
| @ -36,7 +36,7 @@ | |||||||
|  </para> |  </para> | ||||||
|  <para> |  <para> | ||||||
|   You can usually omit the file system type |   You can usually omit the file system type | ||||||
|   (<option><link linkend="opt-fileSystems._name__.fsType">fsType</link></option>), |   (<option><link linkend="opt-fileSystems._name_.fsType">fsType</link></option>), | ||||||
|   since <command>mount</command> can usually detect the type and load the |   since <command>mount</command> can usually detect the type and load the | ||||||
|   necessary kernel module automatically. However, if the file system is needed |   necessary kernel module automatically. However, if the file system is needed | ||||||
|   at early boot (in the initial ramdisk) and is not <literal>ext2</literal>, |   at early boot (in the initial ramdisk) and is not <literal>ext2</literal>, | ||||||
| @ -49,7 +49,7 @@ | |||||||
|    System startup will fail if any of the filesystems fails to mount, dropping |    System startup will fail if any of the filesystems fails to mount, dropping | ||||||
|    you to the emergency shell. You can make a mount asynchronous and |    you to the emergency shell. You can make a mount asynchronous and | ||||||
|    non-critical by adding |    non-critical by adding | ||||||
|    <literal><link linkend="opt-fileSystems._name__.options">options</link> = [ |    <literal><link linkend="opt-fileSystems._name_.options">options</link> = [ | ||||||
|    "nofail" ];</literal>. |    "nofail" ];</literal>. | ||||||
|   </para> |   </para> | ||||||
|  </note> |  </note> | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ | |||||||
|   automatically configure network interfaces. However, you can configure an |   automatically configure network interfaces. However, you can configure an | ||||||
|   interface manually as follows: |   interface manually as follows: | ||||||
| <programlisting> | <programlisting> | ||||||
| <link linkend="opt-networking.interfaces._name__.ipv4.addresses">networking.interfaces.eth0.ipv4.addresses</link> = [ { | <link linkend="opt-networking.interfaces._name_.ipv4.addresses">networking.interfaces.eth0.ipv4.addresses</link> = [ { | ||||||
|   address = "192.168.1.2"; |   address = "192.168.1.2"; | ||||||
|   prefixLength = 24; |   prefixLength = 24; | ||||||
| } ]; | } ]; | ||||||
|  | |||||||
| @ -26,7 +26,7 @@ | |||||||
|   As with IPv4 networking interfaces are automatically configured via DHCPv6. |   As with IPv4 networking interfaces are automatically configured via DHCPv6. | ||||||
|   You can configure an interface manually: |   You can configure an interface manually: | ||||||
| <programlisting> | <programlisting> | ||||||
| <link linkend="opt-networking.interfaces._name__.ipv6.addresses">networking.interfaces.eth0.ipv6.addresses</link> = [ { | <link linkend="opt-networking.interfaces._name_.ipv6.addresses">networking.interfaces.eth0.ipv6.addresses</link> = [ { | ||||||
|   address = "fe00:aa:bb:cc::2"; |   address = "fe00:aa:bb:cc::2"; | ||||||
|   prefixLength = 64; |   prefixLength = 64; | ||||||
| } ]; | } ]; | ||||||
|  | |||||||
| @ -30,7 +30,7 @@ Enter passphrase for /dev/disk/by-uuid/3f6b0024-3a44-4fde-a43a-767b872abe5d: *** | |||||||
|   <filename>/</filename>, add the following to |   <filename>/</filename>, add the following to | ||||||
|   <filename>configuration.nix</filename>: |   <filename>configuration.nix</filename>: | ||||||
| <programlisting> | <programlisting> | ||||||
| <link linkend="opt-boot.initrd.luks.devices._name__.device">boot.initrd.luks.devices.crypted.device</link> = "/dev/disk/by-uuid/3f6b0024-3a44-4fde-a43a-767b872abe5d"; | <link linkend="opt-boot.initrd.luks.devices._name_.device">boot.initrd.luks.devices.crypted.device</link> = "/dev/disk/by-uuid/3f6b0024-3a44-4fde-a43a-767b872abe5d"; | ||||||
| <xref linkend="opt-fileSystems"/>."/".device = "/dev/mapper/crypted"; | <xref linkend="opt-fileSystems"/>."/".device = "/dev/mapper/crypted"; | ||||||
| </programlisting> | </programlisting> | ||||||
|   Should grub be used as bootloader, and <filename>/boot</filename> is located |   Should grub be used as bootloader, and <filename>/boot</filename> is located | ||||||
| @ -60,13 +60,13 @@ Added to key to device /dev/sda2, slot: 2 | |||||||
|   To ensure that this file system is decrypted using the FIDO2 compatible key, add the following to <filename>configuration.nix</filename>: |   To ensure that this file system is decrypted using the FIDO2 compatible key, add the following to <filename>configuration.nix</filename>: | ||||||
| <programlisting> | <programlisting> | ||||||
| <link linkend="opt-boot.initrd.luks.fido2Support">boot.initrd.luks.fido2Support</link> = true; | <link linkend="opt-boot.initrd.luks.fido2Support">boot.initrd.luks.fido2Support</link> = true; | ||||||
| <link linkend="opt-boot.initrd.luks.devices._name__.fido2.credential">boot.initrd.luks.devices."/dev/sda2".fido2.credential</link> = "f1d00200108b9d6e849a8b388da457688e3dd653b4e53770012d8f28e5d3b269865038c346802f36f3da7278b13ad6a3bb6a1452e24ebeeaa24ba40eef559b1b287d2a2f80b7"; | <link linkend="opt-boot.initrd.luks.devices._name_.fido2.credential">boot.initrd.luks.devices."/dev/sda2".fido2.credential</link> = "f1d00200108b9d6e849a8b388da457688e3dd653b4e53770012d8f28e5d3b269865038c346802f36f3da7278b13ad6a3bb6a1452e24ebeeaa24ba40eef559b1b287d2a2f80b7"; | ||||||
| </programlisting> | </programlisting> | ||||||
| 
 | 
 | ||||||
|   You can also use the FIDO2 passwordless setup, but for security reasons, you might want to enable it only when your device is PIN protected, such as <link xlink:href="https://trezor.io/">Trezor</link>. |   You can also use the FIDO2 passwordless setup, but for security reasons, you might want to enable it only when your device is PIN protected, such as <link xlink:href="https://trezor.io/">Trezor</link>. | ||||||
| 
 | 
 | ||||||
| <programlisting> | <programlisting> | ||||||
| <link linkend="opt-boot.initrd.luks.devices._name__.fido2.passwordLess">boot.initrd.luks.devices."/dev/sda2".fido2.passwordLess</link> = true; | <link linkend="opt-boot.initrd.luks.devices._name_.fido2.passwordLess">boot.initrd.luks.devices."/dev/sda2".fido2.passwordLess</link> = true; | ||||||
| </programlisting> | </programlisting> | ||||||
|   </para> |   </para> | ||||||
|  </section> |  </section> | ||||||
|  | |||||||
| @ -19,7 +19,7 @@ | |||||||
|   All users that should have permission to change network settings must belong |   All users that should have permission to change network settings must belong | ||||||
|   to the <code>networkmanager</code> group: |   to the <code>networkmanager</code> group: | ||||||
| <programlisting> | <programlisting> | ||||||
| <link linkend="opt-users.users._name__.extraGroups">users.users.alice.extraGroups</link> = [ "networkmanager" ]; | <link linkend="opt-users.users._name_.extraGroups">users.users.alice.extraGroups</link> = [ "networkmanager" ]; | ||||||
| </programlisting> | </programlisting> | ||||||
|  </para> |  </para> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ | |||||||
|   follows: |   follows: | ||||||
| <!-- FIXME: this might not work if the user is unmanaged. --> | <!-- FIXME: this might not work if the user is unmanaged. --> | ||||||
| <programlisting> | <programlisting> | ||||||
| <link linkend="opt-users.users._name__.openssh.authorizedKeys.keys">users.users.alice.openssh.authorizedKeys.keys</link> = | <link linkend="opt-users.users._name_.openssh.authorizedKeys.keys">users.users.alice.openssh.authorizedKeys.keys</link> = | ||||||
|   [ "ssh-dss AAAAB3NzaC1kc3MAAACBAPIkGWVEt4..." ]; |   [ "ssh-dss AAAAB3NzaC1kc3MAAACBAPIkGWVEt4..." ]; | ||||||
| </programlisting> | </programlisting> | ||||||
|  </para> |  </para> | ||||||
|  | |||||||
| @ -11,11 +11,11 @@ | |||||||
|   that a user account named <literal>alice</literal> shall exist: |   that a user account named <literal>alice</literal> shall exist: | ||||||
| <programlisting> | <programlisting> | ||||||
| <xref linkend="opt-users.users"/>.alice = { | <xref linkend="opt-users.users"/>.alice = { | ||||||
|   <link linkend="opt-users.users._name__.isNormalUser">isNormalUser</link> = true; |   <link linkend="opt-users.users._name_.isNormalUser">isNormalUser</link> = true; | ||||||
|   <link linkend="opt-users.users._name__.home">home</link> = "/home/alice"; |   <link linkend="opt-users.users._name_.home">home</link> = "/home/alice"; | ||||||
|   <link linkend="opt-users.users._name__.description">description</link> = "Alice Foobar"; |   <link linkend="opt-users.users._name_.description">description</link> = "Alice Foobar"; | ||||||
|   <link linkend="opt-users.users._name__.extraGroups">extraGroups</link> = [ "wheel" "networkmanager" ]; |   <link linkend="opt-users.users._name_.extraGroups">extraGroups</link> = [ "wheel" "networkmanager" ]; | ||||||
|   <link linkend="opt-users.users._name__.openssh.authorizedKeys.keys">openssh.authorizedKeys.keys</link> = [ "ssh-dss AAAAB3Nza... alice@foobar" ]; |   <link linkend="opt-users.users._name_.openssh.authorizedKeys.keys">openssh.authorizedKeys.keys</link> = [ "ssh-dss AAAAB3Nza... alice@foobar" ]; | ||||||
| }; | }; | ||||||
| </programlisting> | </programlisting> | ||||||
|   Note that <literal>alice</literal> is a member of the |   Note that <literal>alice</literal> is a member of the | ||||||
| @ -36,7 +36,7 @@ | |||||||
|   account will cease to exist. Also, imperative commands for managing users and |   account will cease to exist. Also, imperative commands for managing users and | ||||||
|   groups, such as useradd, are no longer available. Passwords may still be |   groups, such as useradd, are no longer available. Passwords may still be | ||||||
|   assigned by setting the user's |   assigned by setting the user's | ||||||
|   <link linkend="opt-users.users._name__.hashedPassword">hashedPassword</link> |   <link linkend="opt-users.users._name_.hashedPassword">hashedPassword</link> | ||||||
|   option. A hashed password can be generated using <command>mkpasswd -m |   option. A hashed password can be generated using <command>mkpasswd -m | ||||||
|   sha-512</command> after installing the <literal>mkpasswd</literal> package. |   sha-512</command> after installing the <literal>mkpasswd</literal> package. | ||||||
|  </para> |  </para> | ||||||
|  | |||||||
| @ -385,17 +385,6 @@ | |||||||
|      </para> |      </para> | ||||||
|     </listitem> |     </listitem> | ||||||
|    </varlistentry> |    </varlistentry> | ||||||
|    <varlistentry> |  | ||||||
|     <term> |  | ||||||
|      <varname>types.loaOf</varname> <replaceable>t</replaceable> |  | ||||||
|     </term> |  | ||||||
|     <listitem> |  | ||||||
|      <para> |  | ||||||
|       An attribute set or a list of <replaceable>t</replaceable> type. Multiple |  | ||||||
|       definitions are merged according to the value. |  | ||||||
|      </para> |  | ||||||
|     </listitem> |  | ||||||
|    </varlistentry> |  | ||||||
|    <varlistentry> |    <varlistentry> | ||||||
|     <term> |     <term> | ||||||
|      <varname>types.nullOr</varname> <replaceable>t</replaceable> |      <varname>types.nullOr</varname> <replaceable>t</replaceable> | ||||||
|  | |||||||
| @ -78,7 +78,7 @@ | |||||||
|   <literal>mutableUsers = false</literal>. Another way is to temporarily add |   <literal>mutableUsers = false</literal>. Another way is to temporarily add | ||||||
|   the following to your configuration: |   the following to your configuration: | ||||||
| <screen> | <screen> | ||||||
| <link linkend="opt-users.users._name__.initialHashedPassword">users.users.your-user.initialHashedPassword</link> = "test"; | <link linkend="opt-users.users._name_.initialHashedPassword">users.users.your-user.initialHashedPassword</link> = "test"; | ||||||
| </screen> | </screen> | ||||||
|   <emphasis>Important:</emphasis> delete the $hostname.qcow2 file if you have |   <emphasis>Important:</emphasis> delete the $hostname.qcow2 file if you have | ||||||
|   started the virtual machine at least once without the right users, otherwise |   started the virtual machine at least once without the right users, otherwise | ||||||
|  | |||||||
| @ -211,7 +211,7 @@ nixpkgs https://nixos.org/channels/nixpkgs-unstable</screen> | |||||||
|     use <literal>sudo</literal>) |     use <literal>sudo</literal>) | ||||||
|    </para> |    </para> | ||||||
| <programlisting> | <programlisting> | ||||||
| <link linkend="opt-users.users._name__.initialHashedPassword">users.users.root.initialHashedPassword</link> = ""; | <link linkend="opt-users.users._name_.initialHashedPassword">users.users.root.initialHashedPassword</link> = ""; | ||||||
| </programlisting> | </programlisting> | ||||||
|   </listitem> |   </listitem> | ||||||
|   <listitem> |   <listitem> | ||||||
|  | |||||||
| @ -550,7 +550,7 @@ Retype new UNIX password: ***</screen> | |||||||
|   # Note: setting fileSystems is generally not |   # Note: setting fileSystems is generally not | ||||||
|   # necessary, since nixos-generate-config figures them out |   # necessary, since nixos-generate-config figures them out | ||||||
|   # automatically in hardware-configuration.nix. |   # automatically in hardware-configuration.nix. | ||||||
|   #<link linkend="opt-fileSystems._name__.device">fileSystems."/".device</link> = "/dev/disk/by-label/nixos"; |   #<link linkend="opt-fileSystems._name_.device">fileSystems."/".device</link> = "/dev/disk/by-label/nixos"; | ||||||
| 
 | 
 | ||||||
|   # Enable the OpenSSH server. |   # Enable the OpenSSH server. | ||||||
|   services.sshd.enable = true; |   services.sshd.enable = true; | ||||||
|  | |||||||
| @ -796,7 +796,7 @@ users.users.me = | |||||||
|      or any other display manager in NixOS as they all support auto-login. If you used this module specifically |      or any other display manager in NixOS as they all support auto-login. If you used this module specifically | ||||||
|      because it permitted root auto-login you can override the lightdm-autologin pam module like: |      because it permitted root auto-login you can override the lightdm-autologin pam module like: | ||||||
| <programlisting> | <programlisting> | ||||||
| <link xlink:href="#opt-security.pam.services._name__.text">security.pam.services.lightdm-autologin.text</link> = lib.mkForce '' | <link xlink:href="#opt-security.pam.services._name_.text">security.pam.services.lightdm-autologin.text</link> = lib.mkForce '' | ||||||
|     auth     requisite pam_nologin.so |     auth     requisite pam_nologin.so | ||||||
|     auth     required  pam_succeed_if.so quiet |     auth     required  pam_succeed_if.so quiet | ||||||
|     auth     required  pam_permit.so |     auth     required  pam_permit.so | ||||||
|  | |||||||
| @ -767,6 +767,16 @@ CREATE ROLE postgres LOGIN SUPERUSER; | |||||||
|      See <link xlink:href="https://github.com/NixOS/nixpkgs/pull/82743#issuecomment-674520472">the PR that changed this</link> for more info. |      See <link xlink:href="https://github.com/NixOS/nixpkgs/pull/82743#issuecomment-674520472">the PR that changed this</link> for more info. | ||||||
|     </para> |     </para> | ||||||
|    </listitem> |    </listitem> | ||||||
|  |    <listitem> | ||||||
|  |     <para> | ||||||
|  |      For NixOS configuration options, the type <literal>loaOf</literal>, after | ||||||
|  |      its initial deprecation in release 20.03, has been removed. In NixOS and | ||||||
|  |      Nixpkgs options using this type have been converted to <literal>attrsOf</literal>. | ||||||
|  |      For more information on this change have look at these links: | ||||||
|  |      <link xlink:href="https://github.com/NixOS/nixpkgs/issues/1800">issue #1800</link>, | ||||||
|  |      <link xlink:href="https://github.com/NixOS/nixpkgs/pull/63103">PR #63103</link>. | ||||||
|  |     </para> | ||||||
|  |    </listitem> | ||||||
|   </itemizedlist> |   </itemizedlist> | ||||||
|  </section> |  </section> | ||||||
| 
 | 
 | ||||||
| @ -997,6 +1007,53 @@ services.transmission.settings.rpc-bind-address = "0.0.0.0"; | |||||||
|       the previous behaviour using <literal>undervolt.useTimer</literal>. |       the previous behaviour using <literal>undervolt.useTimer</literal>. | ||||||
|     </para> |     </para> | ||||||
|    </listitem> |    </listitem> | ||||||
|  |    <listitem> | ||||||
|  |      <para> | ||||||
|  |       Agda has been heavily reworked. | ||||||
|  |       <itemizedlist> | ||||||
|  | 	<listitem> | ||||||
|  | 	  <para> | ||||||
|  | 	    <literal>agda.mkDerivation</literal> has been heavily changed and | ||||||
|  | 	    is now located at <package>agdaPackages.mkDerivation</package>. | ||||||
|  | 	  </para> | ||||||
|  | 	</listitem> | ||||||
|  | 	<listitem> | ||||||
|  | 	  <para> | ||||||
|  | 	    New top-level packages <package>agda</package> and | ||||||
|  | 	    <literal>agda.withPackages</literal> have been added, the second | ||||||
|  | 	    of which sets up agda with access to chosen libraries. | ||||||
|  | 	  </para> | ||||||
|  | 	</listitem> | ||||||
|  | 	<listitem> | ||||||
|  | 	  <para> | ||||||
|  | 	    All agda libraries now live under | ||||||
|  | 	    <literal>agdaPackages</literal>. | ||||||
|  | 	  </para> | ||||||
|  | 	</listitem> | ||||||
|  | 	<listitem> | ||||||
|  | 	  <para> | ||||||
|  | 	    Many broken libraries have been removed. | ||||||
|  | 	  </para> | ||||||
|  | 	</listitem> | ||||||
|  |       </itemizedlist> | ||||||
|  |       See the <link | ||||||
|  |       xlink:href="https://nixos.org/nixpkgs/manual/#agda">new | ||||||
|  |       documentation</link> for more information. | ||||||
|  |     </para> | ||||||
|  |    </listitem> | ||||||
|  |    <listitem> | ||||||
|  |     <para> | ||||||
|  |       The <literal>deepin</literal> package set has been removed from | ||||||
|  |       nixpkgs. It was a work in progress to package the | ||||||
|  |       <link xlink:href="https://www.deepin.org/en/dde/">Deepin Desktop Environment (DDE)</link>, | ||||||
|  |       including libraries, tools and applications, and it was still | ||||||
|  |       missing a service to lauch the desktop environment. It has shown | ||||||
|  |       to no longer be a feasible goal due to reasons discussed in | ||||||
|  |       <link xlink:href="https://github.com/NixOS/nixpkgs/issues/94870">issue #94870</link>. | ||||||
|  |       The package <literal>netease-cloud-music</literal> has also been | ||||||
|  |       removed, as it depends on libraries from deepin. | ||||||
|  |     </para> | ||||||
|  |    </listitem> | ||||||
|   </itemizedlist> |   </itemizedlist> | ||||||
|  </section> |  </section> | ||||||
| </section> | </section> | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ | |||||||
|       <title>Configuration Options</title> |       <title>Configuration Options</title> | ||||||
|       <variablelist xml:id="configuration-variable-list"> |       <variablelist xml:id="configuration-variable-list"> | ||||||
|         <xsl:for-each select="attrs"> |         <xsl:for-each select="attrs"> | ||||||
|           <xsl:variable name="id" select="concat('opt-', str:replace(str:replace(str:replace(str:replace(attr[@name = 'name']/string/@value, '*', '_'), '<', '_'), '>', '_'), '?', '_'))" /> |           <xsl:variable name="id" select="concat('opt-', str:replace(str:replace(str:replace(attr[@name = 'name']/string/@value, '*', '_'), '<', '_'), '>', '_'))" /> | ||||||
|           <varlistentry> |           <varlistentry> | ||||||
|             <term xlink:href="#{$id}"> |             <term xlink:href="#{$id}"> | ||||||
|               <xsl:attribute name="xml:id"><xsl:value-of select="$id"/></xsl:attribute> |               <xsl:attribute name="xml:id"><xsl:value-of select="$id"/></xsl:attribute> | ||||||
|  | |||||||
| @ -41,31 +41,30 @@ let | |||||||
|         value) |         value) | ||||||
|     else value; |     else value; | ||||||
| 
 | 
 | ||||||
|   mkIndent = depth: concatStrings (builtins.genList (_:  " ") (2 * depth)); |   indent = "  "; | ||||||
| 
 | 
 | ||||||
|   mkRelation = name: value: "${name} = ${mkVal { inherit value; }}"; |   mkRelation = name: value: | ||||||
|  |     if (isList value) then | ||||||
|  |       concatMapStringsSep "\n" (mkRelation name) value | ||||||
|  |     else "${name} = ${mkVal value}"; | ||||||
| 
 | 
 | ||||||
|   mkVal = { value, depth ? 0 }: |   mkVal = value: | ||||||
|     if (value == true) then "true" |     if (value == true) then "true" | ||||||
|     else if (value == false) then "false" |     else if (value == false) then "false" | ||||||
|     else if (isInt value) then (toString value) |     else if (isInt value) then (toString value) | ||||||
|     else if (isList value) then |  | ||||||
|       concatMapStringsSep " " mkVal { inherit value depth; } |  | ||||||
|     else if (isAttrs value) then |     else if (isAttrs value) then | ||||||
|       (concatStringsSep "\n${mkIndent (depth + 1)}" |       let configLines = concatLists | ||||||
|         ([ "{" ] ++ (mapAttrsToList |         (map (splitString "\n") | ||||||
|           (attrName: attrValue: let |           (mapAttrsToList mkRelation value)); | ||||||
|             mappedAttrValue = mkVal { |       in | ||||||
|               value = attrValue; |       (concatStringsSep "\n${indent}" | ||||||
|               depth = depth + 1; |         ([ "{" ] ++ configLines)) | ||||||
|             }; |       + "\n}" | ||||||
|           in "${attrName} = ${mappedAttrValue}") |  | ||||||
|         value))) + "\n${mkIndent depth}}" |  | ||||||
|     else value; |     else value; | ||||||
| 
 | 
 | ||||||
|   mkMappedAttrsOrString = value: concatMapStringsSep "\n" |   mkMappedAttrsOrString = value: concatMapStringsSep "\n" | ||||||
|     (line: if builtins.stringLength line > 0 |     (line: if builtins.stringLength line > 0 | ||||||
|       then "${mkIndent 1}${line}" |       then "${indent}${line}" | ||||||
|       else line) |       else line) | ||||||
|     (splitString "\n" |     (splitString "\n" | ||||||
|       (if isAttrs value then |       (if isAttrs value then | ||||||
| @ -114,7 +113,10 @@ in { | |||||||
|           { |           { | ||||||
|             "ATHENA.MIT.EDU" = { |             "ATHENA.MIT.EDU" = { | ||||||
|               admin_server = "athena.mit.edu"; |               admin_server = "athena.mit.edu"; | ||||||
|               kdc = "athena.mit.edu"; |               kdc = [ | ||||||
|  |                 "athena01.mit.edu" | ||||||
|  |                 "athena02.mit.edu" | ||||||
|  |               ]; | ||||||
|             }; |             }; | ||||||
|           }; |           }; | ||||||
|         ''; |         ''; | ||||||
|  | |||||||
| @ -463,7 +463,7 @@ in { | |||||||
| 
 | 
 | ||||||
|     users.users = mkOption { |     users.users = mkOption { | ||||||
|       default = {}; |       default = {}; | ||||||
|       type = with types; loaOf (submodule userOpts); |       type = with types; attrsOf (submodule userOpts); | ||||||
|       example = { |       example = { | ||||||
|         alice = { |         alice = { | ||||||
|           uid = 1234; |           uid = 1234; | ||||||
| @ -487,7 +487,7 @@ in { | |||||||
|         { students.gid = 1001; |         { students.gid = 1001; | ||||||
|           hackers = { }; |           hackers = { }; | ||||||
|         }; |         }; | ||||||
|       type = with types; loaOf (submodule groupOpts); |       type = with types; attrsOf (submodule groupOpts); | ||||||
|       description = '' |       description = '' | ||||||
|         Additional groups to be created automatically by the system. |         Additional groups to be created automatically by the system. | ||||||
|       ''; |       ''; | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ | |||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   fileSystems."/boot/firmware" = { |   fileSystems."/boot/firmware" = { | ||||||
|     # This effectively "renames" the loaOf entry set in sd-image.nix |     # This effectively "renames" the attrsOf entry set in sd-image.nix | ||||||
|     mountPoint = "/boot"; |     mountPoint = "/boot"; | ||||||
|     neededForBoot = true; |     neededForBoot = true; | ||||||
|   }; |   }; | ||||||
|  | |||||||
| @ -224,7 +224,7 @@ bool optionTypeIs(Context & ctx, Value & v, const std::string & soughtType) | |||||||
| 
 | 
 | ||||||
| bool isAggregateOptionType(Context & ctx, Value & v) | bool isAggregateOptionType(Context & ctx, Value & v) | ||||||
| { | { | ||||||
|     return optionTypeIs(ctx, v, "attrsOf") || optionTypeIs(ctx, v, "listOf") || optionTypeIs(ctx, v, "loaOf"); |     return optionTypeIs(ctx, v, "attrsOf") || optionTypeIs(ctx, v, "listOf"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| MakeError(OptionPathError, EvalError); | MakeError(OptionPathError, EvalError); | ||||||
|  | |||||||
| @ -587,6 +587,7 @@ | |||||||
|   ./services/networking/atftpd.nix |   ./services/networking/atftpd.nix | ||||||
|   ./services/networking/avahi-daemon.nix |   ./services/networking/avahi-daemon.nix | ||||||
|   ./services/networking/babeld.nix |   ./services/networking/babeld.nix | ||||||
|  |   ./services/networking/biboumi.nix | ||||||
|   ./services/networking/bind.nix |   ./services/networking/bind.nix | ||||||
|   ./services/networking/bitcoind.nix |   ./services/networking/bitcoind.nix | ||||||
|   ./services/networking/autossh.nix |   ./services/networking/autossh.nix | ||||||
|  | |||||||
| @ -33,7 +33,6 @@ in | |||||||
|       { PATH = [ "/bin" ]; |       { PATH = [ "/bin" ]; | ||||||
|         INFOPATH = [ "/info" "/share/info" ]; |         INFOPATH = [ "/info" "/share/info" ]; | ||||||
|         KDEDIRS = [ "" ]; |         KDEDIRS = [ "" ]; | ||||||
|         STRIGI_PLUGIN_PATH = [ "/lib/strigi/" ]; |  | ||||||
|         QT_PLUGIN_PATH = [ "/lib/qt4/plugins" "/lib/kde4/plugins" ]; |         QT_PLUGIN_PATH = [ "/lib/qt4/plugins" "/lib/kde4/plugins" ]; | ||||||
|         QTWEBKIT_PLUGIN_PATH = [ "/lib/mozilla/plugins/" ]; |         QTWEBKIT_PLUGIN_PATH = [ "/lib/mozilla/plugins/" ]; | ||||||
|         GTK_PATH = [ "/lib/gtk-2.0" "/lib/gtk-3.0" ]; |         GTK_PATH = [ "/lib/gtk-2.0" "/lib/gtk-3.0" ]; | ||||||
|  | |||||||
| @ -30,5 +30,7 @@ with lib; | |||||||
|     environment.systemPackages = [ pkgs.gnome3.gpaste ]; |     environment.systemPackages = [ pkgs.gnome3.gpaste ]; | ||||||
|     services.dbus.packages = [ pkgs.gnome3.gpaste ]; |     services.dbus.packages = [ pkgs.gnome3.gpaste ]; | ||||||
|     systemd.packages = [ pkgs.gnome3.gpaste ]; |     systemd.packages = [ pkgs.gnome3.gpaste ]; | ||||||
|  |     # gnome-control-center crashes in Keyboard Shortcuts pane without the GSettings schemas. | ||||||
|  |     services.xserver.desktopManager.gnome3.sessionPath = [ pkgs.gnome3.gpaste ]; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|  | |||||||
| @ -131,7 +131,7 @@ in | |||||||
| 
 | 
 | ||||||
|       knownHosts = mkOption { |       knownHosts = mkOption { | ||||||
|         default = {}; |         default = {}; | ||||||
|         type = types.loaOf (types.submodule ({ name, ... }: { |         type = types.attrsOf (types.submodule ({ name, ... }: { | ||||||
|           options = { |           options = { | ||||||
|             certAuthority = mkOption { |             certAuthority = mkOption { | ||||||
|               type = types.bool; |               type = types.bool; | ||||||
|  | |||||||
| @ -7,7 +7,7 @@ let | |||||||
|   inherit (lib.modules) mkDefault mkIf; |   inherit (lib.modules) mkDefault mkIf; | ||||||
|   inherit (lib.options) literalExample mkEnableOption mkOption; |   inherit (lib.options) literalExample mkEnableOption mkOption; | ||||||
|   inherit (lib.strings) concatStringsSep optionalString toLower; |   inherit (lib.strings) concatStringsSep optionalString toLower; | ||||||
|   inherit (lib.types) addCheck attrsOf lines loaOf nullOr package path port str strMatching submodule; |   inherit (lib.types) addCheck attrsOf lines nullOr package path port str strMatching submodule; | ||||||
| 
 | 
 | ||||||
|   # Checks if given list of strings contains unique |   # Checks if given list of strings contains unique | ||||||
|   # elements when compared without considering case. |   # elements when compared without considering case. | ||||||
| @ -178,7 +178,7 @@ let | |||||||
|       client system-options file "dsm.sys" |       client system-options file "dsm.sys" | ||||||
|     ''; |     ''; | ||||||
|     servers = mkOption { |     servers = mkOption { | ||||||
|       type = loaOf (submodule [ serverOptions ]); |       type = attrsOf (submodule [ serverOptions ]); | ||||||
|       default = {}; |       default = {}; | ||||||
|       example.mainTsmServer = { |       example.mainTsmServer = { | ||||||
|         server = "tsmserver.company.com"; |         server = "tsmserver.company.com"; | ||||||
|  | |||||||
| @ -73,7 +73,7 @@ | |||||||
| <programlisting> | <programlisting> | ||||||
| { pkgs, ... }: | { pkgs, ... }: | ||||||
| { | { | ||||||
|   programs.zsh.ohMyZsh.customPkgs = with pkgs; [ |   programs.zsh.ohMyZsh.customPkgs = [ | ||||||
|     pkgs.nix-zsh-completions |     pkgs.nix-zsh-completions | ||||||
|     # and even more... |     # and even more... | ||||||
|   ]; |   ]; | ||||||
|  | |||||||
| @ -19,6 +19,7 @@ with lib; | |||||||
|     # Completely removed modules |     # Completely removed modules | ||||||
|     (mkRemovedOptionModule [ "fonts" "fontconfig" "penultimate" ] "The corresponding package has removed from nixpkgs.") |     (mkRemovedOptionModule [ "fonts" "fontconfig" "penultimate" ] "The corresponding package has removed from nixpkgs.") | ||||||
|     (mkRemovedOptionModule [ "services" "chronos" ] "The corresponding package was removed from nixpkgs.") |     (mkRemovedOptionModule [ "services" "chronos" ] "The corresponding package was removed from nixpkgs.") | ||||||
|  |     (mkRemovedOptionModule [ "services" "deepin" ] "The corresponding packages were removed from nixpkgs.") | ||||||
|     (mkRemovedOptionModule [ "services" "firefox" "syncserver" "user" ] "") |     (mkRemovedOptionModule [ "services" "firefox" "syncserver" "user" ] "") | ||||||
|     (mkRemovedOptionModule [ "services" "firefox" "syncserver" "group" ] "") |     (mkRemovedOptionModule [ "services" "firefox" "syncserver" "group" ] "") | ||||||
|     (mkRemovedOptionModule [ "services" "marathon" ] "The corresponding package was removed from nixpkgs.") |     (mkRemovedOptionModule [ "services" "marathon" ] "The corresponding package was removed from nixpkgs.") | ||||||
|  | |||||||
| @ -544,7 +544,7 @@ in | |||||||
| 
 | 
 | ||||||
|     security.pam.services = mkOption { |     security.pam.services = mkOption { | ||||||
|       default = []; |       default = []; | ||||||
|       type = with types; loaOf (submodule pamOpts); |       type = with types; attrsOf (submodule pamOpts); | ||||||
|       description = |       description = | ||||||
|         '' |         '' | ||||||
|           This option defines the PAM services.  A service typically |           This option defines the PAM services.  A service typically | ||||||
|  | |||||||
| @ -220,7 +220,7 @@ let | |||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       destinations = mkOption { |       destinations = mkOption { | ||||||
|         type = loaOf (destType config); |         type = attrsOf (destType config); | ||||||
|         description = "Additional destinations."; |         description = "Additional destinations."; | ||||||
|         default = {}; |         default = {}; | ||||||
|         example = literalExample '' |         example = literalExample '' | ||||||
| @ -328,7 +328,7 @@ in | |||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       zetup = mkOption { |       zetup = mkOption { | ||||||
|         type = loaOf srcType; |         type = attrsOf srcType; | ||||||
|         description = "Znapzend configuration."; |         description = "Znapzend configuration."; | ||||||
|         default = {}; |         default = {}; | ||||||
|         example = literalExample '' |         example = literalExample '' | ||||||
|  | |||||||
| @ -160,7 +160,7 @@ in | |||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       appConfig = mkOption { |       appConfig = mkOption { | ||||||
|         type = types.loaOf appConfigModule; |         type = types.attrsOf appConfigModule; | ||||||
|         default = {}; |         default = {}; | ||||||
|         example = literalExample '' |         example = literalExample '' | ||||||
|           "com.github.app" = { |           "com.github.app" = { | ||||||
|  | |||||||
| @ -81,7 +81,7 @@ in | |||||||
|         { office1 = { model = "MFC-7860DW"; ip = "192.168.1.2"; }; |         { office1 = { model = "MFC-7860DW"; ip = "192.168.1.2"; }; | ||||||
|           office2 = { model = "MFC-7860DW"; nodename = "BRW0080927AFBCE"; }; |           office2 = { model = "MFC-7860DW"; nodename = "BRW0080927AFBCE"; }; | ||||||
|         }; |         }; | ||||||
|       type = with types; loaOf (submodule netDeviceOpts); |       type = with types; attrsOf (submodule netDeviceOpts); | ||||||
|       description = '' |       description = '' | ||||||
|         The list of network devices that will be registered against the brscan4 |         The list of network devices that will be registered against the brscan4 | ||||||
|         sane backend. |         sane backend. | ||||||
|  | |||||||
| @ -28,6 +28,12 @@ in | |||||||
|           example = "0.0.0.0"; |           example = "0.0.0.0"; | ||||||
|         }; |         }; | ||||||
|       }; |       }; | ||||||
|  | 
 | ||||||
|  |       openFirewall = mkOption { | ||||||
|  |         type = types.bool; | ||||||
|  |         default = false; | ||||||
|  |         description = "Whether to open ports in the firewall for the server."; | ||||||
|  |       }; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
| @ -35,6 +41,10 @@ in | |||||||
| 
 | 
 | ||||||
|   config = mkIf cfg.enable { |   config = mkIf cfg.enable { | ||||||
| 
 | 
 | ||||||
|  |     networking.firewall = mkIf cfg.openFirewall { | ||||||
|  |       allowedTCPPorts = [ cfg.listen.port ]; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|     environment.systemPackages = [ pkg ]; |     environment.systemPackages = [ pkg ]; | ||||||
| 
 | 
 | ||||||
|     systemd.services.beanstalkd = { |     systemd.services.beanstalkd = { | ||||||
|  | |||||||
| @ -587,16 +587,10 @@ in | |||||||
| 
 | 
 | ||||||
|     nix.systemFeatures = mkDefault ( |     nix.systemFeatures = mkDefault ( | ||||||
|       [ "nixos-test" "benchmark" "big-parallel" "kvm" ] ++ |       [ "nixos-test" "benchmark" "big-parallel" "kvm" ] ++ | ||||||
|       optionals (pkgs.stdenv.isx86_64 && pkgs.hostPlatform.platform ? gcc.arch) ( |       optionals (pkgs.hostPlatform.platform ? gcc.arch) ( | ||||||
|         # a x86_64 builder can run code for `platform.gcc.arch` and minor architectures: |         # a builder can run code for `platform.gcc.arch` and inferior architectures | ||||||
|         [ "gccarch-${pkgs.hostPlatform.platform.gcc.arch}" ] ++ { |         [ "gccarch-${pkgs.hostPlatform.platform.gcc.arch}" ] ++ | ||||||
|           sandybridge    = [ "gccarch-westmere" ]; |         map (x: "gccarch-${x}") lib.systems.architectures.inferiors.${pkgs.hostPlatform.platform.gcc.arch} | ||||||
|           ivybridge      = [ "gccarch-westmere" "gccarch-sandybridge" ]; |  | ||||||
|           haswell        = [ "gccarch-westmere" "gccarch-sandybridge" "gccarch-ivybridge" ]; |  | ||||||
|           broadwell      = [ "gccarch-westmere" "gccarch-sandybridge" "gccarch-ivybridge" "gccarch-haswell" ]; |  | ||||||
|           skylake        = [ "gccarch-westmere" "gccarch-sandybridge" "gccarch-ivybridge" "gccarch-haswell" "gccarch-broadwell" ]; |  | ||||||
|           skylake-avx512 = [ "gccarch-westmere" "gccarch-sandybridge" "gccarch-ivybridge" "gccarch-haswell" "gccarch-broadwell" "gccarch-skylake" ]; |  | ||||||
|         }.${pkgs.hostPlatform.platform.gcc.arch} or [] |  | ||||||
|       ) |       ) | ||||||
|     ); |     ); | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										269
									
								
								nixos/modules/services/networking/biboumi.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										269
									
								
								nixos/modules/services/networking/biboumi.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,269 @@ | |||||||
|  | { config, lib, pkgs, options, ... }: | ||||||
|  | with lib; | ||||||
|  | let | ||||||
|  |   cfg = config.services.biboumi; | ||||||
|  |   inherit (config.environment) etc; | ||||||
|  |   rootDir = "/run/biboumi/mnt-root"; | ||||||
|  |   stateDir = "/var/lib/biboumi"; | ||||||
|  |   settingsFile = pkgs.writeText "biboumi.cfg" ( | ||||||
|  |     generators.toKeyValue { | ||||||
|  |       mkKeyValue = k: v: | ||||||
|  |         if v == null then "" | ||||||
|  |         else generators.mkKeyValueDefault {} "=" k v; | ||||||
|  |     } cfg.settings); | ||||||
|  |   need_CAP_NET_BIND_SERVICE = cfg.settings.identd_port != 0 && cfg.settings.identd_port < 1024; | ||||||
|  | in | ||||||
|  | { | ||||||
|  |   options = { | ||||||
|  |     services.biboumi = { | ||||||
|  |       enable = mkEnableOption "the Biboumi XMPP gateway to IRC"; | ||||||
|  | 
 | ||||||
|  |       settings = mkOption { | ||||||
|  |         description = '' | ||||||
|  |           See <link xlink:href="https://lab.louiz.org/louiz/biboumi/blob/8.5/doc/biboumi.1.rst">biboumi 8.5</link> | ||||||
|  |           for documentation. | ||||||
|  |         ''; | ||||||
|  |         default = {}; | ||||||
|  |         type = types.submodule { | ||||||
|  |           freeformType = with types; | ||||||
|  |             (attrsOf (nullOr (oneOf [str int bool]))) // { | ||||||
|  |               description = "settings option"; | ||||||
|  |             }; | ||||||
|  |           options.admin = mkOption { | ||||||
|  |             type = with types; listOf str; | ||||||
|  |             default = []; | ||||||
|  |             example = ["admin@example.org"]; | ||||||
|  |             apply = concatStringsSep ":"; | ||||||
|  |             description = '' | ||||||
|  |               The bare JID of the gateway administrator. This JID will have more | ||||||
|  |               privileges than other standard users, for example some administration | ||||||
|  |               ad-hoc commands will only be available to that JID. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.ca_file = mkOption { | ||||||
|  |             type = types.path; | ||||||
|  |             default = "/etc/ssl/certs/ca-certificates.crt"; | ||||||
|  |             description = '' | ||||||
|  |               Specifies which file should be used as the list of trusted CA | ||||||
|  |               when negociating a TLS session. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.db_name = mkOption { | ||||||
|  |             type = with types; either path str; | ||||||
|  |             default = "${stateDir}/biboumi.sqlite"; | ||||||
|  |             description = '' | ||||||
|  |               The name of the database to use. | ||||||
|  |             ''; | ||||||
|  |             example = "postgresql://user:secret@localhost"; | ||||||
|  |           }; | ||||||
|  |           options.hostname = mkOption { | ||||||
|  |             type = types.str; | ||||||
|  |             example = "biboumi.example.org"; | ||||||
|  |             description = '' | ||||||
|  |               The hostname served by the XMPP gateway. | ||||||
|  |               This domain must be configured in the XMPP server | ||||||
|  |               as an external component. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.identd_port = mkOption { | ||||||
|  |             type = types.port; | ||||||
|  |             default = 113; | ||||||
|  |             example = 0; | ||||||
|  |             description = '' | ||||||
|  |               The TCP port on which to listen for identd queries. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.log_level = mkOption { | ||||||
|  |             type = types.ints.between 0 3; | ||||||
|  |             default = 1; | ||||||
|  |             description = '' | ||||||
|  |               Indicate what type of log messages to write in the logs. | ||||||
|  |               0 is debug, 1 is info, 2 is warning, 3 is error. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.password = mkOption { | ||||||
|  |             type = with types; nullOr str; | ||||||
|  |             description = '' | ||||||
|  |               The password used to authenticate the XMPP component to your XMPP server. | ||||||
|  |               This password must be configured in the XMPP server, | ||||||
|  |               associated with the external component on | ||||||
|  |               <link linkend="opt-services.biboumi.settings.hostname">hostname</link>. | ||||||
|  | 
 | ||||||
|  |               Set it to null and use <link linkend="opt-services.biboumi.credentialsFile">credentialsFile</link> | ||||||
|  |               if you do not want this password to go into the Nix store. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.persistent_by_default = mkOption { | ||||||
|  |             type = types.bool; | ||||||
|  |             default = false; | ||||||
|  |             description = '' | ||||||
|  |               Whether all rooms will be persistent by default: | ||||||
|  |               the value of the “persistent” option in the global configuration of each | ||||||
|  |               user will be “true”, but the value of each individual room will still | ||||||
|  |               default to false. This means that a user just needs to change the global | ||||||
|  |               “persistent” configuration option to false in order to override this. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.policy_directory = mkOption { | ||||||
|  |             type = types.path; | ||||||
|  |             default = "${pkgs.biboumi}/etc/biboumi"; | ||||||
|  |             description = '' | ||||||
|  |               A directory that should contain the policy files, | ||||||
|  |               used to customize Botan’s behaviour | ||||||
|  |               when negociating the TLS connections with the IRC servers. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.port = mkOption { | ||||||
|  |             type = types.port; | ||||||
|  |             default = 5347; | ||||||
|  |             description = '' | ||||||
|  |               The TCP port to use to connect to the local XMPP component. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.realname_customization = mkOption { | ||||||
|  |             type = types.bool; | ||||||
|  |             default = true; | ||||||
|  |             description = '' | ||||||
|  |               Whether the users will be able to use | ||||||
|  |               the ad-hoc commands that lets them configure | ||||||
|  |               their realname and username. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.realname_from_jid = mkOption { | ||||||
|  |             type = types.bool; | ||||||
|  |             default = false; | ||||||
|  |             description = '' | ||||||
|  |               Whether the realname and username of each biboumi | ||||||
|  |               user will be extracted from their JID. | ||||||
|  |               Otherwise they will be set to the nick | ||||||
|  |               they used to connect to the IRC server. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |           options.xmpp_server_ip = mkOption { | ||||||
|  |             type = types.str; | ||||||
|  |             default = "127.0.0.1"; | ||||||
|  |             description = '' | ||||||
|  |               The IP address to connect to the XMPP server on. | ||||||
|  |               The connection to the XMPP server is unencrypted, | ||||||
|  |               so the biboumi instance and the server should | ||||||
|  |               normally be on the same host. | ||||||
|  |             ''; | ||||||
|  |           }; | ||||||
|  |         }; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       credentialsFile = mkOption { | ||||||
|  |         type = types.path; | ||||||
|  |         description = '' | ||||||
|  |           Path to a configuration file to be merged with the settings. | ||||||
|  |           Beware not to surround "=" with spaces when setting biboumi's options in this file. | ||||||
|  |           Useful to merge a file which is better kept out of the Nix store | ||||||
|  |           because it contains sensible data like | ||||||
|  |           <link linkend="opt-services.biboumi.settings.password">password</link>. | ||||||
|  |         ''; | ||||||
|  |         default = "/dev/null"; | ||||||
|  |         example = "/run/keys/biboumi.cfg"; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       openFirewall = mkEnableOption "opening of the identd port in the firewall"; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   config = mkIf cfg.enable { | ||||||
|  |     networking.firewall = mkIf (cfg.openFirewall && cfg.settings.identd_port != 0) | ||||||
|  |       { allowedTCPPorts = [ cfg.settings.identd_port ]; }; | ||||||
|  | 
 | ||||||
|  |     systemd.services.biboumi = { | ||||||
|  |       description = "Biboumi, XMPP to IRC gateway"; | ||||||
|  |       after = [ "network.target" ]; | ||||||
|  |       wantedBy = [ "multi-user.target" ]; | ||||||
|  | 
 | ||||||
|  |       serviceConfig = { | ||||||
|  |         Type = "notify"; | ||||||
|  |         # Biboumi supports systemd's watchdog. | ||||||
|  |         WatchdogSec = 20; | ||||||
|  |         Restart = "always"; | ||||||
|  |         # Use "+" because credentialsFile may not be accessible to User= or Group=. | ||||||
|  |         ExecStartPre = [("+" + pkgs.writeShellScript "biboumi-prestart" '' | ||||||
|  |           set -eux | ||||||
|  |           cat ${settingsFile} '${cfg.credentialsFile}' | | ||||||
|  |           install -m 644 /dev/stdin /run/biboumi/biboumi.cfg | ||||||
|  |         '')]; | ||||||
|  |         ExecStart = "${pkgs.biboumi}/bin/biboumi /run/biboumi/biboumi.cfg"; | ||||||
|  |         ExecReload = "${pkgs.coreutils}/bin/kill -USR1 $MAINPID"; | ||||||
|  |         # Firewalls needing opening for output connections can still do that | ||||||
|  |         # selectively for biboumi with: | ||||||
|  |         # users.users.biboumi.isSystemUser = true; | ||||||
|  |         # and, for example: | ||||||
|  |         # networking.nftables.ruleset = '' | ||||||
|  |         #   add rule inet filter output meta skuid biboumi tcp accept | ||||||
|  |         # ''; | ||||||
|  |         DynamicUser = true; | ||||||
|  |         RootDirectory = rootDir; | ||||||
|  |         RootDirectoryStartOnly = true; | ||||||
|  |         InaccessiblePaths = [ "-+${rootDir}" ]; | ||||||
|  |         RuntimeDirectory = [ "biboumi" (removePrefix "/run/" rootDir) ]; | ||||||
|  |         RuntimeDirectoryMode = "700"; | ||||||
|  |         StateDirectory = "biboumi"; | ||||||
|  |         StateDirectoryMode = "700"; | ||||||
|  |         MountAPIVFS = true; | ||||||
|  |         UMask = "0066"; | ||||||
|  |         BindPaths = [ | ||||||
|  |           stateDir | ||||||
|  |           # This is for Type="notify" | ||||||
|  |           # See https://github.com/systemd/systemd/issues/3544 | ||||||
|  |           "/run/systemd/notify" | ||||||
|  |           "/run/systemd/journal/socket" | ||||||
|  |         ]; | ||||||
|  |         BindReadOnlyPaths = [ | ||||||
|  |           builtins.storeDir | ||||||
|  |           "/etc" | ||||||
|  |         ]; | ||||||
|  |         # The following options are only for optimizing: | ||||||
|  |         # systemd-analyze security biboumi | ||||||
|  |         AmbientCapabilities = [ (optionalString need_CAP_NET_BIND_SERVICE "CAP_NET_BIND_SERVICE") ]; | ||||||
|  |         CapabilityBoundingSet = [ (optionalString need_CAP_NET_BIND_SERVICE "CAP_NET_BIND_SERVICE") ]; | ||||||
|  |         # ProtectClock= adds DeviceAllow=char-rtc r | ||||||
|  |         DeviceAllow = ""; | ||||||
|  |         LockPersonality = true; | ||||||
|  |         MemoryDenyWriteExecute = true; | ||||||
|  |         NoNewPrivileges = true; | ||||||
|  |         PrivateDevices = true; | ||||||
|  |         PrivateMounts = true; | ||||||
|  |         PrivateNetwork = mkDefault false; | ||||||
|  |         PrivateTmp = true; | ||||||
|  |         # PrivateUsers=true breaks AmbientCapabilities=CAP_NET_BIND_SERVICE | ||||||
|  |         # See https://bugs.archlinux.org/task/65921 | ||||||
|  |         PrivateUsers = !need_CAP_NET_BIND_SERVICE; | ||||||
|  |         ProtectClock = true; | ||||||
|  |         ProtectControlGroups = true; | ||||||
|  |         ProtectHome = true; | ||||||
|  |         ProtectHostname = true; | ||||||
|  |         ProtectKernelLogs = true; | ||||||
|  |         ProtectKernelModules = true; | ||||||
|  |         ProtectKernelTunables = true; | ||||||
|  |         ProtectSystem = "strict"; | ||||||
|  |         RemoveIPC = true; | ||||||
|  |         # AF_UNIX is for /run/systemd/notify | ||||||
|  |         RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" ]; | ||||||
|  |         RestrictNamespaces = true; | ||||||
|  |         RestrictRealtime = true; | ||||||
|  |         RestrictSUIDSGID = true; | ||||||
|  |         SystemCallFilter = [ | ||||||
|  |           "@system-service" | ||||||
|  |           # Groups in @system-service which do not contain a syscall | ||||||
|  |           # listed by perf stat -e 'syscalls:sys_enter_*' biboumi biboumi.cfg | ||||||
|  |           # in tests, and seem likely not necessary for biboumi. | ||||||
|  |           # To run such a perf in ExecStart=, you have to: | ||||||
|  |           # - AmbientCapabilities="CAP_SYS_ADMIN" | ||||||
|  |           # - mount -o remount,mode=755 /sys/kernel/debug/{,tracing} | ||||||
|  |           "~@aio" "~@chown" "~@ipc" "~@keyring" "~@resources" "~@setuid" "~@timer" | ||||||
|  |         ]; | ||||||
|  |         SystemCallArchitectures = "native"; | ||||||
|  |         SystemCallErrorNumber = "EPERM"; | ||||||
|  |       }; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   meta.maintainers = with maintainers; [ julm ]; | ||||||
|  | } | ||||||
| @ -3,7 +3,7 @@ | |||||||
| let | let | ||||||
| 
 | 
 | ||||||
|   inherit (lib.options) literalExample mkEnableOption mkOption; |   inherit (lib.options) literalExample mkEnableOption mkOption; | ||||||
|   inherit (lib.types) bool enum int lines loaOf nullOr path str submodule; |   inherit (lib.types) bool enum int lines attrsOf nullOr path str submodule; | ||||||
|   inherit (lib.modules) mkDefault mkIf mkMerge; |   inherit (lib.modules) mkDefault mkIf mkMerge; | ||||||
| 
 | 
 | ||||||
|   commonDescr = '' |   commonDescr = '' | ||||||
| @ -248,7 +248,7 @@ in | |||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     modems = mkOption { |     modems = mkOption { | ||||||
|       type = loaOf (submodule [ modemConfigOptions ]); |       type = attrsOf (submodule [ modemConfigOptions ]); | ||||||
|       default = {}; |       default = {}; | ||||||
|       example.ttyS1 = { |       example.ttyS1 = { | ||||||
|         type = "cirrus"; |         type = "cirrus"; | ||||||
|  | |||||||
| @ -140,7 +140,7 @@ in | |||||||
|     services.nylon = mkOption { |     services.nylon = mkOption { | ||||||
|       default = {}; |       default = {}; | ||||||
|       description = "Collection of named nylon instances"; |       description = "Collection of named nylon instances"; | ||||||
|       type = with types; loaOf (submodule nylonOpts); |       type = with types; attrsOf (submodule nylonOpts); | ||||||
|       internal = true; |       internal = true; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -655,7 +655,7 @@ in | |||||||
| 
 | 
 | ||||||
|         description = "Define the virtual hosts"; |         description = "Define the virtual hosts"; | ||||||
| 
 | 
 | ||||||
|         type = with types; loaOf (submodule vHostOpts); |         type = with types; attrsOf (submodule vHostOpts); | ||||||
| 
 | 
 | ||||||
|         example = { |         example = { | ||||||
|           myhost = { |           myhost = { | ||||||
|  | |||||||
| @ -43,10 +43,10 @@ services.prosody = { | |||||||
|   <link linkend="opt-services.prosody.ssl.cert">ssl.cert</link> = "/var/lib/acme/example.org/fullchain.pem"; |   <link linkend="opt-services.prosody.ssl.cert">ssl.cert</link> = "/var/lib/acme/example.org/fullchain.pem"; | ||||||
|   <link linkend="opt-services.prosody.ssl.key">ssl.key</link> = "/var/lib/acme/example.org/key.pem"; |   <link linkend="opt-services.prosody.ssl.key">ssl.key</link> = "/var/lib/acme/example.org/key.pem"; | ||||||
|   <link linkend="opt-services.prosody.virtualHosts">virtualHosts</link>."example.org" = { |   <link linkend="opt-services.prosody.virtualHosts">virtualHosts</link>."example.org" = { | ||||||
|       <link linkend="opt-services.prosody.virtualHosts._name__.enabled">enabled</link> = true; |       <link linkend="opt-services.prosody.virtualHosts._name_.enabled">enabled</link> = true; | ||||||
|       <link linkend="opt-services.prosody.virtualHosts._name__.domain">domain</link> = "example.org"; |       <link linkend="opt-services.prosody.virtualHosts._name_.domain">domain</link> = "example.org"; | ||||||
|       <link linkend="opt-services.prosody.virtualHosts._name__.ssl.cert">ssl.cert</link> = "/var/lib/acme/example.org/fullchain.pem"; |       <link linkend="opt-services.prosody.virtualHosts._name_.ssl.cert">ssl.cert</link> = "/var/lib/acme/example.org/fullchain.pem"; | ||||||
|       <link linkend="opt-services.prosody.virtualHosts._name__.ssl.key">ssl.key</link> = "/var/lib/acme/example.org/key.pem"; |       <link linkend="opt-services.prosody.virtualHosts._name_.ssl.key">ssl.key</link> = "/var/lib/acme/example.org/key.pem"; | ||||||
|   }; |   }; | ||||||
|   <link linkend="opt-services.prosody.muc">muc</link> = [ { |   <link linkend="opt-services.prosody.muc">muc</link> = [ { | ||||||
|       <link linkend="opt-services.prosody.muc">domain</link> = "conference.example.org"; |       <link linkend="opt-services.prosody.muc">domain</link> = "conference.example.org"; | ||||||
|  | |||||||
| @ -361,7 +361,7 @@ in | |||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     users.users = mkOption { |     users.users = mkOption { | ||||||
|       type = with types; loaOf (submodule userOptions); |       type = with types; attrsOf (submodule userOptions); | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|   }; |   }; | ||||||
|  | |||||||
| @ -607,7 +607,7 @@ in | |||||||
|             ]; |             ]; | ||||||
|           } |           } | ||||||
|         ''; |         ''; | ||||||
|         type = types.loaOf (types.submodule ({name, ...}: { |         type = types.attrsOf (types.submodule ({name, ...}: { | ||||||
|           options = { |           options = { | ||||||
| 
 | 
 | ||||||
|              name = mkOption { |              name = mkOption { | ||||||
|  | |||||||
| @ -516,7 +516,7 @@ in | |||||||
|         <filename>/dev/mapper/<replaceable>name</replaceable></filename>. |         <filename>/dev/mapper/<replaceable>name</replaceable></filename>. | ||||||
|       ''; |       ''; | ||||||
| 
 | 
 | ||||||
|       type = with types; loaOf (submodule ( |       type = with types; attrsOf (submodule ( | ||||||
|         { name, ... }: { options = { |         { name, ... }: { options = { | ||||||
| 
 | 
 | ||||||
|           name = mkOption { |           name = mkOption { | ||||||
|  | |||||||
| @ -558,7 +558,7 @@ in | |||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|     fileSystems = mkOption { |     fileSystems = mkOption { | ||||||
|       type = with lib.types; loaOf (submodule { |       type = with lib.types; attrsOf (submodule { | ||||||
|         options.neededForBoot = mkOption { |         options.neededForBoot = mkOption { | ||||||
|           default = false; |           default = false; | ||||||
|           type = types.bool; |           type = types.bool; | ||||||
|  | |||||||
| @ -1006,7 +1006,7 @@ in | |||||||
|       "sysctl.d/50-coredump.conf".source = "${systemd}/example/sysctl.d/50-coredump.conf"; |       "sysctl.d/50-coredump.conf".source = "${systemd}/example/sysctl.d/50-coredump.conf"; | ||||||
|       "sysctl.d/50-default.conf".source = "${systemd}/example/sysctl.d/50-default.conf"; |       "sysctl.d/50-default.conf".source = "${systemd}/example/sysctl.d/50-default.conf"; | ||||||
| 
 | 
 | ||||||
|       "tmpfiles.d".source = pkgs.symlinkJoin { |       "tmpfiles.d".source = (pkgs.symlinkJoin { | ||||||
|         name = "tmpfiles.d"; |         name = "tmpfiles.d"; | ||||||
|         paths = map (p: p + "/lib/tmpfiles.d") cfg.tmpfiles.packages; |         paths = map (p: p + "/lib/tmpfiles.d") cfg.tmpfiles.packages; | ||||||
|         postBuild = '' |         postBuild = '' | ||||||
| @ -1016,8 +1016,10 @@ in | |||||||
|               exit 1 |               exit 1 | ||||||
|             ) |             ) | ||||||
|           done |           done | ||||||
|         ''; |         '' + concatMapStrings (name: optionalString (hasPrefix "tmpfiles.d/" name) '' | ||||||
|       }; |           rm -f $out/${removePrefix "tmpfiles.d/" name} | ||||||
|  |         '') config.system.build.etc.targets; | ||||||
|  |       }) + "/*"; | ||||||
| 
 | 
 | ||||||
|       "systemd/system-generators" = { source = hooks "generators" cfg.generators; }; |       "systemd/system-generators" = { source = hooks "generators" cfg.generators; }; | ||||||
|       "systemd/system-shutdown" = { source = hooks "shutdown" cfg.shutdown; }; |       "systemd/system-shutdown" = { source = hooks "shutdown" cfg.shutdown; }; | ||||||
|  | |||||||
| @ -46,7 +46,7 @@ in | |||||||
|         Set of files that have to be linked in <filename>/etc</filename>. |         Set of files that have to be linked in <filename>/etc</filename>. | ||||||
|       ''; |       ''; | ||||||
| 
 | 
 | ||||||
|       type = with types; loaOf (submodule ( |       type = with types; attrsOf (submodule ( | ||||||
|         { name, config, ... }: |         { name, config, ... }: | ||||||
|         { options = { |         { options = { | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -54,7 +54,7 @@ in | |||||||
| 
 | 
 | ||||||
|   options = { |   options = { | ||||||
|     fileSystems = mkOption { |     fileSystems = mkOption { | ||||||
|       type = with lib.types; loaOf (submodule encryptedFSOptions); |       type = with lib.types; attrsOf (submodule encryptedFSOptions); | ||||||
|     }; |     }; | ||||||
|     swapDevices = mkOption { |     swapDevices = mkOption { | ||||||
|       type = with lib.types; listOf (submodule encryptedFSOptions); |       type = with lib.types; listOf (submodule encryptedFSOptions); | ||||||
|  | |||||||
| @ -159,7 +159,7 @@ in | |||||||
|           "/bigdisk".label = "bigdisk"; |           "/bigdisk".label = "bigdisk"; | ||||||
|         } |         } | ||||||
|       ''; |       ''; | ||||||
|       type = types.loaOf (types.submodule [coreFileSystemOpts fileSystemOpts]); |       type = types.attrsOf (types.submodule [coreFileSystemOpts fileSystemOpts]); | ||||||
|       description = '' |       description = '' | ||||||
|         The file systems to be mounted.  It must include an entry for |         The file systems to be mounted.  It must include an entry for | ||||||
|         the root directory (<literal>mountPoint = "/"</literal>).  Each |         the root directory (<literal>mountPoint = "/"</literal>).  Each | ||||||
| @ -193,7 +193,7 @@ in | |||||||
| 
 | 
 | ||||||
|     boot.specialFileSystems = mkOption { |     boot.specialFileSystems = mkOption { | ||||||
|       default = {}; |       default = {}; | ||||||
|       type = types.loaOf (types.submodule coreFileSystemOpts); |       type = types.attrsOf (types.submodule coreFileSystemOpts); | ||||||
|       internal = true; |       internal = true; | ||||||
|       description = '' |       description = '' | ||||||
|         Special filesystems that are mounted very early during boot. |         Special filesystems that are mounted very early during boot. | ||||||
|  | |||||||
| @ -519,7 +519,7 @@ in | |||||||
|         <option>networking.useDHCP</option> is true, then every |         <option>networking.useDHCP</option> is true, then every | ||||||
|         interface not listed here will be configured using DHCP. |         interface not listed here will be configured using DHCP. | ||||||
|       ''; |       ''; | ||||||
|       type = with types; loaOf (submodule interfaceOpts); |       type = with types; attrsOf (submodule interfaceOpts); | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     networking.vswitches = mkOption { |     networking.vswitches = mkOption { | ||||||
| @ -544,7 +544,7 @@ in | |||||||
|           interfaces = mkOption { |           interfaces = mkOption { | ||||||
|             example = [ "eth0" "eth1" ]; |             example = [ "eth0" "eth1" ]; | ||||||
|             description = "The physical network interfaces connected by the vSwitch."; |             description = "The physical network interfaces connected by the vSwitch."; | ||||||
|             type = with types; loaOf (submodule vswitchInterfaceOpts); |             type = with types; attrsOf (submodule vswitchInterfaceOpts); | ||||||
|           }; |           }; | ||||||
| 
 | 
 | ||||||
|           controllers = mkOption { |           controllers = mkOption { | ||||||
|  | |||||||
| @ -43,6 +43,12 @@ in | |||||||
|         ''; |         ''; | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|  |     ociSeccompBpfHook.enable = mkOption { | ||||||
|  |       type = types.bool; | ||||||
|  |       default = false; | ||||||
|  |       description = "Enable the OCI seccomp BPF hook"; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|     containersConf = mkOption { |     containersConf = mkOption { | ||||||
|       default = {}; |       default = {}; | ||||||
|       description = "containers.conf configuration"; |       description = "containers.conf configuration"; | ||||||
| @ -116,6 +122,12 @@ in | |||||||
|       [network] |       [network] | ||||||
|       cni_plugin_dirs = ["${pkgs.cni-plugins}/bin/"] |       cni_plugin_dirs = ["${pkgs.cni-plugins}/bin/"] | ||||||
| 
 | 
 | ||||||
|  |       ${lib.optionalString (cfg.ociSeccompBpfHook.enable == true) '' | ||||||
|  |       [engine] | ||||||
|  |       hooks_dir = [ | ||||||
|  |         "${config.boot.kernelPackages.oci-seccomp-bpf-hook}", | ||||||
|  |       ] | ||||||
|  |       ''} | ||||||
|     '' + cfg.containersConf.extraConfig; |     '' + cfg.containersConf.extraConfig; | ||||||
| 
 | 
 | ||||||
|     environment.etc."containers/registries.conf".source = toTOML "registries.conf" { |     environment.etc."containers/registries.conf".source = toTOML "registries.conf" { | ||||||
|  | |||||||
| @ -101,6 +101,7 @@ in | |||||||
|       log_level = "${cfg.logLevel}" |       log_level = "${cfg.logLevel}" | ||||||
|       manage_ns_lifecycle = true |       manage_ns_lifecycle = true | ||||||
|       pinns_path = "${cfg.package}/bin/pinns" |       pinns_path = "${cfg.package}/bin/pinns" | ||||||
|  |       hooks_dir = [] | ||||||
| 
 | 
 | ||||||
|       ${optionalString (cfg.runtime != null) '' |       ${optionalString (cfg.runtime != null) '' | ||||||
|       default_runtime = "${cfg.runtime}" |       default_runtime = "${cfg.runtime}" | ||||||
|  | |||||||
| @ -627,7 +627,7 @@ in | |||||||
| 		    }; | 		    }; | ||||||
| 
 | 
 | ||||||
|             bindMounts = mkOption { |             bindMounts = mkOption { | ||||||
|               type = with types; loaOf (submodule bindMountOpts); |               type = with types; attrsOf (submodule bindMountOpts); | ||||||
|               default = {}; |               default = {}; | ||||||
|               example = literalExample '' |               example = literalExample '' | ||||||
|                 { "/home" = { hostPath = "/home/alice"; |                 { "/home" = { hostPath = "/home/alice"; | ||||||
|  | |||||||
| @ -41,7 +41,7 @@ let | |||||||
|         description = "Source for the in-container mount"; |         description = "Source for the in-container mount"; | ||||||
|       }; |       }; | ||||||
|       options = mkOption { |       options = mkOption { | ||||||
|         type = loaOf (str); |         type = attrsOf (str); | ||||||
|         default = [ "bind" ]; |         default = [ "bind" ]; | ||||||
|         description = '' |         description = '' | ||||||
|           Mount options of the filesystem to be used. |           Mount options of the filesystem to be used. | ||||||
| @ -61,7 +61,7 @@ in | |||||||
|     containers = mkOption { |     containers = mkOption { | ||||||
|       default = {}; |       default = {}; | ||||||
|       description = "Declarative container configuration"; |       description = "Declarative container configuration"; | ||||||
|       type = with types; loaOf (submodule ({ name, config, ... }: { |       type = with types; attrsOf (submodule ({ name, config, ... }: { | ||||||
|         options = { |         options = { | ||||||
|           cmd = mkOption { |           cmd = mkOption { | ||||||
|             type = types.lines; |             type = types.lines; | ||||||
|  | |||||||
| @ -18,7 +18,10 @@ import ../make-test-python.nix ({ pkgs, ...} : { | |||||||
|         realms = { |         realms = { | ||||||
|           "ATHENA.MIT.EDU" = { |           "ATHENA.MIT.EDU" = { | ||||||
|             admin_server = "athena.mit.edu"; |             admin_server = "athena.mit.edu"; | ||||||
|             kdc = "athena.mit.edu"; |             kdc = [ | ||||||
|  |               "athena01.mit.edu" | ||||||
|  |               "athena02.mit.edu" | ||||||
|  |             ]; | ||||||
|           }; |           }; | ||||||
|         }; |         }; | ||||||
|         domain_realm = { |         domain_realm = { | ||||||
| @ -65,7 +68,8 @@ import ../make-test-python.nix ({ pkgs, ...} : { | |||||||
|       [realms] |       [realms] | ||||||
|         ATHENA.MIT.EDU = { |         ATHENA.MIT.EDU = { | ||||||
|           admin_server = athena.mit.edu |           admin_server = athena.mit.edu | ||||||
|           kdc = athena.mit.edu |           kdc = athena01.mit.edu | ||||||
|  |           kdc = athena02.mit.edu | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|       [domain_realm] |       [domain_realm] | ||||||
|  | |||||||
| @ -2,13 +2,13 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "bchoppr"; |   pname = "bchoppr"; | ||||||
|   version = "1.6.4"; |   version = "1.8.0"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "sjaehn"; |     owner = "sjaehn"; | ||||||
|     repo = pname; |     repo = pname; | ||||||
|     rev = "${version}"; |     rev = "${version}"; | ||||||
|     sha256 = "16b0sg7q2b8l4y4bp5s3yzsj9j6jayjy2mlvqkby6l7hcgjcj493"; |     sha256 = "1nd6byy75f0rbz9dm9drhxmpsfhxhg0y7q3v2m3098llynhy9k2j"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ pkg-config ]; |   nativeBuildInputs = [ pkg-config ]; | ||||||
|  | |||||||
| @ -2,13 +2,13 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "BJumblr"; |   pname = "BJumblr"; | ||||||
|   version = "1.4.0"; |   version = "1.4.2"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "sjaehn"; |     owner = "sjaehn"; | ||||||
|     repo = pname; |     repo = pname; | ||||||
|     rev = version; |     rev = version; | ||||||
|     sha256 = "03x1gvri9yk000fvvc8zvvywf38cc41vkyhhp9xby71b23n5wbn0"; |     sha256 = "0kl6hrxmqrdf0195bfnzsa2h1073fgiqrfhg2276fm1954sm994v"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ pkgconfig ]; |   nativeBuildInputs = [ pkgconfig ]; | ||||||
|  | |||||||
| @ -2,13 +2,13 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "bschaffl"; |   pname = "bschaffl"; | ||||||
|   version = "0.3"; |   version = "1.2.0"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "sjaehn"; |     owner = "sjaehn"; | ||||||
|     repo = pname; |     repo = pname; | ||||||
|     rev = version; |     rev = version; | ||||||
|     sha256 = "1pcch7j1wgsb77mjy58hl3z43p83dv0vcmyh129m9k216b09gy29"; |     sha256 = "1c09acqrbd387ba41f8ch1qykdap5h6cg9if5pgd16i4dmjnpghj"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ pkg-config ]; |   nativeBuildInputs = [ pkg-config ]; | ||||||
|  | |||||||
| @ -2,13 +2,13 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "dragonfly-reverb"; |   pname = "dragonfly-reverb"; | ||||||
|   version = "3.1.1"; |   version = "3.2.1"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "michaelwillis"; |     owner = "michaelwillis"; | ||||||
|     repo = "dragonfly-reverb"; |     repo = "dragonfly-reverb"; | ||||||
|     rev = version; |     rev = version; | ||||||
|     sha256 = "188cm45hr0i33m4h2irql1wrsmsfis65s706wjiid0z59q47rf9p"; |     sha256 = "0vfm2510shah67k87mdyar4wr4vqwii59y9lqfhwm6blxparkrqa"; | ||||||
|     fetchSubmodules = true; |     fetchSubmodules = true; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2,20 +2,21 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "geonkick"; |   pname = "geonkick"; | ||||||
|   version = "2.3.3"; |   version = "2.3.7"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitLab { |   src = fetchFromGitLab { | ||||||
|     owner = "iurie-sw"; |     owner = "iurie-sw"; | ||||||
|     repo = pname; |     repo = pname; | ||||||
|     rev = "v${version}"; |     rev = "v${version}"; | ||||||
|     sha256 = "0h1abb6q2bmi01a3v37adkc4zc03j47jpvffz8p2lpp33xhljghs"; |     sha256 = "1wdcbwiyy6i5agq5lffkyilyc8mv1cc4mp9h0nybn240vb2flqc2"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ cmake pkg-config ]; |   nativeBuildInputs = [ cmake pkg-config ]; | ||||||
| 
 | 
 | ||||||
|   buildInputs = [ redkite libsndfile rapidjson libjack2 lv2 libX11 cairo ]; |   buildInputs = [ redkite libsndfile rapidjson libjack2 lv2 libX11 cairo ]; | ||||||
| 
 | 
 | ||||||
|   cmakeFlags = [ "-DGKICK_REDKITE_SDK_PATH=${redkite}" ]; |   # https://github.com/iurie-sw/geonkick/issues/120 | ||||||
|  |   cmakeFlags = [ "-DGKICK_REDKITE_SDK_PATH=${redkite}" "-DCMAKE_INSTALL_LIBDIR=lib" ]; | ||||||
| 
 | 
 | ||||||
|   meta = { |   meta = { | ||||||
|     homepage = "https://gitlab.com/iurie-sw/geonkick"; |     homepage = "https://gitlab.com/iurie-sw/geonkick"; | ||||||
|  | |||||||
| @ -14,16 +14,16 @@ let | |||||||
| in | in | ||||||
| rustPlatform.buildRustPackage rec { | rustPlatform.buildRustPackage rec { | ||||||
|   pname = "ncspot"; |   pname = "ncspot"; | ||||||
|   version = "0.2.1"; |   version = "0.2.2"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "hrkfdn"; |     owner = "hrkfdn"; | ||||||
|     repo = "ncspot"; |     repo = "ncspot"; | ||||||
|     rev = "v${version}"; |     rev = "v${version}"; | ||||||
|     sha256 = "1yx0fc24bgh1x6fdwznc1hqvjq0j7i0zvws3bsyijzs7q48jm0z7"; |     sha256 = "1i17pidw2hylijwfn96f2bnswfxxwdln2ydsq8b1q4hfzfbxlfk2"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   cargoSha256 = "0bh2shg80xbs2cw10dabrdxkvhf2csk5h9wmmk5z87q6w25paz1f"; |   cargoSha256 = "1cpy4wrj9dz2crva4p18f8hzym73x4m2mcfds4ppri4ir7qg29dr"; | ||||||
| 
 | 
 | ||||||
|   cargoBuildFlags = [ "--no-default-features" "--features" "${lib.concatStringsSep "," features}" ]; |   cargoBuildFlags = [ "--no-default-features" "--features" "${lib.concatStringsSep "," features}" ]; | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										48
									
								
								pkgs/applications/audio/surge/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								pkgs/applications/audio/surge/default.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,48 @@ | |||||||
|  | { stdenv, fetchFromGitHub, cmake, git, pkg-config, python3 | ||||||
|  | , cairo, libsndfile, libxcb, libxkbcommon, xcbutil, xcbutilcursor, xcbutilkeysyms, zenity | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | stdenv.mkDerivation rec { | ||||||
|  |   pname = "surge"; | ||||||
|  |   version = "1.7.1"; | ||||||
|  | 
 | ||||||
|  |   src = fetchFromGitHub { | ||||||
|  |     owner = "surge-synthesizer"; | ||||||
|  |     repo = pname; | ||||||
|  |     rev = "release_${version}"; | ||||||
|  |     sha256 = "1b3ccc78vrpzy18w7070zfa250dnd1bww147xxcnj457vd6n065s"; | ||||||
|  |     leaveDotGit = true; # for SURGE_VERSION | ||||||
|  |     fetchSubmodules = true; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   nativeBuildInputs = [ cmake git pkg-config python3 ]; | ||||||
|  |   buildInputs = [ cairo libsndfile libxcb libxkbcommon xcbutil xcbutilcursor xcbutilkeysyms zenity ]; | ||||||
|  | 
 | ||||||
|  |   postPatch = '' | ||||||
|  |     substituteInPlace src/common/SurgeStorage.cpp --replace "/usr/share/Surge" "$out/share/surge" | ||||||
|  |     substituteInPlace src/common/gui/PopupEditorDialog.cpp --replace '"zenity' '"${zenity}/bin/zenity' | ||||||
|  |     substituteInPlace src/linux/UserInteractionsLinux.cpp --replace '"zenity' '"${zenity}/bin/zenity' | ||||||
|  |     substituteInPlace vstgui.surge/vstgui/lib/platform/linux/x11fileselector.cpp --replace /usr/bin/zenity ${zenity}/bin/zenity | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   installPhase = '' | ||||||
|  |     mkdir -p $out/lib/lv2 $out/lib/vst3 $out/share/surge | ||||||
|  |     cp -r surge_products/Surge.lv2 $out/lib/lv2/ | ||||||
|  |     cp -r surge_products/Surge.vst3 $out/lib/vst3/ | ||||||
|  |     cp -r ../resources/data/* $out/share/surge/ | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   doInstallCheck = true; | ||||||
|  |   installCheckPhase = '' | ||||||
|  |     cd .. | ||||||
|  |     build/surge-headless | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   meta = with stdenv.lib; { | ||||||
|  |     description = "LV2 & VST3 synthesizer plug-in (previously released as Vember Audio Surge)"; | ||||||
|  |     homepage = "https://surge-synthesizer.github.io"; | ||||||
|  |     license = licenses.gpl3; | ||||||
|  |     platforms = [ "x86_64-linux" ]; | ||||||
|  |     maintainers = with maintainers; [ magnetophon orivej ]; | ||||||
|  |   }; | ||||||
|  | } | ||||||
							
								
								
									
										43
									
								
								pkgs/applications/audio/tunefish/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								pkgs/applications/audio/tunefish/default.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,43 @@ | |||||||
|  | { stdenv, fetchFromGitHub, pkg-config, python3 | ||||||
|  | , alsaLib, curl, freetype, gtk3, libGL, libX11, libXext, libXinerama, webkitgtk | ||||||
|  | }: | ||||||
|  | 
 | ||||||
|  | stdenv.mkDerivation { | ||||||
|  |   pname = "tunefish"; | ||||||
|  |   version = "unstable-2020-08-13"; | ||||||
|  | 
 | ||||||
|  |   src = fetchFromGitHub { | ||||||
|  |     owner = "jpcima"; | ||||||
|  |     repo = "tunefish"; | ||||||
|  |     rev = "b3d83cc66201619f6399500f6897fbeb1786d9ed"; | ||||||
|  |     fetchSubmodules = true; | ||||||
|  |     sha256 = "0rjpq3s609fblzkvnc9729glcnfinmxljh0z8ldpzr245h367zxh"; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   nativeBuildInputs = [ pkg-config python3 ]; | ||||||
|  |   buildInputs = [ alsaLib curl freetype gtk3 libGL libX11 libXext libXinerama webkitgtk ]; | ||||||
|  | 
 | ||||||
|  |   postPatch = '' | ||||||
|  |     patchShebangs src/tunefish4/generate-lv2-ttl.py | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   makeFlags = [ | ||||||
|  |     "-C" "src/tunefish4/Builds/LinuxMakefile" | ||||||
|  |     "CONFIG=Release" | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|  |   installPhase = '' | ||||||
|  |     mkdir -p $out/lib/lv2 | ||||||
|  |     cp -r src/tunefish4/Builds/LinuxMakefile/build/Tunefish4.lv2 $out/lib/lv2 | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   enableParallelBuilding = true; | ||||||
|  | 
 | ||||||
|  |   meta = with stdenv.lib; { | ||||||
|  |     homepage = "https://tunefish-synth.com/"; | ||||||
|  |     description = "Virtual analog synthesizer LV2 plugin"; | ||||||
|  |     license = licenses.gpl3Plus; | ||||||
|  |     maintainers = with maintainers; [ orivej ]; | ||||||
|  |     platforms = [ "x86_64-linux" ]; | ||||||
|  |   }; | ||||||
|  | } | ||||||
| @ -4,16 +4,16 @@ | |||||||
| 
 | 
 | ||||||
| buildGoModule rec { | buildGoModule rec { | ||||||
|   pname = "lnd"; |   pname = "lnd"; | ||||||
|   version = "0.10.3-beta"; |   version = "0.11.0-beta"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "lightningnetwork"; |     owner = "lightningnetwork"; | ||||||
|     repo = "lnd"; |     repo = "lnd"; | ||||||
|     rev = "v${version}"; |     rev = "v${version}"; | ||||||
|     sha256 = "129vi8z2sk4hagk7axa675nba6sbj9km88zlq8a1g8di7v2k9z6a"; |     sha256 = "1r1hwz8ka5mnmrvj9zcd78kn68g8fg3d4bdx9i0xy4sc2hh1dcpj"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   vendorSha256 = "0a4bk2qry0isnrvl0adwikqn6imxwzlaq5j3nglb5rmwwq2cdz0r"; |   vendorSha256 = "090b9sxvdwh787w0rhrcbky9pbx64qgqx1pvk9ysk3886nxdhf7k"; | ||||||
| 
 | 
 | ||||||
|   doCheck = false; |   doCheck = false; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -24,11 +24,11 @@ let | |||||||
| in | in | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "wasabiwallet"; |   pname = "wasabiwallet"; | ||||||
|   version = "1.1.11.1"; |   version = "1.1.12"; | ||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://github.com/zkSNACKs/WalletWasabi/releases/download/v${version}/WasabiLinux-${version}.tar.gz"; |     url = "https://github.com/zkSNACKs/WalletWasabi/releases/download/v${version}/Wasabi-${version}.tar.gz"; | ||||||
|     sha256 = "04v8f2h67aqvcb5a8vmzbp2sqnq7g4m0v1ng52ccb4ii668ya8hy"; |     sha256 = "0nfd0pwsgrkaxcxfs8wb3i8kslfcqnc91iahw3rmlcxdzb81kjs4"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   dontBuild = true; |   dontBuild = true; | ||||||
|  | |||||||
| @ -200,7 +200,7 @@ in runCommand | |||||||
|       platforms = [ "x86_64-linux" ]; |       platforms = [ "x86_64-linux" ]; | ||||||
|       maintainers = with maintainers; rec { |       maintainers = with maintainers; rec { | ||||||
|         stable = [ meutraa ]; |         stable = [ meutraa ]; | ||||||
|         beta = [ galagora ]; |         beta = [ meutraa ]; | ||||||
|         canary = [ meutraa ]; |         canary = [ meutraa ]; | ||||||
|         dev = canary; |         dev = canary; | ||||||
|       }."${channel}"; |       }."${channel}"; | ||||||
|  | |||||||
| @ -14,9 +14,9 @@ let | |||||||
|     sha256Hash = "15vm7fvi8c286wx9f28z6ysvm8wqqda759qql0zy9simwx22gy7j"; |     sha256Hash = "15vm7fvi8c286wx9f28z6ysvm8wqqda759qql0zy9simwx22gy7j"; | ||||||
|   }; |   }; | ||||||
|   betaVersion = { |   betaVersion = { | ||||||
|     version = "4.1.0.14"; # "Android Studio 4.1 Beta 4" |     version = "4.1.0.17"; # "Android Studio 4.1 RC 2" | ||||||
|     build = "201.6667167"; |     build = "201.6776251"; | ||||||
|     sha256Hash = "11lkwcbzdl86cyz4lci65cx9z5jjhrc4z40maqx2r5hw1xka9290"; |     sha256Hash = "sha256-3W+eUcffRk7lZxbvf3X/Np4hkwAUqU51sQ061XR7Ddc="; | ||||||
|   }; |   }; | ||||||
|   latestVersion = { # canary & dev |   latestVersion = { # canary & dev | ||||||
|     version = "4.2.0.8"; # "Android Studio 4.2 Canary 8" |     version = "4.2.0.8"; # "Android Studio 4.2 Canary 8" | ||||||
|  | |||||||
| @ -3,13 +3,13 @@ | |||||||
| 
 | 
 | ||||||
| mkDerivation rec { | mkDerivation rec { | ||||||
|   pname = "texstudio"; |   pname = "texstudio"; | ||||||
|   version = "2.12.22"; |   version = "3.0.0"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "${pname}-org"; |     owner = "${pname}-org"; | ||||||
|     repo = pname; |     repo = pname; | ||||||
|     rev = version; |     rev = version; | ||||||
|     sha256 = "037jvsfln8wav17qj9anxz2a7p51v7ky85wmhdj2hgwp40al651g"; |     sha256 = "1663lgl30698awa7fjplr8rjnf6capqvf8z80lzlnkfl5m9ph0jb"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ qmake wrapQtAppsHook pkgconfig ]; |   nativeBuildInputs = [ qmake wrapQtAppsHook pkgconfig ]; | ||||||
|  | |||||||
| @ -1,11 +1,11 @@ | |||||||
| {stdenv, fetchurl, libX11, libXft}: | {stdenv, fetchurl, libX11, libXft}: | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "xfractint"; |   pname = "xfractint"; | ||||||
|   version = "20.04p15"; |   version = "20.04p16"; | ||||||
|   # or fetchFromGitHub(owner,repo,rev) or fetchgit(rev) |   # or fetchFromGitHub(owner,repo,rev) or fetchgit(rev) | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://www.fractint.net/ftp/current/linux/xfractint-${version}.tar.gz"; |     url = "https://www.fractint.net/ftp/current/linux/xfractint-${version}.tar.gz"; | ||||||
|     sha256 = "1wv2hgyjvrjxzqxb55vz65ra80p24j8sd34llykk2qlx73x8f3nk"; |     sha256 = "1ba77jifxv8jql044mdydh4p4ms4w5vw3qrqmcfzlvqfxk7h2m2f"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   buildInputs = [libX11 libXft]; |   buildInputs = [libX11 libXft]; | ||||||
|  | |||||||
| @ -28,5 +28,9 @@ stdenv.mkDerivation { | |||||||
|     description = "Adobe Reader, a viewer for PDF documents"; |     description = "Adobe Reader, a viewer for PDF documents"; | ||||||
|     homepage = "http://www.adobe.com/products/reader"; |     homepage = "http://www.adobe.com/products/reader"; | ||||||
|     license = stdenv.lib.licenses.unfree; |     license = stdenv.lib.licenses.unfree; | ||||||
|  |     knownVulnerabilities = [ | ||||||
|  |       "Numerous unresolved vulnerabilities" | ||||||
|  |       "See: https://www.cvedetails.com/product/497/Adobe-Acrobat-Reader.html?vendor_id=53" | ||||||
|  |     ]; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|  | |||||||
| @ -7,7 +7,7 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "dbeaver-ce"; |   pname = "dbeaver-ce"; | ||||||
|   version = "7.1.5"; |   version = "7.2.0"; | ||||||
| 
 | 
 | ||||||
|   desktopItem = makeDesktopItem { |   desktopItem = makeDesktopItem { | ||||||
|     name = "dbeaver"; |     name = "dbeaver"; | ||||||
| @ -30,7 +30,7 @@ stdenv.mkDerivation rec { | |||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://dbeaver.io/files/${version}/dbeaver-ce-${version}-linux.gtk.x86_64.tar.gz"; |     url = "https://dbeaver.io/files/${version}/dbeaver-ce-${version}-linux.gtk.x86_64.tar.gz"; | ||||||
|     sha256 = "14pdkg9xxnldr7qwpb61hp2dgsd5h9scjn59ajqsqn4f4sgcpba0"; |     sha256 = "0zpxsdzhn5fsrlq04v5kvkrgf4dsj5zmpypj9awsd2mjcbp6yxd7"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   installPhase = '' |   installPhase = '' | ||||||
|  | |||||||
| @ -9,6 +9,10 @@ python3Packages.buildPythonApplication rec { | |||||||
|     sha256 = "1q8h89hqi4kxphn1g5nbcia0haz5k57is9rycwaabm55mj9s9fah"; |     sha256 = "1q8h89hqi4kxphn1g5nbcia0haz5k57is9rycwaabm55mj9s9fah"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  |   postPatch = '' | ||||||
|  |     substituteInPlace setup.py --replace "Radicale==" "Radicale>=" | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|   propagatedBuildInputs = with python3Packages; [ |   propagatedBuildInputs = with python3Packages; [ | ||||||
|     etesync |     etesync | ||||||
|     flask |     flask | ||||||
|  | |||||||
| @ -8,13 +8,13 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "minder"; |   pname = "minder"; | ||||||
|   version = "1.9.1"; |   version = "1.9.2"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "phase1geo"; |     owner = "phase1geo"; | ||||||
|     repo = pname; |     repo = pname; | ||||||
|     rev = version; |     rev = version; | ||||||
|     sha256 = "1823nl9hgsa9l04ra1drj3c7r8s5ybx6c06d9ijpwqz191sz2jg2"; |     sha256 = "0lhwwx515f0ycpinkhgbjnik7dj2c7fckikbgzwkzzs25xqp9ayj"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ pkgconfig meson ninja python3 wrapGAppsHook vala shared-mime-info ]; |   nativeBuildInputs = [ pkgconfig meson ninja python3 wrapGAppsHook vala shared-mime-info ]; | ||||||
|  | |||||||
| @ -33,3 +33,16 @@ index c6c31cbf5..c51b59ce6 100644 | |||||||
|  } |  } | ||||||
|   |   | ||||||
|  int RSettings::getSnapRange() { |  int RSettings::getSnapRange() { | ||||||
|  | diff --git a/qcad.desktop b/qcad.desktop
 | ||||||
|  | index 93c5e9720..2d0e6bf32 100644
 | ||||||
|  | --- a/qcad.desktop
 | ||||||
|  | +++ b/qcad.desktop
 | ||||||
|  | @@ -48,7 +48,7 @@ Comment[sv]=2D CAD-system
 | ||||||
|  |  Comment[sl]=Sistem 2D CAD | ||||||
|  |  Comment[uk]=2D САПР | ||||||
|  |  Comment[tr]=2D CAD Sistemi | ||||||
|  | -Exec=qcad %F
 | ||||||
|  | +Exec=qcad-bin %F
 | ||||||
|  |  X-MultipleArgs=true | ||||||
|  |  Icon=qcad_icon | ||||||
|  |  Terminal=false | ||||||
|  | |||||||
| @ -11,13 +11,13 @@ | |||||||
| 
 | 
 | ||||||
| mkDerivationWith stdenv.mkDerivation rec { | mkDerivationWith stdenv.mkDerivation rec { | ||||||
|   pname = "qcad"; |   pname = "qcad"; | ||||||
|   version = "3.24.3.10"; |   version = "3.25.0.0"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "qcad"; |     owner = "qcad"; | ||||||
|     repo = "qcad"; |     repo = "qcad"; | ||||||
|     rev = "v${version}"; |     rev = "v${version}"; | ||||||
|     sha256 = "0izyn4y1ffq1mgxs5dymkrqih6n6v9ifrcpyk1z2vyhbm5xx4qsa"; |     sha256 = "07qph2645m1wi9yi04ixdvx8dli03q1vimj3laqdmnpipi54lljc"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   patches = [ |   patches = [ | ||||||
| @ -25,10 +25,12 @@ mkDerivationWith stdenv.mkDerivation rec { | |||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|   postPatch = '' |   postPatch = '' | ||||||
|  |     if ! [ -d src/3rdparty/qt-labs-qtscriptgenerator-${qt5.qtbase.version} ]; then | ||||||
|       mkdir src/3rdparty/qt-labs-qtscriptgenerator-${qt5.qtbase.version} |       mkdir src/3rdparty/qt-labs-qtscriptgenerator-${qt5.qtbase.version} | ||||||
|       cp \ |       cp \ | ||||||
|       src/3rdparty/qt-labs-qtscriptgenerator-5.12.3/qt-labs-qtscriptgenerator-5.12.3.pro \ |         src/3rdparty/qt-labs-qtscriptgenerator-5.14.0/qt-labs-qtscriptgenerator-5.14.0.pro \ | ||||||
|         src/3rdparty/qt-labs-qtscriptgenerator-${qt5.qtbase.version}/qt-labs-qtscriptgenerator-${qt5.qtbase.version}.pro |         src/3rdparty/qt-labs-qtscriptgenerator-${qt5.qtbase.version}/qt-labs-qtscriptgenerator-${qt5.qtbase.version}.pro | ||||||
|  |     fi | ||||||
|  ''; |  ''; | ||||||
| 
 | 
 | ||||||
|   qmakeFlags = [ |   qmakeFlags = [ | ||||||
|  | |||||||
| @ -3,17 +3,19 @@ | |||||||
| , makeWrapper, perlPackages, mkDerivation }: | , makeWrapper, perlPackages, mkDerivation }: | ||||||
| 
 | 
 | ||||||
| let | let | ||||||
|   version = "1.6.1"; |  | ||||||
| in mkDerivation rec { |  | ||||||
|   pname = "qdirstat"; |   pname = "qdirstat"; | ||||||
|   inherit version; |   version = "1.7"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "shundhammer"; |     owner = "shundhammer"; | ||||||
|     repo = "qdirstat"; |     repo = pname; | ||||||
|     rev = version; |     rev = version; | ||||||
|     sha256 = "0q77a347qv1aka6sni6l03zh5jzyy9s74aygg554r73g01kxczpb"; |     sha256 = "163x3fxra0l3vvrzm25mh7jvcwjbmwsqlpppkxx76mkz9a1769fy"; | ||||||
|   }; |   }; | ||||||
|  | in | ||||||
|  | 
 | ||||||
|  | mkDerivation { | ||||||
|  |   inherit pname version src; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ qmake makeWrapper ]; |   nativeBuildInputs = [ qmake makeWrapper ]; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2,13 +2,13 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "sdcv"; |   pname = "sdcv"; | ||||||
|   version = "0.5.2"; |   version = "0.5.3"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "Dushistov"; |     owner = "Dushistov"; | ||||||
|     repo = "sdcv"; |     repo = "sdcv"; | ||||||
|     rev = "v${version}"; |     rev = "v${version}"; | ||||||
|     sha256 = "1b67s4nj0s5fh3cjk7858qvhiisc557xx72xwzrb8hq6ijpwx5k0"; |     sha256 = "144qpl9b8r2php0zhi9b7vg6flpvdgjy6yfaipydwwhxi4wy9600"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   hardeningDisable = [ "format" ]; |   hardeningDisable = [ "format" ]; | ||||||
|  | |||||||
							
								
								
									
										38
									
								
								pkgs/applications/misc/zettlr/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								pkgs/applications/misc/zettlr/default.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,38 @@ | |||||||
|  | { appimageTools, lib, fetchurl, gtk3, gsettings-desktop-schemas}: | ||||||
|  | 
 | ||||||
|  | # Based on https://gist.github.com/msteen/96cb7df66a359b827497c5269ccbbf94 and joplin-desktop nixpkgs. | ||||||
|  | let | ||||||
|  |   pname = "zettlr"; | ||||||
|  |   version = "1.7.5"; | ||||||
|  |   name = "${pname}-${version}"; | ||||||
|  |   src = fetchurl { | ||||||
|  |     url = "https://github.com/Zettlr/Zettlr/releases/download/v${version}/Zettlr-${version}-x86_64.appimage"; | ||||||
|  |     sha256 = "040lx01ywdpla34d4abkmh51kchr11s17la6fk6yq77y8zb87xzi"; | ||||||
|  |   }; | ||||||
|  |   appimageContents = appimageTools.extractType2 { | ||||||
|  |     inherit name src; | ||||||
|  |   }; | ||||||
|  | in appimageTools.wrapType2 rec { | ||||||
|  |   inherit name src; | ||||||
|  | 
 | ||||||
|  |   profile = '' | ||||||
|  |     export XDG_DATA_DIRS=${gsettings-desktop-schemas}/share/gsettings-schemas/${gsettings-desktop-schemas.name}:${gtk3}/share/gsettings-schemas/${gtk3.name}:$XDG_DATA_DIRS | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   multiPkgs = null; # no 32bit needed | ||||||
|  |   extraPkgs = appimageTools.defaultFhsEnvArgs.multiPkgs; | ||||||
|  |   extraInstallCommands = '' | ||||||
|  |     mv $out/bin/{${name},${pname}} | ||||||
|  |     install -m 444 -D ${appimageContents}/zettlr.desktop $out/share/applications/zettlr.desktop | ||||||
|  |     install -m 444 -D ${appimageContents}/zettlr.png $out/share/icons/hicolor/512x512/apps/zettlr.png | ||||||
|  |     substituteInPlace $out/share/applications/zettlr.desktop --replace 'Exec=AppRun' 'Exec=${pname}' | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   meta = with lib; { | ||||||
|  |     description = "A markdown editor for writing academic texts and taking notes"; | ||||||
|  |     homepage = "https://www.zettlr.com"; | ||||||
|  |     platforms = [ "x86_64-linux" ]; | ||||||
|  |     license = licenses.gpl3; | ||||||
|  |     maintainers = with maintainers; [ tfmoraes ]; | ||||||
|  |   }; | ||||||
|  | } | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -132,8 +132,8 @@ in rec { | |||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   terraform_0_13 = pluggable (generic { |   terraform_0_13 = pluggable (generic { | ||||||
|     version = "0.13.1"; |     version = "0.13.2"; | ||||||
|     sha256 = "0a2sjjb79ziv42ifhplpkvqgsg8gxvr1wdgkhdj59dwahqv64pm2"; |     sha256 = "04pm57l29j3ai6dvh2343q4yhskkxqj8ayr2hdw2qqjch52p8mrw"; | ||||||
|     patches = [ ./provider-path.patch ]; |     patches = [ ./provider-path.patch ]; | ||||||
|     passthru = { inherit plugins; }; |     passthru = { inherit plugins; }; | ||||||
|   }); |   }); | ||||||
|  | |||||||
| @ -5,13 +5,13 @@ buildGoModule rec { | |||||||
|   /* Do not use "dev" as a version. If you do, Tilt will consider itself |   /* Do not use "dev" as a version. If you do, Tilt will consider itself | ||||||
|     running in development environment and try to serve assets from the |     running in development environment and try to serve assets from the | ||||||
|     source tree, which is not there once build completes.  */ |     source tree, which is not there once build completes.  */ | ||||||
|   version = "0.17.0"; |   version = "0.17.2"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner  = "tilt-dev"; |     owner  = "tilt-dev"; | ||||||
|     repo   = pname; |     repo   = pname; | ||||||
|     rev    = "v${version}"; |     rev    = "v${version}"; | ||||||
|     sha256 = "0bd01fmrf17njzf8ri4bw4qi7bxcvd3dx7yyf42qfvnp7hrfzipk"; |     sha256 = "0wiqnlam4f7085n3djvb5phhvw9df61bj8w6c5rcpffykg33vhmi"; | ||||||
|   }; |   }; | ||||||
|   vendorSha256 = null; |   vendorSha256 = null; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2,7 +2,7 @@ | |||||||
|   "name": "element-desktop", |   "name": "element-desktop", | ||||||
|   "productName": "Element", |   "productName": "Element", | ||||||
|   "main": "src/electron-main.js", |   "main": "src/electron-main.js", | ||||||
|   "version": "1.7.4", |   "version": "1.7.5", | ||||||
|   "description": "A feature-rich client for Matrix.org", |   "description": "A feature-rich client for Matrix.org", | ||||||
|   "author": "Element", |   "author": "Element", | ||||||
|   "repository": { |   "repository": { | ||||||
|  | |||||||
| @ -8,12 +8,12 @@ | |||||||
| 
 | 
 | ||||||
| let | let | ||||||
|   executableName = "element-desktop"; |   executableName = "element-desktop"; | ||||||
|   version = "1.7.4"; |   version = "1.7.5"; | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "vector-im"; |     owner = "vector-im"; | ||||||
|     repo = "riot-desktop"; |     repo = "riot-desktop"; | ||||||
|     rev = "v${version}"; |     rev = "v${version}"; | ||||||
|     sha256 = "16ilkf5b8mz74x1r9fym5xjb4plxzhg3g5njj1sl4qvsbrkk6r9a"; |     sha256 = "0781yg15bzkw5bpfzbdkqix239djgsc7kjdvbilv1d1xxqz3462y"; | ||||||
|   }; |   }; | ||||||
|   electron = electron_9; |   electron = electron_9; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -12,11 +12,11 @@ let | |||||||
| 
 | 
 | ||||||
| in stdenv.mkDerivation rec { | in stdenv.mkDerivation rec { | ||||||
|   pname = "element-web"; |   pname = "element-web"; | ||||||
|   version = "1.7.4"; |   version = "1.7.5"; | ||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://github.com/vector-im/riot-web/releases/download/v${version}/riot-v${version}.tar.gz"; |     url = "https://github.com/vector-im/riot-web/releases/download/v${version}/riot-v${version}.tar.gz"; | ||||||
|     sha256 = "0ssyd5b9yrxidivr3rcjsd8ixkmppsmmr7a8k0sv16yk7hjnvz5b"; |     sha256 = "07qc4hymdp1r2zn9gsgkpwxf6knk6xr88dc3iihlhipmlk46m58b"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   installPhase = '' |   installPhase = '' | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ | |||||||
| 
 | 
 | ||||||
| buildPythonApplication rec { | buildPythonApplication rec { | ||||||
|   pname = "pantalaimon"; |   pname = "pantalaimon"; | ||||||
|   version = "0.6.5"; |   version = "0.7.0"; | ||||||
| 
 | 
 | ||||||
|   disabled = pythonOlder "3.6"; |   disabled = pythonOlder "3.6"; | ||||||
| 
 | 
 | ||||||
| @ -19,7 +19,7 @@ buildPythonApplication rec { | |||||||
|     owner = "matrix-org"; |     owner = "matrix-org"; | ||||||
|     repo = pname; |     repo = pname; | ||||||
|     rev = version; |     rev = version; | ||||||
|     sha256 = "1pjrq71fkpvsc79nwhxhwjkqvqhj5wsnnwvsgslghaajdaw3n6wd"; |     sha256 = "0cx8sqajf5lh8w61yy1l6ry67rv1b45xp264zkw3s7ip80i4ylb2"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   propagatedBuildInputs = [ |   propagatedBuildInputs = [ | ||||||
|  | |||||||
| @ -25,7 +25,7 @@ let | |||||||
|       else ""); |       else ""); | ||||||
| in stdenv.mkDerivation rec { | in stdenv.mkDerivation rec { | ||||||
|   pname = "signal-desktop"; |   pname = "signal-desktop"; | ||||||
|   version = "1.34.5"; # Please backport all updates to the stable channel. |   version = "1.35.1"; # Please backport all updates to the stable channel. | ||||||
|   # All releases have a limited lifetime and "expire" 90 days after the release. |   # All releases have a limited lifetime and "expire" 90 days after the release. | ||||||
|   # When releases "expire" the application becomes unusable until an update is |   # When releases "expire" the application becomes unusable until an update is | ||||||
|   # applied. The expiration date for the current release can be extracted with: |   # applied. The expiration date for the current release can be extracted with: | ||||||
| @ -35,7 +35,7 @@ in stdenv.mkDerivation rec { | |||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://updates.signal.org/desktop/apt/pool/main/s/signal-desktop/signal-desktop_${version}_amd64.deb"; |     url = "https://updates.signal.org/desktop/apt/pool/main/s/signal-desktop/signal-desktop_${version}_amd64.deb"; | ||||||
|     sha256 = "1s8nksrkfivsf9r460ifxsf8l7bnc1zix5yj39kvnx0mbync8lg1"; |     sha256 = "1nxj7h8yrp2sbxxd49q9xdh1zsqixcd01i83lr492f4322cg1yjf"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ |   nativeBuildInputs = [ | ||||||
|  | |||||||
| @ -6,11 +6,11 @@ | |||||||
| 
 | 
 | ||||||
| mkDerivation rec { | mkDerivation rec { | ||||||
|   pname = "teamviewer"; |   pname = "teamviewer"; | ||||||
|   version = "15.5.6"; |   version = "15.8.3"; | ||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://dl.tvcdn.de/download/linux/version_15x/teamviewer_${version}_amd64.deb"; |     url = "https://dl.tvcdn.de/download/linux/version_15x/teamviewer_${version}_amd64.deb"; | ||||||
|     sha256 = "12dzrg9qf5gj9srv482n3jsjar8jhs3s5kkp6v5pvfp8kbmwcbib"; |     sha256 = "1c947yxgs0mv5x6qvy40dypbbhhjbglma1pwl66z39gzg51n2dmc"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   unpackPhase = '' |   unpackPhase = '' | ||||||
|  | |||||||
| @ -4,13 +4,13 @@ | |||||||
| 
 | 
 | ||||||
| mkDerivation rec { | mkDerivation rec { | ||||||
|   pname = "seafile-client"; |   pname = "seafile-client"; | ||||||
|   version = "7.0.7"; |   version = "7.0.9"; | ||||||
| 
 | 
 | ||||||
|   src = fetchFromGitHub { |   src = fetchFromGitHub { | ||||||
|     owner = "haiwen"; |     owner = "haiwen"; | ||||||
|     repo = "seafile-client"; |     repo = "seafile-client"; | ||||||
|     rev = "v${version}"; |     rev = "v${version}"; | ||||||
|     sha256 = "0szdyprljyckmbrw5sypizs22j96q84ak6nyidyr2j6gf4grh9mg"; |     sha256 = "0pcn6lfzma2hvpwsp9q0002wvym7zabpp8fvq29l101gzirn79m9"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ pkgconfig cmake ]; |   nativeBuildInputs = [ pkgconfig cmake ]; | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| { stdenv, fetchurl, pkgconfig, intltool, perlPackages | { stdenv, fetchurl, pkg-config, intltool, perlPackages | ||||||
| , goffice, gnome3, wrapGAppsHook, gtk3, bison, python3Packages | , goffice, gnome3, wrapGAppsHook, gtk3, bison, python3Packages | ||||||
| , itstool | , itstool | ||||||
| }: | }: | ||||||
| @ -7,16 +7,16 @@ let | |||||||
|   inherit (python3Packages) python pygobject3; |   inherit (python3Packages) python pygobject3; | ||||||
| in stdenv.mkDerivation rec { | in stdenv.mkDerivation rec { | ||||||
|   pname = "gnumeric"; |   pname = "gnumeric"; | ||||||
|   version = "1.12.47"; |   version = "1.12.48"; | ||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "mirror://gnome/sources/${pname}/${stdenv.lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; |     url = "mirror://gnome/sources/${pname}/${stdenv.lib.versions.majorMinor version}/${pname}-${version}.tar.xz"; | ||||||
|     sha256 = "1khrf72kiq50y8b5prbj2207k9shn36h2b2i588cc4wa28s9y5a0"; |     sha256 = "14556b0vyxdvdwjlin0rv7jk0vq4nplbmvp9j89bhkfk84xf7k2p"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   configureFlags = [ "--disable-component" ]; |   configureFlags = [ "--disable-component" ]; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ pkgconfig intltool bison itstool wrapGAppsHook ]; |   nativeBuildInputs = [ pkg-config intltool bison itstool wrapGAppsHook ]; | ||||||
| 
 | 
 | ||||||
|   # ToDo: optional libgda, introspection? |   # ToDo: optional libgda, introspection? | ||||||
|   buildInputs = [ |   buildInputs = [ | ||||||
|  | |||||||
| @ -61,15 +61,12 @@ in (mkDrv rec { | |||||||
|   # of rasqal/rasqal.h |   # of rasqal/rasqal.h | ||||||
|   NIX_CFLAGS_COMPILE = [ |   NIX_CFLAGS_COMPILE = [ | ||||||
|     "-I${librdf_rasqal}/include/rasqal" |     "-I${librdf_rasqal}/include/rasqal" | ||||||
|   ] ++ lib.optional stdenv.isx86_64 "-mno-fma"; |   ] ++ lib.optionals stdenv.isx86_64 [ "-mno-fma" "-mno-avx" ] | ||||||
|  |   # https://bugs.documentfoundation.org/show_bug.cgi?id=78174#c10 | ||||||
|  |   ++ [ "-fno-visibility-inlines-hidden" ]; | ||||||
| 
 | 
 | ||||||
|   patches = [ |   patches = [ | ||||||
|     ./xdg-open-brief.patch |     ./xdg-open-brief.patch | ||||||
|     (fetchpatch { |  | ||||||
|       url = "https://git.pld-linux.org/gitweb.cgi?p=packages/libreoffice.git;a=blob_plain;f=poppler-0.86.patch;h=76b8356d5f22ef537a83b0f9b0debab591f152fe;hb=a2737a61353e305a9ee69640fb20d4582c218008"; |  | ||||||
|       name = "poppler-0.86.patch"; |  | ||||||
|       sha256 = "0q6k4l8imgp8ailcv0qx5l83afyw44hah24fi7gjrm9xgv5sbb8j"; |  | ||||||
|     }) |  | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|   tarballPath = "external/tarballs"; |   tarballPath = "external/tarballs"; | ||||||
|  | |||||||
| @ -28,11 +28,11 @@ | |||||||
|     md5name = "976a12a59bc286d634a21d7be0841cc74289ea9077aa1af46be19d1a6e844c19-apr-util-1.5.4.tar.gz"; |     md5name = "976a12a59bc286d634a21d7be0841cc74289ea9077aa1af46be19d1a6e844c19-apr-util-1.5.4.tar.gz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "boost_1_69_0.tar.bz2"; |     name = "boost_1_71_0.tar.xz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/boost_1_69_0.tar.bz2"; |     url = "http://dev-www.libreoffice.org/src/boost_1_71_0.tar.xz"; | ||||||
|     sha256 = "8f32d4617390d1c2d16f26a27ab60d97807b35440d45891fa340fc2648b04406"; |     sha256 = "35e06a3bd7cd8f66be822c7d64e80c2b6051a181e9e897006917cb8e7988a543"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "8f32d4617390d1c2d16f26a27ab60d97807b35440d45891fa340fc2648b04406-boost_1_69_0.tar.bz2"; |     md5name = "35e06a3bd7cd8f66be822c7d64e80c2b6051a181e9e897006917cb8e7988a543-boost_1_71_0.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "breakpad.zip"; |     name = "breakpad.zip"; | ||||||
| @ -63,11 +63,11 @@ | |||||||
|     md5name = "5e7b29b3f113ef870d1e3ecf8adf21f923396401604bda16d44be45e66052331-cairo-1.16.0.tar.xz"; |     md5name = "5e7b29b3f113ef870d1e3ecf8adf21f923396401604bda16d44be45e66052331-cairo-1.16.0.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "libcdr-0.1.5.tar.xz"; |     name = "libcdr-0.1.6.tar.xz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/libcdr-0.1.5.tar.xz"; |     url = "http://dev-www.libreoffice.org/src/libcdr-0.1.6.tar.xz"; | ||||||
|     sha256 = "6ace5c499a8be34ad871e825442ce388614ae2d8675c4381756a7319429e3a48"; |     sha256 = "01cd00b04a030977e544433c2d127c997205332cd9b8e35ec0ee17110da7f861"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "6ace5c499a8be34ad871e825442ce388614ae2d8675c4381756a7319429e3a48-libcdr-0.1.5.tar.xz"; |     md5name = "01cd00b04a030977e544433c2d127c997205332cd9b8e35ec0ee17110da7f861-libcdr-0.1.6.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "clucene-core-2.3.3.4.tar.gz"; |     name = "clucene-core-2.3.3.4.tar.gz"; | ||||||
| @ -76,6 +76,13 @@ | |||||||
|     md5 = "48d647fbd8ef8889e5a7f422c1bfda94"; |     md5 = "48d647fbd8ef8889e5a7f422c1bfda94"; | ||||||
|     md5name = "48d647fbd8ef8889e5a7f422c1bfda94-clucene-core-2.3.3.4.tar.gz"; |     md5name = "48d647fbd8ef8889e5a7f422c1bfda94-clucene-core-2.3.3.4.tar.gz"; | ||||||
|   } |   } | ||||||
|  |   { | ||||||
|  |     name = "dtoa-20180411.tgz"; | ||||||
|  |     url = "http://dev-www.libreoffice.org/src/dtoa-20180411.tgz"; | ||||||
|  |     sha256 = "0082d0684f7db6f62361b76c4b7faba19e0c7ce5cb8e36c4b65fea8281e711b4"; | ||||||
|  |     md5 = ""; | ||||||
|  |     md5name = "0082d0684f7db6f62361b76c4b7faba19e0c7ce5cb8e36c4b65fea8281e711b4-dtoa-20180411.tgz"; | ||||||
|  |   } | ||||||
|   { |   { | ||||||
|     name = "libcmis-0.5.2.tar.xz"; |     name = "libcmis-0.5.2.tar.xz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/libcmis-0.5.2.tar.xz"; |     url = "http://dev-www.libreoffice.org/src/libcmis-0.5.2.tar.xz"; | ||||||
| @ -91,11 +98,11 @@ | |||||||
|     md5name = "86c798780b9e1f5921fe4efe651a93cb420623b45aa1fdff57af8c37f116113f-CoinMP-1.7.6.tgz"; |     md5name = "86c798780b9e1f5921fe4efe651a93cb420623b45aa1fdff57af8c37f116113f-CoinMP-1.7.6.tgz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "cppunit-1.14.0.tar.gz"; |     name = "cppunit-1.15.1.tar.gz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/cppunit-1.14.0.tar.gz"; |     url = "http://dev-www.libreoffice.org/src/cppunit-1.15.1.tar.gz"; | ||||||
|     sha256 = "3d569869d27b48860210c758c4f313082103a5e58219a7669b52bfd29d674780"; |     sha256 = "89c5c6665337f56fd2db36bc3805a5619709d51fb136e51937072f63fcc717a7"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "3d569869d27b48860210c758c4f313082103a5e58219a7669b52bfd29d674780-cppunit-1.14.0.tar.gz"; |     md5name = "89c5c6665337f56fd2db36bc3805a5619709d51fb136e51937072f63fcc717a7-cppunit-1.15.1.tar.gz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "converttexttonumber-1-5-0.oxt"; |     name = "converttexttonumber-1-5-0.oxt"; | ||||||
| @ -105,11 +112,11 @@ | |||||||
|     md5name = "1f467e5bb703f12cbbb09d5cf67ecf4a-converttexttonumber-1-5-0.oxt"; |     md5name = "1f467e5bb703f12cbbb09d5cf67ecf4a-converttexttonumber-1-5-0.oxt"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "curl-7.65.0.tar.xz"; |     name = "curl-7.71.0.tar.xz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/curl-7.65.0.tar.xz"; |     url = "http://dev-www.libreoffice.org/src/curl-7.71.0.tar.xz"; | ||||||
|     sha256 = "7766d263929404f693905b5e5222aa0f2bdf8c66ab4b8758f0c0820a42b966cd"; |     sha256 = "cdf18794393d8bead915312708a9e5d819c6e9919de14b20d5c8e7987abd9772"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "7766d263929404f693905b5e5222aa0f2bdf8c66ab4b8758f0c0820a42b966cd-curl-7.65.0.tar.xz"; |     md5name = "cdf18794393d8bead915312708a9e5d819c6e9919de14b20d5c8e7987abd9772-curl-7.71.0.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "libe-book-0.1.3.tar.xz"; |     name = "libe-book-0.1.3.tar.xz"; | ||||||
| @ -161,11 +168,11 @@ | |||||||
|     md5name = "6994be3555e23226630c587444be19d309b25b0fcf1f87df3b4e3f88943e5860-Firebird-3.0.0.32483-0.tar.bz2"; |     md5name = "6994be3555e23226630c587444be19d309b25b0fcf1f87df3b4e3f88943e5860-Firebird-3.0.0.32483-0.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "fontconfig-2.12.6.tar.bz2"; |     name = "fontconfig-2.13.91.tar.gz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/fontconfig-2.12.6.tar.bz2"; |     url = "http://dev-www.libreoffice.org/src/fontconfig-2.13.91.tar.gz"; | ||||||
|     sha256 = "cf0c30807d08f6a28ab46c61b8dbd55c97d2f292cf88f3a07d3384687f31f017"; |     sha256 = "19e5b1bc9d013a52063a44e1307629711f0bfef35b9aca16f9c793971e2eb1e5"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "cf0c30807d08f6a28ab46c61b8dbd55c97d2f292cf88f3a07d3384687f31f017-fontconfig-2.12.6.tar.bz2"; |     md5name = "19e5b1bc9d013a52063a44e1307629711f0bfef35b9aca16f9c793971e2eb1e5-fontconfig-2.13.91.tar.gz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "crosextrafonts-20130214.tar.gz"; |     name = "crosextrafonts-20130214.tar.gz"; | ||||||
| @ -315,11 +322,11 @@ | |||||||
|     md5name = "db8d87ea720ea9d5edc5388fc7a0497bb11ba9fe972245e0f7f4c7e8b1e1e84d-freetype-2.9.1.tar.bz2"; |     md5name = "db8d87ea720ea9d5edc5388fc7a0497bb11ba9fe972245e0f7f4c7e8b1e1e84d-freetype-2.9.1.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "glm-0.9.4.6-libreoffice.zip"; |     name = "glm-0.9.9.7.zip"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/bae83fa5dc7f081768daace6e199adc3-glm-0.9.4.6-libreoffice.zip"; |     url = "http://dev-www.libreoffice.org/src/glm-0.9.9.7.zip"; | ||||||
|     sha256 = "d0312c360efe04dd048b3311fe375ff36f1993b4c2e3cb58c81062990532904a"; |     sha256 = "c5e167c042afd2d7ad642ace6b643863baeb33880781983563e1ab68a30d3e95"; | ||||||
|     md5 = "bae83fa5dc7f081768daace6e199adc3"; |     md5 = ""; | ||||||
|     md5name = "bae83fa5dc7f081768daace6e199adc3-glm-0.9.4.6-libreoffice.zip"; |     md5name = "c5e167c042afd2d7ad642ace6b643863baeb33880781983563e1ab68a30d3e95-glm-0.9.9.7.zip"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "gpgme-1.9.0.tar.bz2"; |     name = "gpgme-1.9.0.tar.bz2"; | ||||||
| @ -329,11 +336,11 @@ | |||||||
|     md5name = "1b29fedb8bfad775e70eafac5b0590621683b2d9869db994568e6401f4034ceb-gpgme-1.9.0.tar.bz2"; |     md5name = "1b29fedb8bfad775e70eafac5b0590621683b2d9869db994568e6401f4034ceb-gpgme-1.9.0.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "graphite2-minimal-1.3.13.tgz"; |     name = "graphite2-minimal-1.3.14.tgz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/graphite2-minimal-1.3.13.tgz"; |     url = "http://dev-www.libreoffice.org/src/graphite2-minimal-1.3.14.tgz"; | ||||||
|     sha256 = "d47d387161db7f7ebade1920aa7cbdc797e79772597d8b55e80b58d1071bcc36"; |     sha256 = "b8e892d8627c41888ff121e921455b9e2d26836978f2359173d19825da62b8fc"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "d47d387161db7f7ebade1920aa7cbdc797e79772597d8b55e80b58d1071bcc36-graphite2-minimal-1.3.13.tgz"; |     md5name = "b8e892d8627c41888ff121e921455b9e2d26836978f2359173d19825da62b8fc-graphite2-minimal-1.3.14.tgz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "harfbuzz-2.6.0.tar.xz"; |     name = "harfbuzz-2.6.0.tar.xz"; | ||||||
| @ -364,18 +371,18 @@ | |||||||
|     md5name = "5ade6ae2a99bc1e9e57031ca88d36dad-hyphen-2.8.8.tar.gz"; |     md5name = "5ade6ae2a99bc1e9e57031ca88d36dad-hyphen-2.8.8.tar.gz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "icu4c-65_1-src.tgz"; |     name = "icu4c-67_1-src.tgz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/icu4c-65_1-src.tgz"; |     url = "http://dev-www.libreoffice.org/src/icu4c-67_1-src.tgz"; | ||||||
|     sha256 = "53e37466b3d6d6d01ead029e3567d873a43a5d1c668ed2278e253b683136d948"; |     sha256 = "94a80cd6f251a53bd2a997f6f1b5ac6653fe791dfab66e1eb0227740fb86d5dc"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "53e37466b3d6d6d01ead029e3567d873a43a5d1c668ed2278e253b683136d948-icu4c-65_1-src.tgz"; |     md5name = "94a80cd6f251a53bd2a997f6f1b5ac6653fe791dfab66e1eb0227740fb86d5dc-icu4c-67_1-src.tgz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "icu4c-65_1-data.zip"; |     name = "icu4c-67_1-data.zip"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/icu4c-65_1-data.zip"; |     url = "http://dev-www.libreoffice.org/src/icu4c-67_1-data.zip"; | ||||||
|     sha256 = "06359a7c4ad125ba11d3ac30617cd4b932f1214f611db96573032726574896b6"; |     sha256 = "7c16a59cc8c06128b7ecc1dc4fc056b36b17349312829b17408b9e67b05c4a7e"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "06359a7c4ad125ba11d3ac30617cd4b932f1214f611db96573032726574896b6-icu4c-65_1-data.zip"; |     md5name = "7c16a59cc8c06128b7ecc1dc4fc056b36b17349312829b17408b9e67b05c4a7e-icu4c-67_1-data.zip"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "flow-engine-0.9.4.zip"; |     name = "flow-engine-0.9.4.zip"; | ||||||
| @ -462,11 +469,11 @@ | |||||||
|     md5name = "b24890e2bb46e12e72a79f7e965f409f4e16466d00e1dd15d93d73ee6b592523-libjpeg-turbo-1.5.3.tar.gz"; |     md5name = "b24890e2bb46e12e72a79f7e965f409f4e16466d00e1dd15d93d73ee6b592523-libjpeg-turbo-1.5.3.tar.gz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "language-subtag-registry-2019-09-16.tar.bz2"; |     name = "language-subtag-registry-2020-04-01.tar.bz2"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/language-subtag-registry-2019-09-16.tar.bz2"; |     url = "http://dev-www.libreoffice.org/src/language-subtag-registry-2020-04-01.tar.bz2"; | ||||||
|     sha256 = "07b66bc0f2786fde55f6bbcbcb4a455a846eb8e2351c8ce3d0a219a73693736a"; |     sha256 = "fb1ee0dabfd956a445fbe9f351e86a52767808558f20f4256e67fbbb3768e9da"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "07b66bc0f2786fde55f6bbcbcb4a455a846eb8e2351c8ce3d0a219a73693736a-language-subtag-registry-2019-09-16.tar.bz2"; |     md5name = "fb1ee0dabfd956a445fbe9f351e86a52767808558f20f4256e67fbbb3768e9da-language-subtag-registry-2020-04-01.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "JLanguageTool-1.7.0.tar.bz2"; |     name = "JLanguageTool-1.7.0.tar.bz2"; | ||||||
| @ -532,11 +539,11 @@ | |||||||
|     md5name = "d6242790324f1432fb0a6fae71b6851f520b2c5a87675497cf8ea14c2924d52e-liblangtag-0.6.2.tar.bz2"; |     md5name = "d6242790324f1432fb0a6fae71b6851f520b2c5a87675497cf8ea14c2924d52e-liblangtag-0.6.2.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "libnumbertext-1.0.5.tar.xz"; |     name = "libnumbertext-1.0.6.tar.xz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/libnumbertext-1.0.5.tar.xz"; |     url = "http://dev-www.libreoffice.org/src/libnumbertext-1.0.6.tar.xz"; | ||||||
|     sha256 = "e1c9086b4cecb6b25f180316f30740dfabe6a4dbaf70dddc34276fc839e4f4f7"; |     sha256 = "739f220b34bf7cb731c09de2921771d644d37dfd276c45564401e5759f10ae57"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "e1c9086b4cecb6b25f180316f30740dfabe6a4dbaf70dddc34276fc839e4f4f7-libnumbertext-1.0.5.tar.xz"; |     md5name = "739f220b34bf7cb731c09de2921771d644d37dfd276c45564401e5759f10ae57-libnumbertext-1.0.6.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "ltm-1.0.zip"; |     name = "ltm-1.0.zip"; | ||||||
| @ -546,11 +553,11 @@ | |||||||
|     md5name = "083daa92d8ee6f4af96a6143b12d7fc8fe1a547e14f862304f7281f8f7347483-ltm-1.0.zip"; |     md5name = "083daa92d8ee6f4af96a6143b12d7fc8fe1a547e14f862304f7281f8f7347483-ltm-1.0.zip"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "xmlsec1-1.2.28.tar.gz"; |     name = "xmlsec1-1.2.30.tar.gz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/xmlsec1-1.2.28.tar.gz"; |     url = "http://dev-www.libreoffice.org/src/xmlsec1-1.2.30.tar.gz"; | ||||||
|     sha256 = "13eec4811ea30e3f0e16a734d1dbf7f9d246a71d540b48d143a07b489f6222d4"; |     sha256 = "2d84360b03042178def1d9ff538acacaed2b3a27411db7b2874f1612ed71abc8"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "13eec4811ea30e3f0e16a734d1dbf7f9d246a71d540b48d143a07b489f6222d4-xmlsec1-1.2.28.tar.gz"; |     md5name = "2d84360b03042178def1d9ff538acacaed2b3a27411db7b2874f1612ed71abc8-xmlsec1-1.2.30.tar.gz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "libxml2-2.9.10.tar.gz"; |     name = "libxml2-2.9.10.tar.gz"; | ||||||
| @ -581,18 +588,18 @@ | |||||||
|     md5name = "940caef1ec7c78e0c34b0f6b94fe42d0f2022915ffc78643d28538a5cfd0f40e-lxml-4.1.1.tgz"; |     md5name = "940caef1ec7c78e0c34b0f6b94fe42d0f2022915ffc78643d28538a5cfd0f40e-lxml-4.1.1.tgz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "mariadb_client-2.0.0-src.tar.gz"; |     name = "mariadb-connector-c-3.1.8-src.tar.gz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/a233181e03d3c307668b4c722d881661-mariadb_client-2.0.0-src.tar.gz"; |     url = "http://dev-www.libreoffice.org/src/mariadb-connector-c-3.1.8-src.tar.gz"; | ||||||
|     sha256 = "fd2f751dea049c1907735eb236aeace1d811d6a8218118b00bbaa9b84dc5cd60"; |     sha256 = "431434d3926f4bcce2e5c97240609983f60d7ff50df5a72083934759bb863f7b"; | ||||||
|     md5 = "a233181e03d3c307668b4c722d881661"; |     md5 = ""; | ||||||
|     md5name = "a233181e03d3c307668b4c722d881661-mariadb_client-2.0.0-src.tar.gz"; |     md5name = "431434d3926f4bcce2e5c97240609983f60d7ff50df5a72083934759bb863f7b-mariadb-connector-c-3.1.8-src.tar.gz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "mdds-1.5.0.tar.bz2"; |     name = "mdds-1.6.0.tar.bz2"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/mdds-1.5.0.tar.bz2"; |     url = "http://dev-www.libreoffice.org/src/mdds-1.6.0.tar.bz2"; | ||||||
|     sha256 = "144d6debd7be32726f332eac14ef9f17e2d3cf89cb3250eb31a7127e0789680d"; |     sha256 = "f1585c9cbd12f83a6d43d395ac1ab6a9d9d5d77f062c7b5f704e24ed72dae07d"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "144d6debd7be32726f332eac14ef9f17e2d3cf89cb3250eb31a7127e0789680d-mdds-1.5.0.tar.bz2"; |     md5name = "f1585c9cbd12f83a6d43d395ac1ab6a9d9d5d77f062c7b5f704e24ed72dae07d-mdds-1.6.0.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "mDNSResponder-878.200.35.tar.gz"; |     name = "mDNSResponder-878.200.35.tar.gz"; | ||||||
| @ -609,11 +616,11 @@ | |||||||
|     md5name = "ef36c1a1aabb2ba3b0bedaaafe717bf4480be2ba8de6f3894be5fd3702b013ba-libmspub-0.1.4.tar.xz"; |     md5name = "ef36c1a1aabb2ba3b0bedaaafe717bf4480be2ba8de6f3894be5fd3702b013ba-libmspub-0.1.4.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "libmwaw-0.3.15.tar.xz"; |     name = "libmwaw-0.3.16.tar.xz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/libmwaw-0.3.15.tar.xz"; |     url = "http://dev-www.libreoffice.org/src/libmwaw-0.3.16.tar.xz"; | ||||||
|     sha256 = "0440bb09f05e3419423d8dfa36ee847056ebfd837f9cbc091fdb5b057daab0b1"; |     sha256 = "0c639edba5297bde5575193bf5b5f2f469956beaff5c0206d91ce9df6bde1868"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "0440bb09f05e3419423d8dfa36ee847056ebfd837f9cbc091fdb5b057daab0b1-libmwaw-0.3.15.tar.xz"; |     md5name = "0c639edba5297bde5575193bf5b5f2f469956beaff5c0206d91ce9df6bde1868-libmwaw-0.3.16.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "mythes-1.2.4.tar.gz"; |     name = "mythes-1.2.4.tar.gz"; | ||||||
| @ -644,11 +651,11 @@ | |||||||
|     md5name = "2c7b21892f84a4c67546f84611eccdad6259875c971e98ddb027da66ea0ac9c2-libodfgen-0.1.6.tar.bz2"; |     md5name = "2c7b21892f84a4c67546f84611eccdad6259875c971e98ddb027da66ea0ac9c2-libodfgen-0.1.6.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "odfvalidator-1.2.0-incubating-SNAPSHOT-jar-with-dependencies-971c54fd38a968f5860014b44301872706f9e540.jar"; |     name = "odfvalidator-0.9.0-RC2-SNAPSHOT-jar-with-dependencies-2726ab578664434a545f8379a01a9faffac0ae73.jar"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/../extern/odfvalidator-1.2.0-incubating-SNAPSHOT-jar-with-dependencies-971c54fd38a968f5860014b44301872706f9e540.jar"; |     url = "http://dev-www.libreoffice.org/src/../extern/odfvalidator-0.9.0-RC2-SNAPSHOT-jar-with-dependencies-2726ab578664434a545f8379a01a9faffac0ae73.jar"; | ||||||
|     sha256 = "984f2a479df79e27e7b01a5815ac53ae64e07746b882262d8a64566494515504"; |     sha256 = "d55495ab3a86544650587de2a72180ddf8bfc6376d14ddfa923992dbc86a06e0"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "984f2a479df79e27e7b01a5815ac53ae64e07746b882262d8a64566494515504-odfvalidator-1.2.0-incubating-SNAPSHOT-jar-with-dependencies-971c54fd38a968f5860014b44301872706f9e540.jar"; |     md5name = "d55495ab3a86544650587de2a72180ddf8bfc6376d14ddfa923992dbc86a06e0-odfvalidator-0.9.0-RC2-SNAPSHOT-jar-with-dependencies-2726ab578664434a545f8379a01a9faffac0ae73.jar"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "officeotron-0.7.4-master.jar"; |     name = "officeotron-0.7.4-master.jar"; | ||||||
| @ -672,11 +679,11 @@ | |||||||
|     md5name = "14cb464efe7ac6b54799b34456bd69558a749a4931ecfd9cf9f71d7881cac7bc-openssl-1.0.2t.tar.gz"; |     md5name = "14cb464efe7ac6b54799b34456bd69558a749a4931ecfd9cf9f71d7881cac7bc-openssl-1.0.2t.tar.gz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "liborcus-0.15.3.tar.gz"; |     name = "liborcus-0.15.4.tar.bz2"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/liborcus-0.15.3.tar.gz"; |     url = "http://dev-www.libreoffice.org/src/liborcus-0.15.4.tar.bz2"; | ||||||
|     sha256 = "0dd26f3f2e611c51df9ee02d6dbf08887989eaa417b73f6877cd0d94df795fc2"; |     sha256 = "cfb2aa60825f2a78589ed030c07f46a1ee16ef8a2d1bf2279192fbc1ae5a5f61"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "0dd26f3f2e611c51df9ee02d6dbf08887989eaa417b73f6877cd0d94df795fc2-liborcus-0.15.3.tar.gz"; |     md5name = "cfb2aa60825f2a78589ed030c07f46a1ee16ef8a2d1bf2279192fbc1ae5a5f61-liborcus-0.15.4.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "owncloud-android-library-0.9.4-no-binary-deps.tar.gz"; |     name = "owncloud-android-library-0.9.4-no-binary-deps.tar.gz"; | ||||||
| @ -693,11 +700,11 @@ | |||||||
|     md5name = "66adacd705a7d19895e08eac46d1e851332adf2e736c566bef1164e7a442519d-libpagemaker-0.0.4.tar.xz"; |     md5name = "66adacd705a7d19895e08eac46d1e851332adf2e736c566bef1164e7a442519d-libpagemaker-0.0.4.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "pdfium-3963.tar.bz2"; |     name = "pdfium-4137.tar.bz2"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/pdfium-3963.tar.bz2"; |     url = "http://dev-www.libreoffice.org/src/pdfium-4137.tar.bz2"; | ||||||
|     sha256 = "80d4d6bd8faec226936fcde5521c6e92c0c645126ac3ae72dd2c160ca1749895"; |     sha256 = "9a2f9bddca935a263f06c81003483473a525ccd0f4e517bc75fceb914d4c54b6"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "80d4d6bd8faec226936fcde5521c6e92c0c645126ac3ae72dd2c160ca1749895-pdfium-3963.tar.bz2"; |     md5name = "9a2f9bddca935a263f06c81003483473a525ccd0f4e517bc75fceb914d4c54b6-pdfium-4137.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "pixman-0.34.0.tar.gz"; |     name = "pixman-0.34.0.tar.gz"; | ||||||
| @ -791,11 +798,18 @@ | |||||||
|     md5name = "6988d394b62c3494635b6f0760bc3079f9a0cd380baf0f6b075af1eb9fa5e700-serf-1.2.1.tar.bz2"; |     md5name = "6988d394b62c3494635b6f0760bc3079f9a0cd380baf0f6b075af1eb9fa5e700-serf-1.2.1.tar.bz2"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "libstaroffice-0.0.6.tar.xz"; |     name = "skia-m84-c1baf6e1c2a5454148adb516f0f833483b5a0353.tar.xz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/libstaroffice-0.0.6.tar.xz"; |     url = "http://dev-www.libreoffice.org/src/skia-m84-c1baf6e1c2a5454148adb516f0f833483b5a0353.tar.xz"; | ||||||
|     sha256 = "6b00e1ed8194e6072be4441025d1b888e39365727ed5b23e0e8c92c4009d1ec4"; |     sha256 = "f88dc1a500d29c87ef5251c5a6c3ea66aa4c7daf0cf5d349ece64b36f7623be0"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "6b00e1ed8194e6072be4441025d1b888e39365727ed5b23e0e8c92c4009d1ec4-libstaroffice-0.0.6.tar.xz"; |     md5name = "f88dc1a500d29c87ef5251c5a6c3ea66aa4c7daf0cf5d349ece64b36f7623be0-skia-m84-c1baf6e1c2a5454148adb516f0f833483b5a0353.tar.xz"; | ||||||
|  |   } | ||||||
|  |   { | ||||||
|  |     name = "libstaroffice-0.0.7.tar.xz"; | ||||||
|  |     url = "http://dev-www.libreoffice.org/src/libstaroffice-0.0.7.tar.xz"; | ||||||
|  |     sha256 = "f94fb0ad8216f97127bedef163a45886b43c62deac5e5b0f5e628e234220c8db"; | ||||||
|  |     md5 = ""; | ||||||
|  |     md5name = "f94fb0ad8216f97127bedef163a45886b43c62deac5e5b0f5e628e234220c8db-libstaroffice-0.0.7.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "swingExSrc.zip"; |     name = "swingExSrc.zip"; | ||||||
| @ -840,11 +854,11 @@ | |||||||
|     md5name = "99b3f7f8832385748582ab8130fbb9e5607bd5179bebf9751ac1d51a53099d1c-libwpg-0.3.3.tar.xz"; |     md5name = "99b3f7f8832385748582ab8130fbb9e5607bd5179bebf9751ac1d51a53099d1c-libwpg-0.3.3.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "libwps-0.4.10.tar.xz"; |     name = "libwps-0.4.11.tar.xz"; | ||||||
|     url = "http://dev-www.libreoffice.org/src/libwps-0.4.10.tar.xz"; |     url = "http://dev-www.libreoffice.org/src/libwps-0.4.11.tar.xz"; | ||||||
|     sha256 = "1421e034286a9f96d3168a1c54ea570ee7aa008ca07b89de005ad5ce49fb29ca"; |     sha256 = "a8fdaabc28654a975fa78c81873ac503ba18f0d1cdbb942f470a21d29284b4d1"; | ||||||
|     md5 = ""; |     md5 = ""; | ||||||
|     md5name = "1421e034286a9f96d3168a1c54ea570ee7aa008ca07b89de005ad5ce49fb29ca-libwps-0.4.10.tar.xz"; |     md5name = "a8fdaabc28654a975fa78c81873ac503ba18f0d1cdbb942f470a21d29284b4d1-libwps-0.4.11.tar.xz"; | ||||||
|   } |   } | ||||||
|   { |   { | ||||||
|     name = "xsltml_2.1.2.zip"; |     name = "xsltml_2.1.2.zip"; | ||||||
|  | |||||||
| @ -6,10 +6,10 @@ rec { | |||||||
|     inherit sha256; |     inherit sha256; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   major = "6"; |   major = "7"; | ||||||
|   minor = "4"; |   minor = "0"; | ||||||
|   patch = "3"; |   patch = "0"; | ||||||
|   tweak = "2"; |   tweak = "3"; | ||||||
| 
 | 
 | ||||||
|   subdir = "${major}.${minor}.${patch}"; |   subdir = "${major}.${minor}.${patch}"; | ||||||
| 
 | 
 | ||||||
| @ -17,13 +17,13 @@ rec { | |||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://download.documentfoundation.org/libreoffice/src/${subdir}/libreoffice-${version}.tar.xz"; |     url = "https://download.documentfoundation.org/libreoffice/src/${subdir}/libreoffice-${version}.tar.xz"; | ||||||
|     sha256 = "1cmbrhha7mlflnlbpla8fix07cxcgkdb7krnrgs1bylf31y5855w"; |     sha256 = "sha256-sl+vgnLGIWtyw8Y/ovVsxThdOMg2Gby4SRaiaqvZVB0="; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   # FIXME rename |   # FIXME rename | ||||||
|   translations = fetchSrc { |   translations = fetchSrc { | ||||||
|     name = "translations"; |     name = "translations"; | ||||||
|     sha256 = "06z9hz4m3kdcljjc6y5s18001axjibj9xiyakdndkl9pmnnhn9h3"; |     sha256 = "sha256-i3yfD5cmM6D9BctjablIFRqfibjrwLAaxxPIsQdk0sY="; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   # the "dictionaries" archive is not used for LO build because we already build hunspellDicts packages from |   # the "dictionaries" archive is not used for LO build because we already build hunspellDicts packages from | ||||||
| @ -31,6 +31,6 @@ rec { | |||||||
| 
 | 
 | ||||||
|   help = fetchSrc { |   help = fetchSrc { | ||||||
|     name = "help"; |     name = "help"; | ||||||
|     sha256 = "0mpgrwg8z1q38j03l6m1sdpcplyjd5nz1nqaa13vfkryj2lflw45"; |     sha256 = "sha256-hYBEEPRmh16zgGZBUN20xfTY6qL07aKMC1lC/0ij9/0="; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|  | |||||||
| @ -24,11 +24,11 @@ let | |||||||
| in | in | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "PortfolioPerformance"; |   pname = "PortfolioPerformance"; | ||||||
|   version = "0.47.0"; |   version = "0.48.1"; | ||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://github.com/buchen/portfolio/releases/download/${version}/PortfolioPerformance-${version}-linux.gtk.x86_64.tar.gz"; |     url = "https://github.com/buchen/portfolio/releases/download/${version}/PortfolioPerformance-${version}-linux.gtk.x86_64.tar.gz"; | ||||||
|     sha256 = "0l328wvikdmm2i0kbpv9qwd0mkbs24y89cgfg28swhcvpywjpk36"; |     sha256 = "0xhxp4iglggv6rqwsg0xjn8z46v910rj372abkaviwa3cqzf7gdb"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ |   nativeBuildInputs = [ | ||||||
|  | |||||||
| @ -1,13 +1,13 @@ | |||||||
| { stdenv, fetchurl }: | { stdenv, fetchurl }: | ||||||
| let | let | ||||||
|   version = "2.11.0"; |   version = "2.12.0"; | ||||||
| in stdenv.mkDerivation { | in stdenv.mkDerivation { | ||||||
|   pname = "todo.txt-cli"; |   pname = "todo.txt-cli"; | ||||||
|   inherit version; |   inherit version; | ||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://github.com/ginatrapani/todo.txt-cli/releases/download/v${version}/todo.txt_cli-${version}.tar.gz"; |     url = "https://github.com/ginatrapani/todo.txt-cli/releases/download/v${version}/todo.txt_cli-${version}.tar.gz"; | ||||||
|     sha256 = "0majx8lcvhh8ji54qi0sxr833wchdss95fjc92byd8g3lfz27rsz"; |     sha256 = "0gni8nj3wwdf7nl98d1bpx064bz5xari65hb998qqr92h0n9pnp6"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   installPhase = '' |   installPhase = '' | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ | |||||||
| , cups | , cups | ||||||
| , dbus | , dbus | ||||||
| , expat | , expat | ||||||
| , ffmpeg_3 | , ffmpeg | ||||||
| , fontconfig | , fontconfig | ||||||
| , freetype | , freetype | ||||||
| , gdk-pixbuf | , gdk-pixbuf | ||||||
| @ -71,7 +71,7 @@ stdenv.mkDerivation rec { | |||||||
|     cairo |     cairo | ||||||
|     dbus.lib |     dbus.lib | ||||||
|     expat |     expat | ||||||
|     ffmpeg_3 |     ffmpeg | ||||||
|     fontconfig |     fontconfig | ||||||
|     freetype |     freetype | ||||||
|     gdk-pixbuf |     gdk-pixbuf | ||||||
|  | |||||||
| @ -35,11 +35,11 @@ | |||||||
| 
 | 
 | ||||||
| stdenv.mkDerivation rec { | stdenv.mkDerivation rec { | ||||||
|   pname = "zotero"; |   pname = "zotero"; | ||||||
|   version = "5.0.88"; |   version = "5.0.89"; | ||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://download.zotero.org/client/release/${version}/Zotero-${version}_linux-x86_64.tar.bz2"; |     url = "https://download.zotero.org/client/release/${version}/Zotero-${version}_linux-x86_64.tar.bz2"; | ||||||
|     sha256 = "19r9jmakr04raqripfnqm2b9gwpi52lklrrqgqyb1x35a4xvnj62"; |     sha256 = "18p4qnnfx9f2frk7f2nk1d7jr4cjzg9z7lfzrk7vq11qgbjdpqbl"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   nativeBuildInputs = [ wrapGAppsHook ]; |   nativeBuildInputs = [ wrapGAppsHook ]; | ||||||
|  | |||||||
| @ -4,11 +4,11 @@ | |||||||
| }: | }: | ||||||
| python2.pkgs.buildPythonApplication rec { | python2.pkgs.buildPythonApplication rec { | ||||||
|   pname = "chirp-daily"; |   pname = "chirp-daily"; | ||||||
|   version = "20200430"; |   version = "20200807"; | ||||||
| 
 | 
 | ||||||
|   src = fetchurl { |   src = fetchurl { | ||||||
|     url = "https://trac.chirp.danplanet.com/chirp_daily/daily-${version}/${pname}-${version}.tar.gz"; |     url = "https://trac.chirp.danplanet.com/chirp_daily/daily-${version}/${pname}-${version}.tar.gz"; | ||||||
|     sha256 = "060fzplgmpfrk6wkfaasx7phpfk90mmylk6drbwzk4f9r1655vda"; |     sha256 = "60b682793698e6427ad485546eae3a044b8290a220f190633158a2fb0e942fa0"; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   propagatedBuildInputs = with python2.pkgs; [ |   propagatedBuildInputs = with python2.pkgs; [ | ||||||
|  | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Frederik Rietdijk
						Frederik Rietdijk