add prey: Proven tracking software that helps you find, lock and recover your devices when stolen or missing
This commit is contained in:
parent
75bb099867
commit
30933abb97
@ -61,6 +61,7 @@
|
||||
./security/pam.nix
|
||||
./security/pam_usb.nix
|
||||
./security/polkit.nix
|
||||
./security/prey.nix
|
||||
./security/rngd.nix
|
||||
./security/rtkit.nix
|
||||
./security/setuid-wrappers.nix
|
||||
|
42
nixos/modules/security/prey.nix
Normal file
42
nixos/modules/security/prey.nix
Normal file
@ -0,0 +1,42 @@
|
||||
{config, pkgs, ...}:
|
||||
|
||||
with pkgs.lib;
|
||||
|
||||
let
|
||||
cfg = config.services.prey;
|
||||
myPrey = pkgs."prey-bash-client".override {
|
||||
apiKey = cfg.apiKey;
|
||||
deviceKey = cfg.deviceKey;
|
||||
};
|
||||
in {
|
||||
options = {
|
||||
|
||||
services.prey = {
|
||||
enable = mkOption {
|
||||
default = false;
|
||||
type = types.bool;
|
||||
description = ''
|
||||
Enables http://preyproject.com/ bash client. Be sure to specify api and device keys.
|
||||
Once setup, cronjob will run evert 15 minutes and report status.
|
||||
'';
|
||||
};
|
||||
|
||||
deviceKey = mkOption {
|
||||
type = types.string;
|
||||
description = "Device Key obtained from https://panel.preyproject.com/devices (and clicking on the device)";
|
||||
};
|
||||
|
||||
apiKey = mkOption {
|
||||
type = types.string;
|
||||
description = "API key obtained from https://panel.preyproject.com/profile";
|
||||
};
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
config = mkIf cfg.enable {
|
||||
environment.systemPackages = [ myPrey ];
|
||||
services.cron.systemCronJobs = [ "*/15 * * * * root ${myPrey}/prey.sh" ];
|
||||
};
|
||||
|
||||
}
|
46
pkgs/tools/security/prey/default.nix
Normal file
46
pkgs/tools/security/prey/default.nix
Normal file
@ -0,0 +1,46 @@
|
||||
{ stdenv, fetchurl, fetchgit, curl, scrot, imagemagick, xawtv, inetutils, makeWrapper, coreutils
|
||||
, apiKey ? null
|
||||
, deviceKey ? null }:
|
||||
|
||||
# TODO: this should assert keys are set, somehow if set through .override assertion fails
|
||||
#assert apiKey != null;
|
||||
#assert deviceKey != null;
|
||||
|
||||
let
|
||||
modulesSrc = fetchgit {
|
||||
url = "git://github.com/prey/prey-bash-client-modules.git";
|
||||
rev = "aba260ef110834cb2e92923a31f50c15970639ee";
|
||||
};
|
||||
in stdenv.mkDerivation rec {
|
||||
name = "prey-bash-client-${version}";
|
||||
version = "0.6.0";
|
||||
|
||||
src = fetchurl {
|
||||
url = "https://github.com/prey/prey-bash-client/archive/v${version}.tar.gz";
|
||||
sha256 = "09cb15jh4jdwvix9nx048ajkw2r5jaflk68y3rkha541n8n0qwh0";
|
||||
};
|
||||
|
||||
buildInputs = [ curl scrot imagemagick xawtv makeWrapper ];
|
||||
|
||||
phases = "unpackPhase installPhase";
|
||||
|
||||
installPhase = ''
|
||||
substituteInPlace config --replace api_key=\'\' "api_key='${apiKey}'"
|
||||
substituteInPlace config --replace device_key=\'\' "device_key='${deviceKey}'"
|
||||
|
||||
substituteInPlace prey.sh --replace /bin/bash $(type -Pp bash)
|
||||
mkdir -p $out/modules
|
||||
cp -R . $out
|
||||
cp -R ${modulesSrc}/* $out/modules/
|
||||
wrapProgram "$out/prey.sh" \
|
||||
--prefix PATH ":" "${xawtv}/bin:${imagemagick}/bin:${curl}/bin:${scrot}/bin:${inetutils}/bin:${coreutils}/bin" \
|
||||
--set CURL_CA_BUNDLE "/etc/ssl/certs/ca-bundle.crt"
|
||||
'';
|
||||
|
||||
meta = with stdenv.lib; {
|
||||
homepage = http://preyproject.com;
|
||||
description = "Proven tracking software that helps you find, lock and recover your devices when stolen or missing";
|
||||
maintainers = with maintainers; [ iElectric ];
|
||||
license = licenses.gpl3;
|
||||
};
|
||||
}
|
@ -1597,6 +1597,8 @@ let
|
||||
|
||||
pptp = callPackage ../tools/networking/pptp {};
|
||||
|
||||
"prey-bash-client" = callPackage ../tools/security/prey { };
|
||||
|
||||
proxychains = callPackage ../tools/networking/proxychains { };
|
||||
|
||||
proxytunnel = callPackage ../tools/misc/proxytunnel { };
|
||||
|
Loading…
Reference in New Issue
Block a user