feat: switch to camasca
This commit is contained in:
parent
ffd73d8e6a
commit
bf806a2e63
12 changed files with 46 additions and 279 deletions
|
@ -1,18 +0,0 @@
|
|||
{self, ...}: {
|
||||
flake.nixosModules = {
|
||||
reposilite = import ./reposilite/module.nix self;
|
||||
};
|
||||
|
||||
perSystem = {pkgs, ...}: {
|
||||
packages = {
|
||||
reposilite = pkgs.callPackage ./reposilite/derivation.nix {};
|
||||
enigma = pkgs.callPackage ./pkgs/enigma.nix {};
|
||||
vineflower = pkgs.callPackage ./pkgs/vineflower.nix {};
|
||||
koi = pkgs.kdePackages.callPackage ./pkgs/koi.nix {};
|
||||
|
||||
wine-discord-ipc-bridge = pkgs.callPackage ./pkgs/wine-discord-ipc-bridge.nix {
|
||||
inherit (pkgs.pkgsCross.mingw32) stdenv;
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
|
@ -1,42 +0,0 @@
|
|||
{
|
||||
stdenv,
|
||||
fetchurl,
|
||||
temurin-bin,
|
||||
makeWrapper,
|
||||
makeDesktopItem,
|
||||
copyDesktopItems,
|
||||
}:
|
||||
stdenv.mkDerivation (finalAttrs: {
|
||||
name = "enigma";
|
||||
version = "2.5.0";
|
||||
|
||||
src = fetchurl {
|
||||
url = with finalAttrs; "https://maven.fabricmc.net/cuchaz/enigma-swing/${version}/enigma-swing-${version}-all.jar";
|
||||
hash = "sha256-yOPPTKt96aRSbziYDBLBKqfLS2R9GeXgz5m2t1fgFHo=";
|
||||
};
|
||||
|
||||
dontUnpack = true;
|
||||
|
||||
nativeBuildInputs = [makeWrapper copyDesktopItems];
|
||||
|
||||
installPhase = with finalAttrs; ''
|
||||
runHook preInstall
|
||||
|
||||
mkdir -p $out/bin $out/share/${name}
|
||||
cp ${src} $out/share/${name}/${name}.jar
|
||||
makeWrapper ${temurin-bin}/bin/java $out/bin/${name} --add-flags "-jar $out/share/${name}/${name}.jar"
|
||||
|
||||
runHook postInstall
|
||||
'';
|
||||
|
||||
desktopItems = [
|
||||
(makeDesktopItem {
|
||||
name = "enigma";
|
||||
desktopName = "Enigma";
|
||||
exec = "enigma";
|
||||
terminal = false;
|
||||
})
|
||||
];
|
||||
|
||||
meta.mainProgram = "enigma";
|
||||
})
|
|
@ -1,28 +0,0 @@
|
|||
{
|
||||
stdenv,
|
||||
fetchFromGitHub,
|
||||
cmake,
|
||||
ninja,
|
||||
wrapQtAppsHook,
|
||||
qtbase,
|
||||
qtwayland,
|
||||
kcoreaddons,
|
||||
kwidgetsaddons,
|
||||
kconfig,
|
||||
}:
|
||||
stdenv.mkDerivation (finalAttrs: {
|
||||
name = "koi";
|
||||
version = "0.3.1";
|
||||
|
||||
src = fetchFromGitHub {
|
||||
owner = "baduhai";
|
||||
repo = "Koi";
|
||||
rev = finalAttrs.version;
|
||||
hash = "sha256-dhpuKIY/Xi62hzJlnVCIOF0k6uoQ3zH129fLq/r+Kmg=";
|
||||
};
|
||||
|
||||
sourceRoot = "source/src";
|
||||
|
||||
nativeBuildInputs = [cmake ninja wrapQtAppsHook];
|
||||
buildInputs = [qtbase qtwayland kcoreaddons kwidgetsaddons kconfig];
|
||||
})
|
|
@ -1,31 +0,0 @@
|
|||
{
|
||||
stdenv,
|
||||
fetchurl,
|
||||
makeWrapper,
|
||||
jre_headless,
|
||||
}:
|
||||
stdenv.mkDerivation (finalAttrs: {
|
||||
name = "vineflower";
|
||||
version = "1.10.1";
|
||||
|
||||
src = fetchurl {
|
||||
url = with finalAttrs; "https://github.com/Vineflower/vineflower/releases/download/${version}/vineflower-${version}.jar";
|
||||
hash = "sha256-ubII5QeTtkZXprYpIGdSZhP1Sd50BfkkNiSwL0J25Ak=";
|
||||
};
|
||||
|
||||
nativeBuildInputs = [makeWrapper];
|
||||
|
||||
dontUnpack = true;
|
||||
|
||||
installPhase = with finalAttrs; ''
|
||||
runHook preInstall
|
||||
|
||||
mkdir -p $out/bin $out/share/${name}
|
||||
cp ${src} $out/share/${name}/${name}.jar
|
||||
makeWrapper ${jre_headless}/bin/java $out/bin/${name} --add-flags "-jar $out/share/${name}/${name}.jar"
|
||||
|
||||
runHook postInstall
|
||||
'';
|
||||
|
||||
meta.mainProgram = "vineflower";
|
||||
})
|
|
@ -1,26 +0,0 @@
|
|||
{
|
||||
stdenv,
|
||||
fetchFromGitHub,
|
||||
}:
|
||||
stdenv.mkDerivation {
|
||||
name = "wine-discord-ipc-bridge";
|
||||
|
||||
src = fetchFromGitHub {
|
||||
owner = "0e4ef622";
|
||||
repo = "wine-discord-ipc-bridge";
|
||||
rev = "f8198c9d52e708143301017a296f7557c4387127";
|
||||
hash = "sha256-tAknITFlG63+gI5cN9SfUIUZkbIq/MgOPoGIcvoNo4Q=";
|
||||
};
|
||||
|
||||
postPatch = ''
|
||||
patchShebangs winediscordipcbridge-steam.sh
|
||||
'';
|
||||
|
||||
installPhase = ''
|
||||
mkdir -p $out/bin
|
||||
cp winediscordipcbridge.exe $out/bin
|
||||
cp winediscordipcbridge-steam.sh $out/bin
|
||||
'';
|
||||
|
||||
meta.platforms = ["i686-windows" "x86_64-linux"];
|
||||
}
|
|
@ -1,38 +0,0 @@
|
|||
{
|
||||
lib,
|
||||
stdenv,
|
||||
fetchurl,
|
||||
makeWrapper,
|
||||
jre_headless,
|
||||
}:
|
||||
stdenv.mkDerivation (finalAttrs: {
|
||||
name = "reposilite";
|
||||
version = "3.5.14";
|
||||
|
||||
src = fetchurl {
|
||||
url = with finalAttrs; "https://maven.reposilite.com/releases/com/reposilite/reposilite/${version}/reposilite-${version}-all.jar";
|
||||
hash = "sha256-qZXYpz6SBXDBj8c0IZkfVgxEFe/+DxMpdhLJsjks8cM=";
|
||||
};
|
||||
|
||||
nativeBuildInputs = [makeWrapper];
|
||||
|
||||
dontUnpack = true;
|
||||
|
||||
installPhase = with finalAttrs; ''
|
||||
runHook preInstall
|
||||
|
||||
mkdir -p $out/bin $out/share/${name}
|
||||
cp ${src} $out/share/${name}/${name}.jar
|
||||
makeWrapper ${jre_headless}/bin/java $out/bin/${name} --add-flags "-jar $out/share/${name}/${name}.jar"
|
||||
|
||||
runHook postInstall
|
||||
'';
|
||||
|
||||
meta = with lib; {
|
||||
description = "Lightweight and easy-to-use repository management software dedicated for the Maven based artifacts in the JVM ecosystem";
|
||||
homepage = "https://reposilite.com/";
|
||||
license = licenses.asl20;
|
||||
platforms = platforms.unix;
|
||||
mainProgram = "reposilite";
|
||||
};
|
||||
})
|
|
@ -1,79 +0,0 @@
|
|||
self: {
|
||||
lib,
|
||||
config,
|
||||
pkgs,
|
||||
...
|
||||
}: let
|
||||
cfg = config.services.reposilite;
|
||||
|
||||
inherit (pkgs.stdenv.hostPlatform) system;
|
||||
|
||||
inherit
|
||||
(lib)
|
||||
getExe
|
||||
literalExpression
|
||||
mdDoc
|
||||
mkDefault
|
||||
mkEnableOption
|
||||
mkIf
|
||||
mkOption
|
||||
mkPackageOption
|
||||
types
|
||||
;
|
||||
in {
|
||||
options.services.reposilite = {
|
||||
enable = mkEnableOption "reposilite";
|
||||
package = mkPackageOption self.packages.${system} "reposilite" {};
|
||||
environmentFile = mkOption {
|
||||
description = mdDoc ''
|
||||
Environment file as defined in {manpage}`systemd.exec(5)`
|
||||
'';
|
||||
type = types.nullOr types.path;
|
||||
default = null;
|
||||
example = literalExpression ''
|
||||
"/run/agenix.d/1/reposilite"
|
||||
'';
|
||||
};
|
||||
};
|
||||
|
||||
config = mkIf cfg.enable {
|
||||
users = {
|
||||
users.reposilite = {
|
||||
isSystemUser = true;
|
||||
group = "reposilite";
|
||||
};
|
||||
|
||||
groups.reposilite = {};
|
||||
};
|
||||
|
||||
systemd.services."reposilite" = {
|
||||
enable = true;
|
||||
wantedBy = mkDefault ["multi-user.target"];
|
||||
after = mkDefault ["network.target"];
|
||||
script = ''
|
||||
${getExe cfg.package}
|
||||
'';
|
||||
|
||||
serviceConfig = {
|
||||
Type = "simple";
|
||||
Restart = "always";
|
||||
|
||||
EnvironmentFile = mkIf (cfg.environmentFile != null) cfg.environmentFile;
|
||||
|
||||
StateDirectory = "reposilite";
|
||||
StateDirectoryMode = "0700";
|
||||
WorkingDirectory = "/var/lib/reposilite";
|
||||
|
||||
User = "reposilite";
|
||||
Group = "reposilite";
|
||||
|
||||
LimitNOFILE = "1048576";
|
||||
PrivateTmp = true;
|
||||
PrivateDevices = true;
|
||||
ProtectHome = true;
|
||||
ProtectSystem = "strict";
|
||||
AmbientCapabilities = "CAP_NET_BIND_SERVICE";
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue