mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-12-18 03:34:58 +00:00
78 lines
2.7 KiB
Nix
78 lines
2.7 KiB
Nix
|
{ stdenv, fetchurl, makeWrapper, pkgconfig, utillinux, which
|
||
|
, procps, libcap_ng, openssl, python27, iproute , perl
|
||
|
, kernel ? null }:
|
||
|
|
||
|
with stdenv.lib;
|
||
|
|
||
|
let
|
||
|
_kernel = kernel;
|
||
|
in stdenv.mkDerivation rec {
|
||
|
version = "2.5.6";
|
||
|
pname = "openvswitch";
|
||
|
|
||
|
src = fetchurl {
|
||
|
url = "http://openvswitch.org/releases/${pname}-${version}.tar.gz";
|
||
|
sha256 = "14zjcd0ddjv90rwb24l3cac6psd34a9r04jjghn1av0kf6b76zj4";
|
||
|
};
|
||
|
|
||
|
kernel = optional (_kernel != null) _kernel.dev;
|
||
|
|
||
|
nativeBuildInputs = [ pkgconfig ];
|
||
|
buildInputs = [ makeWrapper utillinux openssl libcap_ng python27
|
||
|
perl procps which ];
|
||
|
|
||
|
configureFlags = [
|
||
|
"--localstatedir=/var"
|
||
|
"--sharedstatedir=/var"
|
||
|
"--sbindir=$(out)/bin"
|
||
|
] ++ (optionals (_kernel != null) ["--with-linux"]);
|
||
|
|
||
|
# Leave /var out of this!
|
||
|
installFlags = [
|
||
|
"LOGDIR=$(TMPDIR)/dummy"
|
||
|
"RUNDIR=$(TMPDIR)/dummy"
|
||
|
"PKIDIR=$(TMPDIR)/dummy"
|
||
|
];
|
||
|
|
||
|
postBuild = ''
|
||
|
# fix tests
|
||
|
substituteInPlace xenserver/opt_xensource_libexec_interface-reconfigure --replace '/usr/bin/env python' '${python27.interpreter}'
|
||
|
substituteInPlace vtep/ovs-vtep --replace '/usr/bin/env python' '${python27.interpreter}'
|
||
|
'';
|
||
|
|
||
|
enableParallelBuilding = true;
|
||
|
doCheck = false; # bash-completion test fails with "compgen: command not found"
|
||
|
|
||
|
postInstall = ''
|
||
|
cp debian/ovs-monitor-ipsec $out/share/openvswitch/scripts
|
||
|
makeWrapper \
|
||
|
$out/share/openvswitch/scripts/ovs-monitor-ipsec \
|
||
|
$out/bin/ovs-monitor-ipsec \
|
||
|
--prefix PYTHONPATH : "$out/share/openvswitch/python"
|
||
|
substituteInPlace $out/share/openvswitch/scripts/ovs-monitor-ipsec \
|
||
|
--replace "UnixctlServer.create(None)" "UnixctlServer.create(os.environ['UNIXCTLPATH'])"
|
||
|
substituteInPlace $out/share/openvswitch/scripts/ovs-monitor-ipsec \
|
||
|
--replace "self.psk_file" "root_prefix + self.psk_file"
|
||
|
substituteInPlace $out/share/openvswitch/scripts/ovs-monitor-ipsec \
|
||
|
--replace "self.cert_dir" "root_prefix + self.cert_dir"
|
||
|
'';
|
||
|
|
||
|
meta = with stdenv.lib; {
|
||
|
platforms = platforms.linux;
|
||
|
description = "A multilayer virtual switch";
|
||
|
longDescription =
|
||
|
''
|
||
|
Open vSwitch is a production quality, multilayer virtual switch
|
||
|
licensed under the open source Apache 2.0 license. It is
|
||
|
designed to enable massive network automation through
|
||
|
programmatic extension, while still supporting standard
|
||
|
management interfaces and protocols (e.g. NetFlow, sFlow, SPAN,
|
||
|
RSPAN, CLI, LACP, 802.1ag). In addition, it is designed to
|
||
|
support distribution across multiple physical servers similar
|
||
|
to VMware's vNetwork distributed vswitch or Cisco's Nexus 1000V.
|
||
|
'';
|
||
|
homepage = http://openvswitch.org/;
|
||
|
license = licenses.asl20;
|
||
|
};
|
||
|
}
|