Merge pull request #140726 from ShamrockLee/davix
This commit is contained in:
commit
a233a376c2
2 changed files with 60 additions and 10 deletions
|
@ -1,19 +1,67 @@
|
||||||
{ lib, stdenv, fetchurl, cmake, pkg-config, openssl, libxml2, boost, python3, libuuid }:
|
{ lib
|
||||||
|
, stdenv
|
||||||
|
, fetchurl
|
||||||
|
, cmake
|
||||||
|
, pkg-config
|
||||||
|
, openssl
|
||||||
|
, libxml2
|
||||||
|
, boost
|
||||||
|
, python3
|
||||||
|
, libuuid
|
||||||
|
, curl
|
||||||
|
, gsoap
|
||||||
|
, enableTools ? true
|
||||||
|
# Build the bundled libcurl
|
||||||
|
# and, if defaultToLibCurl,
|
||||||
|
# use instead of an external one
|
||||||
|
, useEmbeddedLibcurl ? true
|
||||||
|
# Use libcurl instead of libneon
|
||||||
|
# Note that the libneon used is bundled in the project
|
||||||
|
# See https://github.com/cern-fts/davix/issues/23
|
||||||
|
, defaultToLibcurl ? false
|
||||||
|
, enableIpv6 ? true
|
||||||
|
, enableTcpNodelay ? true
|
||||||
|
# Build davix_copy.so
|
||||||
|
, enableThirdPartyCopy ? false
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
boolToUpper = b: lib.toUpper (lib.boolToString b);
|
||||||
|
in
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
version = "0.7.6";
|
version = "0.8.0";
|
||||||
pname = "davix";
|
pname = "davix";
|
||||||
nativeBuildInputs = [ cmake pkg-config python3 ];
|
nativeBuildInputs = [ cmake pkg-config python3 ];
|
||||||
buildInputs = [ openssl libxml2 boost libuuid ];
|
buildInputs = [
|
||||||
|
openssl
|
||||||
|
libxml2
|
||||||
|
boost
|
||||||
|
libuuid
|
||||||
|
] ++ lib.optional (defaultToLibcurl && !useEmbeddedLibcurl) curl
|
||||||
|
++ lib.optional (enableThirdPartyCopy) gsoap;
|
||||||
|
|
||||||
# using the url below since the github release page states
|
# using the url below since the github release page states
|
||||||
# "please ignore the GitHub-generated tarballs, as they are incomplete"
|
# "please ignore the GitHub-generated tarballs, as they are incomplete"
|
||||||
# https://github.com/cern-fts/davix/releases/tag/R_0_7_6
|
# https://github.com/cern-fts/davix/releases/tag/R_0_8_0
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "https://github.com/cern-fts/${pname}/releases/download/R_${lib.replaceStrings ["."] ["_"] version}/${pname}-${version}.tar.gz";
|
url = "https://github.com/cern-fts/${pname}/releases/download/R_${lib.replaceStrings ["."] ["_"] version}/${pname}-${version}.tar.gz";
|
||||||
sha256 = "0wq66spnr616cns72f9dvr2xfvkdvfqqmc6d7dx29fpp57zzvrx2";
|
sha256 = "LxCNoECKg/tbnwxoFQ02C6cz5LOg/imNRbDTLSircSQ=";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
preConfigure = ''
|
||||||
|
find . -mindepth 1 -maxdepth 1 -type f -name "patch*.sh" -print0 | while IFS= read -r -d ''' file; do
|
||||||
|
patchShebangs "$file"
|
||||||
|
done
|
||||||
|
'';
|
||||||
|
|
||||||
|
cmakeFlags = [
|
||||||
|
"-DENABLE_TOOLS=${boolToUpper enableTools}"
|
||||||
|
"-DEMBEDDED_LIBCURL=${boolToUpper useEmbeddedLibcurl}"
|
||||||
|
"-DLIBCURL_BACKEND_BY_DEFAULT=${boolToUpper defaultToLibcurl}"
|
||||||
|
"-DENABLE_IPV6=${boolToUpper enableIpv6}"
|
||||||
|
"-DENABLE_TCP_NODELAY=${boolToUpper enableTcpNodelay}"
|
||||||
|
"-DENABLE_THIRD_PARTY_COPY=${boolToUpper enableThirdPartyCopy}"
|
||||||
|
];
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
description = "Toolkit for Http-based file management";
|
description = "Toolkit for Http-based file management";
|
||||||
|
@ -22,10 +70,10 @@ stdenv.mkDerivation rec {
|
||||||
operations with Http based protocols (WebDav, Amazon S3, ...).
|
operations with Http based protocols (WebDav, Amazon S3, ...).
|
||||||
Davix provides an API and a set of command line tools";
|
Davix provides an API and a set of command line tools";
|
||||||
|
|
||||||
license = licenses.lgpl2Plus;
|
license = licenses.lgpl2Plus;
|
||||||
homepage = "http://dmc.web.cern.ch/projects/davix/home";
|
homepage = "http://dmc.web.cern.ch/projects/davix/home";
|
||||||
maintainers = [ maintainers.adev ];
|
changelog = "https://github.com/cern-fts/davix/blob/devel/RELEASE-NOTES.md";
|
||||||
platforms = platforms.all;
|
maintainers = with maintainers; [ adev ];
|
||||||
|
platforms = platforms.all;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3734,6 +3734,8 @@ with pkgs;
|
||||||
|
|
||||||
davix = callPackage ../tools/networking/davix { };
|
davix = callPackage ../tools/networking/davix { };
|
||||||
|
|
||||||
|
davix-copy = appendToName "copy" (davix.override { enableThirdPartyCopy = true; });
|
||||||
|
|
||||||
cantata = libsForQt5.callPackage ../applications/audio/cantata { };
|
cantata = libsForQt5.callPackage ../applications/audio/cantata { };
|
||||||
|
|
||||||
cantoolz = python3Packages.callPackage ../tools/networking/cantoolz { };
|
cantoolz = python3Packages.callPackage ../tools/networking/cantoolz { };
|
||||||
|
|
Loading…
Reference in a new issue