Profile
The Profile
class provides methods to interact with user profiles in the HandCash Connect SDK.
Initialize the User Account
After the user authorizes your application, initialize their account using the authentication token:
Methods
getCurrentProfile()
Retrieves the full profile of the current user, including both public and private information.
Returns: A promise that resolves to the user’s full profile.
Example:
Types:
Response Type:
Field | Type | Description |
---|---|---|
publicProfile | UserPublicProfile | Public information about the user |
privateProfile | UserPrivateProfile | Private information about the user |
getPublicProfilesByHandle(handles)
Retrieves the public profiles of HandCash users by their handles.
handles
: An array of user handles.
Returns: A promise that resolves to an array of user public profiles.
Example:
Response Type:
Field | Type | Description |
---|---|---|
id | string | Unique identifier for the user |
handle | string | User’s HandCash handle |
paymail | string | User’s paymail address |
displayName | string | User’s display name |
avatarUrl | string | URL of the user’s avatar image |
createdAt | Date | Date when the profile was created |
getFriends()
Retrieves a list of the user’s friends and their public profiles. Requires the FRIENDS
permission.
Returns: A promise that resolves to an array of public profiles of the user’s friends.
Example:
Response Type:
Field | Type | Description |
---|---|---|
(Same as UserPublicProfile) |
getPermissionsInfo()
Retrieves the permissions granted to the app by the user, along with the app ID.
Returns: A promise that resolves to an object containing the permissions and app ID.
Permission Enum:
Example:
Response Type:
Field | Type | Description |
---|---|---|
items | Permission[] | Array of Permission enum values |
appId | string | Unique identifier for the app |
Types
The SDK uses several TypeScript types for representing user profiles, permissions, and other data. Here are some key types:
UserProfile
: Combines public and private profile information.UserPublicProfile
: Contains publicly accessible user information.UserPrivateProfile
: Contains private user information.PermissionInfo
: Contains permissions and app ID.
For more detailed information on these types, refer to the SDK’s type definitions.