mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-28 09:53:10 +00:00
rustdesk: init at 1.1.8
This commit is contained in:
parent
0686582d8c
commit
681fdf81b6
50
pkgs/applications/networking/remote/rustdesk/cargo.patch
Normal file
50
pkgs/applications/networking/remote/rustdesk/cargo.patch
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
diff --git a/Cargo.lock b/Cargo.lock
|
||||||
|
index c3e139e..b77d8bd 100644
|
||||||
|
--- a/Cargo.lock
|
||||||
|
+++ b/Cargo.lock
|
||||||
|
@@ -1761,11 +1761,11 @@ dependencies = [
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "magnum-opus"
|
||||||
|
-version = "0.3.4-2"
|
||||||
|
-source = "git+https://github.com/open-trade/magnum-opus#ad0836164abf4a4df69009b1ee08eabe3a13b33f"
|
||||||
|
+version = "0.4.0"
|
||||||
|
+source = "git+https://github.com/TheRadioGuy/magnum-opus#171e1d021004626f7444d1e39b98f50bc3cb2604"
|
||||||
|
dependencies = [
|
||||||
|
- "bindgen 0.59.1",
|
||||||
|
- "target_build_utils",
|
||||||
|
+ "libc",
|
||||||
|
+ "opusic-sys",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
@@ -2188,6 +2188,16 @@ version = "0.1.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "28988d872ab76095a6e6ac88d99b54fd267702734fd7ffe610ca27f533ddb95a"
|
||||||
|
|
||||||
|
+[[package]]
|
||||||
|
+name = "opusic-sys"
|
||||||
|
+version = "0.3.6"
|
||||||
|
+source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
+checksum = "5eace752ce07a037241dba8f02c654799f051e431b27028056bcb480e83b54f5"
|
||||||
|
+dependencies = [
|
||||||
|
+ "cmake",
|
||||||
|
+ "libc",
|
||||||
|
+]
|
||||||
|
+
|
||||||
|
[[package]]
|
||||||
|
name = "parity-tokio-ipc"
|
||||||
|
version = "0.7.2"
|
||||||
|
diff --git a/Cargo.toml b/Cargo.toml
|
||||||
|
index 75504a0..43e1624 100644
|
||||||
|
--- a/Cargo.toml
|
||||||
|
+++ b/Cargo.toml
|
||||||
|
@@ -32,7 +32,7 @@ libc = "0.2"
|
||||||
|
parity-tokio-ipc = { git = "https://github.com/open-trade/parity-tokio-ipc" }
|
||||||
|
flexi_logger = "0.17"
|
||||||
|
runas = "0.2"
|
||||||
|
-magnum-opus = { git = "https://github.com/open-trade/magnum-opus" }
|
||||||
|
+magnum-opus = { git = "https://github.com/TheRadioGuy/magnum-opus" }
|
||||||
|
dasp = { version = "0.11", features = ["signal", "interpolate-linear", "interpolate"], optional = true }
|
||||||
|
rubato = { version = "0.8", optional = true }
|
||||||
|
samplerate = { version = "0.2", optional = true }
|
104
pkgs/applications/networking/remote/rustdesk/default.nix
Normal file
104
pkgs/applications/networking/remote/rustdesk/default.nix
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
{ lib
|
||||||
|
, stdenv
|
||||||
|
, fetchFromGitHub
|
||||||
|
, makeDesktopItem
|
||||||
|
, copyDesktopItems
|
||||||
|
, makeWrapper
|
||||||
|
, rustPlatform
|
||||||
|
, cmake
|
||||||
|
, yasm
|
||||||
|
, nasm
|
||||||
|
, zip
|
||||||
|
, pkg-config
|
||||||
|
, clang
|
||||||
|
, gtk3
|
||||||
|
, xdotool
|
||||||
|
, libxcb
|
||||||
|
, libXfixes
|
||||||
|
, alsa-lib
|
||||||
|
, pulseaudio
|
||||||
|
, libXtst
|
||||||
|
, libvpx
|
||||||
|
, libyuv
|
||||||
|
, libopus
|
||||||
|
, libsciter
|
||||||
|
, llvmPackages
|
||||||
|
, wrapGAppsHook
|
||||||
|
}:
|
||||||
|
|
||||||
|
rustPlatform.buildRustPackage rec {
|
||||||
|
pname = "rustdesk";
|
||||||
|
version = "1.1.8";
|
||||||
|
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "rustdesk";
|
||||||
|
repo = "rustdesk";
|
||||||
|
rev = "0325500ebf331b66220cec6e9078afb83b0e98a7";
|
||||||
|
sha256 = "sha256-xglyyoiAjJx3y8+A2OYHZffjqjDkcTjIluPA/J42VVg=";
|
||||||
|
};
|
||||||
|
|
||||||
|
cargoSha256 = "sha256-4MQKa54f3X7IHGd29H6RY7v2toeHvTHInIpgXjdotjw=";
|
||||||
|
|
||||||
|
LIBCLANG_PATH="${llvmPackages.libclang.lib}/lib";
|
||||||
|
|
||||||
|
# Change magnus-opus version to upstream so that it does not use
|
||||||
|
# vcpkg for libopus since it does not work.
|
||||||
|
cargoPatches = [
|
||||||
|
./cargo.patch
|
||||||
|
];
|
||||||
|
|
||||||
|
# Manually simulate a vcpkg installation so that it can link the libaries
|
||||||
|
# properly.
|
||||||
|
postUnpack = let
|
||||||
|
vcpkg_target = "x64-linux";
|
||||||
|
in ''
|
||||||
|
export VCPKG_ROOT="$TMP/vcpkg";
|
||||||
|
|
||||||
|
mkdir -p $VCPKG_ROOT/installed/${vcpkg_target}/lib
|
||||||
|
|
||||||
|
ln -s ${libvpx.out}/lib/* $VCPKG_ROOT/installed/${vcpkg_target}/lib/
|
||||||
|
ln -s ${libyuv.out}/lib/* $VCPKG_ROOT/installed/${vcpkg_target}/lib/
|
||||||
|
'';
|
||||||
|
|
||||||
|
nativeBuildInputs = [ pkg-config cmake makeWrapper copyDesktopItems yasm nasm clang wrapGAppsHook ];
|
||||||
|
buildInputs = [ alsa-lib pulseaudio libXfixes libxcb xdotool gtk3 libvpx libopus libXtst libyuv ];
|
||||||
|
|
||||||
|
# Checks require an active X display.
|
||||||
|
doCheck = false;
|
||||||
|
|
||||||
|
desktopItems = [ (makeDesktopItem {
|
||||||
|
name = "rustdesk";
|
||||||
|
exec = meta.mainProgram;
|
||||||
|
icon = "rustdesk";
|
||||||
|
desktopName = "RustDesk";
|
||||||
|
comment = meta.description;
|
||||||
|
genericName = "Remote Desktop";
|
||||||
|
categories = ["Network"];
|
||||||
|
}) ];
|
||||||
|
|
||||||
|
# Add static ui resources and libsciter to same folder as binary so that it
|
||||||
|
# can find them.
|
||||||
|
postInstall = ''
|
||||||
|
mkdir -p $out/{share/src,lib/rustdesk}
|
||||||
|
|
||||||
|
# so needs to be next to the executable
|
||||||
|
mv $out/bin/rustdesk $out/lib/rustdesk
|
||||||
|
ln -s ${libsciter}/lib/libsciter-gtk.so $out/lib/rustdesk
|
||||||
|
|
||||||
|
makeWrapper $out/lib/rustdesk/rustdesk $out/bin/rustdesk \
|
||||||
|
--run "cd $out/share"
|
||||||
|
|
||||||
|
cp -a $src/src/ui $out/share/src
|
||||||
|
|
||||||
|
install -Dm0644 $src/logo.svg $out/share/icons/hicolor/scalable/apps/rustdesk.svg
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "Yet another remote desktop software";
|
||||||
|
homepage = "https://rustdesk.com";
|
||||||
|
license = licenses.gpl3Only;
|
||||||
|
maintainers = with maintainers; [ leixb ];
|
||||||
|
platforms = [ "x86_64-linux" ];
|
||||||
|
mainProgram = "rustdesk";
|
||||||
|
};
|
||||||
|
}
|
@ -9542,6 +9542,8 @@ with pkgs;
|
|||||||
inherit (darwin.apple_sdk.frameworks) Security;
|
inherit (darwin.apple_sdk.frameworks) Security;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
rustdesk = callPackage ../applications/networking/remote/rustdesk { };
|
||||||
|
|
||||||
rustscan = callPackage ../tools/security/rustscan {
|
rustscan = callPackage ../tools/security/rustscan {
|
||||||
inherit (darwin.apple_sdk.frameworks) Security;
|
inherit (darwin.apple_sdk.frameworks) Security;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user