feat: switch to camasca
This commit is contained in:
parent
ffd73d8e6a
commit
bf806a2e63
12 changed files with 46 additions and 279 deletions
|
@ -3,7 +3,7 @@
|
||||||
pkgs,
|
pkgs,
|
||||||
config,
|
config,
|
||||||
_utils,
|
_utils,
|
||||||
self,
|
camasca,
|
||||||
nixpkgs,
|
nixpkgs,
|
||||||
agenix,
|
agenix,
|
||||||
home-manager,
|
home-manager,
|
||||||
|
@ -98,12 +98,10 @@ in {
|
||||||
options = "-d";
|
options = "-d";
|
||||||
};
|
};
|
||||||
|
|
||||||
registry = let
|
registry = {
|
||||||
n.flake = nixpkgs;
|
n.flake = nixpkgs;
|
||||||
in {
|
nixpkgs.flake = nixpkgs;
|
||||||
inherit n;
|
u.flake = camasca;
|
||||||
nixpkgs = n;
|
|
||||||
u.flake = self;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
settings = {
|
settings = {
|
||||||
|
|
|
@ -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";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
24
flake.lock
24
flake.lock
|
@ -50,6 +50,29 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"camasca": {
|
||||||
|
"inputs": {
|
||||||
|
"flake-parts": [
|
||||||
|
"flake-parts"
|
||||||
|
],
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1724885464,
|
||||||
|
"narHash": "sha256-PQp5tDi+vRp5CEoUTI5NPbdhlDlp109KLDgpwsGH4J8=",
|
||||||
|
"owner": "uku3lig",
|
||||||
|
"repo": "camasca",
|
||||||
|
"rev": "f9ab5b1b70eeb6f5bc0e47375ef11b8f3eb81d25",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "uku3lig",
|
||||||
|
"repo": "camasca",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"catppuccin": {
|
"catppuccin": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1724469296,
|
"lastModified": 1724469296,
|
||||||
|
@ -388,6 +411,7 @@
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"agenix": "agenix",
|
"agenix": "agenix",
|
||||||
"api-rs": "api-rs",
|
"api-rs": "api-rs",
|
||||||
|
"camasca": "camasca",
|
||||||
"catppuccin": "catppuccin",
|
"catppuccin": "catppuccin",
|
||||||
"crane": "crane",
|
"crane": "crane",
|
||||||
"flake-parts": "flake-parts",
|
"flake-parts": "flake-parts",
|
||||||
|
|
17
flake.nix
17
flake.nix
|
@ -12,7 +12,6 @@
|
||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
./systems
|
./systems
|
||||||
./exprs
|
|
||||||
];
|
];
|
||||||
|
|
||||||
perSystem = {
|
perSystem = {
|
||||||
|
@ -22,12 +21,10 @@
|
||||||
}: {
|
}: {
|
||||||
apps = (nixinate.nixinate.${system} self).nixinate;
|
apps = (nixinate.nixinate.${system} self).nixinate;
|
||||||
|
|
||||||
devShells.default = pkgs.mkShellNoCC {
|
devShells.default = with pkgs;
|
||||||
packages = with pkgs; [
|
mkShellNoCC {
|
||||||
just
|
packages = [just statix];
|
||||||
statix
|
};
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
formatter = pkgs.alejandra;
|
formatter = pkgs.alejandra;
|
||||||
};
|
};
|
||||||
|
@ -36,6 +33,12 @@
|
||||||
inputs = {
|
inputs = {
|
||||||
nixpkgs.url = "nixpkgs/nixos-unstable";
|
nixpkgs.url = "nixpkgs/nixos-unstable";
|
||||||
|
|
||||||
|
camasca = {
|
||||||
|
url = "github:uku3lig/camasca";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
inputs.flake-parts.follows = "flake-parts";
|
||||||
|
};
|
||||||
|
|
||||||
agenix = {
|
agenix = {
|
||||||
url = "github:uku3lig/agenix";
|
url = "github:uku3lig/agenix";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
|
|
@ -1,10 +1,14 @@
|
||||||
{self, pkgs, ...}: {
|
{
|
||||||
|
camasca,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
services.desktopManager.plasma6.enable = true;
|
services.desktopManager.plasma6.enable = true;
|
||||||
|
|
||||||
environment = {
|
environment = {
|
||||||
systemPackages = with pkgs; [
|
systemPackages = with pkgs; [
|
||||||
flameshot
|
flameshot
|
||||||
self.packages.${pkgs.system}.koi
|
camasca.packages.${pkgs.system}.koi
|
||||||
];
|
];
|
||||||
|
|
||||||
plasma6.excludePackages = with pkgs.kdePackages; [
|
plasma6.excludePackages = with pkgs.kdePackages; [
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
{self, ...}: {
|
{camasca, ...}: {
|
||||||
imports = [self.nixosModules.reposilite];
|
imports = [camasca.nixosModules.reposilite];
|
||||||
|
|
||||||
cfTunnels."maven.uku3lig.net" = "http://localhost:8080";
|
cfTunnels."maven.uku3lig.net" = "http://localhost:8080";
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue