summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBenjamin Hipple <bhipple@protonmail.com>2018-07-12 22:22:48 +0000
committerBenjamin Hipple <bhipple@protonmail.com>2018-07-12 23:08:36 -0400
commit47dfba89d18db76ee2f95905ee23e3c7f9d3f8cd (patch)
tree80945c4a1b35af7095d2f46b93ce2e1281e56cac
parentMerge pull request #43424 from dtzWill/update/qtmatrix-quaternion (diff)
downloadnixpkgs-47dfba89d18db76ee2f95905ee23e3c7f9d3f8cd.tar.gz
s4cmd: init at 2.0.1
Tool for interacting with S3 buckets, with some performance optimizations over s3cmd. Skips installing the bash shell completion scripts in /etc, to work around: https://github.com/NixOS/nixpkgs/issues/4968 https://github.com/pypa/setuptools/issues/130
-rw-r--r--pkgs/tools/networking/s4cmd/default.nix35
-rw-r--r--pkgs/top-level/all-packages.nix2
2 files changed, 37 insertions, 0 deletions
diff --git a/pkgs/tools/networking/s4cmd/default.nix b/pkgs/tools/networking/s4cmd/default.nix
new file mode 100644
index 000000000000..20f129357dff
--- /dev/null
+++ b/pkgs/tools/networking/s4cmd/default.nix
@@ -0,0 +1,35 @@
+{ stdenv, python3Packages }:
+
+python3Packages.buildPythonApplication rec {
+ pname = "s4cmd";
+ version = "2.0.1";
+
+ src = python3Packages.fetchPypi {
+ inherit pname version;
+ sha256 = "14gfpnj4xa1sq3x3zd29drpzsygn998y32szwm069ma0w9jwjjz6";
+ };
+
+ propagatedBuildInputs = with python3Packages; [ boto3 pytz ];
+
+ # The upstream package tries to install some bash shell completion scripts in /etc.
+ # Setuptools is bugged and doesn't handle --prefix properly: https://github.com/pypa/setuptools/issues/130
+ patchPhase = ''
+ sed -i '/ data_files=/d' setup.py
+ sed -i 's|os.chmod("/etc.*|pass|' setup.py
+ '';
+
+ # Replace upstream's s4cmd wrapper script with the built-in Nix wrapper
+ postInstall = ''
+ ln -fs $out/bin/s4cmd.py $out/bin/s4cmd
+ '';
+
+ # Test suite requires an S3 bucket
+ doCheck = false;
+
+ meta = with stdenv.lib; {
+ homepage = https://github.com/bloomreach/s4cmd;
+ description = "Super S3 command line tool";
+ license = licenses.asl20;
+ maintainers = [ maintainers.bhipple ];
+ };
+}
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index 9c3109df6d06..6d7f5ce06340 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -4912,6 +4912,8 @@ with pkgs;
s3cmd = callPackage ../tools/networking/s3cmd { };
+ s4cmd = callPackage ../tools/networking/s4cmd { };
+
s3gof3r = callPackage ../tools/networking/s3gof3r { };
s6Dns = callPackage ../tools/networking/s6-dns { };