From 8b91812de6c61ab79eef8c33f2900969ccfb5a63 Mon Sep 17 00:00:00 2001 From: Charles Strahan Date: Mon, 10 Aug 2015 15:01:34 -0400 Subject: [PATCH] pipework: init at 2015-07-30 Pipework lets you connect together containers in arbitrarily complex scenarios. Pipework uses cgroups and namespace and works with "plain" LXC containers (created with lxc-start), and with the awesome Docker. --- pkgs/os-specific/linux/pipework/default.nix | 28 +++++++++++++++++++++ pkgs/top-level/all-packages.nix | 2 ++ 2 files changed, 30 insertions(+) create mode 100644 pkgs/os-specific/linux/pipework/default.nix diff --git a/pkgs/os-specific/linux/pipework/default.nix b/pkgs/os-specific/linux/pipework/default.nix new file mode 100644 index 00000000000..225515cb70a --- /dev/null +++ b/pkgs/os-specific/linux/pipework/default.nix @@ -0,0 +1,28 @@ +{ stdenv, lib, fetchFromGitHub, makeWrapper +, bridge-utils, iproute, lxc, openvswitch, docker, busybox, dhcpcd, dhcp +}: + +stdenv.mkDerivation rec { + name = "pipework-${version}"; + version = "2015-07-30"; + src = fetchFromGitHub { + owner = "jpetazzo"; + repo = "pipework"; + rev = "5a46ecb5f8f933fd268ef315f58a1eb1c46bd93d"; + sha256 = "02znyg5ir37s8xqjcqqz6xnwyqxapn7c4scyqkcapxr932hf1frh"; + }; + buildInputs = [ makeWrapper ]; + installPhase = '' + mkdir -p $out/bin + cp pipework $out/bin + wrapProgram $out/bin/pipework --prefix PATH : \ + ${lib.makeSearchPath "bin" [ bridge-utils iproute lxc openvswitch docker busybox dhcpcd dhcp ]}; + ''; + meta = with lib; { + description = "Software-Defined Networking tools for LXC"; + homepage = "https://github.com/jpetazzo/pipework"; + license = licenses.asl20; + platforms = platforms.linux; + maintainers = with maintainers; [ cstrahan ]; + }; +} diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix index 913949edea2..f3e5d961dbd 100644 --- a/pkgs/top-level/all-packages.nix +++ b/pkgs/top-level/all-packages.nix @@ -10064,6 +10064,8 @@ let perf-tools = callPackage ../os-specific/linux/perf-tools { }; + pipework = callPackage ../os-specific/linux/pipework { }; + plymouth = callPackage ../os-specific/linux/plymouth { }; pmount = callPackage ../os-specific/linux/pmount { };