Skip to main content

Users API

getProfileFromUserName

A call to this function will retrieve the profile of the username being requested. If the user cannot be found (either due to non-existence or privacy settings), an error will be thrown.

caution

This is a legacy API endpoint function. If you are just trying to get a user's accountId, makeUniversalSearch() is recommended instead. This endpoint is here because it can return interesting presence information when the user is playing on a legacy console such as a PS3.

Examples

Look up a user

import { getProfileFromUserName } from "psn-api";

const response = await getProfileFromUserName(authorization, "xelnia");

Returns

The following properties are contained within a profile object that is returned.

NameTypeDescription
onlineIdstringThe account's online username.
accountIdstringThe account's internal ID value, which can be used for numerous calls to the PSN API.
npIdstring
avatarUrlsArray<{ size: string; avatarUrl: string; }>
plus0 or 1Whether or not the account is a PlayStation Plus subscriber.
aboutMestring
languagesUsedstring[]
trophySummary{ level: number; progress: number; earnedTrophies: { bronze: number; silver: number; gold: number; platinum: number; }}The account's trophy level, progress towards the next level, and total number of torphies earned by type.
isOfficiallyVerifiedboolean
personalDetail`{ firstName: string; lastName: string; profilePictureUrls: Array<{ size: string; profilePictureUrl: string; }>}
personalDetailSharingstring
personalDetailSharingRequestMessageFlagboolean
primaryOnlineStatusstring
presencesArray<{ onlineStatus: string; hasBroadcastData: string; lastOnlineDate: string; }>
friendRelationstring
requestMessageFlagboolean
blockingbooleanWhether or not the account is blocked by the retrieving authentication context. For example, if you are using psn-api with your account's access token, and your account has blocked the account you're looking up, this will be true.
followingboolean
consoleAvailability{ availabilityStatus: string; }

Parameters

NameTypeDescription
authorizationAuthorizationPayloadAn object that must contain an accessToken. See this page for how to get one.
userNamestringThe username for the user you wish to retrieve a profile for.

Source

user/getProfileFromUserName.ts


getProfileFromAccountId

A call to this function will retrieve some of the profile information of the account ID being requested. If the account's profile cannot be found (either due to non-existence or privacy settings), an error will be thrown.

Examples

Look up a user

import { getProfileFromAccountId } from "psn-api";

const response = await getProfileFromAccountId(
authorization,
"962157895908076652"
);

Returns

The following properties are contained within a profile object that is returned.

NameTypeDescription
onlineIdstringThe account's online username.
aboutMestring
avatarsArray<{ size: string; url: string; }>
languagesstring[]
isPlusbooleanWhether or not the account is a PlayStation Plus subscriber.
isOfficiallyVerifiedboolean
isMebooleanWhether or not the profile is the one linked to the current Npsso.

Parameters

NameTypeDescription
authorizationAuthorizationPayloadAn object that must contain an accessToken. See this page for how to get one.
accountIdstringThe accountId for the user you wish to retrieve a profile for.

Source

user/getProfileFromAccountId.ts


getUserFriendsAccountIds

A call to this function will retrieve the list of friended accountId values associated with the given accountId parameter. If the friends list cannot be retrieved (either due to the given accountId not existing or due to the user's privacy settings), an error will be thrown.

To find a user's accountId, the makeUniversalSearch() function can be used.

Examples

Look up the accounts on your friends list

import { getUserFriendsAccountIds } from "psn-api";

const response = await getUserFriendsAccountIds(authorization, "me");

Look up the accounts on another user's friends list

import { getUserFriendsAccountIds, makeUniversalSearch } from "psn-api";

const searchResponse = await makeUniversalSearch(
authorization,
"NeutraLiTe",
"SocialAllAccounts"
);

const foundAccountId =
searchResponse.domainResponses[0].results[0].socialMetadata.accountId;

// If this user's friends list is private, this call will throw an error.
const userFriendsAccountIds = await getUserFriendsAccountIds(
authorization,
foundAccountId
);

Returns

NameTypeDescription
friendsstring[]The accountId values of the users on the target user's friends list.
totalItemCountnumberThe total number of friends on the target user's friends list.
nextOffsetnumber
previousOffsetnumber

Parameters

NameTypeDescription
authorizationAuthorizationPayloadAn object that must contain an accessToken. See this page for how to get one.
accountIdstringThe account whose trophy list is being retrieved. Use "me" for the authenticating account. To find a user's accountId, the makeUniversalSearch() function can be used.

Options

These are the possible values that can be in the options object (the third parameter of the function).

NameTypeDescription
limitnumberLimit the number of trophies returned.
offsetnumberReturn trophy data from this result onwards.

Source

user/getUserFriendsAccountIds.ts


getBasicPresence

A call to this function will retrieve the presence of the accountId being requested. If the user cannot be found (either due to non-existence or privacy settings), an error will be thrown.

Examples

Get a user's presence

import { getBasicPresence } from "psn-api";

const response = await getBasicPresence(authorization, "xelnia");

Returns

The following properties are contained within a basicPresence object that is returned.

NameTypeDescription
availability"unavailable" or "availableToPlay"The account's current availability.
lastAvailableDatestringThe last date the account was available, if it's currently unavailable
primaryPlatformInfo{ onlineStatus: "online" or "offline"; platform: "ps4" or "PS5"; lastOnlineDate: string;}Details of the accpunt's primary platform, current status (online or offline), platform type (ps4 or PS5) and date the platform was last online
lastOnlineDatestringLast online date if the account is currently offline
onlineStatus"offline" or "online"Account's current online status
platformstringIf the account is online, it's current platform
gameTitleInfoList{ npTitleId: string; titleName: string; format: "ps4" or "PS5"; launchPlatform: "ps4" or "PS5"; npTitleIconUrl?: string; conceptIconUrl?: string; }[];Details about the game the account is currently playing, if applicable

Parameters

NameTypeDescription
authorizationAuthorizationPayloadAn object that must contain an accessToken. See this page for how to get one.
accountIdstringThe account whose presence is being retrieved. Use "me" for the authenticating account. To find a user's accountId, the makeUniversalSearch() function can be used.

Source

user/getBasicPresence.ts


getRecentlyPlayedGames

A call to this function will retrieve a list of recently played games for the user associated with the accessToken in the provided AuthorizationPayload.

Examples

import { getRecentlyPlayedGames } from "psn-api";

const recentlyPlayedGames = await getRecentlyPlayedGames(authorization, {
limit: 10,
categories: ["ps4_game", "ps5_native_game"]
});

Returns

NameTypeDescription
data.gameLibraryTitlesRetrieve.gamesRecentlyPlayedGame[]List of recently played games.

Parameters

NameTypeDescription
authorizationAuthorizationPayloadAn object that must contain an accessToken. See this page for how to get one.

Options

These are the possible values that can be in the options object (the second parameter of the function).

NameTypeDescription
limitnumberLimit the number of games returned. Defaults to 50.
categoriesstring[]Limit the categories of games returned. Valid entries are ps4_game and ps5_native_game.

Source

graphql/getRecentlyPlayedGames.ts


getUserPlayedGames

A call to this function will retrieve a list of games (ordered by recently played) for a user associated with the accountId provided.
This is similar to getRecentlyPlayedGames(), but allows querying other user's games (if their privacy settings allow it) and returns detailed user playtime info.

Examples

import { getUserPlayedGames } from "psn-api";

// May fail if user privacy settings prohibit listing
const userPlayedGames = await getUserPlayedGames(
authorization,
"2984038888603282554"
);

// Retrieves list of games from user associated with `authorization.accessToken`.
const myPlayedGames = await getUserPlayedGames(authorization, "me");

Returns

NameTypeDescription
titlesobject[]Individual object for each title returned.
titles.titleIdstringId for the specific version of the game played by the user.
Example: "CUSA01433_00"
titles.namestringName of the game.
Example: "Rocket Leagueยฎ"
titles.localizedNamestringName of the game (localized).
Example: "Rocket Leagueยฎ"
titles.imageUrlstringURL for the game icon.
Example: "https://image..."
titles.localizedImageUrlstringURL for the game icon (localized).
Example: "https://image..."
titles.category"ps4_game" \| "ps5_native_game" \| "pspc_game" \| "unknown"Type of game.
Example: "ps4_game"
titles.service"none" \| "none_purchased" \| "ps_plus"Is the game owned outright, or via a service entitlement.
Example: "none"
titles.playCountnumberNumber of times the game has been played.
Example: 100
titles.conceptobjectThe concept is a single identifier for the various versions of a game.
titles.concept.idnumberIdentifier for the concept.
Example: 10009763
titles.concept.titleIdsstring[]Various Title Ids for this game.
Example: ["PPSA20599_00", "PPSA20549_00"]
titles.concept.namestringName of the game concept.
Example: "Zenless Zone Zero"
titles.concept.media{ audios: any[]; videos: any[]; images: Image[] }Media related to the game concept, including images, videos, and audios.
titles.concept.media.images{ url: string; format: string; type: string }[]Array of images associated with the game concept.
titles.concept.media.images.urlstringURL of the image.
Example: "https://image.api.playstation.com/vulcan/ap/rnd/202405/2210/4126b58375cb32a51dfdbfde8637daae8b971c3b10c3bc80.jpg"
titles.concept.media.images.formatstringFormat of the image.
Example: "UNKNOWN"
titles.concept.media.images.typestringType of the image.
Example: "FOUR_BY_THREE_BANNER"
titles.media{ screenshotUrl?: string; [key: string]: string \| undefined; }This object contains various URLs for screenshots and other media associated with the game.
Example: { screenshotUrl: "https://image..." }
titles.media.screenshotUrlstringScreenshot URL.
Example: "https://image..."
titles.firstPlayedDateTimestringDate the game was first played.
Example: "2015-07-10T19:40:19Z"
titles.lastPlayedDateTimestringDate the game was most recently played.
Example: "2024-08-03T19:28:27.12Z"
titles.playDurationstringTime played accurate to 1 second.
Example: "PT228H56M33S"
totalItemCountnumberThe total number of game titles for this account.
Example: 300
nextOffsetnumberPagination info.
Example: 20
previousOffsetnumberPagination info.
Example: 299

Parameters

NameTypeDescription
authorizationAuthorizationPayloadAn object that must contain an accessToken. See this page for how to get one.
accountIdstringThe account whose game list is being retrieved. Use "me" for the authenticating account. To find a user's accountId, the makeUniversalSearch() function can be used.

Options

These are the possible values that can be in the options object (the third parameter of the function).

NameTypeDescription
categoriesstringComma separed list of platforms.
Example: "ps4_game, ps5_native_game, pspc_game, unknown"
limitnumberLimit the number of games returned.
offsetnumberReturn game list data from this result onwards.

Source

user/getUserPlayedGames.ts