mirror of
https://github.com/vector-im/element-call.git
synced 2026-01-18 02:32:27 +00:00
* Embedded package build of Element Call Part of https://github.com/element-hq/element-call/issues/2994 This creates a new "embedded" build (vs "full" build) at the vite level. It will be used by a later PR that actually provides platform specific packages. Embedded build: - Uses relative URLs - Uses relative config.json path and other resource loading - Has a config.json built in - Doesn't include the public folder (e.g. favicon) Out of scope: - this doesn't attempt to exclude SPA functionality, so technically the build could be used in SPA - the above means that the crypto-wasm binary is included in the build * CI artifact name based on type of build * Update src/config/Config.ts
67 lines
2.2 KiB
YAML
67 lines
2.2 KiB
YAML
name: Build & publish images to the package registry for releases
|
|
|
|
on:
|
|
release:
|
|
types: [published]
|
|
|
|
env:
|
|
REGISTRY: ghcr.io
|
|
IMAGE_NAME: ${{ github.repository }}
|
|
|
|
jobs:
|
|
build_element_call:
|
|
if: ${{ github.event_name == 'release' }}
|
|
uses: ./.github/workflows/build-element-call.yaml
|
|
with:
|
|
package: full
|
|
vite_app_version: ${{ github.event.release.tag_name || github.sha }}
|
|
secrets:
|
|
SENTRY_ORG: ${{ secrets.SENTRY_ORG }}
|
|
SENTRY_PROJECT: ${{ secrets.SENTRY_PROJECT }}
|
|
SENTRY_URL: ${{ secrets.SENTRY_URL }}
|
|
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }}
|
|
publish_tarball:
|
|
needs: build_element_call
|
|
if: always()
|
|
name: Publish tarball
|
|
runs-on: ubuntu-latest
|
|
outputs:
|
|
unix_time: ${{steps.current-time.outputs.unix_time}}
|
|
permissions:
|
|
contents: write # required to upload release asset
|
|
packages: write
|
|
steps:
|
|
- name: Get current time
|
|
id: current-time
|
|
run: echo "unix_time=$(date +'%s')" >> $GITHUB_OUTPUT
|
|
- name: 📥 Download artifact
|
|
uses: actions/download-artifact@cc203385981b70ca67e1cc392babf9cc229d5806 # v4
|
|
with:
|
|
github-token: ${{ secrets.GITHUB_TOKEN }}
|
|
run-id: ${{ github.event.workflow_run.id || github.run_id }}
|
|
name: build-output-full
|
|
path: dist
|
|
- name: Create Tarball
|
|
env:
|
|
TARBALL_VERSION: ${{ github.event.release.tag_name || github.sha }}
|
|
run: |
|
|
tar --numeric-owner --transform "s/dist/element-call-${TARBALL_VERSION}/" -cvzf element-call-${TARBALL_VERSION}.tar.gz dist
|
|
- name: Upload
|
|
uses: actions/upload-artifact@4cec3d8aa04e39d1a68397de0c4cd6fb9dce8ec1 # v4.6.1
|
|
env:
|
|
GITHUB_TOKEN: ${{ github.token }}
|
|
with:
|
|
path: "./element-call-*.tar.gz"
|
|
publish_docker:
|
|
needs: publish_tarball
|
|
if: always()
|
|
permissions:
|
|
contents: write
|
|
packages: write
|
|
uses: ./.github/workflows/build-and-publish-docker.yaml
|
|
with:
|
|
artifact_run_id: ${{ github.event.workflow_run.id || github.run_id }}
|
|
docker_tags: |
|
|
type=sha,format=short,event=branch
|
|
type=semver,pattern=v{{version}}
|