mirror of
https://github.com/SmartHoneybee/ubiquitous-memory
synced 2025-10-25 15:53:48 +02:00
Compare commits
21 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
65f66300ea | ||
|
|
896ca40562 | ||
|
|
a3ed63c840 | ||
|
|
c3bf7a5e6e | ||
|
|
8bfcbc152c | ||
|
|
ea209b1cb4 | ||
|
|
a4963df160 | ||
|
|
2c62ab2b0e | ||
|
|
85cb4319c0 | ||
|
|
da7d3b0da6 | ||
|
|
d9d94c2ee9 | ||
|
|
8e4b90726c | ||
|
|
0fc1ecee72 | ||
|
|
4f364878e5 | ||
|
|
a84d8e49ab | ||
|
|
81b4106fc7 | ||
|
|
f92e152276 | ||
|
|
df047ff1c3 | ||
|
|
34f7ec2895 | ||
|
|
04f32e9214 | ||
|
|
e4b062a7f4 |
9
.github/dependabot.yml
vendored
Normal file
9
.github/dependabot.yml
vendored
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
version: 2
|
||||||
|
updates:
|
||||||
|
- package-ecosystem: gomod
|
||||||
|
directory: "/dependabot"
|
||||||
|
schedule:
|
||||||
|
interval: daily
|
||||||
|
time: "00:15"
|
||||||
|
open-pull-requests-limit: 99
|
||||||
|
target-branch: master
|
||||||
122
.github/workflows/release.yml
vendored
Normal file
122
.github/workflows/release.yml
vendored
Normal file
@@ -0,0 +1,122 @@
|
|||||||
|
name: Package and release
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [ master ]
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
env:
|
||||||
|
DEBIAN_RELEASE: buster
|
||||||
|
DOCKER_PWD: /root
|
||||||
|
DOCKER_IMAGE: debian:${DEBIAN_RELEASE}
|
||||||
|
GO_VERSION: 1.15.5
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
os: [dragonfly, freebsd, linux, netbsd, openbsd]
|
||||||
|
arch: [amd64, arm, arm64, mips, mips64, mips64le, ppc64, ppc64le, s390x ]
|
||||||
|
exclude:
|
||||||
|
- os: dragonfly
|
||||||
|
arch: arm
|
||||||
|
- os: dragonfly
|
||||||
|
arch: arm64
|
||||||
|
- os: dragonfly
|
||||||
|
arch: mips
|
||||||
|
- os: dragonfly
|
||||||
|
arch: mips64
|
||||||
|
- os: dragonfly
|
||||||
|
arch: mips64le
|
||||||
|
- os: dragonfly
|
||||||
|
arch: ppc64
|
||||||
|
- os: dragonfly
|
||||||
|
arch: ppc64le
|
||||||
|
- os: dragonfly
|
||||||
|
arch: s390x
|
||||||
|
- os: freebsd
|
||||||
|
arch: arm64
|
||||||
|
- os: freebsd
|
||||||
|
arch: mips
|
||||||
|
- os: freebsd
|
||||||
|
arch: mips64
|
||||||
|
- os: freebsd
|
||||||
|
arch: mips64le
|
||||||
|
- os: freebsd
|
||||||
|
arch: ppc64
|
||||||
|
- os: freebsd
|
||||||
|
arch: ppc64le
|
||||||
|
- os: freebsd
|
||||||
|
arch: s390x
|
||||||
|
- os: netbsd
|
||||||
|
arch: arm64
|
||||||
|
- os: netbsd
|
||||||
|
arch: mips
|
||||||
|
- os: netbsd
|
||||||
|
arch: mips64
|
||||||
|
- os: netbsd
|
||||||
|
arch: mips64le
|
||||||
|
- os: netbsd
|
||||||
|
arch: ppc64
|
||||||
|
- os: netbsd
|
||||||
|
arch: ppc64le
|
||||||
|
- os: netbsd
|
||||||
|
arch: s390x
|
||||||
|
- os: openbsd
|
||||||
|
arch: arm64
|
||||||
|
- os: openbsd
|
||||||
|
arch: mips
|
||||||
|
- os: openbsd
|
||||||
|
arch: mips64
|
||||||
|
- os: openbsd
|
||||||
|
arch: mips64le
|
||||||
|
- os: openbsd
|
||||||
|
arch: ppc64
|
||||||
|
- os: openbsd
|
||||||
|
arch: ppc64le
|
||||||
|
- os: openbsd
|
||||||
|
arch: s390x
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Clone repository
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Set environment from runtime properties
|
||||||
|
run: echo "MATTERMOST_RELEASE=$(grep 'mattermost' dependabot/go.mod | cut -d' ' -f3)" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
- name: Pull docker image
|
||||||
|
run: 'docker pull "${{ env.DOCKER_IMAGE }}"'
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
env:
|
||||||
|
GOOS: ${{ matrix.os }}
|
||||||
|
GOARCH: ${{ matrix.arch }}
|
||||||
|
run: docker run --mount="type=bind,source=$PWD,destination=${{ env.DOCKER_PWD }}" --rm=true --tty=true --workdir="${{ env.DOCKER_PWD }}" -e DEBIAN_RELEASE -e MATTERMOST_RELEASE -e GOOS -e GOARCH "${{ env.DOCKER_IMAGE }}" ./build.sh
|
||||||
|
|
||||||
|
- name: Tag release
|
||||||
|
if: github.ref == 'refs/heads/master'
|
||||||
|
uses: actions/github-script@v3
|
||||||
|
# this throws an error if the tag already exists. can't find a way around that without writing our own Github REST client or forking github's scripts repo.
|
||||||
|
# would prefer to do this before any of these jobs run, but we need to know the mattermost version which only happens after a clone. could potentially
|
||||||
|
# setup a separate job which does clone + tag, but felt like this was "good enough" for now.
|
||||||
|
continue-on-error: true
|
||||||
|
with:
|
||||||
|
script: |
|
||||||
|
github.git.createRef({
|
||||||
|
owner: context.repo.owner,
|
||||||
|
repo: context.repo.repo,
|
||||||
|
ref: 'refs/tags/${{ env.MATTERMOST_RELEASE }}',
|
||||||
|
sha: context.sha
|
||||||
|
})
|
||||||
|
|
||||||
|
- name: Create Github release
|
||||||
|
if: github.ref == 'refs/heads/master'
|
||||||
|
uses: softprops/action-gh-release@v1
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
tag_name: ${{ env.MATTERMOST_RELEASE }}
|
||||||
|
files: |
|
||||||
|
mattermost-${{ env.MATTERMOST_RELEASE }}-${{ matrix.os }}-${{ matrix.arch }}.tar.gz
|
||||||
|
mattermost-${{ env.MATTERMOST_RELEASE }}-${{ matrix.os }}-${{ matrix.arch }}.tar.gz.sha512sum
|
||||||
44
.travis.yml
44
.travis.yml
@@ -1,44 +0,0 @@
|
|||||||
language: c
|
|
||||||
os: linux
|
|
||||||
dist: bionic
|
|
||||||
services:
|
|
||||||
- docker
|
|
||||||
env:
|
|
||||||
global:
|
|
||||||
- DEBIAN_RELEASE='buster'
|
|
||||||
- DOCKER_PWD='/root'
|
|
||||||
- DOCKER_IMAGE="debian:${DEBIAN_RELEASE}"
|
|
||||||
matrix:
|
|
||||||
- GOOS='dragonfly' GOARCH='amd64'
|
|
||||||
- GOOS='freebsd' GOARCH='amd64'
|
|
||||||
- GOOS='freebsd' GOARCH='arm'
|
|
||||||
- GOOS='linux' GOARCH='arm'
|
|
||||||
- GOOS='linux' GOARCH='arm64'
|
|
||||||
- GOOS='linux' GOARCH='mips'
|
|
||||||
- GOOS='linux' GOARCH='mips64'
|
|
||||||
- GOOS='linux' GOARCH='mips64le'
|
|
||||||
- GOOS='linux' GOARCH='mipsle'
|
|
||||||
- GOOS='linux' GOARCH='ppc64'
|
|
||||||
- GOOS='linux' GOARCH='ppc64le'
|
|
||||||
- GOOS='linux' GOARCH='s390x'
|
|
||||||
- GOOS='netbsd' GOARCH='amd64'
|
|
||||||
- GOOS='netbsd' GOARCH='arm'
|
|
||||||
- GOOS='openbsd' GOARCH='amd64'
|
|
||||||
- GOOS='openbsd' GOARCH='arm'
|
|
||||||
before_install:
|
|
||||||
- export MATTERMOST_RELEASE="$(grep 'mattermost' dependabot/go.mod | cut -d' ' -f3)"
|
|
||||||
- docker pull "${DOCKER_IMAGE}"
|
|
||||||
- chmod +x build.sh
|
|
||||||
script:
|
|
||||||
- docker run --interactive=true --mount="type=bind,source=${PWD},destination=${DOCKER_PWD}" --rm=true --tty=true --workdir="${DOCKER_PWD}" -e DEBIAN_RELEASE -e MATTERMOST_RELEASE -e GOOS -e GOARCH "${DOCKER_IMAGE}" ./build.sh
|
|
||||||
before_deploy:
|
|
||||||
- git config --local user.name 'Travis CI'
|
|
||||||
- git config --local user.email 'travis@travis-ci.org'
|
|
||||||
- git tag "${MATTERMOST_RELEASE}" || true
|
|
||||||
deploy:
|
|
||||||
provider: releases
|
|
||||||
api_key: "${GITHUB_OAUTH_TOKEN}"
|
|
||||||
file:
|
|
||||||
- "${TRAVIS_BUILD_DIR}/mattermost-${MATTERMOST_RELEASE}-${GOOS}-${GOARCH}.tar.gz"
|
|
||||||
- "${TRAVIS_BUILD_DIR}/mattermost-${MATTERMOST_RELEASE}-${GOOS}-${GOARCH}.tar.gz.sha512sum"
|
|
||||||
skip_cleanup: true
|
|
||||||
@@ -1,9 +1,9 @@
|
|||||||
# ubiquitous-memory: [Here be dragons][2]
|
# ubiquitous-memory: [Here be dragons][2]
|
||||||
|
|
||||||
[](https://travis-ci.org/SmartHoneybee/ubiquitous-memory)
|
[](https://github.com/SmartHoneybee/ubiquitous-memory/actions/workflows/release.yml)
|
||||||
|
|
||||||
[Travis CI][0] recipe that builds [Mattermost][1] for various operating systems and architectures.
|
[Github Actions][0] script that builds [Mattermost][1] for various operating systems and architectures.
|
||||||
|
|
||||||
[0]: https://travis-ci.org/SmartHoneybee/ubiquitous-memory
|
[0]: https://github.com/SmartHoneybee/ubiquitous-memory/actions
|
||||||
[1]: https://mattermost.com/
|
[1]: https://mattermost.com/
|
||||||
[2]: https://en.wikipedia.org/wiki/Here_be_dragons
|
[2]: https://en.wikipedia.org/wiki/Here_be_dragons
|
||||||
|
|||||||
@@ -1,17 +1,17 @@
|
|||||||
From 556e16211ed1b4c146ca2a094688618458182ae7 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Your Name <you@example.com>
|
|
||||||
Date: Wed, 6 Jun 2018 12:34:56 +0100
|
|
||||||
Subject: [PATCH] Split make goal
|
|
||||||
|
|
||||||
---
|
|
||||||
build/release.mk | 4 ++--
|
|
||||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/build/release.mk b/build/release.mk
|
diff --git a/build/release.mk b/build/release.mk
|
||||||
index 238343e..1b7859f 100644
|
index 3e9a11339..c8bd5409f 100644
|
||||||
--- a/build/release.mk
|
--- a/build/release.mk
|
||||||
+++ b/build/release.mk
|
+++ b/build/release.mk
|
||||||
@@ -77,7 +77,7 @@ endif
|
@@ -97,7 +97,7 @@ package:
|
||||||
|
cp -RL $(BUILD_WEBAPP_DIR)/dist/* $(DIST_PATH)/client
|
||||||
|
|
||||||
|
@#Download MMCTL
|
||||||
|
- scripts/download_mmctl_release.sh "" $(DIST_PATH)/bin
|
||||||
|
+ #scripts/download_mmctl_release.sh "" $(DIST_PATH)/bin
|
||||||
|
|
||||||
|
@# Help files
|
||||||
|
ifeq ($(BUILD_ENTERPRISE_READY),true)
|
||||||
|
@@ -126,7 +126,7 @@ endif
|
||||||
|
|
||||||
|
|
||||||
@# ----- PLATFORM SPECIFIC -----
|
@# ----- PLATFORM SPECIFIC -----
|
||||||
@@ -20,7 +20,7 @@ index 238343e..1b7859f 100644
|
|||||||
@# Make osx package
|
@# Make osx package
|
||||||
@# Copy binary
|
@# Copy binary
|
||||||
ifeq ($(BUILDER_GOOS_GOARCH),"darwin_amd64")
|
ifeq ($(BUILDER_GOOS_GOARCH),"darwin_amd64")
|
||||||
@@ -145,7 +145,7 @@ endif
|
@@ -196,7 +196,7 @@ endif
|
||||||
rm -f $(DIST_PATH)/bin/platform.exe
|
rm -f $(DIST_PATH)/bin/platform.exe
|
||||||
rm -f $(DIST_PATH)/bin/mmctl.exe
|
rm -f $(DIST_PATH)/bin/mmctl.exe
|
||||||
rm -f $(DIST_PATH)/prepackaged_plugins/*
|
rm -f $(DIST_PATH)/prepackaged_plugins/*
|
||||||
@@ -29,14 +29,12 @@ index 238343e..1b7859f 100644
|
|||||||
@# Make linux package
|
@# Make linux package
|
||||||
@# Copy binary
|
@# Copy binary
|
||||||
ifeq ($(BUILDER_GOOS_GOARCH),"linux_amd64")
|
ifeq ($(BUILDER_GOOS_GOARCH),"linux_amd64")
|
||||||
@@ -155,7 +155,7 @@ else
|
@@ -207,7 +207,7 @@ else
|
||||||
cp $(GOPATH)/bin/linux_amd64/mattermost $(DIST_PATH)/bin # from cross-compiled bin dir
|
cp $(GOBIN)/linux_amd64/platform $(DIST_PATH)/bin # from cross-compiled bin dir
|
||||||
cp $(GOPATH)/bin/linux_amd64/platform $(DIST_PATH)/bin # from cross-compiled bin dir
|
|
||||||
endif
|
endif
|
||||||
- MMCTL_FILE="linux_amd64.tar" && curl -f -O -L https://github.com/mattermost/mmctl/releases/download/$(MMCTL_REL_TO_DOWNLOAD)/$$MMCTL_FILE && tar -xvf $$MMCTL_FILE -C $(DIST_PATH)/bin && rm $$MMCTL_FILE
|
#Download MMCTL for Linux
|
||||||
+
|
- scripts/download_mmctl_release.sh "Linux" $(DIST_PATH)/bin
|
||||||
|
+ #scripts/download_mmctl_release.sh "Linux" $(DIST_PATH)/bin
|
||||||
@# Prepackage plugins
|
@# Prepackage plugins
|
||||||
@for plugin_package in $(PLUGIN_PACKAGES) ; do \
|
@for plugin_package in $(PLUGIN_PACKAGES) ; do \
|
||||||
ARCH="linux-amd64"; \
|
ARCH="linux-amd64"; \
|
||||||
--
|
|
||||||
2.11.0
|
|
||||||
|
|||||||
15
build.sh
Normal file → Executable file
15
build.sh
Normal file → Executable file
@@ -10,6 +10,8 @@ MATTERMOST_RELEASE="${MATTERMOST_RELEASE:-v5.4.0}"
|
|||||||
# node key id and release
|
# node key id and release
|
||||||
NODE_KEY="${NODE_KEY:-9FD3B784BC1C6FC31A8A0A1C1655A0AB68576280}"
|
NODE_KEY="${NODE_KEY:-9FD3B784BC1C6FC31A8A0A1C1655A0AB68576280}"
|
||||||
NODE_RELEASE="${NODE_RELEASE:-10}"
|
NODE_RELEASE="${NODE_RELEASE:-10}"
|
||||||
|
# golang version
|
||||||
|
GO_VERSION="${GO_VERSION:-1.15.5}"
|
||||||
|
|
||||||
if [ "$(id -u)" -eq 0 ]; then # as root user
|
if [ "$(id -u)" -eq 0 ]; then # as root user
|
||||||
# create build user, if needed
|
# create build user, if needed
|
||||||
@@ -43,15 +45,18 @@ if [ "$(id -u)" -eq 0 ]; then # as root user
|
|||||||
> '/etc/apt/sources.list.d/nodesource.list'
|
> '/etc/apt/sources.list.d/nodesource.list'
|
||||||
# update repositories
|
# update repositories
|
||||||
apt-get update
|
apt-get update
|
||||||
# install go from Debian backports
|
|
||||||
apt-get install --quiet --target-release "${DEBIAN_RELEASE}-backports" \
|
|
||||||
golang-go
|
|
||||||
# install dependencies
|
# install dependencies
|
||||||
apt-get install --quiet \
|
apt-get install --quiet \
|
||||||
wget build-essential patch git nodejs
|
wget build-essential patch git nodejs
|
||||||
# install 'pngquant' build dependencies (required by node module)
|
# install 'pngquant' build dependencies (required by node module)
|
||||||
apt-get build-dep --quiet \
|
apt-get build-dep --quiet \
|
||||||
pngquant
|
pngquant
|
||||||
|
# install go from golang.org
|
||||||
|
wget https://golang.org/dl/go${GO_VERSION}.linux-amd64.tar.gz
|
||||||
|
tar -xvf go${GO_VERSION}.linux-amd64.tar.gz
|
||||||
|
mv go /usr/local
|
||||||
|
export GOROOT=/usr/local/go
|
||||||
|
export PATH=$GOROOT/bin:$PATH
|
||||||
# FIXME go (executed by build user) writes to GOROOT
|
# FIXME go (executed by build user) writes to GOROOT
|
||||||
install --directory --owner="${BUILD_USER_NAME}" \
|
install --directory --owner="${BUILD_USER_NAME}" \
|
||||||
"$(go env GOROOT)/pkg/$(go env GOOS)_$(go env GOARCH)"
|
"$(go env GOROOT)/pkg/$(go env GOOS)_$(go env GOARCH)"
|
||||||
@@ -65,6 +70,8 @@ if [ "$(id -u)" -eq 0 ]; then # as root user
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
# as non-root user
|
# as non-root user
|
||||||
|
export GOROOT=/usr/local/go
|
||||||
|
export PATH=$GOROOT/bin:$PATH
|
||||||
cd "${HOME}"
|
cd "${HOME}"
|
||||||
# download and extract Mattermost sources
|
# download and extract Mattermost sources
|
||||||
for COMPONENT in server webapp; do
|
for COMPONENT in server webapp; do
|
||||||
@@ -88,7 +95,7 @@ if [ "$(go env GOOS)_$(go env GOARCH)" != 'linux_amd64' ]; then
|
|||||||
"${HOME}/go/bin/linux_amd64"
|
"${HOME}/go/bin/linux_amd64"
|
||||||
fi
|
fi
|
||||||
patch --directory="${HOME}/go/src/github.com/mattermost/mattermost-server" \
|
patch --directory="${HOME}/go/src/github.com/mattermost/mattermost-server" \
|
||||||
--strip=1 < "${HOME}/build-release.patch"
|
--strip=1 -t < "${HOME}/build-release.patch"
|
||||||
sed -i \
|
sed -i \
|
||||||
-e 's#go generate#env --unset=GOOS --unset=GOARCH go generate#' \
|
-e 's#go generate#env --unset=GOOS --unset=GOARCH go generate#' \
|
||||||
-e 's#$(GO) generate#env --unset=GOOS --unset=GOARCH go generate#' \
|
-e 's#$(GO) generate#env --unset=GOOS --unset=GOARCH go generate#' \
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
module github.com/SmartHoneybee/ubiquitous-memory/dependabot
|
module github.com/SmartHoneybee/ubiquitous-memory/dependabot
|
||||||
|
|
||||||
require github.com/mattermost/mattermost-server/v5 v5.26.1
|
require github.com/mattermost/mattermost-server/v5 v5.35.3
|
||||||
|
|||||||
Reference in New Issue
Block a user