diff options
Diffstat (limited to 'pkgs/mx-puppet-slack')
| -rw-r--r-- | pkgs/mx-puppet-slack/default.nix | 59 | ||||
| -rwxr-xr-x | pkgs/mx-puppet-slack/generate.sh | 24 | ||||
| -rw-r--r-- | pkgs/mx-puppet-slack/node-composition.nix | 20 | ||||
| -rw-r--r-- | pkgs/mx-puppet-slack/node-env.nix | 578 | ||||
| -rw-r--r-- | pkgs/mx-puppet-slack/node-packages.nix | 4217 | 
5 files changed, 4898 insertions, 0 deletions
| diff --git a/pkgs/mx-puppet-slack/default.nix b/pkgs/mx-puppet-slack/default.nix new file mode 100644 index 0000000..ddc4ef2 --- /dev/null +++ b/pkgs/mx-puppet-slack/default.nix @@ -0,0 +1,59 @@ +{ stdenv +, fetchFromGitHub +, pkgs +, lib +, nodejs +, nodePackages +, pkg-config +, libjpeg +, pixman +, cairo +, pango +}: + +let +  # No official version ever released +  src = fetchFromGitHub { +    owner = "Sorunome"; +    repo = pname; +    rev = "691e53d2d703bd169e1f23a8d8dff3f008d8c4ef"; +    sha256 = "sha256-cjRmlVCk6jX+CCQiAc/dcormPLe/BafBJeRHCv6Mu1k="; +  }; + +  myNodePackages = import ./node-composition.nix { +    inherit pkgs nodejs; +    inherit (stdenv.hostPlatform) system; +  }; + +  pname = "mx-puppet-slack"; + +in +myNodePackages.package.override { + +  inherit src; + +  nativeBuildInputs = [ nodePackages.node-pre-gyp pkg-config ]; +  buildInputs = [ libjpeg pixman cairo pango ]; + +  postInstall = '' +    # Patch shebangs in node_modules, otherwise the webpack build fails with interpreter problems +    patchShebangs --build "$out/lib/node_modules/${pname}/node_modules/" +    # compile Typescript sources +    npm run build +    # Make an executable to run the server +    mkdir -p $out/bin +    cat <<EOF > $out/bin/${pname} +    #!/bin/sh +    exec ${nodejs}/bin/node $out/lib/node_modules/${pname}/build/index.js "\$@" +    EOF +    chmod +x $out/bin/${pname} +  ''; + +  meta = with lib; { +    description = "A slack puppeting bridge for matrix"; +    license = licenses.asl20; +    homepage = "https://github.com/Sorunome/mx-puppet-slack"; +    maintainers = with maintainers; [ pacman99 ]; +    platforms = platforms.unix; +  }; +} diff --git a/pkgs/mx-puppet-slack/generate.sh b/pkgs/mx-puppet-slack/generate.sh new file mode 100755 index 0000000..d36f515 --- /dev/null +++ b/pkgs/mx-puppet-slack/generate.sh @@ -0,0 +1,24 @@ +#!/usr/bin/env bash + + +#!/usr/bin/env nix-shell +#! nix-shell -i bash -p nodePackages.node2nix + +# No official release +rev=691e53d2d703bd169e1f23a8d8dff3f008d8c4ef +u=https://raw.githubusercontent.com/Sorunome/mx-puppet-slack/$rev +# Download package.json and package-lock.json +curl -O $u/package.json +curl -O $u/package-lock.json + +node2nix \ +  --nodejs-12 \ +  --node-env node-env.nix \ +  --input package.json \ +  --lock package-lock.json \ +  --output node-packages.nix \ +  --composition node-composition.nix + +sed -i 's|<nixpkgs>|../../..|' node-composition.nix + +rm -f package.json package-lock.json diff --git a/pkgs/mx-puppet-slack/node-composition.nix b/pkgs/mx-puppet-slack/node-composition.nix new file mode 100644 index 0000000..16fd035 --- /dev/null +++ b/pkgs/mx-puppet-slack/node-composition.nix @@ -0,0 +1,20 @@ +# This file has been generated by node2nix 1.9.0. Do not edit! + +{ pkgs ? import ../../.. { +    inherit system; +  } +, system ? builtins.currentSystem +, nodejs ? pkgs."nodejs-12_x" +}: + +let +  nodeEnv = import ./node-env.nix { +    inherit (pkgs) stdenv lib python2 runCommand writeTextFile; +    inherit pkgs nodejs; +    libtool = if pkgs.stdenv.isDarwin then pkgs.darwin.cctools else null; +  }; +in +import ./node-packages.nix { +  inherit (pkgs) fetchurl nix-gitignore stdenv lib fetchgit; +  inherit nodeEnv; +} diff --git a/pkgs/mx-puppet-slack/node-env.nix b/pkgs/mx-puppet-slack/node-env.nix new file mode 100644 index 0000000..576ce15 --- /dev/null +++ b/pkgs/mx-puppet-slack/node-env.nix @@ -0,0 +1,578 @@ +# This file originates from node2nix + +{ lib, stdenv, nodejs, python2, pkgs, libtool, runCommand, writeTextFile }: + +let +  # Workaround to cope with utillinux in Nixpkgs 20.09 and util-linux in Nixpkgs master +  utillinux = if pkgs ? utillinux then pkgs.utillinux else pkgs.util-linux; + +  python = if nodejs ? python then nodejs.python else python2; + +  # Create a tar wrapper that filters all the 'Ignoring unknown extended header keyword' noise +  tarWrapper = runCommand "tarWrapper" { } '' +    mkdir -p $out/bin + +    cat > $out/bin/tar <<EOF +    #! ${stdenv.shell} -e +    $(type -p tar) "\$@" --warning=no-unknown-keyword --delay-directory-restore +    EOF + +    chmod +x $out/bin/tar +  ''; + +  # Function that generates a TGZ file from a NPM project +  buildNodeSourceDist = +    { name, version, src, ... }: + +    stdenv.mkDerivation { +      name = "node-tarball-${name}-${version}"; +      inherit src; +      buildInputs = [ nodejs ]; +      buildPhase = '' +        export HOME=$TMPDIR +        tgzFile=$(npm pack | tail -n 1) # Hooks to the pack command will add output (https://docs.npmjs.com/misc/scripts) +      ''; +      installPhase = '' +        mkdir -p $out/tarballs +        mv $tgzFile $out/tarballs +        mkdir -p $out/nix-support +        echo "file source-dist $out/tarballs/$tgzFile" >> $out/nix-support/hydra-build-products +      ''; +    }; + +  includeDependencies = { dependencies }: +    lib.optionalString (dependencies != [ ]) +      (lib.concatMapStrings +        (dependency: +          '' +            # Bundle the dependencies of the package +            mkdir -p node_modules +            cd node_modules + +            # Only include dependencies if they don't exist. They may also be bundled in the package. +            if [ ! -e "${dependency.name}" ] +            then +                ${composePackage dependency} +            fi + +            cd .. +          '' +        ) +        dependencies); + +  # Recursively composes the dependencies of a package +  composePackage = { name, packageName, src, dependencies ? [ ], ... }@args: +    builtins.addErrorContext "while evaluating node package '${packageName}'" '' +      DIR=$(pwd) +      cd $TMPDIR + +      unpackFile ${src} + +      # Make the base dir in which the target dependency resides first +      mkdir -p "$(dirname "$DIR/${packageName}")" + +      if [ -f "${src}" ] +      then +          # Figure out what directory has been unpacked +          packageDir="$(find . -maxdepth 1 -type d | tail -1)" + +          # Restore write permissions to make building work +          find "$packageDir" -type d -exec chmod u+x {} \; +          chmod -R u+w "$packageDir" + +          # Move the extracted tarball into the output folder +          mv "$packageDir" "$DIR/${packageName}" +      elif [ -d "${src}" ] +      then +          # Get a stripped name (without hash) of the source directory. +          # On old nixpkgs it's already set internally. +          if [ -z "$strippedName" ] +          then +              strippedName="$(stripHash ${src})" +          fi + +          # Restore write permissions to make building work +          chmod -R u+w "$strippedName" + +          # Move the extracted directory into the output folder +          mv "$strippedName" "$DIR/${packageName}" +      fi + +      # Unset the stripped name to not confuse the next unpack step +      unset strippedName + +      # Include the dependencies of the package +      cd "$DIR/${packageName}" +      ${includeDependencies { inherit dependencies; }} +      cd .. +      ${lib.optionalString (builtins.substring 0 1 packageName == "@") "cd .."} +    ''; + +  pinpointDependencies = { dependencies, production }: +    let +      pinpointDependenciesFromPackageJSON = writeTextFile { +        name = "pinpointDependencies.js"; +        text = '' +          var fs = require('fs'); +          var path = require('path'); + +          function resolveDependencyVersion(location, name) { +              if(location == process.env['NIX_STORE']) { +                  return null; +              } else { +                  var dependencyPackageJSON = path.join(location, "node_modules", name, "package.json"); + +                  if(fs.existsSync(dependencyPackageJSON)) { +                      var dependencyPackageObj = JSON.parse(fs.readFileSync(dependencyPackageJSON)); + +                      if(dependencyPackageObj.name == name) { +                          return dependencyPackageObj.version; +                      } +                  } else { +                      return resolveDependencyVersion(path.resolve(location, ".."), name); +                  } +              } +          } + +          function replaceDependencies(dependencies) { +              if(typeof dependencies == "object" && dependencies !== null) { +                  for(var dependency in dependencies) { +                      var resolvedVersion = resolveDependencyVersion(process.cwd(), dependency); + +                      if(resolvedVersion === null) { +                          process.stderr.write("WARNING: cannot pinpoint dependency: "+dependency+", context: "+process.cwd()+"\n"); +                      } else { +                          dependencies[dependency] = resolvedVersion; +                      } +                  } +              } +          } + +          /* Read the package.json configuration */ +          var packageObj = JSON.parse(fs.readFileSync('./package.json')); + +          /* Pinpoint all dependencies */ +          replaceDependencies(packageObj.dependencies); +          if(process.argv[2] == "development") { +              replaceDependencies(packageObj.devDependencies); +          } +          replaceDependencies(packageObj.optionalDependencies); + +          /* Write the fixed package.json file */ +          fs.writeFileSync("package.json", JSON.stringify(packageObj, null, 2)); +        ''; +      }; +    in +    '' +      node ${pinpointDependenciesFromPackageJSON} ${if production then "production" else "development"} + +      ${lib.optionalString (dependencies != []) +        '' +          if [ -d node_modules ] +          then +              cd node_modules +              ${lib.concatMapStrings (dependency: pinpointDependenciesOfPackage dependency) dependencies} +              cd .. +          fi +        ''} +    ''; + +  # Recursively traverses all dependencies of a package and pinpoints all +  # dependencies in the package.json file to the versions that are actually +  # being used. + +  pinpointDependenciesOfPackage = { packageName, dependencies ? [ ], production ? true, ... }@args: +    '' +      if [ -d "${packageName}" ] +      then +          cd "${packageName}" +          ${pinpointDependencies { inherit dependencies production; }} +          cd .. +          ${lib.optionalString (builtins.substring 0 1 packageName == "@") "cd .."} +      fi +    ''; + +  # Extract the Node.js source code which is used to compile packages with +  # native bindings +  nodeSources = runCommand "node-sources" { } '' +    tar --no-same-owner --no-same-permissions -xf ${nodejs.src} +    mv node-* $out +  ''; + +  # Script that adds _integrity fields to all package.json files to prevent NPM from consulting the cache (that is empty) +  addIntegrityFieldsScript = writeTextFile { +    name = "addintegrityfields.js"; +    text = '' +      var fs = require('fs'); +      var path = require('path'); + +      function augmentDependencies(baseDir, dependencies) { +          for(var dependencyName in dependencies) { +              var dependency = dependencies[dependencyName]; + +              // Open package.json and augment metadata fields +              var packageJSONDir = path.join(baseDir, "node_modules", dependencyName); +              var packageJSONPath = path.join(packageJSONDir, "package.json"); + +              if(fs.existsSync(packageJSONPath)) { // Only augment packages that exist. Sometimes we may have production installs in which development dependencies can be ignored +                  console.log("Adding metadata fields to: "+packageJSONPath); +                  var packageObj = JSON.parse(fs.readFileSync(packageJSONPath)); + +                  if(dependency.integrity) { +                      packageObj["_integrity"] = dependency.integrity; +                  } else { +                      packageObj["_integrity"] = "sha1-000000000000000000000000000="; // When no _integrity string has been provided (e.g. by Git dependencies), add a dummy one. It does not seem to harm and it bypasses downloads. +                  } + +                  if(dependency.resolved) { +                      packageObj["_resolved"] = dependency.resolved; // Adopt the resolved property if one has been provided +                  } else { +                      packageObj["_resolved"] = dependency.version; // Set the resolved version to the version identifier. This prevents NPM from cloning Git repositories. +                  } + +                  if(dependency.from !== undefined) { // Adopt from property if one has been provided +                      packageObj["_from"] = dependency.from; +                  } + +                  fs.writeFileSync(packageJSONPath, JSON.stringify(packageObj, null, 2)); +              } + +              // Augment transitive dependencies +              if(dependency.dependencies !== undefined) { +                  augmentDependencies(packageJSONDir, dependency.dependencies); +              } +          } +      } + +      if(fs.existsSync("./package-lock.json")) { +          var packageLock = JSON.parse(fs.readFileSync("./package-lock.json")); + +          if(![1, 2].includes(packageLock.lockfileVersion)) { +            process.stderr.write("Sorry, I only understand lock file versions 1 and 2!\n"); +            process.exit(1); +          } + +          if(packageLock.dependencies !== undefined) { +              augmentDependencies(".", packageLock.dependencies); +          } +      } +    ''; +  }; + +  # Reconstructs a package-lock file from the node_modules/ folder structure and package.json files with dummy sha1 hashes +  reconstructPackageLock = writeTextFile { +    name = "addintegrityfields.js"; +    text = '' +      var fs = require('fs'); +      var path = require('path'); + +      var packageObj = JSON.parse(fs.readFileSync("package.json")); + +      var lockObj = { +          name: packageObj.name, +          version: packageObj.version, +          lockfileVersion: 1, +          requires: true, +          dependencies: {} +      }; + +      function augmentPackageJSON(filePath, dependencies) { +          var packageJSON = path.join(filePath, "package.json"); +          if(fs.existsSync(packageJSON)) { +              var packageObj = JSON.parse(fs.readFileSync(packageJSON)); +              dependencies[packageObj.name] = { +                  version: packageObj.version, +                  integrity: "sha1-000000000000000000000000000=", +                  dependencies: {} +              }; +              processDependencies(path.join(filePath, "node_modules"), dependencies[packageObj.name].dependencies); +          } +      } + +      function processDependencies(dir, dependencies) { +          if(fs.existsSync(dir)) { +              var files = fs.readdirSync(dir); + +              files.forEach(function(entry) { +                  var filePath = path.join(dir, entry); +                  var stats = fs.statSync(filePath); + +                  if(stats.isDirectory()) { +                      if(entry.substr(0, 1) == "@") { +                          // When we encounter a namespace folder, augment all packages belonging to the scope +                          var pkgFiles = fs.readdirSync(filePath); + +                          pkgFiles.forEach(function(entry) { +                              if(stats.isDirectory()) { +                                  var pkgFilePath = path.join(filePath, entry); +                                  augmentPackageJSON(pkgFilePath, dependencies); +                              } +                          }); +                      } else { +                          augmentPackageJSON(filePath, dependencies); +                      } +                  } +              }); +          } +      } + +      processDependencies("node_modules", lockObj.dependencies); + +      fs.writeFileSync("package-lock.json", JSON.stringify(lockObj, null, 2)); +    ''; +  }; + +  prepareAndInvokeNPM = { packageName, bypassCache, reconstructLock, npmFlags, production }: +    let +      forceOfflineFlag = if bypassCache then "--offline" else "--registry http://www.example.com"; +    in +    '' +      # Pinpoint the versions of all dependencies to the ones that are actually being used +      echo "pinpointing versions of dependencies..." +      source $pinpointDependenciesScriptPath + +      # Patch the shebangs of the bundled modules to prevent them from +      # calling executables outside the Nix store as much as possible +      patchShebangs . + +      # Deploy the Node.js package by running npm install. Since the +      # dependencies have been provided already by ourselves, it should not +      # attempt to install them again, which is good, because we want to make +      # it Nix's responsibility. If it needs to install any dependencies +      # anyway (e.g. because the dependency parameters are +      # incomplete/incorrect), it fails. +      # +      # The other responsibilities of NPM are kept -- version checks, build +      # steps, postprocessing etc. + +      export HOME=$TMPDIR +      cd "${packageName}" +      runHook preRebuild + +      ${lib.optionalString bypassCache '' +        ${lib.optionalString reconstructLock '' +          if [ -f package-lock.json ] +          then +              echo "WARNING: Reconstruct lock option enabled, but a lock file already exists!" +              echo "This will most likely result in version mismatches! We will remove the lock file and regenerate it!" +              rm package-lock.json +          else +              echo "No package-lock.json file found, reconstructing..." +          fi + +          node ${reconstructPackageLock} +        ''} + +        node ${addIntegrityFieldsScript} +      ''} + +      npm ${forceOfflineFlag} --nodedir=${nodeSources} ${npmFlags} ${lib.optionalString production "--production"} rebuild + +      if [ "''${dontNpmInstall-}" != "1" ] +      then +          # NPM tries to download packages even when they already exist if npm-shrinkwrap is used. +          rm -f npm-shrinkwrap.json + +          npm ${forceOfflineFlag} --nodedir=${nodeSources} ${npmFlags} ${lib.optionalString production "--production"} install +      fi +    ''; + +  # Builds and composes an NPM package including all its dependencies +  buildNodePackage = +    { name +    , packageName +    , version +    , dependencies ? [ ] +    , buildInputs ? [ ] +    , production ? true +    , npmFlags ? "" +    , dontNpmInstall ? false +    , bypassCache ? false +    , reconstructLock ? false +    , preRebuild ? "" +    , dontStrip ? true +    , unpackPhase ? "true" +    , buildPhase ? "true" +    , meta ? { } +    , ... +    }@args: + +    let +      extraArgs = removeAttrs args [ "name" "dependencies" "buildInputs" "dontStrip" "dontNpmInstall" "preRebuild" "unpackPhase" "buildPhase" "meta" ]; +    in +    stdenv.mkDerivation ({ +      name = "${name}-${version}"; +      buildInputs = [ tarWrapper python nodejs ] +        ++ lib.optional (stdenv.isLinux) utillinux +        ++ lib.optional (stdenv.isDarwin) libtool +        ++ buildInputs; + +      inherit nodejs; + +      inherit dontStrip; # Stripping may fail a build for some package deployments +      inherit dontNpmInstall preRebuild unpackPhase buildPhase; + +      compositionScript = composePackage args; +      pinpointDependenciesScript = pinpointDependenciesOfPackage args; + +      passAsFile = [ "compositionScript" "pinpointDependenciesScript" ]; + +      installPhase = '' +        # Create and enter a root node_modules/ folder +        mkdir -p $out/lib/node_modules +        cd $out/lib/node_modules + +        # Compose the package and all its dependencies +        source $compositionScriptPath + +        ${prepareAndInvokeNPM { inherit packageName bypassCache reconstructLock npmFlags production; }} + +        # Create symlink to the deployed executable folder, if applicable +        if [ -d "$out/lib/node_modules/.bin" ] +        then +            ln -s $out/lib/node_modules/.bin $out/bin +        fi + +        # Create symlinks to the deployed manual page folders, if applicable +        if [ -d "$out/lib/node_modules/${packageName}/man" ] +        then +            mkdir -p $out/share +            for dir in "$out/lib/node_modules/${packageName}/man/"* +            do +                mkdir -p $out/share/man/$(basename "$dir") +                for page in "$dir"/* +                do +                    ln -s $page $out/share/man/$(basename "$dir") +                done +            done +        fi + +        # Run post install hook, if provided +        runHook postInstall +      ''; + +      meta = { +        # default to Node.js' platforms +        platforms = nodejs.meta.platforms; +      } // meta; +    } // extraArgs); + +  # Builds a node environment (a node_modules folder and a set of binaries) +  buildNodeDependencies = +    { name +    , packageName +    , version +    , src +    , dependencies ? [ ] +    , buildInputs ? [ ] +    , production ? true +    , npmFlags ? "" +    , dontNpmInstall ? false +    , bypassCache ? false +    , reconstructLock ? false +    , dontStrip ? true +    , unpackPhase ? "true" +    , buildPhase ? "true" +    , ... +    }@args: + +    let +      extraArgs = removeAttrs args [ "name" "dependencies" "buildInputs" ]; +    in +    stdenv.mkDerivation ({ +      name = "node-dependencies-${name}-${version}"; + +      buildInputs = [ tarWrapper python nodejs ] +        ++ lib.optional (stdenv.isLinux) utillinux +        ++ lib.optional (stdenv.isDarwin) libtool +        ++ buildInputs; + +      inherit dontStrip; # Stripping may fail a build for some package deployments +      inherit dontNpmInstall unpackPhase buildPhase; + +      includeScript = includeDependencies { inherit dependencies; }; +      pinpointDependenciesScript = pinpointDependenciesOfPackage args; + +      passAsFile = [ "includeScript" "pinpointDependenciesScript" ]; + +      installPhase = '' +        mkdir -p $out/${packageName} +        cd $out/${packageName} + +        source $includeScriptPath + +        # Create fake package.json to make the npm commands work properly +        cp ${src}/package.json . +        chmod 644 package.json +        ${lib.optionalString bypassCache '' +          if [ -f ${src}/package-lock.json ] +          then +              cp ${src}/package-lock.json . +          fi +        ''} + +        # Go to the parent folder to make sure that all packages are pinpointed +        cd .. +        ${lib.optionalString (builtins.substring 0 1 packageName == "@") "cd .."} + +        ${prepareAndInvokeNPM { inherit packageName bypassCache reconstructLock npmFlags production; }} + +        # Expose the executables that were installed +        cd .. +        ${lib.optionalString (builtins.substring 0 1 packageName == "@") "cd .."} + +        mv ${packageName} lib +        ln -s $out/lib/node_modules/.bin $out/bin +      ''; +    } // extraArgs); + +  # Builds a development shell +  buildNodeShell = +    { name +    , packageName +    , version +    , src +    , dependencies ? [ ] +    , buildInputs ? [ ] +    , production ? true +    , npmFlags ? "" +    , dontNpmInstall ? false +    , bypassCache ? false +    , reconstructLock ? false +    , dontStrip ? true +    , unpackPhase ? "true" +    , buildPhase ? "true" +    , ... +    }@args: + +    let +      nodeDependencies = buildNodeDependencies args; +    in +    stdenv.mkDerivation { +      name = "node-shell-${name}-${version}"; + +      buildInputs = [ python nodejs ] ++ lib.optional (stdenv.isLinux) utillinux ++ buildInputs; +      buildCommand = '' +        mkdir -p $out/bin +        cat > $out/bin/shell <<EOF +        #! ${stdenv.shell} -e +        $shellHook +        exec ${stdenv.shell} +        EOF +        chmod +x $out/bin/shell +      ''; + +      # Provide the dependencies in a development shell through the NODE_PATH environment variable +      inherit nodeDependencies; +      shellHook = lib.optionalString (dependencies != [ ]) '' +        export NODE_PATH=${nodeDependencies}/lib/node_modules +        export PATH="${nodeDependencies}/bin:$PATH" +      ''; +    }; +in +{ +  buildNodeSourceDist = lib.makeOverridable buildNodeSourceDist; +  buildNodePackage = lib.makeOverridable buildNodePackage; +  buildNodeDependencies = lib.makeOverridable buildNodeDependencies; +  buildNodeShell = lib.makeOverridable buildNodeShell; +} diff --git a/pkgs/mx-puppet-slack/node-packages.nix b/pkgs/mx-puppet-slack/node-packages.nix new file mode 100644 index 0000000..16612c6 --- /dev/null +++ b/pkgs/mx-puppet-slack/node-packages.nix @@ -0,0 +1,4217 @@ +# This file has been generated by node2nix 1.9.0. Do not edit! + +{ nodeEnv, fetchurl, fetchgit, nix-gitignore, stdenv, lib, globalBuildInputs ? [ ] }: + +let +  sources = { +    "@babel/code-frame-7.8.3" = { +      name = "_at_babel_slash_code-frame"; +      packageName = "@babel/code-frame"; +      version = "7.8.3"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.3.tgz"; +        sha512 = "a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g=="; +      }; +    }; +    "@babel/helper-validator-identifier-7.9.5" = { +      name = "_at_babel_slash_helper-validator-identifier"; +      packageName = "@babel/helper-validator-identifier"; +      version = "7.9.5"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.9.5.tgz"; +        sha512 = "/8arLKUFq882w4tWGj9JYzRpAlZgiWUJ+dtteNTDqrRBz9Iguck9Rn3ykuBDoUwh2TO4tSAJlrxDUOXWklJe4g=="; +      }; +    }; +    "@babel/highlight-7.9.0" = { +      name = "_at_babel_slash_highlight"; +      packageName = "@babel/highlight"; +      version = "7.9.0"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@babel/highlight/-/highlight-7.9.0.tgz"; +        sha512 = "lJZPilxX7Op3Nv/2cvFdnlepPXDxi29wxteT57Q965oc5R9v86ztx0jfxVrTcBk8C2kcPkkDa2Z4T3ZsPPVWsQ=="; +      }; +    }; +    "@dabh/diagnostics-2.0.2" = { +      name = "_at_dabh_slash_diagnostics"; +      packageName = "@dabh/diagnostics"; +      version = "2.0.2"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@dabh/diagnostics/-/diagnostics-2.0.2.tgz"; +        sha512 = "+A1YivoVDNNVCdfozHSR8v/jyuuLTMXwjWuxPFlFlUapXoGc+Gj9mDlTDDfrwl7rXCl2tNZ0kE8sIBO6YOn96Q=="; +      }; +    }; +    "@sindresorhus/is-2.1.1" = { +      name = "_at_sindresorhus_slash_is"; +      packageName = "@sindresorhus/is"; +      version = "2.1.1"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@sindresorhus/is/-/is-2.1.1.tgz"; +        sha512 = "/aPsuoj/1Dw/kzhkgz+ES6TxG0zfTMGLwuK2ZG00k/iJzYHTLCE8mVU8EPqEOp/lmxPoq1C1C9RYToRKb2KEfg=="; +      }; +    }; +    "@sindresorhus/is-4.0.1" = { +      name = "_at_sindresorhus_slash_is"; +      packageName = "@sindresorhus/is"; +      version = "4.0.1"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@sindresorhus/is/-/is-4.0.1.tgz"; +        sha512 = "Qm9hBEBu18wt1PO2flE7LPb30BHMQt1eQgbV76YntdNk73XZGpn3izvGTYxbGgzXKgbCjiia0uxTd3aTNQrY/g=="; +      }; +    }; +    "@slack/events-api-2.3.4" = { +      name = "_at_slack_slash_events-api"; +      packageName = "@slack/events-api"; +      version = "2.3.4"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@slack/events-api/-/events-api-2.3.4.tgz"; +        sha512 = "4H+/op+GwIJ5aqpN7K1WcLuyqvpjCw48HYS4Xaw35tN84T0MDfOvQIA6Sacor9OpwCxKaY60Mwo73FT5Q+VvKg=="; +      }; +    }; +    "@slack/logger-1.1.1" = { +      name = "_at_slack_slash_logger"; +      packageName = "@slack/logger"; +      version = "1.1.1"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@slack/logger/-/logger-1.1.1.tgz"; +        sha512 = "PAC5CMnNAv/FPtJ0le+YD2wUV+tZ7n3Bnjj9dBI+deIcHsExCnQkQmZE79cLvfuYXbz3PWyv5coti30MJQhEjA=="; +      }; +    }; +    "@slack/rtm-api-5.0.5" = { +      name = "_at_slack_slash_rtm-api"; +      packageName = "@slack/rtm-api"; +      version = "5.0.5"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@slack/rtm-api/-/rtm-api-5.0.5.tgz"; +        sha512 = "x2B4hyoxjg62cxf4M5QRomx+xYp2XoajPKdd24SM2Sl4m+IrzwKzmcrysQuYmF6BMsm3IoTKymW5BBGckHGTIw=="; +      }; +    }; +    "@slack/types-1.10.0" = { +      name = "_at_slack_slash_types"; +      packageName = "@slack/types"; +      version = "1.10.0"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@slack/types/-/types-1.10.0.tgz"; +        sha512 = "tA7GG7Tj479vojfV3AoxbckalA48aK6giGjNtgH6ihpLwTyHE3fIgRrvt8TWfLwW8X8dyu7vgmAsGLRG7hWWOg=="; +      }; +    }; +    "@slack/web-api-5.15.0" = { +      name = "_at_slack_slash_web-api"; +      packageName = "@slack/web-api"; +      version = "5.15.0"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@slack/web-api/-/web-api-5.15.0.tgz"; +        sha512 = "tjQ8Zqv/Fmj9SOL9yIEd7IpTiKfKHi9DKAkfRVeotoX0clMr3SqQtBqO+KZMX27gm7dmgJsQaDKlILyzdCO+IA=="; +      }; +    }; +    "@sorunome/matrix-bot-sdk-0.5.13" = { +      name = "_at_sorunome_slash_matrix-bot-sdk"; +      packageName = "@sorunome/matrix-bot-sdk"; +      version = "0.5.13"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@sorunome/matrix-bot-sdk/-/matrix-bot-sdk-0.5.13.tgz"; +        sha512 = "WEeuei8/QS9FO76n71nT17TBZ3tRW2POjOpN7YIvsy5tA0WD0tMUKWZDcTo1A+xKOvzgjRTy9v88rKSLIr4wHA=="; +      }; +    }; +    "@szmarczak/http-timer-4.0.5" = { +      name = "_at_szmarczak_slash_http-timer"; +      packageName = "@szmarczak/http-timer"; +      version = "4.0.5"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-4.0.5.tgz"; +        sha512 = "PyRA9sm1Yayuj5OIoJ1hGt2YISX45w9WcFbh6ddT0Z/0yaFxOtGLInr4jUfU1EAFVs0Yfyfev4RNwBlUaHdlDQ=="; +      }; +    }; +    "@types/body-parser-1.19.0" = { +      name = "_at_types_slash_body-parser"; +      packageName = "@types/body-parser"; +      version = "1.19.0"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.0.tgz"; +        sha512 = "W98JrE0j2K78swW4ukqMleo8R7h/pFETjM2DQ90MF6XK2i4LO4W3gQ71Lt4w3bfm2EvVSyWHplECvB5sK22yFQ=="; +      }; +    }; +    "@types/cacheable-request-6.0.1" = { +      name = "_at_types_slash_cacheable-request"; +      packageName = "@types/cacheable-request"; +      version = "6.0.1"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/cacheable-request/-/cacheable-request-6.0.1.tgz"; +        sha512 = "ykFq2zmBGOCbpIXtoVbz4SKY5QriWPh3AjyU4G74RYbtt5yOc5OfaY75ftjg7mikMOla1CTGpX3lLbuJh8DTrQ=="; +      }; +    }; +    "@types/connect-3.4.33" = { +      name = "_at_types_slash_connect"; +      packageName = "@types/connect"; +      version = "3.4.33"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/connect/-/connect-3.4.33.tgz"; +        sha512 = "2+FrkXY4zllzTNfJth7jOqEHC+enpLeGslEhpnTAkg21GkRrWV4SsAtqchtT4YS9/nODBU2/ZfsBY2X4J/dX7A=="; +      }; +    }; +    "@types/debug-4.1.5" = { +      name = "_at_types_slash_debug"; +      packageName = "@types/debug"; +      version = "4.1.5"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/debug/-/debug-4.1.5.tgz"; +        sha512 = "Q1y515GcOdTHgagaVFhHnIFQ38ygs/kmxdNpvpou+raI9UO3YZcHDngBSYKQklcKlvA7iuQlmIKbzvmxcOE9CQ=="; +      }; +    }; +    "@types/express-4.17.8" = { +      name = "_at_types_slash_express"; +      packageName = "@types/express"; +      version = "4.17.8"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/express/-/express-4.17.8.tgz"; +        sha512 = "wLhcKh3PMlyA2cNAB9sjM1BntnhPMiM0JOBwPBqttjHev2428MLEB4AYVN+d8s2iyCVZac+o41Pflm/ZH5vLXQ=="; +      }; +    }; +    "@types/express-serve-static-core-4.17.13" = { +      name = "_at_types_slash_express-serve-static-core"; +      packageName = "@types/express-serve-static-core"; +      version = "4.17.13"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.13.tgz"; +        sha512 = "RgDi5a4nuzam073lRGKTUIaL3eF2+H7LJvJ8eUnCI0wA6SNjXc44DCmWNiTLs/AZ7QlsFWZiw/gTG3nSQGL0fA=="; +      }; +    }; +    "@types/http-cache-semantics-4.0.0" = { +      name = "_at_types_slash_http-cache-semantics"; +      packageName = "@types/http-cache-semantics"; +      version = "4.0.0"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/http-cache-semantics/-/http-cache-semantics-4.0.0.tgz"; +        sha512 = "c3Xy026kOF7QOTn00hbIllV1dLR9hG9NkSrLQgCVs8NF6sBU+VGWjD3wLPhmh1TYAc7ugCFsvHYMN4VcBN1U1A=="; +      }; +    }; +    "@types/is-stream-1.1.0" = { +      name = "_at_types_slash_is-stream"; +      packageName = "@types/is-stream"; +      version = "1.1.0"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/is-stream/-/is-stream-1.1.0.tgz"; +        sha512 = "jkZatu4QVbR60mpIzjINmtS1ZF4a/FqdTUTBeQDVOQ2PYyidtwFKr0B5G6ERukKwliq+7mIXvxyppwzG5EgRYg=="; +      }; +    }; +    "@types/keyv-3.1.1" = { +      name = "_at_types_slash_keyv"; +      packageName = "@types/keyv"; +      version = "3.1.1"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/keyv/-/keyv-3.1.1.tgz"; +        sha512 = "MPtoySlAZQ37VoLaPcTHCu1RWJ4llDkULYZIzOYxlhxBqYPB0RsRlmMU0R6tahtFe27mIdkHV+551ZWV4PLmVw=="; +      }; +    }; +    "@types/lodash-4.14.168" = { +      name = "_at_types_slash_lodash"; +      packageName = "@types/lodash"; +      version = "4.14.168"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.168.tgz"; +        sha512 = "oVfRvqHV/V6D1yifJbVRU3TMp8OT6o6BG+U9MkwuJ3U8/CsDHvalRpsxBqivn71ztOFZBTfJMvETbqHiaNSj7Q=="; +      }; +    }; +    "@types/lodash.isstring-4.0.6" = { +      name = "_at_types_slash_lodash.isstring"; +      packageName = "@types/lodash.isstring"; +      version = "4.0.6"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/lodash.isstring/-/lodash.isstring-4.0.6.tgz"; +        sha512 = "uUGvF9G1G7jQ5H42Y38GA9rZmUoY8wI/OMSwnW0BZA+Ra0uxzpuQf4CixXl3yG3TvF6LjuduMyt1WvKl+je8QA=="; +      }; +    }; +    "@types/mime-2.0.3" = { +      name = "_at_types_slash_mime"; +      packageName = "@types/mime"; +      version = "2.0.3"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/mime/-/mime-2.0.3.tgz"; +        sha512 = "Jus9s4CDbqwocc5pOAnh8ShfrnMcPHuJYzVcSUU7lrh8Ni5HuIqX3oilL86p3dlTrk0LzHRCgA/GQ7uNCw6l2Q=="; +      }; +    }; +    "@types/node-12.12.34" = { +      name = "_at_types_slash_node"; +      packageName = "@types/node"; +      version = "12.12.34"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/node/-/node-12.12.34.tgz"; +        sha512 = "BneGN0J9ke24lBRn44hVHNeDlrXRYF+VRp0HbSUNnEZahXGAysHZIqnf/hER6aabdBgzM4YOV4jrR8gj4Zfi0g=="; +      }; +    }; +    "@types/p-queue-2.3.2" = { +      name = "_at_types_slash_p-queue"; +      packageName = "@types/p-queue"; +      version = "2.3.2"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/p-queue/-/p-queue-2.3.2.tgz"; +        sha512 = "eKAv5Ql6k78dh3ULCsSBxX6bFNuGjTmof5Q/T6PiECDq0Yf8IIn46jCyp3RJvCi8owaEmm3DZH1PEImjBMd/vQ=="; +      }; +    }; +    "@types/prop-types-15.7.3" = { +      name = "_at_types_slash_prop-types"; +      packageName = "@types/prop-types"; +      version = "15.7.3"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.3.tgz"; +        sha512 = "KfRL3PuHmqQLOG+2tGpRO26Ctg+Cq1E01D2DMriKEATHgWLfeNDmq9e29Q9WIky0dQ3NPkd1mzYH8Lm936Z9qw=="; +      }; +    }; +    "@types/qs-6.9.5" = { +      name = "_at_types_slash_qs"; +      packageName = "@types/qs"; +      version = "6.9.5"; +      src = fetchurl { +        url = "https://registry.npmjs.org/@types/qs/-/qs-6.9.5.tgz"; +        sha512 = "/JHkVHtx/REVG0VVToGRGH2+23hsYLHdyG+GrvoUGlGAd0ErauXDyvHtRI/7H7mzLm+tBCKA7pfcpkQ1lf58iQ=="; +      }; +    }; +    "@types/range-parser-1.2.3" = { +      name = "_at_types_slash_range-parser"; | 
