Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Mac build fix #11

Open
wants to merge 111 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
111 commits
Select commit Hold shift + click to select a range
9ef4340
Add protobuff files
LauraRozier Mar 16, 2023
029e695
Add (improvised) missing files
LauraRozier Mar 16, 2023
98e3444
Update bindings
LauraRozier Mar 16, 2023
e0b914f
Fix AttributeError('out_of_game_heartbeat_seconds')
LauraRozier Mar 16, 2023
cb9f8c3
Update README.md
TheSentry Apr 10, 2023
0d24e8a
implemented the RSA call.
ABaumher Apr 30, 2023
4f39c71
actually staging the changes this time, lol
ABaumher Apr 30, 2023
4edb254
Updated enums to the current version available. Continued modificatio…
ABaumher Apr 30, 2023
d0c2a14
Updated protocol buffer message files to work with auth. Merged chang…
ABaumher May 2, 2023
0b16bfc
updated the EMsg constants. They were out of date
ABaumher May 2, 2023
77474d5
minor changes to protobuf client. Prototyping new workflow. Preparing…
ABaumher May 4, 2023
6cc7ecb
Updated bugfixes to a version that runs in GOG Galaxy. This still req…
ABaumher May 4, 2023
b61273b
Got the RSA Key all the way back to the Backend, so we can change the…
ABaumher May 4, 2023
58c8f29
Update that gets the password RSA key for the user. Implements the ba…
ABaumher May 5, 2023
7498c57
Maybe breaking. Looking for an old message i wrote, so i need this ba…
ABaumher May 5, 2023
da90375
updated consts, protobuf, protocol buffer to report modern os types (…
ABaumher May 5, 2023
83a69a1
Testing various changes. This will break at some point before hitting…
ABaumher May 6, 2023
76ccfca
Breaking Change: Renamed types.py so Visual Studio would stop complai…
ABaumher May 6, 2023
708083c
adding type hints, mostly. need to track down where job_list was adde…
ABaumher May 6, 2023
141eed8
Public Key data comes back in hexidecimal, so that is now handled pro…
ABaumher May 6, 2023
0eef845
Full login with no SteamGuard test. Likely will require a few bugfixe…
ABaumher May 6, 2023
dc762dd
Login processed properly, goes to confirm to get the tokens, and none…
ABaumher May 7, 2023
0285aa2
Merged in Thibmo's fixes and proto files. this is not a complete merg…
ABaumher May 7, 2023
4429a71
Dealing with getting the proto files properly parsed and built so the…
ABaumher May 8, 2023
3cd0b49
Added Protos. Updated Tasks.py to properly import them. They still do…
ABaumher May 8, 2023
91f2670
Reverted py files to what they were before merging with Thibmo's fork.
ABaumher May 8, 2023
95bbacf
Updated the protobuf list to the files we currently use. There are a …
ABaumher May 8, 2023
f65f179
Figured out how to handle conflicts with the service messages. we sho…
ABaumher May 8, 2023
e4cf9bd
Finally found the version of protoc the old version was using. we can…
ABaumher May 9, 2023
a44be78
Updates throughout the code base. Preparing for full auth workflow an…
ABaumher May 10, 2023
a135724
Full integration of all parts of new auth flow implemented. Bugfixing…
ABaumher May 10, 2023
d9641f3
Bugs Fixed. Now logs in, but no other messages are sent. needs a Clie…
ABaumher May 10, 2023
0d50163
Experimental branch; i don't want to break something on the main fix.…
ABaumher May 10, 2023
7922c28
Added a readme for alpha testers
ABaumher May 10, 2023
452d83a
Update README_ALPHA.md
ABaumher May 10, 2023
dc6adcd
Attempt to fix issue raised by HiddenAnomaly
ABaumher May 10, 2023
d008b6c
preparing to call old client login method. preparing to remove public…
ABaumher May 11, 2023
825de45
Merge branch 'remove_public_profiles_backend' into AuthFix
ABaumher May 11, 2023
5869ef9
Finished removing public profiles. Started adding the token login cal…
ABaumher May 11, 2023
81e3a66
Fixed a few issues created by removing public backend
ABaumher May 11, 2023
f506150
Getting persistent login to work. Fixed a few errors.
ABaumher May 11, 2023
b8f9a0e
Removed logger info for packet information. This massively bloated th…
ABaumher May 11, 2023
0bcaf03
fix mobile confirm flow. not pretty but should work
May 11, 2023
8946473
Enable job processing - achievements, collections, game times
slo May 11, 2023
6f1aa9e
Merge pull request #1 from don-de-marco/AuthFix
ABaumher May 12, 2023
398c39d
bugfix. trying to stay logged in. failing. Currently, the stay logged…
ABaumher May 12, 2023
ad838f2
disabled cache login. Wrote comments explaining it
ABaumher May 12, 2023
e45d0e5
Temporary "fix" that removes the job_list so the code will work again.
ABaumher May 12, 2023
a656d12
Persistent login now works.
ABaumher May 15, 2023
167aa0f
Remove guard data requirements, as they were breaking mobile login
ABaumher May 15, 2023
fe25334
(try to) fix the conflicting protobuf files situation
May 13, 2023
33908dc
fix proto2 syntax statement
May 13, 2023
46c3370
Bugfix to properly recover when refresh token expires or is revoked.
ABaumher May 15, 2023
921bd72
Update README_ALPHA.md
ABaumher May 15, 2023
6869909
Update README_ALPHA.md
ABaumher May 15, 2023
7f01fc0
Update README_ALPHA.md
ABaumher May 15, 2023
d75bf9c
Update README_ALPHA.md
ABaumher May 15, 2023
4647e5f
Update README_ALPHA.md
ABaumher May 15, 2023
5805697
Update README.md
ABaumher May 15, 2023
8521a9b
Update protobuf_steammessages.txt
ABaumher May 15, 2023
86a709e
Merge pull request #1 from don-de-marco/abaumher-rebase
ABaumher May 15, 2023
6aa370d
Update README.md
ABaumher May 16, 2023
9873e50
Update README.md
ABaumher May 16, 2023
e0a78a1
Update README.md
ABaumher May 16, 2023
374dbd2
added install.txt so readme works properly
ABaumher May 16, 2023
e0a00a5
Update the install so it works properly. Merge changes that i didn't …
ABaumher May 16, 2023
04ff339
Fix the readme and install.txt so they now work
ABaumher May 16, 2023
7b23678
Actually fixed it this time. Requires galaxy plugin in install
ABaumher May 16, 2023
3b7c90e
Added beautiful soup to app requirements so it does not crash. fixed …
ABaumher May 16, 2023
9435073
revert app.txt change. remove user_profile, which caused the conflict…
ABaumher May 16, 2023
e511960
Bugfix so mobile code works correctly
ABaumher May 17, 2023
3f242fe
updated translate error to log the error received so we can more easi…
ABaumher May 17, 2023
8cfb1c4
bugfix for mobile confirm. If you hit continue before confirming, it …
ABaumher May 17, 2023
bc8af72
Reverted UI so it's user and password. cleaned up the css and html so…
ABaumher May 18, 2023
6d5e8e3
fixes multiple bugs: a residual debug that caused errors on a failed …
ABaumher May 18, 2023
4247b66
missed a pair of errors related to removing user name from pages.
ABaumher May 18, 2023
cb6f315
Mobile confirm bugfix, html now displays errors properly.
ABaumher May 18, 2023
050f9e1
Attempting to refactor all the code to work with mobile confirm. I st…
ABaumher May 18, 2023
45d450b
fallback on mobile confirm should now work.
ABaumher May 18, 2023
4b3f3ff
Bugfixes (again). Email code works again.
ABaumher May 18, 2023
1ede3a7
Tracked down a bug where the client would silently crash if you revok…
ABaumher May 19, 2023
276cabe
bugfix, priority list was sorting ascending, wanted descending.
ABaumher May 19, 2023
37762fd
Multiple bugfixes. Mobile confirm should finally work (though, probab…
ABaumher May 20, 2023
50ceaab
Bugfix. Wrapping recv in a task was done improperly. it's now fixed. …
ABaumher May 20, 2023
c8b8a7b
Updated the ui for mobile confirm for clarity. link now uses the prop…
ABaumher May 20, 2023
bb47e90
Experiemental Resend Code implementation. Two Factor expire now kicks…
ABaumher May 21, 2023
9e226de
Revert "Updated the ui for mobile confirm for clarity. link now uses …
ABaumher May 21, 2023
e2d6f6c
Revert "Experiemental Resend Code implementation. Two Factor expire n…
ABaumher May 21, 2023
23423d9
Reverts all the changes made to try to fix the resend issue. We now j…
ABaumher May 21, 2023
b68aff8
Merge pull request #4 from ABaumher/revert_pls
ABaumher May 21, 2023
cd5133a
hopefully fixed error message for login page after a timeout
ABaumher May 21, 2023
05a1615
Updated index with a message explaining what happens when email times…
ABaumher May 21, 2023
a137cd5
some fixes to readme, move pip req to reqs file, fix start of pytest
MisterZeus May 22, 2023
30369f8
Merge pull request #5 from ABaumher/mobile_confirm_refactor
ABaumher May 22, 2023
236ab56
Update README.md
ABaumher May 22, 2023
f93ea59
Update README.md
ABaumher May 22, 2023
9c700b7
Merge branch 'master' into master
MisterZeus May 22, 2023
489230c
check whether users have py installed
MisterZeus May 22, 2023
3aa2cfa
Merge branch 'master' of https://github.com/MisterZeus/galaxy-integra…
MisterZeus May 22, 2023
a51a0fc
remove exeprobe, make if simpler
MisterZeus May 22, 2023
23ef0c0
readme tweaks
MisterZeus May 22, 2023
3a03a84
Merge pull request #3 from MisterZeus/master
ABaumher May 23, 2023
eb8879b
Update gitignore to ignore zip files, so it excudes the release. reim…
ABaumher May 23, 2023
432e77c
Temporary fix for achievements sync. Limit simultaneous jobs.
wwMRd May 25, 2023
3da5c06
Merge pull request #8 from wwMRd/achievements_temp_fix
ABaumher May 26, 2023
5231719
Added .DStore to ignore list
bgebhardt May 29, 2023
e3bb216
Revert "Added .DStore to ignore list"
bgebhardt May 29, 2023
6a253d0
Added mac-related .dot files
bgebhardt May 29, 2023
9ab4a60
updated required pip-tools
bgebhardt May 29, 2023
dbd6f45
Updated mac build instructions
bgebhardt May 29, 2023
33d791d
Added instructions to setup protobuf compiling on Mac
bgebhardt May 29, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,14 @@ build/
output/
*.log
*.log.[1-9]
/.vs
/env
*.user
/env1
/protoc
*.zip

# mac
.DS_Store
# used by pyenv
.python-version
14 changes: 14 additions & 0 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@

MIT License

Copyright (c) 2021-2023, FriendsOfGalaxy, Slo, Andrew Baumher, TheSentry, Thibmo et.al.
Portions of this code Copyright (c) 2015-2023, Rossen Georgiev <[email protected]>
Portions of this code Copyright (c) 2017-2023, Hiroyuki Takagi

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

This software includes the work that is distributed in the Apache License 2.0.
199 changes: 158 additions & 41 deletions README.md
100755 → 100644
Original file line number Diff line number Diff line change
Expand Up @@ -2,57 +2,174 @@

GOG Galaxy 2.0 Community integration for Steam.

## Installation
## Open Beta:
This project is in open beta. It is not completely bulletproof, but it has been extensively tested. We are hoping that crowdsourcing the error checking will help find anything we may have missed.

### Known Issues:
* Large libraries are known to be a little wonky. Sometimes, the plugin may crash after initially starting it, but then immediately work properly once you hit "retry". There's not much we can do here.
* If you take too long to enter a 2FA code, any login stuff after that have a small chance of crashing. This is because steam kicks us out after roughly a minute of inactivity. We reconnect, but if we were sending them something when they kicked us out, we'd never get a response and after a minute of waiting, the plugin will close. Restarting the plugin will fix this, but it is something we are looking at fixing in a later version. In our tests, it has happened, but is difficult to replicate. If this issue is more prevalent than we anticipate, it's something we will address immediately.
* Closing GOG immediately after connecting for the first time may cause GOG to crash. Similarly, disconnecting Steam immediately after connecting it may cause the plugin to crash, though you usually can hit retry and it'll work again. Basically, GOG thinks we are immediately done syncing once we connect, and that is not the case, especially for larger libraries. So, it thinks it can disconnect immediately too, and if we're in the middle of writing some data down, it has to wait, but has basically hamstrung us in the process. It's not an ideal situation. Fortunately, it only happens once, and won't happen at all if you give it time.

### Installation:
* There is a zip file in the releases directory. Download this.
* Navigate to where GOG stores the steam plugin.
* Windows:
<br>`%localappdata%\GOG.com\Galaxy\plugins\installed\steam_ca27391f-2675-49b1-92c0-896d43afa4f8`
* MacOS:
<br>`~/Library/Application Support/GOG.com/Galaxy/plugins/installed/steam_ca27391f-2675-49b1-92c0-896d43afa4f8`
* If the file does not exist, create it. If it does, delete everything inside it.
* Extract the zip release so all the contents are in that file.
* Start GOG Galaxy.

### Logging:
We tried to kill as many bugs and test as many behaviors as possible, but we aren't perfect.
<br>You may find some case we haven't tested.
<br>Please raise an issue here, and in the comment, attach your logs.
<br>They can be found here:
* Windows:<br>`%programdata%\GOG.com\Galaxy\logs`
* MacOS: <br>`/Users/Shared/GOG.com/Galaxy/Logs`

We typically only need the `steam_<numbers and letters>.log` file.

## Setup (For Developers)
* Download [Python 3.7.9 32-bit][Python379]
* Install it with the defaults
* Create a new virtual env:
- If you only have Python 3.7.9<br>
`python -m venv .venv`
- If you have multiple Python versions installed (assumes you have `py` as well)<br>
`py -3.7 -m venv .venv`
* Activate the virtual env
- Windows, Powershell:<br>
`.venv\Scripts\activate`
- MacOS, terminal:<br>
`.venv/Scripts/activate`
* Install the dev dependencies:<br>
`pip install -r requirements/dev.txt`
* Make your edits
* Update the protobufs (See README_UPDATE_PROTOBUF_FILES.md for more info)
<br>Take notice of the initial diff between the files in `protobuf_files` and `protobuf_files/orig`
<br>Generating the python files is done via:
`inv GenerateProtobufMessages`
* Build your edits:
`inv build`
* Test your edits:
`inv test`
* Install your edits for a local test:
`inv install`
* Build a release package (zip):
`inv pack`

### Mac development set up

*Install Python 3.7 on Mac:* The easiest way to manage Python versions on Mac is using pyenv as follows.
1. install [Homebrew — The Missing Package Manager for macOS (or Linux)](https://brew.sh/)
2. `brew install pyenv`
3. `pyenv install 3.7.9`

*Build the plugin*
1. clone the repo:
`gh repo clone ABaumher/galaxy-integration-steam`
2. create a virtual environment in the dev directory
`python -m venv .venv`
3. activate the venv:
`source .venv/bin/activate`
4. Install the dev dependencies:
`pip install -r requirements/dev.txt`
5. Build the plugin with `inv build`


## Installation (non-developers)

*~~The latest release should be available for download via the "Connect" button in Galaxy~~*
We aren't ready to publish this project to Galaxy just yet. We have the tools to do so, but the code is not stable enough for us to consider that just yet.

In the meantime, we've provided a simplified version of the developer install process that only does the bare minimum to install the plugin. There are only a few commands you need to run, but if you want to know what they do, they are documented above each command. A tl;dr: version is below it.

Please do the following:
* Download or clone this repo. If you download a zip, make sure to extract it. You need to be in the main directory for this to work.
* Download [Python 3.7.9 32-bit][Python379].
<br> If you have another version of python installed, make sure `install py` is checked.
<br> This makes it easier to select which version of python you are using and we need our virtual environment in 3.7.9.
<br> If using Windows, make sure you have enabled the setting that `adds Python to the PATH environmental variable`.
<br> These should be the default settings, but make sure anyway.
* Create a new virtual env:
- If you only have python 3.7.9<br>
`python -m venv .venv`
- IF you have multiple python versions installed (assumes you have `py` as well)<br>
`py -3.7 -m venv .venv`
* Activate the virtual env
- Windows, Powershell:<br>
`.venv\Scripts\activate`
- MacOS, terminal:<br>
`.venv/Scripts/activate`
* Use Pip to get the python tools we need to install the plugin.
<br>These will only be applied to the `.venv` virtual environment you created earlier:<br>
`pip install -r requirements/install.txt`
* Install the plugin. It should work if you have deleted the original plugin, but will patch it if it is there.<br>
`inv install`

### Installation (non-dev, TL;DR):

<b>Windows (Powershell recommended)</b>
```
@echo You must have installed python 3.7.9 (32 bit). If not, the rest of this won't work.
py.exe -3.7 -m venv .venv
@echo If the previous command did not work, you do not have py installed or py is not in your PATH.
@echo If you only have python 3.7.9, run the next command.
@echo If it worked, skip the next command.
python.exe -m venv .venv
@echo virtual environment is installed. on to the next step.
.venv\Scripts\activate
pip install -r requirements/install.txt
inv install
```

<b>MacOS</b> (assumes your shell is bash, which is the default. if you are good enough to change that, you can figure out how to run these)
```
echo You must have installed python 3.7.9 (MacOS). If not, the rest of this won't work.
py -3.7 -m venv .venv
echo If the previous command did not work, you do not have py installed or py is not in your PATH.
echo If you only have python 3.7.9, run the next command.
echo If it worked, skip the next command.
python -m venv .venv
echo virtual environment is installed. on to the next step.
.venv/Scripts/activate
pip install -r requirements/install.txt
inv install
```

### Install Error fixes:
If `inv install` throws a bunch of errors, make sure you have the proper python venv set up. It should complain about `getargspec`. If this happens, you created the wrong virtual environment. You can either delete the `.venv` folder and reinstall it, or create a new virtual environment with a different name and use that.

Make sure you use `py -3.7` when creating your venv. If you don't have `py`, get it. You can specify the full path to python 3.7 instead if you want, but that's harder to do and harder to explain here.

## Why this fork?

Well, without being too complicated, Steam changed how they do authentication. We used to be able to use one call and magically get a lot of info we needed. But, if we're being honest, it was a little insecure, and it easy. While we were using it for legitimate purposes, not everyone else was, and one of Valve's greatest deterrence to botting or DOS attacks (etc) is making things difficult. The new workflow uses a significant back-and-forth between a Steam Server and ourselves, closely resembling a common web form of authentication called OAuth2. This meant a lot of under-the-hood changes.

*The latest release should be available for download via the "Connect" button in Galaxy*

### To install a custom build:
* make sure Galaxy is closed
* remove the currently installed plugin directory (if present), usually<br>
`%localappdata%\GOG.com\Galaxy\plugins\installed\steam_ca27391f-2675-49b1-92c0-896d43afa4f8`
* create a new folder under a name of your choice (the name doesn't matter) at the following path:<br>
`%localappdata%\GOG.com\Galaxy\plugins\installed\`
* copy the custom build files to the newly created folder

If the latest version available on Github is newer than the version specified in the `manifest.json` file in the custom build, Galaxy will download the newer version and replace the files. To prevent this from happening, you can manually set the version in `manifest.json` to a significantly higher value (e.g. `9.9`).

## Configuration of the backend operation mode

The plugin supports different data collectors, called `backends`.

Currently supported `backends` are:
1. `Steam Network`
- uses internal Steam protocols
- supports library, game times, achievements, importing tags, friends presence
2. `Public Profiles`
- works without providing user credentials
- requires steamcommunity.com user's profile to be set as public with access at least for games library
- supports library, game times, achievements, importing tags

NOTE: Data imported by different `backends` may differ due to both Steam side inconsistencies and limitations of specific `backend` implementation.

NOTE: interaction with local games and local Steam client is the same for all `backends`.

The behavior is configurable using a `config file`.

### Config file location
## Credits

- Windows:
`%localappdata%\GOG.com\Galaxy\plugins\installed\steam_plugin_config.ini`
### Current Version:
This is a fork of https://github.com/FriendsOfGalaxy/galaxy-integration-steam

- MacOS:
`~/Library/Application Support/GOG.com/Galaxy/plugins/installed/steam_plugin_config.ini`
The new Authorization flow implementation is heavily influenced by SteamKit. https://github.com/SteamRE/SteamKit<br>
While we have not utilized their source code, they have implemented the new authentication workflow before we did, and we used their knowledge of how to do so in order to implement it ourselves. If you are doing anything steam related in C#, you should check them out; their project has far more features than our own.

### Default behavior
Some work was influenced by ValvePython. https://github.com/ValvePython/steam<br>
Our projects do the same thing, but use different methods (we use asyncio, they use gevent, for example). Both projects were working on the new Auth Flow simultaneously, with little collaboration between us. That said, their scope is much larger than our own and lets you do a lot more things. If you are looking for a python means of implementing a steam network authentication, you should use their work instead.

Initial `backend` (with the login window) is set to use `Steam Network` and switches to `Public Profiles` automatically when stored token become invalid (for the main reason see #74).
### The names of individual developers will appear here, soon(ish). Any thanks can be directed there

## Credits
### Original Version:

Based on work and research done by others:
Original Plugin was based on work and research done by others:
* https://github.com/prncc/steam-scraper
* https://github.com/rhaarm/steam-scraper
* https://github.com/mulhod/steam_reviews
* https://github.com/summersb92/aeolipile
* https://github.com/rcpoison/steam-scraper
* https://github.com/chmccc/steam-scraper


[Python379]: https://www.python.org/downloads/release/python-379/
17 changes: 0 additions & 17 deletions README_UPDATE_PROTOBUF_FILES.md

This file was deleted.

Loading