]> git.immae.eu Git - perso/Immae/Config/Nix.git/blobdiff - pkgs/python-packages/buildbot/plugins/buildslist/default.nix
Fix packages and make buildslist sandboxed
[perso/Immae/Config/Nix.git] / pkgs / python-packages / buildbot / plugins / buildslist / default.nix
index 372968af31ba51484aaae4dd41aa47d3d60c153d..a1a87b2bd8951df4c1bb3a766582003717767b79 100644 (file)
@@ -1,14 +1,30 @@
-{ mylibs, buildBowerComponents, pythonPackages, yarn, nodejs }:
+{ mylibs, runCommand, buildBowerComponents, pythonPackages, libsass, python, fetchurl, jq, yarn, nodejs }:
 let
   buildslist_src = mylibs.fetchedGit ./buildslist.json;
+  packagejson = runCommand "package.json" { buildInputs = [ jq ]; } ''
+    cat ${buildslist_src.src}/package.json | jq -r '.version = "${pythonPackages.buildbot-pkg.version}"' > $out
+    '';
   buildslist_yarn = mylibs.yarn2nixPackage.mkYarnModules rec {
     name = "buildslist-yarn-modules";
     pname = name;
     inherit (pythonPackages.buildbot-pkg) version;
-    packageJSON = "${buildslist_src.src}/package.json";
+    packageJSON = packagejson;
     yarnLock = "${buildslist_src.src}/yarn.lock";
+    yarnNix = ./yarn-packages.nix;
     pkgConfig = {
       all = { buildInputs = [ mylibs.yarn2nixPackage.src ]; };
+      node-sass = {
+        buildInputs = [ libsass python ];
+        postInstall = let
+          nodeHeaders = fetchurl {
+            url = "https://nodejs.org/download/release/v${nodejs.version}/node-v${nodejs.version}-headers.tar.gz";
+            sha256 = "16f20ya3ys6w5w6y6l4536f7jrgk4gz46bf71w1r1xxb26a54m32";
+          };
+        in
+          ''
+            node scripts/build.js --tarball=${nodeHeaders}
+          '';
+      };
     };
   };
   buildslist_bower = buildBowerComponents {
@@ -23,8 +39,7 @@ pythonPackages.buildPythonPackage rec {
 
   preConfigure = ''
     export HOME=$PWD
-    cp -a ${buildslist_yarn}/node_modules .
-    chmod -R u+w node_modules
+    ln -s ${buildslist_yarn}/node_modules .
     cp -a ${buildslist_bower}/bower_components ./libs
     chmod -R u+w libs
     '';