From 5a633fdd8284dd1a2b6f3c95806f033ef4a4becf Mon Sep 17 00:00:00 2001 From: K900 Date: Tue, 14 Nov 2023 00:40:37 +0300 Subject: Packaging rework (#531) * fix: get rid of title view jank on latest beta * Count the number of installs for each plugin (#557) * Bump aiohttp from 3.8.4 to 3.8.5 in /backend (#558) * fix: include Decky version in request for index.js This avoids the If-Modified-Since logic in aiohttp and ensures Steam doesn't cache old JS, even if the timestamps are normalized. * fix: clean up shellcheck warnings in act runner script * fix: gitignore settings/ * fix: ensure state directories exist when running without the installer * feat: determine root directory correctly when running from in-tree * fix: fix typo in CI script * refactor: build a proper Python package with poetry * refactor: move decky_plugin under the poetry structure There's no need to special case it anymore, just treat it like any other Python module. * sandboxed_plugin: better fix, attempt 2 --------- Co-authored-by: AAGaming Co-authored-by: Party Wumpus <48649272+PartyWumpus@users.noreply.github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- .github/workflows/build.yml | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) (limited to '.github/workflows/build.yml') diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 25d9fe9f..4333e87e 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -69,12 +69,14 @@ jobs: sudo cp /usr/lib/libsqlite3.so.0.8.6 /usr/lib/x86_64-linux-gnu/ && rm -r /tmp/sqlite-autoconf-3420000 + - name: Install Poetry + uses: snok/install-poetry@v1 + with: + virtualenvs-create: false + - name: Install Python dependencies ⬇️ working-directory: ./backend - run: | - python -m pip install --upgrade pip - pip install pyinstaller==5.13.0 - pip install -r requirements.txt + run: poetry install --no-interaction - name: Install JS dependencies ⬇️ working-directory: ./frontend @@ -87,20 +89,21 @@ jobs: run: pnpm run build - name: Build Python Backend 🛠️ - run: pyinstaller --noconfirm --onefile --name "PluginLoader" --add-data ./backend/static:/static --add-data ./backend/locales:/locales --add-data ./plugin:/plugin --hidden-import=logging.handlers --hidden-import=sqlite3 ./backend/main.py - + working-directory: ./backend + run: pyinstaller pyinstaller.spec + - name: Upload package artifact ⬆️ if: ${{ !env.ACT }} uses: actions/upload-artifact@v3 with: name: PluginLoader - path: ./dist/PluginLoader + path: ./backend/dist/PluginLoader - name: Download package artifact locally if: ${{ env.ACT }} uses: actions/upload-artifact@v3 with: - path: ./dist/PluginLoader + path: ./backend/dist/PluginLoader release: name: Release stable version of the package @@ -177,7 +180,7 @@ jobs: with: name: Release ${{ steps.ready_tag.outputs.tag_name }} tag_name: ${{ steps.ready_tag.outputs.tag_name }} - files: ./dist/PluginLoader + files: ./backend/dist/PluginLoader prerelease: false generate_release_notes: true @@ -264,6 +267,6 @@ jobs: with: name: Prerelease ${{ steps.ready_tag.outputs.tag_name }} tag_name: ${{ steps.ready_tag.outputs.tag_name }} - files: ./dist/PluginLoader + files: ./backend/dist/PluginLoader prerelease: true generate_release_notes: true -- cgit v1.2.3