X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/6502f3f487b6403a24b84bde2091fad2f3bdcc5f..be48afb2b5b4b138f09dcb112541fa56106a16d6:/.github/workflows/release.yml diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 117f26ad..b7ce03f1 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -5,6 +5,9 @@ on: tags: - v* +permissions: + contents: write # to fetch code (actions/checkout) and create release + env: IMAGE_NAME: signal-cli IMAGE_REGISTRY: ghcr.io/asamk @@ -14,12 +17,16 @@ env: jobs: ci_wf: + permissions: + contents: write uses: AsamK/signal-cli/.github/workflows/ci.yml@master # ${{ github.repository }} not accepted here lib_to_jar: needs: ci_wf runs-on: ubuntu-latest + permissions: + contents: write outputs: signal_cli_version: ${{ steps.cli_ver.outputs.version }} @@ -28,7 +35,7 @@ jobs: steps: - name: Download signal-cli build from CI workflow - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 - name: Get signal-cli version id: cli_ver @@ -41,28 +48,28 @@ jobs: tree . ARCHIVE_DIR=$(ls signal-cli-archive-*/ -d | tail -n1) tar -xzf ./"${ARCHIVE_DIR}"/*.tar.gz - mv ./"${ARCHIVE_DIR}"/*.tar.gz signal-cli-${{ steps.cli_ver.outputs.version }}-Linux.tar.gz + mv ./"${ARCHIVE_DIR}"/*.tar.gz signal-cli-${{ steps.cli_ver.outputs.version }}.tar.gz rm -rf signal-cli-archive-*/ - - name: Get signal-client jar version - id: lib_ver - run: | - JAR_PREFIX=libsignal-client- - jar_file=$(find ./signal-cli-*/lib/ -name "$JAR_PREFIX*.jar") - jar_version=$(echo "$jar_file" | xargs basename | sed "s/$JAR_PREFIX//; s/.jar//") - echo "$jar_version" - echo "signal_client_version=${jar_version}" >> $GITHUB_OUTPUT - - - name: Download signal-client builds - env: - RELEASES_URL: https://github.com/signalapp/libsignal/releases/download/ - FILE_NAMES: signal_jni.dll libsignal_jni.dylib - SIGNAL_CLIENT_VER: ${{ steps.lib_ver.outputs.signal_client_version }} - run: | - for file_name in $FILE_NAMES; do - curl -sOL "${RELEASES_URL}/v${SIGNAL_CLIENT_VER}/${file_name}" # note: added v - done - tree . +# - name: Get signal-client jar version +# id: lib_ver +# run: | +# JAR_PREFIX=libsignal-client- +# jar_file=$(find ./signal-cli-*/lib/ -name "$JAR_PREFIX*.jar") +# jar_version=$(echo "$jar_file" | xargs basename | sed "s/$JAR_PREFIX//; s/.jar//") +# echo "$jar_version" +# echo "signal_client_version=${jar_version}" >> $GITHUB_OUTPUT +# +# - name: Download signal-client builds +# env: +# RELEASES_URL: https://github.com/signalapp/libsignal/releases/download/ +# FILE_NAMES: signal_jni.dll libsignal_jni.dylib +# SIGNAL_CLIENT_VER: ${{ steps.lib_ver.outputs.signal_client_version }} +# run: | +# for file_name in $FILE_NAMES; do +# curl -sOL "${RELEASES_URL}/v${SIGNAL_CLIENT_VER}/${file_name}" # note: added v +# done +# tree . - name: Compress native app env: @@ -72,24 +79,24 @@ jobs: tar -czf signal-cli-${SIGNAL_CLI_VER}-Linux-native.tar.gz -C signal-cli-native signal-cli rm -rf signal-cli-native/ - - name: Replace Windows lib - env: - SIGNAL_CLI_VER: ${{ steps.cli_ver.outputs.version }} - SIGNAL_CLIENT_VER: ${{ steps.lib_ver.outputs.signal_client_version }} - run: | - mv signal_jni.dll libsignal_jni.so - zip -u ./signal-cli-*/lib/libsignal-client-${SIGNAL_CLIENT_VER}.jar ./libsignal_jni.so - tar -czf signal-cli-${SIGNAL_CLI_VER}-Windows.tar.gz signal-cli-*/ - - - name: Replace macOS lib - env: - SIGNAL_CLI_VER: ${{ steps.cli_ver.outputs.version }} - SIGNAL_CLIENT_VER: ${{ steps.lib_ver.outputs.signal_client_version }} - run: | - jar_file=./signal-cli-*/lib/libsignal-client-${SIGNAL_CLIENT_VER}.jar - zip -d $jar_file libsignal_jni.so - zip $jar_file libsignal_jni.dylib - tar -czf signal-cli-${SIGNAL_CLI_VER}-macOS.tar.gz signal-cli-*/ +# - name: Replace Windows lib +# env: +# SIGNAL_CLI_VER: ${{ steps.cli_ver.outputs.version }} +# SIGNAL_CLIENT_VER: ${{ steps.lib_ver.outputs.signal_client_version }} +# run: | +# mv signal_jni.dll libsignal_jni.so +# zip -u ./signal-cli-*/lib/libsignal-client-${SIGNAL_CLIENT_VER}.jar ./libsignal_jni.so +# tar -czf signal-cli-${SIGNAL_CLI_VER}-Windows.tar.gz signal-cli-*/ +# +# - name: Replace macOS lib +# env: +# SIGNAL_CLI_VER: ${{ steps.cli_ver.outputs.version }} +# SIGNAL_CLIENT_VER: ${{ steps.lib_ver.outputs.signal_client_version }} +# run: | +# jar_file=./signal-cli-*/lib/libsignal-client-${SIGNAL_CLIENT_VER}.jar +# zip -d $jar_file libsignal_jni.so +# zip $jar_file libsignal_jni.dylib +# tar -czf signal-cli-${SIGNAL_CLI_VER}-macOS.tar.gz signal-cli-*/ - name: Create release id: create_release @@ -101,16 +108,26 @@ jobs: release_name: v${{ steps.cli_ver.outputs.version }} # note: added `v` draft: true - - name: Upload Linux archive + - name: Upload archive uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: signal-cli-${{ steps.cli_ver.outputs.version }}-Linux.tar.gz - asset_name: signal-cli-${{ steps.cli_ver.outputs.version }}-Linux.tar.gz + asset_path: signal-cli-${{ steps.cli_ver.outputs.version }}.tar.gz + asset_name: signal-cli-${{ steps.cli_ver.outputs.version }}.tar.gz asset_content_type: application/x-compressed-tar # .tar.gz +# - name: Upload Linux archive +# uses: actions/upload-release-asset@v1 +# env: +# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# with: +# upload_url: ${{ steps.create_release.outputs.upload_url }} +# asset_path: signal-cli-${{ steps.cli_ver.outputs.version }}-Linux.tar.gz +# asset_name: signal-cli-${{ steps.cli_ver.outputs.version }}-Linux.tar.gz +# asset_content_type: application/x-compressed-tar # .tar.gz + - name: Upload Linux native archive uses: actions/upload-release-asset@v1 env: @@ -121,91 +138,37 @@ jobs: asset_name: signal-cli-${{ steps.cli_ver.outputs.version }}-Linux-native.tar.gz asset_content_type: application/x-compressed-tar # .tar.gz - - name: Upload windows archive - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: signal-cli-${{ steps.cli_ver.outputs.version }}-Windows.tar.gz - asset_name: signal-cli-${{ steps.cli_ver.outputs.version }}-Windows.tar.gz - asset_content_type: application/x-compressed-tar # .tar.gz - - - name: Upload macos archive - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: signal-cli-${{ steps.cli_ver.outputs.version }}-macOS.tar.gz - asset_name: signal-cli-${{ steps.cli_ver.outputs.version }}-macOS.tar.gz - asset_content_type: application/x-compressed-tar # .tar.gz - - - run_repackaged: - - needs: - - lib_to_jar - - strategy: - matrix: - runner: - - windows-latest - - macos-latest - - runs-on: ${{ matrix.runner }} - - defaults: - run: - shell: bash # Explicit for windows - - env: - JAVA_VERSION: 19 - - steps: - - - name: Download the release file - env: - SIGNAL_CLI_VER: ${{ needs.lib_to_jar.outputs.signal_cli_version }} - RELEASE_ID: ${{ needs.lib_to_jar.outputs.release_id }} - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - run: | - file_name=signal-cli-${SIGNAL_CLI_VER}-${RUNNER_OS}.tar.gz - echo "$file_name" - assets_json=$(curl -s \ - -H "Authorization: Bearer $GITHUB_TOKEN" \ - "${GITHUB_API_URL}/repos/${GITHUB_REPOSITORY}/releases/${RELEASE_ID}/assets") - asset_dl_url=$(echo "$assets_json" | jq -r ".[] | select (.name == \"$file_name\") | .url") - echo "$asset_dl_url" - curl -sLOJ \ - -H 'Accept: application/octet-stream' \ - -H "Authorization: Bearer $GITHUB_TOKEN" \ - "$asset_dl_url" - tar -xzf "$file_name" - - - name: Set up JDK for running signal-cli executable - uses: actions/setup-java@v3 - with: - distribution: 'adopt' - java-version: ${{ env.JAVA_VERSION }} - java-package: 'jre' - - - name: Run signal-cli - run: | - cd signal-cli-*/bin - if [[ "$RUNNER_OS" == 'Windows' ]]; then - EXECUTABLE_SUFFIX=".bat" - fi - ./signal-cli${EXECUTABLE_SUFFIX} listAccounts +# - name: Upload windows archive +# uses: actions/upload-release-asset@v1 +# env: +# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# with: +# upload_url: ${{ steps.create_release.outputs.upload_url }} +# asset_path: signal-cli-${{ steps.cli_ver.outputs.version }}-Windows.tar.gz +# asset_name: signal-cli-${{ steps.cli_ver.outputs.version }}-Windows.tar.gz +# asset_content_type: application/x-compressed-tar # .tar.gz +# +# - name: Upload macos archive +# uses: actions/upload-release-asset@v1 +# env: +# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# with: +# upload_url: ${{ steps.create_release.outputs.upload_url }} +# asset_path: signal-cli-${{ steps.cli_ver.outputs.version }}-macOS.tar.gz +# asset_name: signal-cli-${{ steps.cli_ver.outputs.version }}-macOS.tar.gz +# asset_content_type: application/x-compressed-tar # .tar.gz build-container: needs: ci_wf runs-on: ubuntu-latest + permissions: + contents: read + packages: write steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - name: Download signal-cli build from CI workflow - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 - name: Get signal-cli version id: cli_ver @@ -219,7 +182,7 @@ jobs: tar xf ./"${ARCHIVE_DIR}"/*.tar.gz rm -r signal-cli-archive-* signal-cli-native mkdir -p build/install/ - mv ./signal-cli-*/ build/install/signal-cli + mv ./signal-cli-"${GITHUB_REF_NAME#v}"/ build/install/signal-cli - name: Build Image id: build_image @@ -248,11 +211,14 @@ jobs: build-container-native: needs: ci_wf runs-on: ubuntu-latest + permissions: + contents: read + packages: write steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - name: Download signal-cli build from CI workflow - uses: actions/download-artifact@v3 + uses: actions/download-artifact@v4 - name: Get signal-cli version id: cli_ver