Merge branch 'PolyMC:develop' into develop
This commit is contained in:
commit
38f12c50f7
69
.github/ISSUE_TEMPLATE/rfc.yml
vendored
Normal file
69
.github/ISSUE_TEMPLATE/rfc.yml
vendored
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
# Template based on https://gitlab.archlinux.org/archlinux/rfcs/-/blob/0ba3b61e987e197f8d1901709409b8564958f78a/rfcs/0000-template.rst
|
||||||
|
name: Request for Comment (RFC)
|
||||||
|
description: Propose a larger change and start a discussion.
|
||||||
|
labels: [RFC]
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
### Use this form to suggest a larger change for PolyMC.
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: Goal
|
||||||
|
description: Short description, 1-2 sentences.
|
||||||
|
placeholder: Remove the cat from the launcher.
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: Motivation
|
||||||
|
description: |
|
||||||
|
Introduce the topic. If this is a not-well-known section of PolyMC, a detailed explanation of the background is recommended.
|
||||||
|
Some example points of discussion:
|
||||||
|
- What specific problems are you facing right now that you're trying to address?
|
||||||
|
- Are there any previous discussions? Link to them and summarize them (don't
|
||||||
|
- force your readers to read them though!).
|
||||||
|
- Is there any precedent set by other software? If so, link to resources.
|
||||||
|
placeholder: I don't like cats. I think many users also don't like cats.
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: Specification
|
||||||
|
description: A concrete, thorough explanation of what is being planned.
|
||||||
|
placeholder: Remove the cat button and all references to the cat from the codebase. Including resource files.
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: Drawbacks
|
||||||
|
description: Carefully consider every possible objection and issue with your proposal. This section should be updated as feedback comes in from discussion.
|
||||||
|
placeholder: Some users might like cats.
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: Unresolved Questions
|
||||||
|
description: |
|
||||||
|
Are there any portions of your proposal which need to be discussed with the community before the RFC can proceed?
|
||||||
|
Be careful here -- an RFC with a lot of remaining questions is likely to be stalled.
|
||||||
|
If your RFC is mostly unresolved questions and not too much substance, it may not be ready.
|
||||||
|
placeholder: Do a lot of users care about the cat?
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: Alternatives Considered
|
||||||
|
description: A list of alternatives, that have been considered and offer equal or similar features to the proposed change.
|
||||||
|
placeholder: Maybe the cat could be replaced with an axolotl?
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: checkboxes
|
||||||
|
attributes:
|
||||||
|
label: This suggestion is unique
|
||||||
|
options:
|
||||||
|
- label: I have searched the issue tracker and did not find an issue describing my suggestion, especially not one that has been rejected.
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: You may use the editor below to elaborate further.
|
75
.github/workflows/build.yml
vendored
75
.github/workflows/build.yml
vendored
@ -1,7 +1,12 @@
|
|||||||
name: build_portable
|
name: Build
|
||||||
|
|
||||||
on:
|
on:
|
||||||
[push, pull_request, workflow_dispatch]
|
workflow_call:
|
||||||
|
inputs:
|
||||||
|
build_type:
|
||||||
|
description: Type of build (Debug, Release, RelWithDebInfo, MinSizeRel)
|
||||||
|
type: string
|
||||||
|
default: Debug
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
@ -10,9 +15,14 @@ jobs:
|
|||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
|
|
||||||
|
- os: ubuntu-20.04
|
||||||
|
qt_version: 5.12.8
|
||||||
|
qt_host: linux
|
||||||
|
|
||||||
- os: ubuntu-20.04
|
- os: ubuntu-20.04
|
||||||
qt_version: 5.15.2
|
qt_version: 5.15.2
|
||||||
qt_host: linux
|
qt_host: linux
|
||||||
|
app_image: true
|
||||||
|
|
||||||
- os: windows-2022
|
- os: windows-2022
|
||||||
qt_version: 5.15.2
|
qt_version: 5.15.2
|
||||||
@ -59,6 +69,12 @@ jobs:
|
|||||||
copy "${{ github.workspace }}\Qt\Tools\OpenSSL\Win_x86\bin\libssl-1_1.dll" "${{ github.workspace }}\${{ env.INSTALL_DIR }}\"
|
copy "${{ github.workspace }}\Qt\Tools\OpenSSL\Win_x86\bin\libssl-1_1.dll" "${{ github.workspace }}\${{ env.INSTALL_DIR }}\"
|
||||||
copy "${{ github.workspace }}\Qt\Tools\OpenSSL\Win_x86\bin\libcrypto-1_1.dll" "${{ github.workspace }}\${{ env.INSTALL_DIR }}\"
|
copy "${{ github.workspace }}\Qt\Tools\OpenSSL\Win_x86\bin\libcrypto-1_1.dll" "${{ github.workspace }}\${{ env.INSTALL_DIR }}\"
|
||||||
|
|
||||||
|
- name: Set short version
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
ver_short=`git rev-parse --short HEAD`
|
||||||
|
echo "VERSION=$ver_short" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Install OpenJDK
|
- name: Install OpenJDK
|
||||||
uses: AdoptOpenJDK/install-jdk@v1
|
uses: AdoptOpenJDK/install-jdk@v1
|
||||||
with:
|
with:
|
||||||
@ -72,6 +88,7 @@ jobs:
|
|||||||
key: ${{ runner.os }}-${{ matrix.qt_version }}-${{ matrix.qt_arch }}-qt_cache
|
key: ${{ runner.os }}-${{ matrix.qt_version }}-${{ matrix.qt_arch }}-qt_cache
|
||||||
|
|
||||||
- name: Install Qt
|
- name: Install Qt
|
||||||
|
if: runner.os != 'Linux' || matrix.app_image == true
|
||||||
uses: jurplel/install-qt-action@v2
|
uses: jurplel/install-qt-action@v2
|
||||||
with:
|
with:
|
||||||
version: ${{ matrix.qt_version }}
|
version: ${{ matrix.qt_version }}
|
||||||
@ -80,18 +97,23 @@ jobs:
|
|||||||
cached: ${{ steps.cache-qt.outputs.cache-hit }}
|
cached: ${{ steps.cache-qt.outputs.cache-hit }}
|
||||||
dir: "${{ github.workspace }}/Qt/"
|
dir: "${{ github.workspace }}/Qt/"
|
||||||
|
|
||||||
|
- name: Install System Qt on Linux
|
||||||
|
if: runner.os == 'Linux' && matrix.app_image != true
|
||||||
|
run: |
|
||||||
|
sudo apt-get -y install qtbase5-dev qtchooser qt5-qmake qtbase5-dev-tools libqt5core5a libqt5network5 libqt5gui5
|
||||||
|
|
||||||
- name: Install Ninja
|
- name: Install Ninja
|
||||||
uses: urkle/action-get-ninja@v1
|
uses: urkle/action-get-ninja@v1
|
||||||
|
|
||||||
- name: Download linuxdeploy family
|
- name: Download linuxdeploy family for AppImage on Linux
|
||||||
if: runner.os == 'Linux'
|
if: matrix.app_image == true
|
||||||
run: |
|
run: |
|
||||||
wget "https://github.com/linuxdeploy/linuxdeploy/releases/download/continuous/linuxdeploy-x86_64.AppImage"
|
wget "https://github.com/linuxdeploy/linuxdeploy/releases/download/continuous/linuxdeploy-x86_64.AppImage"
|
||||||
wget "https://github.com/linuxdeploy/linuxdeploy-plugin-appimage/releases/download/continuous/linuxdeploy-plugin-appimage-x86_64.AppImage"
|
wget "https://github.com/linuxdeploy/linuxdeploy-plugin-appimage/releases/download/continuous/linuxdeploy-plugin-appimage-x86_64.AppImage"
|
||||||
wget "https://github.com/linuxdeploy/linuxdeploy-plugin-qt/releases/download/continuous/linuxdeploy-plugin-qt-x86_64.AppImage"
|
wget "https://github.com/linuxdeploy/linuxdeploy-plugin-qt/releases/download/continuous/linuxdeploy-plugin-qt-x86_64.AppImage"
|
||||||
|
|
||||||
- name: Download JREs for AppImage on Linux
|
- name: Download JREs for AppImage on Linux
|
||||||
if: runner.os == 'Linux'
|
if: matrix.app_image == true
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
${{ github.workspace }}/.github/scripts/prepare_JREs.sh
|
${{ github.workspace }}/.github/scripts/prepare_JREs.sh
|
||||||
@ -99,12 +121,12 @@ jobs:
|
|||||||
- name: Configure CMake
|
- name: Configure CMake
|
||||||
if: runner.os != 'Linux'
|
if: runner.os != 'Linux'
|
||||||
run: |
|
run: |
|
||||||
cmake -S . -B ${{ env.BUILD_DIR }} -DCMAKE_INSTALL_PREFIX=${{ env.INSTALL_DIR }} -DCMAKE_BUILD_TYPE=Debug -G Ninja
|
cmake -S . -B ${{ env.BUILD_DIR }} -DCMAKE_INSTALL_PREFIX=${{ env.INSTALL_DIR }} -DCMAKE_BUILD_TYPE=${{ inputs.build_type }} -G Ninja
|
||||||
|
|
||||||
- name: Configure CMake on Linux
|
- name: Configure CMake on Linux
|
||||||
if: runner.os == 'Linux'
|
if: runner.os == 'Linux'
|
||||||
run: |
|
run: |
|
||||||
cmake -S . -B ${{ env.BUILD_DIR }} -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=Debug -DLauncher_LAYOUT=lin-system -G Ninja
|
cmake -S . -B ${{ env.BUILD_DIR }} -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=${{ inputs.build_type }} -DLauncher_LAYOUT=lin-system -G Ninja
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
@ -115,16 +137,16 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
cmake --install ${{ env.BUILD_DIR }}
|
cmake --install ${{ env.BUILD_DIR }}
|
||||||
|
|
||||||
- name: Install for AppImage on Linux
|
- name: Install on Linux
|
||||||
if: runner.os == 'Linux'
|
if: runner.os == 'Linux'
|
||||||
run: |
|
run: |
|
||||||
DESTDIR=${{ env.INSTALL_DIR }} cmake --install ${{ env.BUILD_DIR }}
|
DESTDIR=${{ env.INSTALL_DIR }} cmake --install ${{ env.BUILD_DIR }}
|
||||||
|
|
||||||
- name: Bundle AppImage
|
- name: Bundle AppImage
|
||||||
if: runner.os == 'Linux'
|
if: matrix.app_image == true
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
export OUTPUT="PolyMC-${{ github.sha }}-x86_64.AppImage"
|
export OUTPUT="PolyMC-${{ runner.os }}-${{ env.VERSION }}-${{ inputs.build_type }}-x86_64.AppImage"
|
||||||
|
|
||||||
chmod +x linuxdeploy-*.AppImage
|
chmod +x linuxdeploy-*.AppImage
|
||||||
|
|
||||||
@ -145,13 +167,13 @@ jobs:
|
|||||||
- name: Run windeployqt
|
- name: Run windeployqt
|
||||||
if: runner.os == 'Windows'
|
if: runner.os == 'Windows'
|
||||||
run: |
|
run: |
|
||||||
windeployqt --no-translations "${{ env.INSTALL_DIR }}/polymc.exe"
|
windeployqt --no-translations --no-system-d3d-compiler --no-opengl-sw "${{ env.INSTALL_DIR }}/polymc.exe"
|
||||||
|
|
||||||
- name: Run macdeployqt
|
- name: Run macdeployqt
|
||||||
if: runner.os == 'macOS'
|
if: runner.os == 'macOS'
|
||||||
run: |
|
run: |
|
||||||
cd ${{ env.INSTALL_DIR }}
|
cd ${{ env.INSTALL_DIR }}
|
||||||
macdeployqt "PolyMC.app" -executable="PolyMC.app/Contents/MacOS/polymc" -always-overwrite -use-debug-libs
|
macdeployqt "PolyMC.app" -executable="PolyMC.app/Contents/MacOS/polymc" -always-overwrite
|
||||||
|
|
||||||
- name: chmod binary on macOS
|
- name: chmod binary on macOS
|
||||||
if: runner.os == 'macOS'
|
if: runner.os == 'macOS'
|
||||||
@ -162,25 +184,38 @@ jobs:
|
|||||||
if: runner.os == 'macOS'
|
if: runner.os == 'macOS'
|
||||||
run: |
|
run: |
|
||||||
cd ${{ env.INSTALL_DIR }}
|
cd ${{ env.INSTALL_DIR }}
|
||||||
tar -czf ../polymc.tar.gz *
|
tar -czf ../PolyMC.tar.gz *
|
||||||
|
|
||||||
- name: Upload AppImage for Linux
|
- name: tar on Linux
|
||||||
if: runner.os == 'Linux'
|
if: runner.os == 'Linux' && matrix.app_image != true
|
||||||
|
run: |
|
||||||
|
cd ${{ env.INSTALL_DIR }}
|
||||||
|
tar -czf ../PolyMC.tar.gz *
|
||||||
|
|
||||||
|
- name: Upload Linux tar.gz
|
||||||
|
if: runner.os == 'Linux' && matrix.app_image != true
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: PolyMC-${{ github.sha }}-x86_64.AppImage
|
name: PolyMC-${{ runner.os }}-${{ env.VERSION }}-${{ inputs.build_type }}
|
||||||
path: PolyMC-${{ github.sha }}-x86_64.AppImage
|
path: PolyMC.tar.gz
|
||||||
|
|
||||||
|
- name: Upload AppImage for Linux
|
||||||
|
if: matrix.app_image == true
|
||||||
|
uses: actions/upload-artifact@v2
|
||||||
|
with:
|
||||||
|
name: PolyMC-${{ runner.os }}-${{ env.VERSION }}-${{ inputs.build_type }}-x86_64.AppImage
|
||||||
|
path: PolyMC-${{ runner.os }}-${{ env.VERSION }}-${{ inputs.build_type }}-x86_64.AppImage
|
||||||
|
|
||||||
- name: Upload package for Windows
|
- name: Upload package for Windows
|
||||||
if: runner.os == 'Windows'
|
if: runner.os == 'Windows'
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: polymc-${{ runner.os }}-${{ github.sha }}-portable
|
name: PolyMC-${{ runner.os }}-${{ env.VERSION }}-${{ inputs.build_type }}
|
||||||
path: ${{ env.INSTALL_DIR }}/**
|
path: ${{ env.INSTALL_DIR }}/**
|
||||||
|
|
||||||
- name: Upload package for macOS
|
- name: Upload package for macOS
|
||||||
if: runner.os == 'macOS'
|
if: runner.os == 'macOS'
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
with:
|
with:
|
||||||
name: polymc-${{ runner.os }}-${{ github.sha }}-portable
|
name: PolyMC-${{ runner.os }}-${{ env.VERSION }}-${{ inputs.build_type }}
|
||||||
path: polymc.tar.gz
|
path: PolyMC.tar.gz
|
||||||
|
22
.github/workflows/trigger_builds.yml
vendored
Normal file
22
.github/workflows/trigger_builds.yml
vendored
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
name: Build Application
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches-ignore:
|
||||||
|
- 'stable'
|
||||||
|
pull_request:
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
|
||||||
|
build_debug:
|
||||||
|
name: Build Debug
|
||||||
|
uses: ./.github/workflows/build.yml
|
||||||
|
with:
|
||||||
|
build_type: Debug
|
||||||
|
|
||||||
|
build_release:
|
||||||
|
name: Build Release
|
||||||
|
uses: ./.github/workflows/build.yml
|
||||||
|
with:
|
||||||
|
build_type: Release
|
99
.github/workflows/trigger_release.yml
vendored
Normal file
99
.github/workflows/trigger_release.yml
vendored
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
name: Build Application and Make Release
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- '*'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
|
||||||
|
build_release:
|
||||||
|
name: Build Release
|
||||||
|
uses: ./.github/workflows/build.yml
|
||||||
|
with:
|
||||||
|
build_type: Release
|
||||||
|
|
||||||
|
create_release:
|
||||||
|
needs: build_release
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
outputs:
|
||||||
|
upload_url: ${{ steps.create_release.outputs.upload_url }}
|
||||||
|
steps:
|
||||||
|
- name: Grab and store version
|
||||||
|
run: |
|
||||||
|
tag_name=$(echo ${{ github.ref }} | grep -oE "[^/]+$")
|
||||||
|
echo "VERSION=$tag_name" >> $GITHUB_ENV
|
||||||
|
- name: Create release
|
||||||
|
id: create_release
|
||||||
|
uses: softprops/action-gh-release@v1
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
tag_name: ${{ github.ref }}
|
||||||
|
name: PolyMC ${{ env.VERSION }}
|
||||||
|
draft: true
|
||||||
|
prerelease: false
|
||||||
|
|
||||||
|
upload_release:
|
||||||
|
needs: create_release
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
|
||||||
|
- name: Download artifacts
|
||||||
|
uses: actions/download-artifact@v2
|
||||||
|
|
||||||
|
- name: Grab and store version
|
||||||
|
run: |
|
||||||
|
tag_name=$(echo ${{ github.ref }} | grep -oE "[^/]+$")
|
||||||
|
echo "VERSION=$tag_name" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
- name: Package artifacts properly
|
||||||
|
run: |
|
||||||
|
mv PolyMC-Linux*/PolyMC.tar.gz PolyMC-Linux-${{ env.VERSION }}.tar.gz
|
||||||
|
mv PolyMC-*.AppImage/PolyMC-*.AppImage PolyMC-Linux-${{ env.VERSION }}-x86_64.AppImage
|
||||||
|
mv PolyMC-Windows* PolyMC-Windows-${{ env.VERSION }}
|
||||||
|
mv PolyMC-macOS*/PolyMC.tar.gz PolyMC-macOS-${{ env.VERSION }}.tar.gz
|
||||||
|
|
||||||
|
cd PolyMC-Windows-${{ env.VERSION }}
|
||||||
|
zip -r -9 ../PolyMC-Windows-${{ env.VERSION }}.zip *
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
- name: Upload Linux asset
|
||||||
|
uses: actions/upload-release-asset@v1
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
upload_url: ${{ needs.create_release.outputs.upload_url }}
|
||||||
|
asset_name: PolyMC-Linux-${{ env.VERSION }}.tar.gz
|
||||||
|
asset_path: PolyMC-Linux-${{ env.VERSION }}.tar.gz
|
||||||
|
asset_content_type: application/gzip
|
||||||
|
|
||||||
|
- name: Upload Linux AppImage asset
|
||||||
|
uses: actions/upload-release-asset@v1
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
upload_url: ${{ needs.create_release.outputs.upload_url }}
|
||||||
|
asset_name: PolyMC-Linux-${{ env.VERSION }}-x86_64.AppImage
|
||||||
|
asset_path: PolyMC-Linux-${{ env.VERSION }}-x86_64.AppImage
|
||||||
|
asset_content_type: application/x-executable
|
||||||
|
|
||||||
|
- name: Upload Windows asset
|
||||||
|
uses: actions/upload-release-asset@v1
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
upload_url: ${{ needs.create_release.outputs.upload_url }}
|
||||||
|
asset_name: PolyMC-Windows-${{ env.VERSION }}.zip
|
||||||
|
asset_path: PolyMC-Windows-${{ env.VERSION }}.zip
|
||||||
|
asset_content_type: application/zip
|
||||||
|
|
||||||
|
- name: Upload macOS asset
|
||||||
|
uses: actions/upload-release-asset@v1
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
upload_url: ${{ needs.create_release.outputs.upload_url }}
|
||||||
|
asset_name: PolyMC-macOS-${{ env.VERSION }}.tar.gz
|
||||||
|
asset_path: PolyMC-macOS-${{ env.VERSION }}.tar.gz
|
||||||
|
asset_content_type: application/gzip
|
@ -73,7 +73,7 @@ set(Launcher_META_URL "https://meta.polymc.org/v1/" CACHE STRING "URL to fetch L
|
|||||||
set(Launcher_IMGUR_CLIENT_ID "5b97b0713fba4a3" CACHE STRING "Client ID you can get from Imgur when you register an application")
|
set(Launcher_IMGUR_CLIENT_ID "5b97b0713fba4a3" CACHE STRING "Client ID you can get from Imgur when you register an application")
|
||||||
|
|
||||||
# MSA Client ID
|
# MSA Client ID
|
||||||
set(Launcher_MSA_CLIENT_ID "17b47edd-c884-4997-926d-9e7f9a6b4647" CACHE STRING "Client ID you can get from Microsoft Identity Platform when you register an application")
|
set(Launcher_MSA_CLIENT_ID "549033b2-1532-4d4e-ae77-1bbaa46f9d74" CACHE STRING "Client ID you can get from Microsoft Identity Platform when you register an application")
|
||||||
|
|
||||||
# Bug tracker URL
|
# Bug tracker URL
|
||||||
set(Launcher_BUG_TRACKER_URL "https://github.com/PolyMC/PolyMC/issues" CACHE STRING "URL for the bug tracker.")
|
set(Launcher_BUG_TRACKER_URL "https://github.com/PolyMC/PolyMC/issues" CACHE STRING "URL for the bug tracker.")
|
||||||
|
50
README.md
50
README.md
@ -10,7 +10,8 @@ This is a **fork** of the MultiMC Launcher and not endorsed by MultiMC. The Poly
|
|||||||
<br>
|
<br>
|
||||||
|
|
||||||
# Installation
|
# Installation
|
||||||
- All packages (archived by version) can be found [here](https://packages.polymc.org/) ([latest](https://packages.polymc.org/latest)).
|
|
||||||
|
- All packages (archived by version) can be found [here](https://packages.polymc.org/) ([latest](https://packages.polymc.org/latest))
|
||||||
- Last build status: https://jenkins.polymc.org/job/PolyMC/lastBuild/
|
- Last build status: https://jenkins.polymc.org/job/PolyMC/lastBuild/
|
||||||
|
|
||||||
## 🐧 Linux
|
## 🐧 Linux
|
||||||
@ -29,33 +30,27 @@ There are several AUR packages available:
|
|||||||
|
|
||||||
[![polymc](https://img.shields.io/badge/aur-polymc-blue)](https://aur.archlinux.org/packages/polymc/)
|
[![polymc](https://img.shields.io/badge/aur-polymc-blue)](https://aur.archlinux.org/packages/polymc/)
|
||||||
[![polymc-bin](https://img.shields.io/badge/aur-polymc--bin-blue)](https://aur.archlinux.org/packages/polymc-bin/)
|
[![polymc-bin](https://img.shields.io/badge/aur-polymc--bin-blue)](https://aur.archlinux.org/packages/polymc-bin/)
|
||||||
[![polymc-git](https://img.shields.io/badge/aur-polymc--git-blue)](https://aur.archlinux.org/packages/polymc-git/)
|
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
# stable source package:
|
# source package:
|
||||||
yay -S polymc
|
yay -S polymc
|
||||||
# stable binary package:
|
# binary package:
|
||||||
yay -S polymc-bin
|
yay -S polymc-bin
|
||||||
# latest git package:
|
|
||||||
yay -S polymc-git
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### <img src="https://www.vectorlogo.zone/logos/debian/debian-icon.svg" height="20" /> Debian
|
### <img src="https://www.vectorlogo.zone/logos/debian/debian-icon.svg" height="20" /> Debian and <img src="https://www.vectorlogo.zone/logos/ubuntu/ubuntu-icon.svg" height="20" /> Ubuntu
|
||||||
|
|
||||||
We use [makedeb](https://docs.makedeb.org/) for our Debian packages.
|
We use [makedeb](https://docs.makedeb.org/) for our Debian packages.
|
||||||
Several MPR packages are available:
|
Several MPR packages are available:
|
||||||
|
|
||||||
[![polymc](https://img.shields.io/badge/mpr-polymc-orange)](https://mpr.makedeb.org/packages/polymc)
|
[![polymc](https://img.shields.io/badge/mpr-polymc-orange)](https://mpr.makedeb.org/packages/polymc)
|
||||||
[![polymc-bin](https://img.shields.io/badge/mpr-polymc--bin-orange)](https://mpr.makedeb.org/packages/polymc-bin)
|
[![polymc-bin](https://img.shields.io/badge/mpr-polymc--bin-orange)](https://mpr.makedeb.org/packages/polymc-bin)
|
||||||
[![polymc-git](https://img.shields.io/badge/mpr-polymc--git-orange)](https://mpr.makedeb.org/packages/polymc-git)
|
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
# stable source package:
|
# source package:
|
||||||
sudo tap install polymc
|
sudo tap install polymc
|
||||||
# stable binary package:
|
# binary package:
|
||||||
sudo tap install polymc-bin
|
sudo tap install polymc-bin
|
||||||
# latest git package:
|
|
||||||
sudo tap install polymc-git
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### <img src="https://www.vectorlogo.zone/logos/nixos/nixos-icon.svg" height="20" /> Nix
|
### <img src="https://www.vectorlogo.zone/logos/nixos/nixos-icon.svg" height="20" /> Nix
|
||||||
@ -85,13 +80,6 @@ sudo dnf copr enable polymc/polymc
|
|||||||
sudo dnf install polymc
|
sudo dnf install polymc
|
||||||
```
|
```
|
||||||
|
|
||||||
Alternatively, a COPR maintained by a PolyMC user (instead of Jenkins' automated builds) is available [here](https://copr.fedorainfracloud.org/coprs/sentry/polymc).
|
|
||||||
|
|
||||||
```sh
|
|
||||||
sudo dnf copr enable sentry/polymc
|
|
||||||
sudo dnf install polymc
|
|
||||||
```
|
|
||||||
|
|
||||||
### <img src="https://lotar.altervista.org/wiki/_media/news/slackware-logo.png" height="20" /> Slackware
|
### <img src="https://lotar.altervista.org/wiki/_media/news/slackware-logo.png" height="20" /> Slackware
|
||||||
|
|
||||||
[A SlackBuild](https://codeberg.org/glowiak/SlackBuilds/src/branch/master/repository/polymc.md) is available. You will need [qt5](http://slackbuilds.org/repository/14.2/libraries/qt5/) (on 15.0 installed by default), [a JDK](https://codeberg.org/glowiak/SlackBuilds/src/branch/master/repository/adoptium-jdk8.md), and if you're on 14.2, you need to compile newer CMake version manually. To build, type in extracted directory with all dependiences met:
|
[A SlackBuild](https://codeberg.org/glowiak/SlackBuilds/src/branch/master/repository/polymc.md) is available. You will need [qt5](http://slackbuilds.org/repository/14.2/libraries/qt5/) (on 15.0 installed by default), [a JDK](https://codeberg.org/glowiak/SlackBuilds/src/branch/master/repository/adoptium-jdk8.md), and if you're on 14.2, you need to compile newer CMake version manually. To build, type in extracted directory with all dependiences met:
|
||||||
@ -99,7 +87,7 @@ sudo dnf install polymc
|
|||||||
sudo ./polymc.SlackBuild
|
sudo ./polymc.SlackBuild
|
||||||
sudo installpkg /tmp/polymc-version-arch-1_SBo.tgz
|
sudo installpkg /tmp/polymc-version-arch-1_SBo.tgz
|
||||||
|
|
||||||
If you are too lazy to do all these steps, you can just download [a prebuild x86_64 package](http://glowiak.github.io/file/polymc-latest-slackware) and install it with /sbin/installpkg:
|
You can also download a community-maintained [prebuilt x86_64 package](http://glowiak.github.io/file/polymc-latest-slackware) and install it with /sbin/installpkg:
|
||||||
|
|
||||||
sudo /sbin/installpkg ~/Downloads/polymc-version-x86_64-1_SBo.tgz
|
sudo /sbin/installpkg ~/Downloads/polymc-version-x86_64-1_SBo.tgz
|
||||||
|
|
||||||
@ -109,28 +97,37 @@ If you are too lazy to do all these steps, you can just download [a prebuild x86
|
|||||||
|
|
||||||
## <img src="https://www.vectorlogo.zone/logos/apple/apple-tile.svg" height="20" /> MacOS
|
## <img src="https://www.vectorlogo.zone/logos/apple/apple-tile.svg" height="20" /> MacOS
|
||||||
|
|
||||||
MacOS currently does not have any packages. We are still working on setting up MacOS packaging. Meanwhile, you can [build](https://github.com/PolyMC/PolyMC/blob/develop/BUILD.md#macos) it for yourself.
|
MacOS has experimental development builds available [here](https://github.com/PolyMC/PolyMC/actions)
|
||||||
|
|
||||||
## <img src="https://www.vectorlogo.zone/logos/freebsd/freebsd-icon.svg" height="20" /> FreeBSD
|
## <img src="https://www.vectorlogo.zone/logos/freebsd/freebsd-icon.svg" height="20" /> FreeBSD
|
||||||
|
|
||||||
For FreeBSD available are:
|
There are community-maintained binary packages available:
|
||||||
|
|
||||||
- [AppBSD Image](http://glowiak.github.io/file/polymc-latest-fbsd64-appbsd) - a portable application, requires [AppBSD](https://codeberg.org/glowiak/appbsd/) to be installed.
|
- [AppBSD Image](http://glowiak.github.io/file/polymc-latest-fbsd64-appbsd) - a portable application, requires [AppBSD](https://codeberg.org/glowiak/appbsd/) to be installed.
|
||||||
|
|
||||||
- [Gzipped binaries](http://glowiak.github.io/file/polymc-latest-fbsd64-raw) - traditional way to distribute, unpack and run.
|
- [Gzipped binaries](http://glowiak.github.io/file/polymc-latest-fbsd64-raw) - traditional way to distribute, unpack and run.
|
||||||
|
|
||||||
In both cases you need X11, Qt5 and Java installed. Both files are 64bit only.
|
In both cases you need X11, Qt5 and Java installed. Both files are 64bit only.
|
||||||
|
You can build from source - see [BUILD.md](./BUILD.md)
|
||||||
|
|
||||||
## <img src="https://raw.githubusercontent.com/AliasIO/wappalyzer/master/src/drivers/webextension/images/icons/OpenBSD%20httpd.svg" height="20" /> OpenBSD
|
## <img src="https://raw.githubusercontent.com/AliasIO/wappalyzer/master/src/drivers/webextension/images/icons/OpenBSD%20httpd.svg" height="20" /> OpenBSD
|
||||||
|
|
||||||
For OpenBSD available are [gzipped 32-bit binaries](http://glowiak.github.io/file/polymc-latest-obsd32-raw), download, unpack and run.
|
There are community-maintained binary packages available:
|
||||||
|
|
||||||
You need X11, Qt5 and Java installed.
|
- [gzipped 32-bit binaries](http://glowiak.github.io/file/polymc-latest-obsd32-raw), download, unpack and run.
|
||||||
|
|
||||||
|
You need X11, Qt5 and Java installed.
|
||||||
|
You can build from source - see [BUILD.md](./BUILD.md)
|
||||||
|
|
||||||
## Development Builds
|
## Development Builds
|
||||||
|
|
||||||
There are per-commit development builds available [here](https://github.com/PolyMC/PolyMC/actions). These have debug information in the binaries, so their file sizes are relatively larger.
|
There are per-commit development builds available [here](https://github.com/PolyMC/PolyMC/actions). These have debug information in the binaries, so their file sizes are relatively larger.
|
||||||
Builds are provided for Linux, AppImage on Linux, Windows, and macOS.
|
Portable builds are provided for AppImage on Linux, Windows, and macOS.
|
||||||
|
|
||||||
|
For Debian and Arch, you can use these packages for the latest development versions:
|
||||||
|
[![polymc-git](https://img.shields.io/badge/aur-polymc--git-blue)](https://aur.archlinux.org/packages/polymc-git/)
|
||||||
|
[![polymc-git](https://img.shields.io/badge/mpr-polymc--git-orange)](https://mpr.makedeb.org/packages/polymc-git)
|
||||||
|
For flatpak, you can use [flathub-beta](https://discourse.flathub.org/t/how-to-use-flathub-beta/2111)
|
||||||
|
|
||||||
# Help & Support
|
# Help & Support
|
||||||
|
|
||||||
@ -158,6 +155,7 @@ If you want to contribute to PolyMC you might find it useful to join our Discord
|
|||||||
If you want to build PolyMC yourself, check [BUILD.md](BUILD.md) for build instructions.
|
If you want to build PolyMC yourself, check [BUILD.md](BUILD.md) for build instructions.
|
||||||
|
|
||||||
## Code formatting
|
## Code formatting
|
||||||
|
|
||||||
Just follow the existing formatting.
|
Just follow the existing formatting.
|
||||||
|
|
||||||
In general, in order of importance:
|
In general, in order of importance:
|
||||||
|
@ -192,27 +192,6 @@ Application::Application(int &argc, char **argv) : QApplication(argc, argv)
|
|||||||
#endif
|
#endif
|
||||||
startTime = QDateTime::currentDateTime();
|
startTime = QDateTime::currentDateTime();
|
||||||
|
|
||||||
#ifdef Q_OS_LINUX
|
|
||||||
{
|
|
||||||
QFile osrelease("/proc/sys/kernel/osrelease");
|
|
||||||
if (osrelease.open(QFile::ReadOnly | QFile::Text)) {
|
|
||||||
QTextStream in(&osrelease);
|
|
||||||
auto contents = in.readAll();
|
|
||||||
if(
|
|
||||||
contents.contains("WSL", Qt::CaseInsensitive) ||
|
|
||||||
contents.contains("Microsoft", Qt::CaseInsensitive)
|
|
||||||
) {
|
|
||||||
showFatalErrorMessage(
|
|
||||||
"Unsupported system detected!",
|
|
||||||
"Linux-on-Windows distributions are not supported.\n\n"
|
|
||||||
"Please use the Windows binary when playing on Windows."
|
|
||||||
);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Don't quit on hiding the last window
|
// Don't quit on hiding the last window
|
||||||
this->setQuitOnLastWindowClosed(false);
|
this->setQuitOnLastWindowClosed(false);
|
||||||
|
|
||||||
|
@ -228,6 +228,18 @@ void LaunchController::login() {
|
|||||||
emitFailed(errorString);
|
emitFailed(errorString);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
case AccountState::Disabled: {
|
||||||
|
auto errorString = tr("The launcher's client identification has changed. Please remove this account and add it again.");
|
||||||
|
QMessageBox::warning(
|
||||||
|
m_parentWidget,
|
||||||
|
tr("Client identification changed"),
|
||||||
|
errorString,
|
||||||
|
QMessageBox::StandardButton::Ok,
|
||||||
|
QMessageBox::StandardButton::Ok
|
||||||
|
);
|
||||||
|
emitFailed(errorString);
|
||||||
|
return;
|
||||||
|
}
|
||||||
case AccountState::Gone: {
|
case AccountState::Gone: {
|
||||||
auto errorString = tr("The account no longer exists on the servers. It may have been migrated, in which case please add the new account you migrated this one to.");
|
auto errorString = tr("The account no longer exists on the servers. It may have been migrated, in which case please add the new account you migrated this one to.");
|
||||||
QMessageBox::warning(
|
QMessageBox::warning(
|
||||||
|
@ -327,6 +327,10 @@ bool AccountData::resumeStateFromV3(QJsonObject data) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(type == AccountType::MSA) {
|
if(type == AccountType::MSA) {
|
||||||
|
auto clientIDV = data.value("msa-client-id");
|
||||||
|
if (clientIDV.isString()) {
|
||||||
|
msaClientID = clientIDV.toString();
|
||||||
|
} // leave msaClientID empty if it doesn't exist or isn't a string
|
||||||
msaToken = tokenFromJSONV3(data, "msa");
|
msaToken = tokenFromJSONV3(data, "msa");
|
||||||
userToken = tokenFromJSONV3(data, "utoken");
|
userToken = tokenFromJSONV3(data, "utoken");
|
||||||
xboxApiToken = tokenFromJSONV3(data, "xrp-main");
|
xboxApiToken = tokenFromJSONV3(data, "xrp-main");
|
||||||
@ -360,6 +364,7 @@ QJsonObject AccountData::saveState() const {
|
|||||||
}
|
}
|
||||||
else if (type == AccountType::MSA) {
|
else if (type == AccountType::MSA) {
|
||||||
output["type"] = "MSA";
|
output["type"] = "MSA";
|
||||||
|
output["msa-client-id"] = msaClientID;
|
||||||
tokenToJSONV3(output, msaToken, "msa");
|
tokenToJSONV3(output, msaToken, "msa");
|
||||||
tokenToJSONV3(output, userToken, "utoken");
|
tokenToJSONV3(output, userToken, "utoken");
|
||||||
tokenToJSONV3(output, xboxApiToken, "xrp-main");
|
tokenToJSONV3(output, xboxApiToken, "xrp-main");
|
||||||
|
@ -47,6 +47,7 @@ enum class AccountState {
|
|||||||
Offline,
|
Offline,
|
||||||
Working,
|
Working,
|
||||||
Online,
|
Online,
|
||||||
|
Disabled,
|
||||||
Errored,
|
Errored,
|
||||||
Expired,
|
Expired,
|
||||||
Gone
|
Gone
|
||||||
@ -81,6 +82,7 @@ struct AccountData {
|
|||||||
bool legacy = false;
|
bool legacy = false;
|
||||||
bool canMigrateToMSA = false;
|
bool canMigrateToMSA = false;
|
||||||
|
|
||||||
|
QString msaClientID;
|
||||||
Katabasis::Token msaToken;
|
Katabasis::Token msaToken;
|
||||||
Katabasis::Token userToken;
|
Katabasis::Token userToken;
|
||||||
Katabasis::Token xboxApiToken;
|
Katabasis::Token xboxApiToken;
|
||||||
|
@ -291,6 +291,9 @@ QVariant AccountList::data(const QModelIndex &index, int role) const
|
|||||||
case AccountState::Expired: {
|
case AccountState::Expired: {
|
||||||
return tr("Expired", "Account status");
|
return tr("Expired", "Account status");
|
||||||
}
|
}
|
||||||
|
case AccountState::Disabled: {
|
||||||
|
return tr("Disabled", "Account status");
|
||||||
|
}
|
||||||
case AccountState::Gone: {
|
case AccountState::Gone: {
|
||||||
return tr("Gone", "Account status");
|
return tr("Gone", "Account status");
|
||||||
}
|
}
|
||||||
|
@ -43,6 +43,8 @@ QString AccountTask::getStateMessage() const
|
|||||||
return tr("Authentication task succeeded.");
|
return tr("Authentication task succeeded.");
|
||||||
case AccountTaskState::STATE_OFFLINE:
|
case AccountTaskState::STATE_OFFLINE:
|
||||||
return tr("Failed to contact the authentication server.");
|
return tr("Failed to contact the authentication server.");
|
||||||
|
case AccountTaskState::STATE_DISABLED:
|
||||||
|
return tr("Client ID has changed. New session needs to be created.");
|
||||||
case AccountTaskState::STATE_FAILED_SOFT:
|
case AccountTaskState::STATE_FAILED_SOFT:
|
||||||
return tr("Encountered an error during authentication.");
|
return tr("Encountered an error during authentication.");
|
||||||
case AccountTaskState::STATE_FAILED_HARD:
|
case AccountTaskState::STATE_FAILED_HARD:
|
||||||
@ -78,6 +80,12 @@ bool AccountTask::changeState(AccountTaskState newState, QString reason)
|
|||||||
emitFailed(reason);
|
emitFailed(reason);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
case AccountTaskState::STATE_DISABLED: {
|
||||||
|
m_data->errorString = reason;
|
||||||
|
m_data->accountState = AccountState::Disabled;
|
||||||
|
emitFailed(reason);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
case AccountTaskState::STATE_FAILED_SOFT: {
|
case AccountTaskState::STATE_FAILED_SOFT: {
|
||||||
m_data->errorString = reason;
|
m_data->errorString = reason;
|
||||||
m_data->accountState = AccountState::Errored;
|
m_data->accountState = AccountState::Errored;
|
||||||
|
@ -35,6 +35,7 @@ enum class AccountTaskState
|
|||||||
STATE_CREATED,
|
STATE_CREATED,
|
||||||
STATE_WORKING,
|
STATE_WORKING,
|
||||||
STATE_SUCCEEDED,
|
STATE_SUCCEEDED,
|
||||||
|
STATE_DISABLED, //!< MSA Client ID has changed. Tell user to reloginn
|
||||||
STATE_FAILED_SOFT, //!< soft failure. authentication went through partially
|
STATE_FAILED_SOFT, //!< soft failure. authentication went through partially
|
||||||
STATE_FAILED_HARD, //!< hard failure. main tokens are invalid
|
STATE_FAILED_HARD, //!< hard failure. main tokens are invalid
|
||||||
STATE_FAILED_GONE, //!< hard failure. main tokens are invalid, and the account no longer exists
|
STATE_FAILED_GONE, //!< hard failure. main tokens are invalid, and the account no longer exists
|
||||||
|
@ -176,6 +176,9 @@ void MinecraftAccount::authFailed(QString reason)
|
|||||||
{
|
{
|
||||||
switch (m_currentTask->taskState()) {
|
switch (m_currentTask->taskState()) {
|
||||||
case AccountTaskState::STATE_OFFLINE:
|
case AccountTaskState::STATE_OFFLINE:
|
||||||
|
case AccountTaskState::STATE_DISABLED: {
|
||||||
|
// NOTE: user will need to fix this themselves.
|
||||||
|
}
|
||||||
case AccountTaskState::STATE_FAILED_SOFT: {
|
case AccountTaskState::STATE_FAILED_SOFT: {
|
||||||
// NOTE: this doesn't do much. There was an error of some sort.
|
// NOTE: this doesn't do much. There was an error of some sort.
|
||||||
}
|
}
|
||||||
|
@ -12,9 +12,10 @@ using OAuth2 = Katabasis::DeviceFlow;
|
|||||||
using Activity = Katabasis::Activity;
|
using Activity = Katabasis::Activity;
|
||||||
|
|
||||||
MSAStep::MSAStep(AccountData* data, Action action) : AuthStep(data), m_action(action) {
|
MSAStep::MSAStep(AccountData* data, Action action) : AuthStep(data), m_action(action) {
|
||||||
|
m_clientId = APPLICATION->getMSAClientID();
|
||||||
OAuth2::Options opts;
|
OAuth2::Options opts;
|
||||||
opts.scope = "XboxLive.signin offline_access";
|
opts.scope = "XboxLive.signin offline_access";
|
||||||
opts.clientIdentifier = APPLICATION->getMSAClientID();
|
opts.clientIdentifier = m_clientId;
|
||||||
opts.authorizationUrl = "https://login.microsoftonline.com/consumers/oauth2/v2.0/devicecode";
|
opts.authorizationUrl = "https://login.microsoftonline.com/consumers/oauth2/v2.0/devicecode";
|
||||||
opts.accessTokenUrl = "https://login.microsoftonline.com/consumers/oauth2/v2.0/token";
|
opts.accessTokenUrl = "https://login.microsoftonline.com/consumers/oauth2/v2.0/token";
|
||||||
|
|
||||||
@ -48,6 +49,10 @@ void MSAStep::rehydrate() {
|
|||||||
void MSAStep::perform() {
|
void MSAStep::perform() {
|
||||||
switch(m_action) {
|
switch(m_action) {
|
||||||
case Refresh: {
|
case Refresh: {
|
||||||
|
if (m_data->msaClientID != m_clientId) {
|
||||||
|
emit hideVerificationUriAndCode();
|
||||||
|
emit finished(AccountTaskState::STATE_DISABLED, tr("Microsoft user authentication failed - client identification has changed."));
|
||||||
|
}
|
||||||
m_oauth2->refresh();
|
m_oauth2->refresh();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -57,6 +62,7 @@ void MSAStep::perform() {
|
|||||||
m_oauth2->setExtraRequestParams(extraOpts);
|
m_oauth2->setExtraRequestParams(extraOpts);
|
||||||
|
|
||||||
*m_data = AccountData();
|
*m_data = AccountData();
|
||||||
|
m_data->msaClientID = m_clientId;
|
||||||
m_oauth2->login();
|
m_oauth2->login();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -29,4 +29,5 @@ private slots:
|
|||||||
private:
|
private:
|
||||||
Katabasis::DeviceFlow *m_oauth2 = nullptr;
|
Katabasis::DeviceFlow *m_oauth2 = nullptr;
|
||||||
Action m_action;
|
Action m_action;
|
||||||
|
QString m_clientId;
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user