-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #9 from nextcloud/add-packaging
Add packaging
- Loading branch information
Showing
7 changed files
with
293 additions
and
19 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,167 @@ | ||
# This workflow is provided via the organization template repository | ||
# | ||
# https://github.com/nextcloud/.github | ||
# https://docs.github.com/en/actions/learn-github-actions/sharing-workflows-with-your-organization | ||
|
||
name: Build and publish app release | ||
|
||
on: | ||
release: | ||
types: [published] | ||
|
||
env: | ||
PHP_VERSION: 8.1 | ||
|
||
jobs: | ||
build_and_publish: | ||
runs-on: ubuntu-latest | ||
|
||
# Only allowed to be run on nextcloud-releases repositories | ||
if: ${{ github.repository_owner == 'nextcloud-releases' }} | ||
|
||
steps: | ||
- name: Check actor permission | ||
uses: skjnldsv/check-actor-permission@e591dbfe838300c007028e1219ca82cc26e8d7c5 # v2.1 | ||
with: | ||
require: write | ||
|
||
- name: Set app env | ||
run: | | ||
# Split and keep last | ||
echo "APP_NAME=${GITHUB_REPOSITORY##*/}" >> $GITHUB_ENV | ||
echo "APP_VERSION=${GITHUB_REF##*/}" >> $GITHUB_ENV | ||
- name: Checkout | ||
uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9 # v3.5.3 | ||
with: | ||
path: ${{ env.APP_NAME }} | ||
|
||
- name: Get appinfo data | ||
id: appinfo | ||
uses: skjnldsv/xpath-action@7e6a7c379d0e9abc8acaef43df403ab4fc4f770c # master | ||
with: | ||
filename: ${{ env.APP_NAME }}/appinfo/info.xml | ||
expression: "//info//dependencies//nextcloud/@min-version" | ||
|
||
- name: Read package.json node and npm engines version | ||
uses: skjnldsv/read-package-engines-version-actions@8205673bab74a63eb9b8093402fd9e0e018663a1 # v2.2 | ||
id: versions | ||
# Continue if no package.json | ||
continue-on-error: true | ||
with: | ||
path: ${{ env.APP_NAME }} | ||
fallbackNode: '^20' | ||
fallbackNpm: '^9' | ||
|
||
- name: Set up node ${{ steps.versions.outputs.nodeVersion }} | ||
# Skip if no package.json | ||
if: ${{ steps.versions.outputs.nodeVersion }} | ||
uses: actions/setup-node@e33196f7422957bea03ed53f6fbb155025ffc7b8 # v3 | ||
with: | ||
node-version: ${{ steps.versions.outputs.nodeVersion }} | ||
|
||
- name: Set up npm ${{ steps.versions.outputs.npmVersion }} | ||
# Skip if no package.json | ||
if: ${{ steps.versions.outputs.npmVersion }} | ||
run: npm i -g npm@"${{ steps.versions.outputs.npmVersion }}" | ||
|
||
- name: Set up php ${{ env.PHP_VERSION }} | ||
uses: shivammathur/setup-php@4bd44f22a98a19e0950cbad5f31095157cc9621b # v2 | ||
with: | ||
php-version: ${{ env.PHP_VERSION }} | ||
coverage: none | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Check composer.json | ||
id: check_composer | ||
uses: andstor/file-existence-action@20b4d2e596410855db8f9ca21e96fbe18e12930b # v2 | ||
with: | ||
files: "${{ env.APP_NAME }}/composer.json" | ||
|
||
- name: Install composer dependencies | ||
if: steps.check_composer.outputs.files_exists == 'true' | ||
run: | | ||
cd ${{ env.APP_NAME }} | ||
composer install --no-dev | ||
- name: Build ${{ env.APP_NAME }} | ||
# Skip if no package.json | ||
if: ${{ steps.versions.outputs.nodeVersion }} | ||
run: | | ||
cd ${{ env.APP_NAME }} | ||
npm ci | ||
npm run build | ||
- name: Check Krankerl config | ||
id: krankerl | ||
uses: andstor/file-existence-action@20b4d2e596410855db8f9ca21e96fbe18e12930b # v2 | ||
with: | ||
files: ${{ env.APP_NAME }}/krankerl.toml | ||
|
||
- name: Install Krankerl | ||
if: steps.krankerl.outputs.files_exists == 'true' | ||
run: | | ||
wget https://github.com/ChristophWurst/krankerl/releases/download/v0.14.0/krankerl_0.14.0_amd64.deb | ||
sudo dpkg -i krankerl_0.14.0_amd64.deb | ||
- name: Package ${{ env.APP_NAME }} ${{ env.APP_VERSION }} with krankerl | ||
if: steps.krankerl.outputs.files_exists == 'true' | ||
run: | | ||
cd ${{ env.APP_NAME }} | ||
krankerl package | ||
- name: Package ${{ env.APP_NAME }} ${{ env.APP_VERSION }} with makefile | ||
if: steps.krankerl.outputs.files_exists != 'true' | ||
run: | | ||
cd ${{ env.APP_NAME }} | ||
make appstore | ||
- name: Checkout server ${{ fromJSON(steps.appinfo.outputs.result).nextcloud.min-version }} | ||
continue-on-error: true | ||
id: server-checkout | ||
run: | | ||
NCVERSION=${{ fromJSON(steps.appinfo.outputs.result).nextcloud.min-version }} | ||
wget --quiet https://download.nextcloud.com/server/releases/latest-$NCVERSION.zip | ||
unzip latest-$NCVERSION.zip | ||
- name: Checkout server master fallback | ||
uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9 # v3.5.3 | ||
if: ${{ steps.server-checkout.outcome != 'success' }} | ||
with: | ||
submodules: true | ||
repository: nextcloud/server | ||
path: nextcloud | ||
|
||
- name: Sign app | ||
run: | | ||
# Extracting release | ||
cd ${{ env.APP_NAME }}/build/artifacts | ||
tar -xvf ${{ env.APP_NAME }}.tar.gz | ||
cd ../../../ | ||
# Setting up keys | ||
echo "${{ secrets.APP_PRIVATE_KEY }}" > ${{ env.APP_NAME }}.key | ||
wget --quiet "https://github.com/nextcloud/app-certificate-requests/raw/master/${{ env.APP_NAME }}/${{ env.APP_NAME }}.crt" | ||
# Signing | ||
php nextcloud/occ integrity:sign-app --privateKey=../${{ env.APP_NAME }}.key --certificate=../${{ env.APP_NAME }}.crt --path=../${{ env.APP_NAME }}/build/artifacts/${{ env.APP_NAME }} | ||
# Rebuilding archive | ||
cd ${{ env.APP_NAME }}/build/artifacts | ||
tar -zcvf ${{ env.APP_NAME }}.tar.gz ${{ env.APP_NAME }} | ||
- name: Attach tarball to github release | ||
uses: svenstaro/upload-release-action@1beeb572c19a9242f4361f4cee78f8e0d9aec5df # v2 | ||
id: attach_to_release | ||
with: | ||
repo_token: ${{ secrets.GITHUB_TOKEN }} | ||
file: ${{ env.APP_NAME }}/build/artifacts/${{ env.APP_NAME }}.tar.gz | ||
asset_name: ${{ env.APP_NAME }}-${{ env.APP_VERSION }}.tar.gz | ||
tag: ${{ github.ref }} | ||
overwrite: true | ||
|
||
- name: Upload app to Nextcloud appstore | ||
uses: nextcloud-releases/nextcloud-appstore-push-action@a011fe619bcf6e77ddebc96f9908e1af4071b9c1 # v1 | ||
with: | ||
app_name: ${{ env.APP_NAME }} | ||
appstore_token: ${{ secrets.APPSTORE_TOKEN }} | ||
download_url: ${{ steps.attach_to_release.outputs.browser_download_url }} | ||
app_private_key: ${{ secrets.APP_PRIVATE_KEY }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -34,7 +34,7 @@ concurrency: | |
|
||
jobs: | ||
phpunit-oci: | ||
runs-on: ubuntu-latest | ||
runs-on: ubuntu-22.04 | ||
|
||
strategy: | ||
matrix: | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
# Makefile for building the project | ||
|
||
app_name=call_summary_bot | ||
|
||
project_dir=$(CURDIR)/../$(app_name) | ||
build_dir=$(CURDIR)/build/artifacts | ||
appstore_dir=$(build_dir)/appstore | ||
source_dir=$(build_dir)/source | ||
sign_dir=$(build_dir)/sign | ||
package_name=$(app_name) | ||
cert_dir=$(HOME)/.nextcloud/certificates | ||
version+=main | ||
composer=$(shell which composer 2> /dev/null) | ||
|
||
all: appstore | ||
|
||
# Dev env management | ||
dev-setup: clean | ||
|
||
# Installs and updates the composer dependencies. If composer is not installed | ||
# a copy is fetched from the web | ||
composer: | ||
ifeq (, $(composer)) | ||
@echo "No composer command available, downloading a copy from the web" | ||
mkdir -p $(build_tools_directory) | ||
curl -sS https://getcomposer.org/installer | php | ||
mv composer.phar $(build_tools_directory) | ||
php $(build_tools_directory)/composer.phar install --prefer-dist | ||
php $(build_tools_directory)/composer.phar update --prefer-dist | ||
else | ||
composer install --prefer-dist | ||
composer update --prefer-dist | ||
endif | ||
|
||
release: appstore create-tag | ||
|
||
create-tag: | ||
git tag -a v$(version) -m "Tagging the $(version) release." | ||
git push origin v$(version) | ||
|
||
clean: | ||
rm -rf $(build_dir) | ||
|
||
appstore: dev-setup | ||
mkdir -p $(sign_dir) | ||
rsync -a \ | ||
--exclude=/.git \ | ||
--exclude=/.github \ | ||
--exclude=/.tx \ | ||
--exclude=/build \ | ||
--exclude=/docs \ | ||
--exclude=/node_modules \ | ||
--exclude=/src \ | ||
--exclude=/tests \ | ||
--exclude=/vendor \ | ||
--exclude=/.eslintrc.js \ | ||
--exclude=/.l10nignore \ | ||
--exclude=/.php-cs-fixer.cache \ | ||
--exclude=/.php-cs-fixer.dist.php \ | ||
--exclude=/.gitattributes \ | ||
--exclude=/.gitignore \ | ||
--exclude=/.scrutinizer.yml \ | ||
--exclude=/.travis.yml \ | ||
--exclude=/babel.config.js \ | ||
--exclude=/composer.json \ | ||
--exclude=/composer.lock \ | ||
--exclude=/Makefile \ | ||
--exclude=/package.json \ | ||
--exclude=/package-lock.json \ | ||
--exclude=/psalm.xml \ | ||
--exclude=/README.md \ | ||
--exclude=/stylelint.config.js \ | ||
--exclude=/webpack.js \ | ||
$(project_dir)/ $(sign_dir)/$(app_name) | ||
@if [ -f $(cert_dir)/$(app_name).key ]; then \ | ||
echo "Signing app files…"; \ | ||
php ../../occ integrity:sign-app \ | ||
--privateKey=$(cert_dir)/$(app_name).key\ | ||
--certificate=$(cert_dir)/$(app_name).crt\ | ||
--path=$(sign_dir)/$(app_name); \ | ||
fi | ||
tar -czf $(build_dir)/$(app_name).tar.gz \ | ||
-C $(sign_dir) $(app_name) | ||
@if [ -f $(cert_dir)/$(app_name).key ]; then \ | ||
echo "Signing package…"; \ | ||
openssl dgst -sha512 -sign $(cert_dir)/$(app_name).key $(build_dir)/$(app_name).tar.gz | openssl base64; \ | ||
fi | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Oops, something went wrong.