mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-18 07:46:09 +01:00
Merge pull request #178389 from Kranzes/mattermost
This commit is contained in:
commit
5e2899a2c6
2 changed files with 56 additions and 98 deletions
|
@ -1,101 +1,50 @@
|
|||
{ lib, stdenv, fetchurl, fetchFromGitHub, buildGoPackage, buildEnv
|
||||
{ lib
|
||||
, buildGo118Module
|
||||
, fetchFromGitHub
|
||||
, fetchurl
|
||||
, nixosTests
|
||||
}:
|
||||
|
||||
# The suffix for the Mattermost version.
|
||||
, versionSuffix ? "nixpkgs"
|
||||
buildGo118Module rec {
|
||||
pname = "mattermost";
|
||||
version = "7.0.1";
|
||||
|
||||
# The constant build date.
|
||||
, buildDate ? "1970-01-01"
|
||||
|
||||
# Set to true to set the build hash to the Nix store path.
|
||||
, storePathAsBuildHash ? false }:
|
||||
|
||||
let
|
||||
version = "6.3.6";
|
||||
|
||||
goPackagePath = "github.com/mattermost/mattermost-server";
|
||||
|
||||
mattermost-server-build = buildGoPackage rec {
|
||||
pname = "mattermost-server";
|
||||
inherit version goPackagePath;
|
||||
|
||||
src = fetchFromGitHub {
|
||||
owner = "mattermost";
|
||||
repo = "mattermost-server";
|
||||
rev = "v${version}";
|
||||
sha256 = "905zxMucDTxxrLoh5ZoAExW4eFmi+xa98aI3EpJZ2Og=";
|
||||
};
|
||||
|
||||
ldflags = [
|
||||
"-s" "-w"
|
||||
"-X ${goPackagePath}/model.BuildNumber=${version}${lib.optionalString (versionSuffix != null) "-${versionSuffix}"}"
|
||||
"-X ${goPackagePath}/model.BuildDate=${buildDate}"
|
||||
"-X ${goPackagePath}/model.BuildEnterpriseReady=false"
|
||||
];
|
||||
src = fetchFromGitHub {
|
||||
owner = "mattermost";
|
||||
repo = "mattermost-server";
|
||||
rev = "v${version}";
|
||||
sha256 = "sha256-oxZaOOV5pkK9HAi/AQ+MLZgfwvF6d/ArzYrXzUQGTDA=";
|
||||
};
|
||||
|
||||
mattermost-server = if storePathAsBuildHash then mattermost-server-build.overrideAttrs (orig: {
|
||||
buildPhase = ''
|
||||
origGo="$(type -p go)"
|
||||
|
||||
# Override the Go binary to set the build hash in -ldflags to $out.
|
||||
# Technically this is more accurate than a Git hash!
|
||||
# nixpkgs does not appear to support environment variables in ldflags
|
||||
# for go packages, so we have to rewrite -ldflags before calling go.
|
||||
go() {
|
||||
local args=()
|
||||
local ldflags="-X ${goPackagePath}/model.BuildHash=$out"
|
||||
local found=0
|
||||
for arg in "$@"; do
|
||||
if [[ "$arg" == -ldflags=* ]] && [ $found -eq 0 ]; then
|
||||
arg="-ldflags=''${ldflags} ''${arg#-ldflags=}"
|
||||
found=1
|
||||
fi
|
||||
args+=("$arg")
|
||||
done
|
||||
"$origGo" "''${args[@]}"
|
||||
}
|
||||
|
||||
${orig.buildPhase}
|
||||
'';
|
||||
}) else mattermost-server-build;
|
||||
|
||||
mattermost-webapp = stdenv.mkDerivation {
|
||||
pname = "mattermost-webapp";
|
||||
inherit version;
|
||||
|
||||
src = fetchurl {
|
||||
url = "https://releases.mattermost.com/${version}/mattermost-${version}-linux-amd64.tar.gz";
|
||||
sha256 = "JDsCDZEtbeBTYuzOSwrxFNRKXy+9KXirjaCz6ODP5uw=";
|
||||
};
|
||||
|
||||
installPhase = ''
|
||||
mkdir -p $out
|
||||
tar --strip 1 --directory $out -xf $src \
|
||||
mattermost/client \
|
||||
mattermost/i18n \
|
||||
mattermost/fonts \
|
||||
mattermost/templates \
|
||||
mattermost/config
|
||||
|
||||
# For some reason a bunch of these files are +x...
|
||||
find $out -type f -exec chmod -x {} \;
|
||||
'';
|
||||
webapp = fetchurl {
|
||||
url = "https://releases.mattermost.com/${version}/mattermost-${version}-linux-amd64.tar.gz";
|
||||
sha256 = "sha256-NWVDPDqdx7mdWCr/qBi8HsUsCJbT63x37UZGecHsZr4=";
|
||||
};
|
||||
|
||||
in
|
||||
buildEnv {
|
||||
name = "mattermost-${version}";
|
||||
paths = [ mattermost-server mattermost-webapp ];
|
||||
vendorSha256 = "sha256-0sKuk0klxeep8J96RntDP9DHsVM4vrOmsKXiaWurVis=";
|
||||
|
||||
meta = with lib; {
|
||||
description = "Open-source, self-hosted Slack-alternative";
|
||||
homepage = "https://www.mattermost.org";
|
||||
sourceProvenance = with sourceTypes; [
|
||||
fromSource
|
||||
binaryNativeCode # mattermost-webapp
|
||||
];
|
||||
license = with licenses; [ agpl3 asl20 ];
|
||||
maintainers = with maintainers; [ fpletz ryantm numinit ];
|
||||
platforms = platforms.unix;
|
||||
};
|
||||
}
|
||||
subPackages = [ "cmd/mattermost" ];
|
||||
|
||||
ldflags = [
|
||||
"-s"
|
||||
"-w"
|
||||
"-X github.com/mattermost/mattermost-server/v6/model.Version=${version}"
|
||||
];
|
||||
|
||||
postInstall = ''
|
||||
tar --strip 1 --directory $out -xf $webapp \
|
||||
mattermost/{client,i18n,fonts,templates,config}
|
||||
|
||||
# For some reason a bunch of these files are executable
|
||||
find $out/{client,i18n,fonts,templates,config} -type f -exec chmod -x {} \;
|
||||
'';
|
||||
|
||||
passthru.tests.mattermost = nixosTests.mattermost;
|
||||
|
||||
meta = with lib; {
|
||||
description = "Mattermost is an open source platform for secure collaboration across the entire software development lifecycle";
|
||||
homepage = "https://www.mattermost.org";
|
||||
license = with licenses; [ agpl3 asl20 ];
|
||||
maintainers = with maintainers; [ fpletz ryantm numinit kranzes ];
|
||||
};
|
||||
}
|
||||
|
|
|
@ -1,24 +1,33 @@
|
|||
{ lib, fetchFromGitHub, buildGoModule }:
|
||||
{ lib
|
||||
, fetchFromGitHub
|
||||
, buildGoModule
|
||||
}:
|
||||
|
||||
buildGoModule rec {
|
||||
pname = "mmctl";
|
||||
version = "6.4.2";
|
||||
version = "7.0.1";
|
||||
|
||||
src = fetchFromGitHub {
|
||||
owner = "mattermost";
|
||||
repo = "mmctl";
|
||||
rev = "v${version}";
|
||||
sha256 = "sha256-FlqkY4LvAW9Cibs+3UkMDWA+uc62wMh13BllWuxjVZU=";
|
||||
sha256 = "sha256-xNj8aM3hpcvxwXCdFCfkXDBagIdCjcjWLGNp43KsV10=";
|
||||
};
|
||||
|
||||
vendorSha256 = null;
|
||||
|
||||
checkPhase = "make test";
|
||||
|
||||
ldflags = [
|
||||
"-s"
|
||||
"-w"
|
||||
"-X github.com/mattermost/mmctl/v6/commands.Version=${version}"
|
||||
];
|
||||
|
||||
meta = with lib; {
|
||||
description = "A remote CLI tool for Mattermost";
|
||||
homepage = "https://github.com/mattermost/mmctl";
|
||||
license = licenses.asl20;
|
||||
maintainers = with maintainers; [ ppom ];
|
||||
platforms = platforms.linux ++ platforms.darwin;
|
||||
};
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue