Skip to main content

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

PyPI version Downloads python-logo pytest pre-commit Code style: black Documentation Status License: MIT

Coverage

Coverage Report
FileStmtsMissCoverMissing
/opt/hostedtoolcache/Python/3.10.8/x64/lib/python3.10/site-packages/psnawp_api
   init.py10100% 
   psnawp.py300100% 
/opt/hostedtoolcache/Python/3.10.8/x64/lib/python3.10/site-packages/psnawp_api/core
   init.py00100% 
   authenticator.py4633 93%
   psnawp_exceptions.py90100% 
/opt/hostedtoolcache/Python/3.10.8/x64/lib/python3.10/site-packages/psnawp_api/models
   init.py00100% 
   client.py470100% 
   group.py520100% 
   search.py150100% 
   user.py560100% 
/opt/hostedtoolcache/Python/3.10.8/x64/lib/python3.10/site-packages/psnawp_api/utils
   init.py00100% 
   endpoints.py20100% 
   misc.py130100% 
   request_builder.py711515 79%
TOTAL3421895% 

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

  1. Login into your My PlayStation account.
  2. In another tab, go to https://ca.account.sony.com/api/v1/ssocookie
  3. 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"))

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

PSNAWP-1.1.0.tar.gz (6.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

PSNAWP-1.1.0-py3-none-any.whl (36.7 kB view details)

Uploaded Python 3

File details

Details for the file PSNAWP-1.1.0.tar.gz.

File metadata

  • Download URL: PSNAWP-1.1.0.tar.gz
  • Upload date:
  • Size: 6.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.6

File hashes

Hashes for PSNAWP-1.1.0.tar.gz
Algorithm Hash digest
SHA256 123e14cd0434d7eb7e7170a7c4d9ccfe95102c19cb7cbb6e8214f0f09aaedfa9
MD5 019a31e3d30d00cb390a6e57c9c37917
BLAKE2b-256 38fbd5852989f3c1b36abfe390714a2c088ca911f0a369c175d409c411c72e26

See more details on using hashes here.

File details

Details for the file PSNAWP-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: PSNAWP-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 36.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.6

File hashes

Hashes for PSNAWP-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8b8aa0d67598b9eade03b08a71f6a20cd5cd66ffce61e1bf26de12212152417b
MD5 9ec28b212a8d8c9ff0f2a2a9054d14dc
BLAKE2b-256 f5701e49915fc343a6d3594dd0f493bf36e1c5981902a593789197669370a202

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page