A downloadable asset pack

Download NowName your own price

Disclaimer

Only use this if you know what you are doing. With Client Secret anyone could get access to your campaign info, all of your patrons' profile info, email addresses, and their pledge amounts

For production, it would be better to have a dedicated server to handle authorisation.

Setup

First, you need to create a client on Patreon.

Go to the https://www.patreon.com/portal/registration/register-clients and click on the "Create Client" button.

  • App Name — enter your game name
  • Description — enter some text. It will displayed to the user on authentication  page.
  • App Category — Select something
  • Redirect URIs — enter http://localhost:6167/auth
  • Client API Version — should be 2
  • Other fields are not required.

You only need 2 fields "Client ID" and "Client Secret" from the newly created client.

Somewhere in your game (for example, in the "options.rpy") write this code:

define PATREON_CLIENT_ID = "<YOUR_CLIENT_ID>"
define PATREON_CLIENT_SECRET = "<YOUR_CLIENT_SECRET>"

Replace the "<YOUR_CLIENT_ID>" with your Client ID value and
"<YOUR_CLIENT_SECRET>" with your Client Secret value.

From the archive that you downloaded from itch, you'll need 4 files inside the "patreon_auth" folder. Extract this folder inside your game folder (i.e ("MyGame/game/patreon_auth")

Now somewhere in the game you can use this action to start auth process:

PatreonAuth(PATREON_CLIENT_ID, PATREON_CLIENT_SECRET, "/auth")

For example:

textbutton _("Auth with Patreon") action PatreonAuth(PATREON_CLIENT_ID, PATREON_CLIENT_SECRET, "/auth")

By default, user info are saved inside persistent.PATREON_USER_DATA variable.

For example, to get user name:

persistent.PATREON_USER_DATA.get("data").get("attributes").get("full_name")

More info about other fields here: https://docs.patreon.com/#user-v2.

Scopes

Some info are not sent from Patreon by default. To get it, you need to edit scopes inside the "patreon_auth/PatreonAuth.rpy" file.

For example, to get user email, update the scope parameter to this:
scope = "identity identity[email]".

Also, you need to update requested fields inside the on_success_auth function. Add "email" to the "fields[user]" field:

user = client.get_user_data({"fields[user]": "full_name,image_url,email"...

More info about scopes here https://docs.patreon.com/#scopes

How to tell if a player is subscribed

Something like this should work:

included = persistent.PATREON_USER_DATA.get("included")
if len(included) > 0:
  attributes = included[0].get("attributes", {})
  patron_status = attributes.get("patron_status")
  amount = attributes.get("currently_entitled_amount_cents")

patron_status variable could be one of those: active_patrondeclined_patronformer_patron or None (if user never pledged).

More info here: https://docs.patreon.com/#member

Update user info

To update user info, you can use something like this (not tested):

client = PatreonClient(persistent.PATREON_TOKENS.get("access_token"))
# fields may vary, depending on your needs
user = client.get_user_data({"fields[user]": "full_name,image_url", "include": "memberships", "fields[member]": "patron_status,currently_entitled_amount_cents"})
persistent.PATREON_USER_DATA = user
renpy.restart_interaction()

Expiration

After a month Patreon tokens will expire and you won't be able to update user info.

You'll need to either manually refresh the tokens (see https://docs.patreon.com/#step-7-keeping-up-to-date) or ask the player to sign in via Patreon again.

StatusReleased
CategoryAssets
Release date Nov 17, 2023
Rating
Rated 5.0 out of 5 stars
(3 total ratings)
AuthorDinaki
Made withRen'Py
Tagsauthentication, patreon, Ren'Py, script
Code licenseMIT License

Download

Download NowName your own price

Click download now to get access to the following files:

patreon_auth.zip 83 kB

Comments

Log in with itch.io to leave a comment.

This just screams security/privacy issue. If you put your client ID and secret in Ren'Py code, which anyone can go in and read, they'd have access to your client and would potentially be able to retrieve all your Patreon data, including names and email addresses.

(3 edits)

Yeah, you right. I didn't think someone could use that in the final public build. I added a warning at the beginning.

(3 edits)

Hi, your code is awesome, but whenever I log in to patreon and then try to save the game I get an error:

```

I'm sorry, but an uncaught exception occurred.

While running game code:

  File "renpy/common/00gamemenu.rpy", line 174, in script

    $ ui.interact()

  File "renpy/common/00gamemenu.rpy", line 174, in <module>

    $ ui.interact()

  File "renpy/common/00action_file.rpy", line 397, in __call__

    renpy.save(fn, extra_info=save_name)

TypeError: cannot pickle '_thread.lock' object (perhaps store.webserver.server._BaseServer__is_shut_down._cond._lock = <unlocked _thread.lock object at 0x00000000066a4600>)

I managed to put a band aid on this by making renpy restart after each authentication, I saw you had them in your code, but for some reason it did not do it on my laptop so in the end that's fine.

Also it does not work on mobile, the patreon link shows up and then the page loads for a while and then crashes.

Also it crashes directly in the browser:


I've uploaded a new version that fixes the first problem with saving.

I'll look into the second problem when I have more time.

Hello, I have a problem. Observe the following error when clicking the "Auth With Patreon" button This page is not working No data was sent by localhost ERR_EMPTY_RESPONSE

"http://localhost:6167/auth?code=08DDd0e75udOHwbpHrJorzUF8Hdtme&state=None"

(1 edit)

Hello. Have you replaced `PATREON_CLIENT_ID` and `PATREON_CLIENT_SECRET` in the "options.rpy" file?

There is no `APP_NAME would like to...` window?

Yes, I changed it to

Patreon authentication

set PATREON_CLIENT_ID = "93VC-W99QouZubcHXV9F76GchkNzIjyHwaYppU3hQX9CN2ZrQTPhuUTsm7UIsGiY"

set PATREON_CLIENT_SECRET = "MC2CJKrpErv96aVhOHJTH54bmSMta5YonMqFJoRGG4aqiSTnSNqR5p_vpfltql2v"

In Options.py

Everything works normally until the

View your public profile (Allow) (Deny)

When clicking Allow, the error message appears on the web page.

[This page is not workinglocalhost did not send any data.

ERR_EMPTY_RESPONSE]

The problem appears after the `APP_NAME would like to...` window

(3 edits)

Did you change anything else?

I just replaced ID and SECRET in options.rpy in the default project and got a successful result.



Possible solution:

In the patreon_auth/OAuth2Strategy.rpy replace this line:

return "http://localhost:" + str(webserver.PORT) + self.callback_url

With this:

return "http://127.0.0.1:" + str(webserver.PORT) + self.callback_url

And in the patreon client replace Redirect URIs with http://127.0.0.1:6167/auth

{"error":"invalid_request","error_description":"Mismatching redirect URI."}



Now this error appears when clicking (Allow)

I didn't modify anything, I used the file you released here. And I put the pateron credentials. Is there a problem with the files you imported and for some reason I don't have them?

(import http.server

     from urllib.parse import urlparse, parse_qs, urlencode

     from urllib.request import urlopen, Request

     import threading

     import json)

I managed to resolve this error mentioned above, but now the screen has the same error of not loading again.

Thanks for sharing the code! 

Do you plan to publish this code on github? 

What is the usage license of your tool? 

Hello. No plans to publish on github for now.

MIT License.