Merge pull request #271881 from Kranzes/sshx-pkgs
sshx: update, split component and add web to sshx-server
This commit is contained in:
commit
216b111fb8
3 changed files with 83 additions and 53 deletions
|
@ -1,53 +0,0 @@
|
||||||
{ lib
|
|
||||||
, rustPlatform
|
|
||||||
, fetchFromGitHub
|
|
||||||
, pkg-config
|
|
||||||
, protobuf
|
|
||||||
, zstd
|
|
||||||
, stdenv
|
|
||||||
, darwin
|
|
||||||
}:
|
|
||||||
|
|
||||||
rustPlatform.buildRustPackage rec {
|
|
||||||
pname = "sshx";
|
|
||||||
version = "unstable-2023-11-04";
|
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "ekzhang";
|
|
||||||
repo = "sshx";
|
|
||||||
rev = "91c82d46cde4d1ffa0ae34e2a9a49911e2e53baa";
|
|
||||||
hash = "sha256-X9c7ZKIpWI5EsbkgB8FJWlwQQXHAcPjLKp2Bvo0fo/w=";
|
|
||||||
};
|
|
||||||
|
|
||||||
cargoHash = "sha256-mOK5gpPuUKzN5xnJs5nFyslxr9IIHtiCylMP53ObDqg=";
|
|
||||||
|
|
||||||
nativeBuildInputs = [
|
|
||||||
pkg-config
|
|
||||||
protobuf
|
|
||||||
];
|
|
||||||
|
|
||||||
buildInputs = [
|
|
||||||
zstd
|
|
||||||
] ++ lib.optionals stdenv.isDarwin [
|
|
||||||
darwin.apple_sdk.frameworks.Security
|
|
||||||
];
|
|
||||||
|
|
||||||
env = {
|
|
||||||
ZSTD_SYS_USE_PKG_CONFIG = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
outputs = [ "out" "server" ];
|
|
||||||
|
|
||||||
postInstall = ''
|
|
||||||
moveToOutput 'bin/sshx' "$out"
|
|
||||||
moveToOutput 'bin/sshx-server' "$server"
|
|
||||||
'';
|
|
||||||
|
|
||||||
meta = with lib; {
|
|
||||||
description = "Fast, collaborative live terminal sharing over the web";
|
|
||||||
homepage = "https://github.com/ekzhang/sshx";
|
|
||||||
license = licenses.mit;
|
|
||||||
maintainers = with maintainers; [ pinpox ];
|
|
||||||
mainProgram = "sshx";
|
|
||||||
};
|
|
||||||
}
|
|
79
pkgs/tools/misc/sshx/default.nix
Normal file
79
pkgs/tools/misc/sshx/default.nix
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
{ lib
|
||||||
|
, callPackage
|
||||||
|
, rustPlatform
|
||||||
|
, fetchFromGitHub
|
||||||
|
, protobuf
|
||||||
|
, darwin
|
||||||
|
, stdenv
|
||||||
|
, buildNpmPackage
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
version = "unstable-2023-11-23";
|
||||||
|
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "ekzhang";
|
||||||
|
repo = "sshx";
|
||||||
|
rev = "2677f7e1fa3b369132cc7f27f6028a04b92ba5cf";
|
||||||
|
hash = "sha256-9fo8hNUzJr4gse0J2tw7j+alqE82+y8McADzTkxryWk=";
|
||||||
|
};
|
||||||
|
|
||||||
|
mkSshxPackage = { pname, cargoHash, ... }@args:
|
||||||
|
rustPlatform.buildRustPackage (rec {
|
||||||
|
inherit
|
||||||
|
pname
|
||||||
|
version
|
||||||
|
src
|
||||||
|
cargoHash;
|
||||||
|
|
||||||
|
nativeBuildInputs = [ protobuf ];
|
||||||
|
buildInputs = lib.optional stdenv.isDarwin darwin.apple_sdk.frameworks.Security;
|
||||||
|
|
||||||
|
cargoBuildFlags = [ "--package" pname ];
|
||||||
|
cargoTestFlags = cargoBuildFlags;
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "Fast, collaborative live terminal sharing over the web";
|
||||||
|
homepage = "https://github.com/ekzhang/sshx";
|
||||||
|
license = lib.licenses.mit;
|
||||||
|
maintainers = with lib.maintainers; [ pinpox kranzes ];
|
||||||
|
mainProgram = pname;
|
||||||
|
};
|
||||||
|
} // args);
|
||||||
|
in
|
||||||
|
{
|
||||||
|
sshx = mkSshxPackage {
|
||||||
|
pname = "sshx";
|
||||||
|
cargoHash = "sha256-dA5Aen/qANW8si75pj/RsBknvOo3KDyU5UISAmmcfRE=";
|
||||||
|
};
|
||||||
|
|
||||||
|
sshx-server = mkSshxPackage rec {
|
||||||
|
pname = "sshx-server";
|
||||||
|
cargoHash = "sha256-1GRWCMXsOzqvORgtwfuywV4wLyX3r4nURhM3Dl5V9Ss=";
|
||||||
|
|
||||||
|
postPatch = ''
|
||||||
|
substituteInPlace crates/sshx-server/src/web.rs \
|
||||||
|
--replace 'ServeDir::new("build")' 'ServeDir::new("${passthru.web.outPath}")' \
|
||||||
|
--replace 'ServeFile::new("build/spa.html")' 'ServeFile::new("${passthru.web.outPath}/spa.html")'
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru.web = buildNpmPackage {
|
||||||
|
pname = "sshx-web";
|
||||||
|
|
||||||
|
inherit
|
||||||
|
version
|
||||||
|
src;
|
||||||
|
|
||||||
|
postPatch = ''
|
||||||
|
substituteInPlace vite.config.ts \
|
||||||
|
--replace 'execSync("git rev-parse --short HEAD").toString().trim()' '"${src.rev}"'
|
||||||
|
'';
|
||||||
|
|
||||||
|
npmDepsHash = "sha256-bKePCxo6+n0EG+4tbbMimPedJ0Hu1O8yZsgspmhobOs=";
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
mkdir -p "$out"
|
||||||
|
cp -r build/* "$out"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -13526,6 +13526,10 @@ with pkgs;
|
||||||
|
|
||||||
sshuttle = callPackage ../tools/security/sshuttle { };
|
sshuttle = callPackage ../tools/security/sshuttle { };
|
||||||
|
|
||||||
|
inherit (callPackages ../tools/misc/sshx { })
|
||||||
|
sshx
|
||||||
|
sshx-server;
|
||||||
|
|
||||||
ssldump = callPackage ../tools/networking/ssldump { };
|
ssldump = callPackage ../tools/networking/ssldump { };
|
||||||
|
|
||||||
sslsplit = callPackage ../tools/networking/sslsplit { };
|
sslsplit = callPackage ../tools/networking/sslsplit { };
|
||||||
|
|
Loading…
Reference in a new issue