summary refs log tree commit diff
path: root/pkgs/tools
diff options
context:
space:
mode:
authorAlyssa Ross <hi@alyssa.is>2018-08-15 15:45:41 +0100
committerAlyssa Ross <hi@alyssa.is>2018-08-15 15:48:23 +0100
commit026f49e28c535ad04a54d689c773275a7ab99f9f (patch)
treec6646516db0deab9ba972bc91b160b97a3bc07fa /pkgs/tools
parent0a57de6f5b138ab99bfb72efae742a715f46c46e (diff)
downloadnixpkgs-026f49e28c535ad04a54d689c773275a7ab99f9f.tar
nixpkgs-026f49e28c535ad04a54d689c773275a7ab99f9f.tar.gz
nixpkgs-026f49e28c535ad04a54d689c773275a7ab99f9f.tar.bz2
nixpkgs-026f49e28c535ad04a54d689c773275a7ab99f9f.tar.lz
nixpkgs-026f49e28c535ad04a54d689c773275a7ab99f9f.tar.xz
nixpkgs-026f49e28c535ad04a54d689c773275a7ab99f9f.tar.zst
nixpkgs-026f49e28c535ad04a54d689c773275a7ab99f9f.zip
slack-cli: remove wrapper package
Diffstat (limited to 'pkgs/tools')
-rw-r--r--pkgs/tools/networking/slack-cli/default.nix56
-rw-r--r--pkgs/tools/networking/slack-cli/wrapper.nix21
2 files changed, 35 insertions, 42 deletions
diff --git a/pkgs/tools/networking/slack-cli/default.nix b/pkgs/tools/networking/slack-cli/default.nix
index 24d82782466..dc8b25d868c 100644
--- a/pkgs/tools/networking/slack-cli/default.nix
+++ b/pkgs/tools/networking/slack-cli/default.nix
@@ -5,29 +5,43 @@
 # for token storage, except that it would make the Nix package inconsistent with
 # upstream and other distributions.
 
-{ stdenv, fetchFromGitHub }:
+{ stdenv, lib, writeShellScriptBin, fetchFromGitHub, curl, jq }:
 
-stdenv.mkDerivation rec {
-  name = "slack-cli-${version}";
-  version = "0.18.0";
+let
+  wrapper = writeShellScriptBin "slack" ''
+    [ "$1" = "init" -a -z "$SLACK_CLI_TOKEN" ] && cat >&2 <<-'MESSAGE'
+    WARNING: slack-cli must be configured using the SLACK_CLI_TOKEN environment
+    variable. Using `slack init` will not work because it tries to write to the
+    Nix store.
 
-  src = fetchFromGitHub {
-    owner = "rockymadden";
-    repo = "slack-cli";
-    rev = "v${version}";
-    sha256 = "022yr3cpfg0v7cxi62zzk08vp0l3w851qpfh6amyfgjiynnfyddl";
-  };
+    MESSAGE
 
-  dontBuild = true;
-
-  installPhase = ''
-    mkdir -p "$out/bin"
-    cp src/slack "$out/bin"
+    export PATH=${lib.makeBinPath [ curl jq ]}:"$PATH"
+    exec "$(dirname "$0")/.slack-wrapped" "$@"
   '';
 
-  meta = {
-    license = stdenv.lib.licenses.mit;
-    maintainers = [ stdenv.lib.maintainers.qyliss ];
-    platforms = stdenv.lib.platforms.unix;
-  };
-}
+in stdenv.mkDerivation rec {
+    name = "slack-cli-${version}";
+    version = "0.18.0";
+
+    src = fetchFromGitHub {
+      owner = "rockymadden";
+      repo = "slack-cli";
+      rev = "v${version}";
+      sha256 = "022yr3cpfg0v7cxi62zzk08vp0l3w851qpfh6amyfgjiynnfyddl";
+    };
+
+    dontBuild = true;
+
+    installPhase = ''
+      mkdir -p "$out/bin"
+      cp src/slack "$out/bin/.slack-wrapped"
+      ln -s ${wrapper}/bin/slack "$out/bin/slack"
+    '';
+
+    meta = {
+      license = lib.licenses.mit;
+      maintainers = [ lib.maintainers.qyliss ];
+      platforms = lib.platforms.unix;
+    };
+  }
diff --git a/pkgs/tools/networking/slack-cli/wrapper.nix b/pkgs/tools/networking/slack-cli/wrapper.nix
deleted file mode 100644
index f31553bda37..00000000000
--- a/pkgs/tools/networking/slack-cli/wrapper.nix
+++ /dev/null
@@ -1,21 +0,0 @@
-{ lib, writeShellScriptBin, curl, jq }:
-
-slack-cli:
-
-(writeShellScriptBin "slack" ''
-  [ "$1" = "init" -a -z "$SLACK_CLI_TOKEN" ] && cat >&2 <<-'MESSAGE'
-  WARNING: slack-cli must be configured using the SLACK_CLI_TOKEN environment
-  variable. Using `slack init` will not work because it tries to write to the
-  Nix store.
-
-  MESSAGE
-
-  export PATH=${lib.makeBinPath [ curl jq ]}:"$PATH"
-  exec ${slack-cli}/bin/slack "$@"
-'') // {
-  unwrapped = slack-cli;
-
-  meta = slack-cli.meta;
-  name = slack-cli.name;
-  version = slack-cli.version;
-}