Skip to content

Latest commit

 

History

History
85 lines (71 loc) · 6.02 KB

README.md

File metadata and controls

85 lines (71 loc) · 6.02 KB

Upload a new app version to Nextcloud's appstore

This Github Action automatically publishes a new app version in the Nextcloud appstore after you created a new Github release.

Workflow

The following workflow can be automated when using this Github Action:

  1. Create a new release of your app in Github.
  2. Let a new Github Workflow be triggered which automates the following steps:
    • Chechout the tag version of your new release.
    • Build a tarball for your app.
    • Attach the tarball to the Github Release.
    • Upload a new app version into the Nextcloud appstore referencing your attached tarball. This includes creating a signature and authenticating against Nextcloud's appstore via token (or username and password).

Prerequisites

  1. Register you app in the Nextcloud appstore like described here.

  2. Paste the content of your app's private key into a new Github Secret named APP_PRIVATE_KEY. This key is later used for signing the new app version before uploading it to the appstore.

  3. For authentication against the Nextcloud appstore you can use one of the following approaches:

    1. Token (recommended): create a new Github Secret for your Nextcloud appstore account token named APPSTORE_TOKEN. The token can be copied by logging into https://apps.nextcloud.com an then visiting My account -> API-Token.
    2. Username & password: create two Github Secrets APPSTORE_USERNAME and APPSTORE_PASSWORD holding your personal login information for the Nextcloud appstore. Make sure this user is allowed to create new app releases for you app.
  4. Make sure you are able to build a tarball for your app inside of Github actions. This could be achieved by using an appropriate Makefile. Here are two examples:

Usage

In general you'll have to create a new .yml-file in your app's repository inside of .github/workflows (for example .github/workflows/build_release.yml) to use this Github Action. The following sections list a few useful examples on how you can combine this Action with others to automate your workflow. All samples can also be found in the examples directory of this repository.

Example without code signing

The following example shows how you can use this Github Action with your Nextcloud Appstore token after a new Github Release was created:

name: Build and publish app release

on:
  release:
      types: [published]

env:
  APP_NAME: workflow_ocr

jobs:
  build_and_publish:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout
        uses: actions/checkout@v2
        with:
          path: ${{ env.APP_NAME }}
      - name: Run build
        run: cd ${{ env.APP_NAME }} && make appstore
      - name: Upload app tarball to release
        uses: svenstaro/upload-release-action@v2
        id: attach_to_release
        with:
          repo_token: ${{ secrets.GITHUB_TOKEN }}
          file: ${{ env.APP_NAME }}/build/artifacts/appstore/${{ env.APP_NAME }}.tar.gz
          asset_name: ${{ env.APP_NAME }}.tar.gz 
          tag: ${{ github.ref }}
          overwrite: true
      - name: Upload app to Nextcloud appstore
        uses: R0Wi/nextcloud-appstore-push-action@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 }}
          nightly: ${{ github.event.release.prerelease }}

Input variables

Name Description Default Possible values Required
app_name The id of your Nextcloud app - string true
appstore_token A valid access token to upload a new version of your app into Nextcloud appstore - string false*
appstore_username Username for Nextcloud appstore - string false*
appstore_password Password for Nextcloud appstore - string false*
download_url The download url of you app tarball - string true
app_private_key The private key string of you app to sign the new release. Usually stored in Github Secrets - string true
nightly Controls if the app will be published as nightly into the Nextcloud appstore false true, false false

*Either appstore_token or appstore_username and appstore_password must be set.

Output variables

There are currently no output variables.