Python API Wrapper for PlayStation Network API
Project description
PlayStation Network API Wrapper Python (PSNAWP)
Retrieve User Information, Trophies, Game and Store data from the PlayStation Network
Coverage Report
File | Stmts | Miss | Cover | Missing |
---|---|---|---|---|
/opt/hostedtoolcache/Python/3.11.1/x64/lib/python3.11/site-packages/psnawp_api | ||||
init.py | 1 | 0 | 100% | |
psnawp.py | 35 | 0 | 100% | |
/opt/hostedtoolcache/Python/3.11.1/x64/lib/python3.11/site-packages/psnawp_api/core | ||||
init.py | 0 | 0 | 100% | |
authenticator.py | 46 | 3 | 3 | 93% |
psnawp_exceptions.py | 9 | 0 | 100% | |
/opt/hostedtoolcache/Python/3.11.1/x64/lib/python3.11/site-packages/psnawp_api/models | ||||
init.py | 0 | 0 | 100% | |
client.py | 68 | 0 | 100% | |
game_title.py | 22 | 0 | 100% | |
group.py | 52 | 0 | 100% | |
search.py | 22 | 0 | 100% | |
title_stats.py | 64 | 2 | 2 | 97% |
user.py | 69 | 0 | 100% | |
/opt/hostedtoolcache/Python/3.11.1/x64/lib/python3.11/site-packages/psnawp_api/models/trophies | ||||
init.py | 0 | 0 | 100% | |
trophy.py | 112 | 0 | 100% | |
trophy_constants.py | 25 | 0 | 100% | |
trophy_group.py | 89 | 0 | 100% | |
trophy_summary.py | 25 | 0 | 100% | |
trophy_titles.py | 84 | 0 | 100% | |
utility_functions.py | 7 | 0 | 100% | |
/opt/hostedtoolcache/Python/3.11.1/x64/lib/python3.11/site-packages/psnawp_api/utils | ||||
init.py | 0 | 0 | 100% | |
endpoints.py | 2 | 0 | 100% | |
misc.py | 35 | 0 | 100% | |
request_builder.py | 72 | 15 | 15 | 79% |
TOTAL | 839 | 20 | 98% |
How to install
From PyPI
pip install PSNAWP
Using setup.py
To install the library into python. First you need to clone the repo at your local machine and run the following command from the root directory of the repo
python setup.py install
Important Links
PyPI: https://pypi.org/project/PSNAWP/
Read the Docs: https://psnawp.readthedocs.io/en/latest/
Getting Started
To get started you need to obtain npsso <64 character code>. You need to follow the following steps
- Login into your My PlayStation account.
- In another tab, go to https://ca.account.sony.com/api/v1/ssocookie
- If you are logged in you should see a text similar to this
{"npsso":"<64 character npsso code>"}
This npsso code will be used in the api for authentication purposes. The refresh token that is generated from npsso lasts about 2 months. After that you have to get a new npsso token. The bot will print a warning if there are less than 3 days left in refresh token expiration.
Following is the quick example on how to use this library
from psnawp_api import PSNAWP
psnawp = PSNAWP('<64 character npsso code>')
# This is you
client = psnawp.me()
print(client.online_id)
print(client.account_id)
print(client.get_account_devices())
print(client.get_profile_legacy())
print(client.friends_list())
print(client.blocked_list())
print(client.available_to_play())
groups = client.get_groups()
print(groups)
# Getting user from online
example_user_1 = psnawp.user(online_id="VaultTec-Co")
example_user_2 = psnawp.user(online_id="test")
print(example_user_1.online_id)
print(example_user_1.account_id)
print(example_user_1.profile())
print(example_user_1.prev_online_id)
print(example_user_1.get_presence())
print(example_user_1.friendship())
print(example_user_1.is_blocked())
# Getting user from Account ID
user_account_id = psnawp.user(account_id='9122947611907501295')
print(user_account_id.online_id)
# Sending Message
group = psnawp.group(group_id='38335156987791a6750a33ae452ec8666177b65e-103')
print(group.get_group_information())
print(group.get_conversation(10))
print(group.send_message("Hello World"))
print(group.change_name("API Testing 3"))
print(group.leave_group())
# Creating new group
new_group = psnawp.group(users_list=[example_user_1, example_user_2])
search = psnawp.search()
print(search.get_title_details(title_id="PPSA03420_00"))
print(search.universal_search("GTA 5"))
# Get Play Times (PS4, PS5 above only)
titles_with_stats = client.title_stats()
Note: If you want to create multiple instances of psnawp you need to get npsso code from separate PSN accounts. If you generate a new npsso with same account your previous npsso will expire immediately.
Contribution
All bug reposts and features requests are welcomed, although I am new at making python libraries, so it may take me a while to implement some features. Suggestions are welcomes if I am doing something that is an unconventional way of doing it.
Disclaimer
This project was not intended to be used for spam, abuse, or anything of the sort. Any use of this project for those purposes is not endorsed. Please keep this in mind when creating applications using this API wrapper.
Credit
This project contains code from PlayStationNetwork::API and PSN-PHP Wrapper that was translated to Python. See more in LICENSE
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file PSNAWP-1.2.1.tar.gz
.
File metadata
- Download URL: PSNAWP-1.2.1.tar.gz
- Upload date:
- Size: 32.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 126f9ce2df2d75e9406d621817eaf299f8977c829c03636ea90e9c44219756c1 |
|
MD5 | 37ceb56071daa405b7761122fde9d2aa |
|
BLAKE2b-256 | 7373fc10bf8ae8a1c29194c9f47dd5816cb752733378e7f3c744457064f1ca9b |
File details
Details for the file PSNAWP-1.2.1-py3-none-any.whl
.
File metadata
- Download URL: PSNAWP-1.2.1-py3-none-any.whl
- Upload date:
- Size: 39.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 99f875d4f6d603865350d83ea7a25dd7bafabd9afbb4ec527582bd34ba9e4600 |
|
MD5 | eaccdaccf1c1c355ce2c9d915bff6f82 |
|
BLAKE2b-256 | 35b17b3af0c1c722286fd5c461529917692dd787a6ddddea978c3f5cc6f73f1c |