This package gives access to Push Protocol (Push Nodes) APIs. Visit Developer Docs or Push.org to learn more.
yarn add @pushprotocol/restapi@latest ethers@^5.6
or
npm install @pushprotocol/restapi@latest ethers@^5.6
import * as PushAPI from '@pushprotocol/restapi' ;
About generating the "signer" object for different platforms
When using in SERVER-SIDE code:
const ethers = require ( 'ethers' ) ;
const PK = 'your_channel_address_secret_key' ;
const Pkey = `0x${ PK } ` ;
const _signer = new ethers . Wallet ( Pkey ) ;
When using in FRONT-END code:
// any other web3 ui lib is also acceptable
import { useWeb3React } from "@web3-react/core" ;
.
.
.
const { account, library, chainId } = useWeb3React ( ) ;
const _signer = library . getSigner ( account ) ;
About blockchain agnostic address format
In any of the below methods (unless explicitly stated otherwise) we accept either -
CAIP format : for any on chain addresses We strongly recommend using this address format . Learn more about the format and examples .
(Example : eip155:1:0xab16a96d359ec26a11e2c2b3d8f8b8942d5bfcdb
)
ETH address format: only for backwards compatibility.
(Example: 0xab16a96d359ec26a11e2c2b3d8f8b8942d5bfcdb
)
Chat blockchain agnostic address format
Note - For chat related apis, the address is in the format: eip155:<address> instead of eip155:<chainId>:<address>, we call this format Partial CAIP
(Example : eip155:0xab16a96d359ec26a11e2c2b3d8f8b8942d5bfcdb
)
// Initialize PushAPI class instance
const userAlice = await PushAPI . initialize ( signer , {
env : 'staging' ,
} ) ;
Parameters:
Param
Type
Default
Remarks
signer
SignerType
-
EthersV5 or Viem Signer.
options
*
PushAPIInitializeProps
-
Optional configuration properties for initializing the PushAPI.
options.env
*
ENV
staging
API env - 'prod', 'staging', 'dev'.
options.progressHook
*
(progress: ProgressHookType) => void
-
A callback function to receive progress updates during initialization.
options.account
*
string
-
The account to associate with the PushAPI. If not provided, it is derived from signer.
options.version
*
string
ENC_TYPE_V3
The encryption version to use for the PushAPI.
options.versionMeta
*
{ NFTPGP_V1 ?: password: string }
-
Metadata related to the encryption version, including a password if needed.
options.autoUpgrade
*
boolean
true
If true
, upgrades encryption keys to the latest encryption version.
options.origin
*
string
-
Specify origin or source while creating a Push Profile.
* - Optional
Option
Value
PROFILE
STREAM.PROFILE
ENCRYPTION
STREAM.ENCRYPTION
NOTIF
STREAM.NOTIF
NOTIF_OPS
STREAM.NOTIF_OPS
CHAT
STREAM.CHAT
CHAT_OPS
STREAM.CHAT_OPS
Fetch Inbox Or Spam notifications
// lists feeds
const aliceInfo = await userAlice . notification . list ( ) ;
Parameters:
Parameter
Type
Default
Description
spam
INBOX or SPAM
INBOX
A string representing the type of feed to retrieve.
options*
object
-
An object containing additional options for filtering and pagination.
options.account*
string
-
Account in full CAIP
options.channels*
[string]
-
An array of channels to filter feeds by.
options.page*
number
-
A number representing the page of results to retrieve.
options.limit*
number
-
A number representing the maximum number of feeds to retrieve per page.
options.raw*
boolean
-
A boolean indicating whether to retrieve raw feed data.
* - Optional
// fetches list of channels to which the user is subscribed
const subscriptions = await userAlice . notification . subscriptions ( ) ;
Parameters:
Parameter
Type
Default
Description
options*
object
-
An object containing additional options for subscriptions.
options.account*
string
-
Account in CAIP .
options.page*
number
-
page of results to retrieve.
options.limit*
number
-
represents the maximum number of subscriptions to retrieve per page.
* - Optional
// subscribes to a channel
const subscribeStatus = await userAlice . notification . subscribe ( channelInCAIP )
Parameters:
Parameter
Type
Default
Description
channel
string
-
Channel/Alias address in CAIP format
options*
SubscribeUnsubscribeOptions
-
Optional configuration
options.onSuccess*
() => void
-
A callback function to execute when the subscription is successful.
options.onError*
(err: Error) => void
-
A callback function to execute when an error occurs during subscription.
* - Optional
// unsubscribes to the channel
const unsubscribeStatus = await userAlice . notification . unsubscribe ( channelInCAIP )
Parameters:
Parameter
Type
Default
Description
channel
string
-
Channel/Alias address in CAIP format
options*
SubscribeUnsubscribeOptions
-
Optional configuration
options.onSuccess*
() => void
-
A callback function to execute when the unsubscription is successful.
options.onError*
(err: Error) => void
-
A callback function to execute when an error occurs during unsubscription.
* - Optional
// fetches information about the channel
const channelInfo = await userAlice . channel . info ( pushChannelInCAIP )
Parameters:
Parameter
Type
Default
Description
channel*
string
-
Channel address in CAIP format
* - Optional
// returns channel matching the query
const searchResult = await userAlice . channel . search ( "push" )
Parameters:
Parameter
Type
Default
Description
query
string
-
The search query to find channels.
options*
ChannelSearchOptions
-
Configuration options for the search.
options.page*
number
-
The page of results to retrieve. Default is set to 1
options.limit*
number
-
The maximum number of channels to retrieve per page. Default is set to 10
* - Optional
Get Subscribers Of A Channel
// fetches subscribers of a channel
const subscribersResult = await userAlice . channel . subscribers ( )
Parameters:
Parameter
Type
Default
Description
options*
ChannelInfoOptions
-
Configuration options for retrieving subscribers.
options.channel*
string
-
Channel address in CAIP
* - Optional
// sends a notification
const sendNotifRes = await userAlice . channel . send ( [ '*' ] , { notification : { title : 'test' , body : 'test' , } , } )
Parameters:
Parameter
Type
Default
Description
recipients
string[]
-
An array of recipient addresses. Possible values are: Broadcast -> [*], Targeted -> [0xA], Subset -> [0xA, 0xB]
options
NotificationOptions
-
Configuration options for sending notifications.
options.notification
INotification
-
An object containing the notification's title and body. (Mandatory)
options.payload*
IPayload
-
An object containing additional payload information for the notification.
options.payload.title*
string
-
The title for the notification. If not provided, it is taken from notification.title.
options.payload.body*
string
-
The body of the notification. If not provided, it is taken from notification.body.
options.payload.cta*
string
-
Call to action for the notification.
options.payload.embed
string
-
Media information like image/video links
options.payload.meta*
{ domain?: string, type: string, data: string }
-
Metadata for the notification, including domain, type, and data.
options.config*
IConfig
-
An object containing configuration options for the notification.
options.config.expiry*
number
-
Expiry time for the notification in seconds
options.config.silent*
boolean
-
Indicates whether the notification is silent.
options.config.hidden*
boolean
-
Indicates whether the notification is hidden.
options.advanced*
IAdvance
-
An object containing advanced options for the notification.
options.advanced.graph*
{ id: string, counter: number }
-
Advanced options related to the graph based notification.
options.advanced.ipfs*
string
-
IPFS information for the notification.
options.advanced.minimal*
string
-
Minimal Payload type notification.
options.advanced.chatid*
string
-
For chat based notification.
options.advanced.pgpPrivateKey*
string
-
PGP private key for chat based notification.
options.channel*
string
-
Channel address in CAIP. Mostly used when a delegator sends a notification on behalf of the channel
* - Optional
// creates a channel
const createChannelRes = await userAlice . channel . create ( { name : channelName , description : channelDescription , url : channelURL , icon : base64FormatImage , alias ?: aliasAddressInCAIP } )
Parameters:
Parameter
Type
Default
Description
options
CreateChannelOptions
-
Configuration options for creating a channel.
options.name
string
-
The name of the channel.
options.description
string
-
A description of the channel.
options.icon
string (base64 encoded)
-
The channel's icon in base64 encoded string format.
options.url
string
-
The URL associated with the channel.
options.alias*
string
-
alias address in CAIP
options.progresshook*
() => void
-
(Optional) A callback function to execute when the channel creation progresses.
* - Optional
Update channel information
// updates channel info
const updateChannelRes = await userAlice . channel . update ( { name : newChannelName , description : newChannelDescription , url : newChannelURL , icon : newBase64FormatImage , alias ?: newAliasAddressInCAIP } )
Parameters:
Parameter
Type
Default
Description
options
-
-
Configuration options for creating a channel.
options.name
string
-
New name of the channel.
options.description
string
-
New description of the channel.
options.icon
string (base64 encoded)
-
The channel's new icon in base64 encoded string format.
options.url
string
-
New URL associated with the channel.
options.alias*
string
-
New alias address in CAIP
options.progresshook*
() => void
-
A callback function to execute when the channel updation progresses.
* - Optional
const verifyChannelRes = await userAlice . channel . verify ( channelToBeVerified )
Parameters:
Parameter
Type
Default
Description
channelToBeVerified
string
-
Channel address in CAIP to be verified
// creates channel settings
const createChannelSettingRes = userAlice . channel . settings ( [ { type : 0 , default : 1 , description : 'marketing' } , { type : 2 , default : 10 , description : 'loan liquidation threshold' , data : { upper : 100 , lower : 5 , enabled : true , ticker : 5 } } ] )
Parameters:
Property
Type
Default
Description
type
number
-
The type of notification setting. 1 for boolean type and 2 for slider type
default
number
-
The default value for the setting.
description
string
-
A description of the setting.
data.upper*
number
-
Valid for slider type only. The upper limit for the setting.
data.lower*
number
-
Valid for slider type only. The lower limit for the setting.
data.enabled*
boolean
-
Valid for slider type only. If the settting should be enabled by default.
data.ticker*
number
-
Valid for slider type only. Offset for slider values
| * - Optional
Get delegators information
// fetch delegate information
const delegatorsInfo = userAlice . channel . delegate . get ( )
Parameters:
Parameter
Type
Default
Description
options*
ChannelInfoOptions
-
Configuration options for retrieving delegator information.
options.channel*
string
-
channel address in CAIP
* - Optional
Expected response (Get Delegates)
[
'0x69e666767Ba3a661369e1e2F572EdE7ADC926029' ,
'0x74415Bc4C4Bf4Baecc2DD372426F0a1D016Fa924' ,
'0x7b9e036BD304fd1Bea0523dE718038bbe345521A' ,
'0xD8634C39BBFd4033c0d3289C4515275102423681'
]
Add delegator to a channel or alias
// adds a delegate
const addDelegatorRes = userAlice . channel . delegate . add ( delegatorAddressInCAIP )
Parameters:
Parameter
Type
Default
Description
delegate
string
-
delegator address in CAIP
Note: Support for contract interaction via viem is coming soon
Remove delegator from a channel or alias
// removes a delegate
const removeDelegatorRes = userAlice . channel . delegate . remove ( delegatorAddressInCAIP )
Parameters:
Parameter
Type
Default
Description
delegate
string
-
delegator address in CAIP
Note: Support for contract interaction via viem is coming soon
// fetch alias info
const aliasInfo = userAlice . channel . alias . info ( { alias : '0xABC' , aliasChain :'POLYGON' } )
Parameter
Type
Default
Description
options
AliasOptions
-
Configuration options for retrieving alias information.
options.alias
string
-
The alias address
options.aliasChain
ALIAS_CHAIN
-
The name of the alias chain, which can be 'POLYGON' or 'BSC' or 'OPTIMISM' or 'POLYGONZKEVM'
// userAlice.stream(account?, {options?})
// Initial setup
const stream = userAlice . stream ( account ?, {
// stream supports other products as well, such as STREAM.CHAT, STREAM.CHAT_OPS
// more info can be found at push.org/docs/chat
listen : [ STREAM . NOTIF ] ,
filter ?: {
channels ?: [ '*' ] , // pass in specific channels to only listen to those
chats ?: [ '*' ] , // pass in specific chat ids to only listen to those
} ,
connection ?: {
auto ?: true , // should connection be automatic, else need to call stream.connect();
retries ?: 3 , // number of retries in case of error
} ,
raw ?: false // enable true to show all data
} )
// recevive stream of notification
userAlice . stream . on ( STREAM . NOTIF , ( data : any ) => {
console . log ( data )
} )
Expected response (Inbox)
{
"event" : "notification.inbox" ,
"origin" : "other" ,
"timestamp" : "2023-10-06T01:55:51.000Z" ,
"from" : "0xfFA1aF9E558B68bBC09ad74058331c100C135280" ,
"to" : [
"eip155:0xffa1af9e558b68bbc09ad74058331c100c135280"
] ,
"notifID" : "1676" ,
"channel" : {
"name" : "Testing Goerli" ,
"icon" : "https://gateway.ipfs.io/ipfs/bafybeifu3tisz7cntfnoolwe6tthi554b2cdl46jzcr5amo6swucyautzq/QmYZZnnEuTnzjkhhnRZWaHgYTeHsohLZEme9LomWRYQAZ5" ,
"url" : "https://dev.push.org/"
} ,
"meta" : {
"type" : "NOTIFICATION.BROADCAST"
} ,
"message" : {
"notification" : {
"title" : "Testing Goerli - notification TITLE:" ,
"body" : "notification BODY"
} ,
"payload" : {
"title" : "payload title" ,
"body" : "sample msg body" ,
"cta" : "" ,
"embed" : "" ,
"meta" : {
"domain" : "push.org"
}
}
} ,
"config" : {
"expiry" : null ,
"silent" : false ,
"hidden" : false
} ,
"source" : "ETH_TEST_GOERLI" ,
"raw" : {
"verificationProof" : "eip712v2:0xf2b50f07c7cdae4a493860554301dc017dd6f819f92db3aba534dffde210bfaa0f545818e919c42c3bb51181339af33ad83e3bc691ada7fcccdcbc7fb3b3abd91b::uid::feaa2d31-85ec-47d2-b38c-6f797f637de7"
}
}
Expected response (Spam)
{
"event" : "notification.spam" ,
"origin" : "other" ,
"timestamp" : "2023-10-06T01:55:51.000Z" ,
"from" : "0xfFA1aF9E558B68bBC09ad74058331c100C135280" ,
"to" : [
"eip155:0x1f1a304af17f22cac91eeca5f31a0f814d752377"
] ,
"notifID" : "1677" ,
"channel" : {
"name" : "Testing Goerli" ,
"icon" : "https://gateway.ipfs.io/ipfs/bafybeifu3tisz7cntfnoolwe6tthi554b2cdl46jzcr5amo6swucyautzq/QmYZZnnEuTnzjkhhnRZWaHgYTeHsohLZEme9LomWRYQAZ5" ,
"url" : "https://dev.push.org/"
} ,
"meta" : {
"type" : "NOTIFICATION.TARGETTED"
} ,
"message" : {
"notification" : {
"title" : "Testing Goerli - notification TITLE:" ,
"body" : "notification BODY"
} ,
"payload" : {
"title" : "payload title" ,
"body" : "sample msg body" ,
"cta" : "" ,
"embed" : "" ,
"meta" : {
"domain" : "push.org"
}
}
} ,
"config" : {
"expiry" : null ,
"silent" : false ,
"hidden" : false
} ,
"source" : "ETH_TEST_GOERLI" ,
"raw" : {
"verificationProof" : "eip712v2:0x6b903f16d0ce87483643e1502e7416203cb7ecef0e947a497f0fb6fbe1c43c3511f2f602b757ab02c1be7daa07f3872ee14e4d05134f1ecb3d11fe58324422c01c::uid::6c0fad10-d1eb-4779-84d3-3a96bd96263f"
}
}
// Initialize PushAPI class instance
const userAlice = await PushAPI . initialize ( signer , {
env : ENV . LOCAL ,
streamOptions : {
listen : [ STREAM . PROFILE , STREAM . ENCRYPTION , ...Object . values ( STREAM ) ] ,
filter : {
channels : [ 'Channel1' , 'Channel2' ] ,
chats : [ 'Chat1' , 'Chat2' ]
} ,
connection : {
auto : true ,
retries : 3
} ,
raw : true ,
enabled : true
} ,
} ) ;
Param
Type
Default
Remarks
signer
SignerType
-
EthersV5 or Viem Signer.
options
*
PushAPIInitializeProps
-
Optional configuration properties for initializing the PushAPI.
options.env
*
ENV
staging
API env - 'prod', 'staging', 'dev'.
options.progressHook
*
(progress: ProgressHookType) => void
-
A callback function to receive progress updates during initialization.
options.account
*
string
-
The account to associate with the PushAPI. If not provided, it is derived from signer.
options.version
*
string
ENC_TYPE_V3
The encryption version to use for the PushAPI.
options.versionMeta
*
{ NFTPGP_V1 ?: password: string }
-
Metadata related to the encryption version, including a password if needed.
options.autoUpgrade
*
boolean
true
If true
, upgrades encryption keys to the latest encryption version.
options.origin
*
string
-
Specify origin or source while creating a Push Profile.
options.streamOptions
*
PushStreamInitializeProps
-
Configuration options for the stream.
options.streamOptions.listen
*
STREAM[]
-
Specifies which streams to listen to.
options.streamOptions.filter
*
{ channels?: string[]; chats?: string[]; }
-
Specifies which channels or chats to filter for.
options.streamOptions.connection
*
{ auto?: boolean; retries?: number; }
-
Connection settings, including auto-connect and number of retries.
options.streamOptions.raw
*
boolean
-
If set to true
, will provide raw stream data.
options.streamOptions.enabled
*
boolean
-
Specifies if the stream is enabled or not.
* - Optional
Option
Value
PROFILE
STREAM.PROFILE
ENCRYPTION
STREAM.ENCRYPTION
NOTIF
STREAM.NOTIF
NOTIF_OPS
STREAM.NOTIF_OPS
CHAT
STREAM.CHAT
CHAT_OPS
STREAM.CHAT_OPS
// Fetch Info
const aliceInfo = await userAlice . info ( ) ;
Expected response
{
did : 'eip155:0xEaC9c666570782E262f1E2a0b1d3BE4B95aFA7cd' ,
wallets : 'eip155:0xEaC9c666570782E262f1E2a0b1d3BE4B95aFA7cd' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTu6YUBCACa7JaMqfhAnD/9ynE5Rhi8KNQ1tfdQe0ay/9jXX2naZIA+\n' +
'6WCi1uNcB2TTLfMuzsEl4u/26LTgtkr51snRt2QKgEqi5dXqbRD76wiRLd4h\n' +
'ktBb4WB28o+BWOHYYJQq8he+zu3mQWjKLb1e9DyS0cTzwPwWVKce9IsG3NOi\n' +
'eM7O5Kg5cU3qHXR+frF25peCBrzNXH+xuuTJPsX85h9dSz/u6dWXhk2LsX3s\n' +
'cmX5mFcFErnGvUBddDGZc11q+WzZAtENPCxQrNjpkMtzCj9UMwgsJdzBghZZ\n' +
'ZouGTG2uhfmIj3/KHOdwx/KGpTgC1iMVOb78kw9LmaxL6fGy4x9uvvI3ABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO7phQQLCQcICZABDloJB8hpcgMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBMga3B8GDU79nd/0mAEOWgkHyGlyAAAbHAf/bJMPIyvNZNjO\n' +
'JK2xA1hYpzIGdbi3jMego6GXrmet3qY50zMKDccB2Ot399y/nmWMVEyfKYaP\n' +
'7N+mJbeAqIZ8TAHtpw++k/h8/hXoxb9iPsQyWYossuG499XyHnk+KEd4g0Wf\n' +
'mqPk/XJB3xLLgW820jOsRRbWLyYKJEdh1Q+GIM+D6oIJ9ZmyRPv25u6yCF2P\n' +
'2IQZErWeYD/LxqMDw+uHdRZJRiyFy/Y7A43clejN+p3my8oktXh2N4+tEl7i\n' +
'Hwxc5z9AOffuEyUerm0Rjwdn8rG8po7AfuXwmTiW1Sdc9TdJtAK/n6e9EFHV\n' +
'gHzArwyaydHHy80Wqa+UF591NkPi387ATQRk7umFAQgAs0ao+EFoKJirGHfI\n' +
'69vZg+eAAUUKG657BzNzTAF2r5Y+a61jdcCAL+DXBcfks+H0dqG36zjOZTCJ\n' +
'NirABp5RRPFty2VvUtOyezuKX/MBVg3st3t/yE3SncVaWMblAv3iegviNNpH\n' +
'cFKqpHoVBWDNdhFHNsKTjpJcq3BVohy2Dxh8Di8N/1+gEPxADvIuH9MQ8MJk\n' +
'6lB9XYXBmmqtlQ3sB916mvusUIl8Zxw1C76yY0PAXz055zJMiL1vwo5gKDiV\n' +
'iKyzry3wq7upPGJyeTKu7uUMifTPhJtyYvon2TIik5DIgHpqKziirCrolA+s\n' +
'7LhnFbawqDKleEdyCcL5mFCzXQARAQABwsB2BBgBCAAqBYJk7umFCZABDloJ\n' +
'B8hpcgKbDBYhBMga3B8GDU79nd/0mAEOWgkHyGlyAABIqQgAmK9ijEEvtWTm\n' +
'7/mhkuDEtfPfcMexfkaCcGL4SdZqVz/h+eIL8+4EbI9uq+YTzcjtX8FAEQta\n' +
'KWFACNEOPmSy6Sb9bDoNZUVpDaZzNNtqIK9Brt4zjJLEsDfmkuW3S/SgIYBQ\n' +
'yTkuNmmAf8dr7L4fG0JlxPyGaL1/w9UDAr7xdU7WcHuyPc0edDGeE7NwaGWp\n' +
'uBipXFw8AkikV3fCTDuOi3uhkIzZ5zlGCshD7m0aDSABwr4hbFzLFBDSrsiW\n' +
'GKhWGYgf5Vx8qzlwXYYnoW/rn3UXWpeTXjq46ZNaxjHJ4VxGMyn/tHZOEjDE\n' +
'vHapLIAgGyw2b+s+zZSqsXaMkH8WOw==\n' +
'=gPzx\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
encryptedPrivateKey : '{"ciphertext":"4f1243e1ffa76180f46ade2eb093867750c6bf72e8d6c71c7c0edca176c2f9fb32c603bb5e52d933730e0350292431b6e5287b8201f60ce9151b6a141bde98cdc3d9e5df8f84e00e5e4173bdf28b66e9590db10195fbd41ed241a65ab84fb5da251f613376bf78efe1af64613dd54fb05dced7cf8de0907d61489712ad42f06b5c775d97d15dee09b1c58cd79f596674e403353bc7e03297aa0d3fdaecac573c962409622ff8b1335b6fbb661bd2d5f5a076d9079f857849ba917662b40151041eca71385844160fc603c4d1beefbf71b26ac8968de52d6bb534ef6d6e2ea987170059d7d881dc684d28b5b2817804fba3b659e3ec0e802583e581b9f75d2f7e69e428cba91e62719e9ca6697588389db89b982370d23952120c0f972ab4b3a0da888d52b5055c60785d276152e43929df532bc7d5d68c6bc3cfdd1ca780df346113999a19d8e4a96c02f149d1ee4cde802277081ef339153872c00c9e9ddfe3ba8da8c68c0565752fea32258087e66aab37397a27b0228b5ed1aeb09a93b80778fd7f949409106c4cd82ff550aafb9d7bdce8727a76882f59ef2c54a137e51f04b6c27a0b1b92cd781dafb489a5e8203232669f5416454cc9cfe8c5b0fd8abc19d9ef16285a8da0aca2ed747adef7b49b8215790266d9c4791c250b0580e89c6429d10a1bcd45cf016a7ae30e1db948147d992722a7191e31852e6fd3c3679d868f34ebbe65f255be4b90dd64ceb52eaeee7d3356683b7fd511729493c887289ddb0f00c65ca2a95114f0e37d3b73d06333e2787c5fa6dd6f6c9e8334ff153dd63e30c81247efd497cf2c038843d8653edf23822eae07dd19d0be26a921673185bcf016533fdb59150ff46096419e6a6aeb1bd4293fc8146848d715d43afd04aa40f2b5ae9d058671677aad2413952a20b5214e18bbf3b4b033d936d673a0302967de3f74b05b74bc6c89f30ddeaab1bf6c567fcee355797b6cba17c3fcc8955bdf096e2dda2577b3374089d8c9d287552e5658c91e812bd0b8b63482c8de98fde216dd557eb34bafca2f8e73dc4582fa36332e8869f2717519921605915d8e1c75a37295e198ec0af75926d89a6832456304474a10c567334998226d9b6f709ebc216fb067d958e78a622040c91f46af202273d0b40307fb34cba5a6a57fbb196ac6e88c16d527b9bdb04b12fa7ed0bc771692712ccd146c41890b5caddbbb13b8ba77e632b2d7597256fb576ce87d2aff35a0e953b8227a5dcbf30f7d189ca7f77f6f8b2c4eb2752199a7a485ab52a6b65b6edd6cf65caaeb6f65544cc74c2fb3431fa484fb69adbda08d2402da953f20425832b6a2d712d56a5cc34095f25fb9524a478a71d387b7dea45b4bd41e79c61dceca332898dfeecf83999ed4fad892e2ede714b93f3969ad140f38bfa95d321ae5ef089cf0ce435d59f8b6611c0fd014c67ed38646f0771f1a74c1f950ee0900d883aca3ec4efbb2f7737e717007ae757d874573d4d70c9d7e38f8ff30a29b983036e684c4eaf35a7c03ed32a8e3fc62f0863c56830127a5f3c0e905a93e7466a4f43f0793cb6752b9be8d03d7be26170f694ecbb200f611bbf1dac4b6ec085deb8c3d8ee188d8c9c8c17ca720c0f0dee4d00e5866b5443b6af6e69ca64b8eb5a8f5fa1e1d27bfacbf1b0ae11241215358f5045b0d1a73d1b15dbd904709340c1e2b42a4ef78f76b8f901d6337849cff1052f06a8919255b596fb36d2fdf789fdf611813d20729c26d517dde6f11a3f6045ec5158652e128cf7c483a0fb8ab772cb5cdb56e42e6bf8c863f173307c3e053168e54e9e65bcacbb144413ff76d08a94929e6cdde2c5944246a4b344f3ca0ada3b403429750bdce76f04668b05ed79e9119f00901e7f7b4f1eea8a1b5b0186e3ed41277040a257601b0f3917db595f3f1808d92071a4e9521a251e9c5a66f2c8a57511f61b9fd88df77330aeb4bc15c043814b33610d60f6d0a13fd7977efaa1843913f6d3a79bc88020406c9979163684efe7b7ade9613221d06b52cd96abd31b77a707748d52e6e16c8c90821f29359b35307c10dafce5f35c0ff9802c23aef19f0a95b49a317cd6207002a5a9b822b4c056c4cbf9b27045dda8325d93060f358bb837f00954a6e281d1bdd1817a7cce8ed4a801f9164d32c52739c1ac650109868664be1fabab47c675222dc9ff9d75f9fb49531c832264aa5b55998675975f59e34829ce90b00092bd77e46328a6459d5c967d905b8e976611b839925ad742500231fa86cb5f7e6f39cb1e2e36b81c55269ea0f5fdcba5c8c0e38a899540d52be49c83efae5243998b926f029dc2980d4fdb1c125db409d015e0b36bc02272da1c688ee1f61d23cbde585064ab1e2164d0ca529774ec7797407ba5d988c58853e74a124a64dc24d0289b6a599354faf64790177c3032f5d660d7b76dfbf1c03388a7c75b2309c509c6a92144e124c8bd188274bc844e8f0aa7b5a06e79ad5776b5a62003b89aef194dcc03cd3c1b1f3ea541805cfc4e18aa159f9b5395185b573538c9bab16876dff91f365d16dcc56b339b01b86882ef8e52c51edd9c5b2f8a35713ed6eb43036e09f64f6e59ab417958faff974b6705400b341439fef4cba371c601927da7e0a8f23e1c6d3e070a19c2216da85f159d60303ab1321e479f4c371372845cef03daa7d2776c18face6cfa2ff9eed26f9f0a353a0f1c9a99b2556dccc1212fcb5c2078a3b0e58a7f3f7b3f346d624435ef94c95d40dc726d2e7400ae405e89473a934e7646124e34473dfe17f7f9cf481aa059ef422508ffe67f9b9276084973db0683269a046c1a0aafa7ab075b28008cbfb862b7e30c8b2afa1c2923d914b3d2469266e8e0182274a3d8d89642723820e61aa2d97a9370789ec4e89ebee05b6c0bef10778caf2a34c2d7622dde5fa64b012bea6205127c3c845229ef553f013b73823dc6631078fc628532e3e518bdc790ab8460078dedf0c5cb00492136813e2b91679bba82f3cf95169751933bee4358f84154014dbcc1de1a30613218039ebb2444429380fd283d3b60bd5d5b470e861f6ecc751c22aa467168512a0ef45755e6b59a7be591bd3b08fde874b166ccfbbedba10a0956d2d18cbda515341c2112d6094a746e9f562db6543e5bde2c4d4f7c06b7550400d66f7242a14f34cd8a7374372f0eea49a49b72909fc11ff81ea54a1e2c07225cdee856383a657b0f13c14b00ae3b7b2a32a22beaab8cfd18641dbfa82619fdcdddd3339e9423e71c487305e8aa932b694e94c37c7e418e4014c8bb264f47e8283e216eeeabf0fbdd2f5eb8d0ea979738d4f18b7bf72d7711f5d22653f217c7305314ec2c47a0ecbf1dc8f9bc1379ae38e2a04e736a1171b947609bb66f8d352ce57230d709f196953471c5504c7f9f40ed2f64bf3bd04bd57521a364ea03b5f0603cceec7851738d97c3fd73c16547d4d143b009a79832a1ed244937dce09edf2d5e32ae52ab0331c449325dce9e5e8ed1563c967a5f92031f4275e3179274ef3e0752ac01caf8a20aabb23d584d4d6607833f95cfc92832d936c37bb8b37222aa842f48944d06b37434c8dce5f19b450a7d1bd568672ef2c8eaa2afb7cff404b33377a61061f56b01849feb918521a7d63cfbe12466aedc7159c577f213f2c157586b8719164cd7108edfa9211287b43aadbad997bc62f8169eec4a6e02aeb535f670878e6af538b5281da04470d318f893102613977390a434e0557302a68ce42e532d350446d4d813b84c07b42bf22fbe4889096ec6303574c95040d8dcfed1b9bd26782c5033d7d1a491fece156cbc19a705204ed38a547e00a09b73bc7a702ef9c2e659171d1daab63958268148aba59766bc7a4ffb68c1ae047d1f0c5fb45fbacd07079f72af301c6aa00eebc0662c6792fc707d388b339d4f45afbf576bacf8730ec3e0f1e9dc0f9a6d58fd146b2293aed8d110da24336f9a4c01ae12c03ce214c6502f5fbc5224dd8b8b2e4edf2af16b811e5c8595fa76cafe34ba66199caaed48b5dfd5ae74a3e6b6d51a09c70afc30ebc0f40d51a15f1a8c2c41ec482eddf14bed3fd11a9e2aa4446268af25b49e429e2528d5df57797f6f3cd431eb5ded8f830c85cecde8012c31500ce9363903739a6759704fa87bfef984ed0285c8c0a5bf2f0985b1b511eb4145e4b27e2df6aa7b5c7a913b76b1ca869151b75c0717389b3d186f4e4637a5ceba3cef64809c3a06551a6a46be31af61c0ef78afb057f6cc625647dc04dcd74eb97f7aee0f5640e24b7662c799013efb83c80ec2851acda7c6328de789ae99ce296494225bd169e49c9a12dc7e281778f7fe275e72571cd5a3608733998d2f6b96c1d26c25223153fc5afc2f6e3d72f57fbcb2d087d718d3b6703b286f1e340c23cd3bc715797edf3ce6d5169bcf783ac9686233cc0358725143008b25bfbd329e1c30654e4b4c9461239d41ae77f706e64e5e60ce6de83becfd056f2678f17474ab9f4976b2d7d5d014d78f716d7d4edbf6ce4ed44ed677274d6b9b6e4bf4946dfd1ed8b821c81957b4bf5cd534ed6ca84dadd9d6380513dc6406b32dcd5c1bfa468a79e88a56656e71aed0c6675540e1617a31e1c122295427590e83b63e8da58a6c5c21a15703994bdc2b90d399b62679a4269224257f3ead5a2dd0980e6f5a45c5a9392929cc4743e106c7335136c9f8a3a29190462eef908eab02cda97dbcb71dff26b0ef4dae51de293b4cff0ebf37fce1391247c5ccf77dfb64974c4a1e6beeaf82041bb0d653e2e9b612f3442bba8480b86fd7b35514fc056d7429d5fb36199d4a6f632ea615d9acc961082d9d91aca416b57582bcd2f182f5f5be02b3f597c680b2e6b37ee4d133e51d077491cb536d6261808c42684d0912fd7bcc97dacdf32394e7b","salt":"da23dc7dbf23136dabc337a0caa170c0db7e4efec5f5c8a648dff9b7cd7df49f","nonce":"fe0e4ec3d40fb7de21a354bf","version":"eip191-aes256-gcm-hkdf-sha256","preKey":"b43efae4c92a35d9c0b5f6178cb8b8a6642c77d0a9281f61beb9f6e8f7b006a5"}' ,
verificationProof : 'eip191v2:0x97ca70a87ec658e0e488e8b9f71644ee23840d809803fcf5bdcd174c9f39cdeb27f6e3a8885fec5bede5f264b3996bc3fa019b0d52745a5573a972b7e79e321c1c' ,
msgSent : 0 ,
maxMsgPersisted : 1000 ,
profile : {
name : null ,
desc : null ,
picture : '' ,
profileVerificationProof : null
} ,
origin : null ,
name : null ,
about : null ,
profilePicture : '' ,
numMsg : 0 ,
allowedNumMsg : 1000 ,
encryptionType : 'eip191-aes256-gcm-hkdf-sha256' ,
signature : '0x97ca70a87ec658e0e488e8b9f71644ee23840d809803fcf5bdcd174c9f39cdeb27f6e3a8885fec5bede5f264b3996bc3fa019b0d52745a5573a972b7e79e321c1c' ,
sigType : 'eip191v2' ,
encryptedPassword : null ,
nftOwner : null ,
linkedListHash : null ,
nfts : null
}
Parameter
Type
Remarks
did
string
user decentralized identity
wallets
string
all wallets associated to the did
publicKey
string
Public PGP key
encryptedPrivateKey
string
Encrypted PGP Private Key
verificationProof
string
Verification proof
msgSent
number
Number of messages sent
maxMsgPersisted
number
Maximum number of messages that can be persisted
profile
object
User profile information
origin
string
Origin information (source of the data)
name
string
Profile Name ( Deprecated )
about
string
Profile Description ( Deprecated )
profilePicture
string
Profile Picture ( Deprecated )
numMsg
number
Number of messages sent ( Deprecated )
allowedNumMsg
number
Maximum number of messages that can be persisted ( Deprecated )
encryptionType
string
Type of encryption used
signature
string
Account signature ( Deprecated )
sigType
string
Type of signature ( Dprecated )
encryptedPassword
null
Encrypted user password ( Deprecated )
nftOwner
null
Owner of NFT ( Deprecated )
linkedListHash
null
Deprecated
nfts
null
Information about owned NFTs( Dprecated )
// Fetch Push Profile
const aliceProfileInfo = await userAlice . profile . info ( ) ;
Expected response
{
name : null ,
desc : null ,
picture : '' ,
profileVerificationProof : null
}
Param
Type
Remarks
name
string
or null
Profile Name
desc
string
or null
Profile Description
picture
string
or null
Profile Picture
profileVerificationProof
string
or null
Profile VerificationProof
// Update Push Profile
const updatedProfile = await userAlice . profile . update ( { name : updatedName } ) ;
Param
Type
Default
Remarks
options
object
-
Configuration options for updating profile
options.name
*
string
-
Profile Name
options.desc
*
string
-
Profile Description
options.picture
*
string
-
Profile Picture
* - Optional
Expected response
{
name : 'Bob The Builder' ,
desc : null ,
picture : '' ,
blockedUsersList : [ ] ,
verificationProof : 'pgpv2:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7dERCZAIZdJAfLB6iRYhBK0xCN+/G/tf7pts7whl0kB8\n' +
'sHqJAADd9Af/Z4DcYGZyQmVmIXM3CSDf2RaJOsEchm3hN93ErvTwGrKiviKW\n' +
'3/k6HWON3COHqmL5D1wlgZERTqaw3Xft1JC/82P108/IgDHiid4Wo4ojONn+\n' +
'ZZV6KUfH1i0+wxXNsSvS1XtVYVnq/pQbXi8fzayCYM9jwdiFzBosQTLmXIbY\n' +
'mUl1OezZ35kPQuZWjtZ2jyATQit6QL0uvQBiGAIevj1LRiB8uQsi0+Xr7R6I\n' +
'D7WQ0Iwr85OIENGyv1KgrH/1Q944SjamWWI31gUhedH5a+THVLNDJGg3CAfq\n' +
'FoOb2DNDviovMQxZwUOyCRCxVE6Ohw5Hwkw1YQOvzSwJRzz70l8A8w==\n' +
'=k8OV\n' +
'-----END PGP SIGNATURE-----\n'
}
Param
Type
Remarks
name
string
or null
Profile Name
desc
string
or null
Profile Description
picture
string
or null
Profile Picture
profileVerificationProof
string
Profile Verification Proof
// List all chats
const aliceChats = await userAlice . chat . list ( 'CHATS' ) ;
// List all chat requests
const aliceRequests = await userAlice . chat . list ( 'REQUESTS' ) ;
Param
Type
Default
Remarks
type
CHATS
or REQUESTS
-
Type of Chats to be listed
options
*
Object
-
Optional configuration properties for listing chat
options.page
*
number
1
The page number for pagination
options.limit
*
number
10
The maximum number of items to retrieve per page
* - Optional
Expected response
[
{
chatId : '6168440929ced5109c50534d40bb98a5e109ebf1d33df966ae898f002fac8973' ,
about : null ,
did : 'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562' ,
intent : 'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562' ,
intentSentBy : 'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562' ,
intentTimestamp : '2023-08-29T08:05:03.000Z' ,
publicKey :
'{"key":"-----BEGIN PGP PUBLIC KEY BLOCK-----\\n\\nxsBNBGTt9AcBCADXjt9OEXDQyE7w2veaHqTUN9fALt7c+cubz2nhWfmD07M1\\n5Spm3ScT/4HdlPpUBYnGUKlCT09g663RvvmDzp8442vZhfYeKbetrcNFxfnp\\n+ePQGiLDY0h2FmjQGkmZGP43ZLyhNT4eCIGPcPSpzaWAKw4wgE/tW2hli5m/\\n7e8HFno+bHp2ycNoPJpdqhY77CJL9zPqFdctCPxI5r1/+xkVLcf+NZ+vD7mz\\nq8xVpu3Tij5Jb5ShDPQ3qqPsqdCcB/fpnEtAOT/Ryuf5Qqic/bDrzImfaIO9\\nYmdnuc6uQBR1s8WbLHmOsQvJhe2D8MtggV5HwHbkPqxXBmpGIJnMeLHZABEB\\nAAHNAMLAigQQAQgAPgWCZO30BwQLCQcICZBvKHl019glPAMVCAoEFgACAQIZ\\nAQKbAwIeARYhBEyKE1gcoT4IIxerrG8oeXTX2CU8AADltgf/dREUaHmfMnwa\\nWwcoGxfya7xeSeqGLWoWsCDg55lq0rf59IFKw59AKL+4kKQrmVDW0x6oo844\\nxBv3NBq7OssNbRr4XYIXJN4oP8g0SdOYinTTcnHFjJcRHfTIa+lmlf7fwc7d\\n2DRW3Kyu66OGq9sLzcgI3Q4Fg3VOQGRDdVGF4zJGjPEpnHsJuGCVnbn5L94p\\nMZHEMIahYrYg2asglSByNUZIH+r0Y8rCzKp8rs37X/Q8RBrmW/oTnE/bb+xo\\n1jHgRR3MUs2Ea0oAqv/TwqpBRzMIWQ8tGKfEaJ22p02FJaE5q9KMbLp0mMIe\\nd33xGwOezLKoK5L9cHKg7wmz4sWvUs7ATQRk7fQHAQgApXcZbj43S5sr7v8d\\nq9JwcXkSdpRuzGw5zyauxUUElq2RLKPvsP8En+OJQceKWQcpvz16xLjnSoZI\\nfgIl1wXUaEb2T45rUrWmnoO+Csy2h6FePNmlHOerY2/C0GHQX3XP/B0t41By\\nG/o4losESsBaHEYugHIg5kXhgsGnlgoC3Bu4zHFmIvLlZXjCWYUG2JnhNHlG\\nrD67/Xuox1FO+Hh/rR7sSsWIH6S+SFgG/P4bwiW0JAYQP6bC4tbXfzvKJk2R\\ndeySnppEAwdn/3lCU5QscYIIUXSaPoV3Q6hg+wRigBk2ixkqdOTJmJROTOo3\\nUdnaeGSwP23USJIUncZWgcIokwARAQABwsB2BBgBCAAqBYJk7fQHCZBvKHl0\\n19glPAKbDBYhBEyKE1gcoT4IIxerrG8oeXTX2CU8AABx6Af/XRamjQ4T79rf\\nhNArQt3VuHvpIUP860MCg0aW5rMtZ8q4+TwOyjiEgOUIFx215Yprb3R3NTKV\\nQWJr8n++ZGDmQ8iro8nrRMRELmoEJzyWp3yr0dyr2lx01//bud+vVw+ARPLt\\nVUnX8eguLKRrltQmIRwCqX01PCTiN2RDB2Akd+zlBGRiHoavW9dDdGGBY9wW\\nA2Pyw73BeMzVA3akiGzLsdRIshO0DBALaX0G5ytqyIf3QjXOqO6C7gp9XW7R\\njXhRhzvR9NjZPmSXEeYqYw2CUPxzaLsKoSP4dbXE7Hl+sYJptzke7LE1StzH\\nG64gRgEYMCKvRZaPXYnPJXAZwDhijw==\\n=8aQd\\n-----END PGP PUBLIC KEY BLOCK-----\\n","signature":"DEPRECATED"}' ,
profilePicture :
'' ,
threadhash : 'bafyreiewla5iyd7rnvjw2c5w6dbab4zkyf2desbowzouijoea2jzakxz6i' ,
wallets : 'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562' ,
combinedDID :
'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562_eip155:0x84a9385e9b97df87b80c2e689997133703853874' ,
name : null ,
groupInformation : null ,
msg : {
fromDID : 'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562' ,
toDID : 'eip155:0x84a9385e9b97df87b80c2e689997133703853874' ,
messageObj : [ Object ] ,
messageContent : 'Hello Alice!' ,
messageType : 'Text' ,
timestamp : 1693316103747 ,
fromCAIP10 : 'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562' ,
toCAIP10 : 'eip155:0x84a9385e9b97df87b80c2e689997133703853874' ,
encryptedSecret :
'-----BEGIN PGP MESSAGE-----\n' +
'\n' +
'wcBMA3d9z8TNUuddAQf/U2hMcybh5mUt9FFen5tfZ52PaB0vc2G+wYYIsBfu\n' +
'zg58rgLy8uGMxvzhtCWhpIE91G62d8M4OmaDa+PLjs8SqyRoyih/9pt8P4cw\n' +
'UJVHHDcJNC9r6/AV4aZySdz5u5utE7o3iB1FU0Sr9HEQsImmOM7J6LZJ3xWJ\n' +
'V+o4ToLbqUFYKg2uY1kUXpyX+D6JRinagnAosh4zCICLUqrEkKNqbyV2mr+5\n' +
'FK+fClWBGCwpf38L220FqHYPQ4bQXks0N07yW4OVjVpCTZVuNttr7PIEqcyZ\n' +
'qIovbQbkltiDpsb/yYysEHTwBtvugna7xMW7SRY34x3iWm/HBNJmfBG7LnjI\n' +
'6cHATAMrTKobmmcFTAEH/20nW6aNzfj1vn/5GIWjZ5Z4Rw6G3Syt+0NxPUix\n' +
'dpKIFOR0/BEJkafGMdlk/vRElsyluKbzykBlIQ0hHGRpGMNEW8s8GrJeiXvV\n' +
'JSNZ24u5DDk8DIBaJWJnyWM7XzgcmOmn9rvVbvc9qgNNgtDeMIZwUpiDipnA\n' +
'++7n72h0JSs8dWFQ62FSf5ACHC0UVbPiL3TRrRBEo7vQp4JsJyXp70CUclqU\n' +
'3ANLvNhINV6GGtpXEKnsBVkkg35HR92nIzk+8HL86SsRUYfXkufzXdkPpmRn\n' +
'SG7MoDecNf/bwoqP8/l2X2h3R1c+WTQFb6Z+eK/NsJ/AnSErFZh3yEHAi1Rz\n' +
'yIXSQAEA2KupLnBVC9fqZqhUySvOW/Hs/hD6iEEGIl+U/RC9AwdG2jpg4sVi\n' +
'f9PhBJ5Tanynb3aHngRKtIzjP5m223A=\n' +
'=5w+B\n' +
'-----END PGP MESSAGE-----\n' ,
encType : 'pgp' ,
signature :
'-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7fQHCZBvKHl019glPBYhBEyKE1gcoT4IIxerrG8oeXTX\n' +
'2CU8AACRLQf/bbeJoUNwRkJYz100R3ULO27HGjKnFeOaMZWRNF8JqWzNmCBL\n' +
'Cj3aIBkDuCUj7avBsanScbSa7tD8Mc8PZgpSkd22nNH5iHiDJqlPtySJ2KoZ\n' +
'3ekVXfOgfLlHtN78ghTxABewYQRuB6kwtv3XQW8X9sCL2jEF4NIIl5eXZvIT\n' +
'nhbHhhOR47k2E0hiHjPv2t3ggrwkrw6ISDgV8qYcrnf7vEFeGHpeSc25QLJH\n' +
'pXCeeHhH7h4C9L3PEdMt8T+Ne36cfNiwTGdOavin/yfNES6k0kqZxP44hn1M\n' +
'ZBk4jfyaDUh70mv4FtxdPcdb1TGQsPC1YYAIh/059EBqkdJFhVF4+A==\n' +
'=DBch\n' +
'-----END PGP SIGNATURE-----\n' ,
sigType : 'pgpv2' ,
verificationProof :
'pgpv2:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7fQHCZBvKHl019glPBYhBEyKE1gcoT4IIxerrG8oeXTX\n' +
'2CU8AADsmwf/UpJCmnqztJLt1Ltg0OD7xoDvumitRwkfhnXzUdBWxM3i7vj4\n' +
'cfjtcpQI2R5W0TXj9e2fymimIc98kjUqpDiUIaVAuD0OnEbJdIluGLBTJeks\n' +
'YTRikqkgjFJT9Y6/2VRQj59IR0rgC0sec8mSKPlxuhixkdSS7Wec0+84cGmX\n' +
'aieskReKeitKacYkU4Uf82Klc7Ft8+duBsaMGR3TS22PzHfYIHmy+8Z3b1SK\n' +
'pMyJ8NBXCG2F+05WdoUsXBR+lO74RjSDWnWZlgRngWjjvSXQuZ/QznIyBVmQ\n' +
'oOxJM5LSCCwH6ch5J/HmXudJG+3wsCINchvSQx0LntZUoeSp8cezvg==\n' +
'=KUqZ\n' +
'-----END PGP SIGNATURE-----\n' ,
link : null ,
} ,
} ,
] ;
Param
Type
Remarks
msg
IMessageIPFS
message object
did
string
user DID
wallets
string
user wallets
profilePicture
string
user profile picture
publicKey
string
user public key
about
string
user description
threadhash
string
cid from the latest message sent on this conversation
intent
string
addresses concatenated from the users who have approved the intent
intentSentBy
string
address of the user who sent the intent
intentTimestamp
number
timestamp of the intent
combinedDID
string
concatenated addresses of the members of this chat (for DM the 2 addresses and from Group the addresses from all group members)
cid
string
content identifier on IPFS
chatId
string
chat identifier
groupInformation
GroupDTO
if group chat, all group information
// Latest Chat message with the target user
const aliceChats = await userAlice . chat . latest ( bobAddress ) ;
Param
Type
Default
Remarks
target
string
-
Target DID ( For Group Chats target is chatId, for 1 To 1 chat target is Push DID )
Expected response
[
{
link : 'bafyreibfikschwlfi275hr7lrfqgj73mf6absailazh4sm5fwihspy2ky4' ,
toDID : 'eip155:0xb340E384FC4549591bc7994b0f90074753dEC72a' ,
encType : 'pgp' ,
fromDID : 'eip155:0x0F1AAC847B5720DDf01BFa07B7a8Ee641690816d' ,
sigType : 'pgp' ,
toCAIP10 : 'eip155:0xb340E384FC4549591bc7994b0f90074753dEC72a' ,
signature :
'-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBQJjh5tjCRBaJmgmByp5FRYhBJC23yBJT2d/pTAID1omaCYH\n' +
'KnkVAAAZmwf/buPLw6caSZmYnw6D3/p6HF1kWlkGUOTP4RasaU/6dkeDaZs9\n' +
'SJlz2wC8oOpBGWHMJ/5n3ZWmU71E6U7IKIY793MyIv5t32vTNkwsRHUX7IIn\n' +
'QFF+FzTIEtHHVTRlnkqNR2YUk1kqcpZCZWHfahi5W2d/WkXlFNdvyyFH4W8L\n' +
'd03FGhOyXbWwU3xicBz5mSBpIFaaSCXl1SdgJDPXLSk3b65EEOjCOaiz85xC\n' +
'G+6SW4RUzCGSDcOd9F2EXvvY5H9LgQNi1jjlZn6JrPTPJTJ+wXZXzcZmtOXG\n' +
'EKcwvPbbPY9wd+gavRSOgYLYn5xoZQW/o3hW7AQlbC5Kj6js48Z0HQ==\n' +
'=qLiJ\n' +
'-----END PGP SIGNATURE-----\n' ,
timestamp : 1669831523684 ,
fromCAIP10 : 'eip155:0x0F1AAC847B5720DDf01BFa07B7a8Ee641690816d' ,
messageType : 'Text' ,
messageContent : 'Hi' ,
encryptedSecret :
'-----BEGIN PGP MESSAGE-----\n' +
'\n' +
'wcBMA1fn1CNqxQ7nAQgArlo75qe54WerfRKFv1+F9j4NRMvSTgUztvIe51eg\n' +
'd5MVuj6RYxKERr2bTuBt5cMDJMlNuTnBBkPe4L8+SlsI46L9wmXV9xLoZq1a\n' +
'94JdxD98RGMF99Jde/3hC/X6GS1yVqPpKPKdWx/tkOPeyqeO/wFF7kqShgIi\n' +
'Wgq6hGz1fzD3GZhKGY0VSLuC3s0aUy/qw5En1Xd0uX0jdXBl07IIj8p1G2zx\n' +
'9BuVlksSK34yvIc0RQfCeRadMHkxbA0Hyj31Wrr+Y310YLTppL0s5bQR9APL\n' +
'WHsIztJ1fHTnXsPhnA7YG0SQpHTyJhuX3rgBjxGrvbZBArmZ+R/Pq9IkOkJe\n' +
'z8HATAMOsbaZjGN5JwEH/jYjLN6AFRWeaB5CSBSAF+CvHsUgadGmxTdSHBM6\n' +
'LM9rfGg/MCnpRBuHckA0NNZh+wepq6TDA54ZopsdP14gHj4MKCdfqZr86Jft\n' +
'ldtjeSgPTFEEJxPMJ4/Z3UeFU9rvOgfxX6l0eHWS0MYwJ3sVYvSyqqHir1K5\n' +
'TRdEIgtQ3NvLTKkX4bKTSU+SInrvDA+wsc2BcBsbgNhRiGb+XYrbqXBshL1a\n' +
'lIdpnomkAQgOZMO2n347uURYoruH3OtFeNABJ9D/nEU+LdhDOPGZPefvPBc5\n' +
'BxK4ExKZ2Wo/TZw8lgC53uqOljsGV63Hp71LkyesKWu5/+vdVrYx/vU63shh\n' +
'x/TSQAEiaFYEfkWSOthtH0nrJHhkY7FWgjp/1bj/J4J9HCQrVtt2WlQfhowZ\n' +
'ILxhKk/vep0sJviM3SfJ4hPtoYpZESc=\n' +
'=43Ta\n' +
'-----END PGP MESSAGE-----\n' ,
} ,
] ;
Param
Type
Remarks
fromCAIP10
string
sender address
toCAIP10
string
receiver address
fromDID
string
sender did
toDID
string
receiver did
messageType
string
message type
messageContent
string
message content
signature
string
signature of the message
sigType
string
signature type
link
string
content identifier of the previous messages
timestamp
number
timestamp of the message
encType
string
encryption type
encryptedSecret
string
encrypted secret
// Chat History with the target user
const aliceChatHistoryWithBob = await userAlice . chat . history ( bobAddress ) ;
Param
Type
Default
Remarks
target
string
-
Target DID ( For Group Chats target is chatId, for 1 To 1 chat target is Push DID )
options
*
object
-
Optional Configuration for fetching chat history
options.reference
*
string
or null
-
Refers to message refernce hash from where the previous messages are fetched. If null, messages are fetched from latest message
options.limit
*
number
10
No. of messages to be loaded
* - Optional
Expected response
[
{
link : 'bafyreibfikschwlfi275hr7lrfqgj73mf6absailazh4sm5fwihspy2ky4' ,
toDID : 'eip155:0xb340E384FC4549591bc7994b0f90074753dEC72a' ,
encType : 'pgp' ,
fromDID : 'eip155:0x0F1AAC847B5720DDf01BFa07B7a8Ee641690816d' ,
sigType : 'pgp' ,
toCAIP10 : 'eip155:0xb340E384FC4549591bc7994b0f90074753dEC72a' ,
signature :
'-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBQJjh5tjCRBaJmgmByp5FRYhBJC23yBJT2d/pTAID1omaCYH\n' +
'KnkVAAAZmwf/buPLw6caSZmYnw6D3/p6HF1kWlkGUOTP4RasaU/6dkeDaZs9\n' +
'SJlz2wC8oOpBGWHMJ/5n3ZWmU71E6U7IKIY793MyIv5t32vTNkwsRHUX7IIn\n' +
'QFF+FzTIEtHHVTRlnkqNR2YUk1kqcpZCZWHfahi5W2d/WkXlFNdvyyFH4W8L\n' +
'd03FGhOyXbWwU3xicBz5mSBpIFaaSCXl1SdgJDPXLSk3b65EEOjCOaiz85xC\n' +
'G+6SW4RUzCGSDcOd9F2EXvvY5H9LgQNi1jjlZn6JrPTPJTJ+wXZXzcZmtOXG\n' +
'EKcwvPbbPY9wd+gavRSOgYLYn5xoZQW/o3hW7AQlbC5Kj6js48Z0HQ==\n' +
'=qLiJ\n' +
'-----END PGP SIGNATURE-----\n' ,
timestamp : 1669831523684 ,
fromCAIP10 : 'eip155:0x0F1AAC847B5720DDf01BFa07B7a8Ee641690816d' ,
messageType : 'Text' ,
messageContent : 'Hi' ,
encryptedSecret :
'-----BEGIN PGP MESSAGE-----\n' +
'\n' +
'wcBMA1fn1CNqxQ7nAQgArlo75qe54WerfRKFv1+F9j4NRMvSTgUztvIe51eg\n' +
'd5MVuj6RYxKERr2bTuBt5cMDJMlNuTnBBkPe4L8+SlsI46L9wmXV9xLoZq1a\n' +
'94JdxD98RGMF99Jde/3hC/X6GS1yVqPpKPKdWx/tkOPeyqeO/wFF7kqShgIi\n' +
'Wgq6hGz1fzD3GZhKGY0VSLuC3s0aUy/qw5En1Xd0uX0jdXBl07IIj8p1G2zx\n' +
'9BuVlksSK34yvIc0RQfCeRadMHkxbA0Hyj31Wrr+Y310YLTppL0s5bQR9APL\n' +
'WHsIztJ1fHTnXsPhnA7YG0SQpHTyJhuX3rgBjxGrvbZBArmZ+R/Pq9IkOkJe\n' +
'z8HATAMOsbaZjGN5JwEH/jYjLN6AFRWeaB5CSBSAF+CvHsUgadGmxTdSHBM6\n' +
'LM9rfGg/MCnpRBuHckA0NNZh+wepq6TDA54ZopsdP14gHj4MKCdfqZr86Jft\n' +
'ldtjeSgPTFEEJxPMJ4/Z3UeFU9rvOgfxX6l0eHWS0MYwJ3sVYvSyqqHir1K5\n' +
'TRdEIgtQ3NvLTKkX4bKTSU+SInrvDA+wsc2BcBsbgNhRiGb+XYrbqXBshL1a\n' +
'lIdpnomkAQgOZMO2n347uURYoruH3OtFeNABJ9D/nEU+LdhDOPGZPefvPBc5\n' +
'BxK4ExKZ2Wo/TZw8lgC53uqOljsGV63Hp71LkyesKWu5/+vdVrYx/vU63shh\n' +
'x/TSQAEiaFYEfkWSOthtH0nrJHhkY7FWgjp/1bj/J4J9HCQrVtt2WlQfhowZ\n' +
'ILxhKk/vep0sJviM3SfJ4hPtoYpZESc=\n' +
'=43Ta\n' +
'-----END PGP MESSAGE-----\n' ,
} ,
{
link : null ,
toDID : 'eip155:0x0F1AAC847B5720DDf01BFa07B7a8Ee641690816d' ,
encType : 'PlainText' ,
fromDID : 'eip155:0xb340E384FC4549591bc7994b0f90074753dEC72a' ,
sigType : '' ,
toCAIP10 : 'eip155:0x0F1AAC847B5720DDf01BFa07B7a8Ee641690816d' ,
signature : '' ,
timestamp : 1669831499724 ,
fromCAIP10 : 'eip155:0xb340E384FC4549591bc7994b0f90074753dEC72a' ,
messageType : 'Text' ,
messageContent : 'Hey Fabio!' ,
encryptedSecret : '' ,
} ,
] ;
Param
Type
Remarks
fromCAIP10
string
sender address
toCAIP10
string
receiver address
fromDID
string
sender did
toDID
string
receiver did
messageType
string
message type
messageContent
string
message content
signature
string
signature of the message
sigType
string
signature type
link
string
content identifier of the previous messages
timestamp
number
timestamp of the message
encType
string
encryption type
encryptedSecret
string
encrypted secret
// Alice sends message to bob
const aliceMessagesBob = await userAlice . chat . send ( bobAddress , {
content : 'Hello Bob!' ,
type : 'Text' ,
} ) ;
Param
Type
Default
Remarks
recipient
string
-
Recipient ( For Group Chats target is chatId, for 1 To 1 chat target is Push DID )
options
object
-
Configuration for message to be sent
options.type
*
Text
or Image
or Audio
or Video
or File
or MediaEmbed
or GIF
or Meta
or Reaction
or Receipt
or Intent
or Reply
or Composite
-
Type of message Content
options.content
string
or {type:
Textor
Imageor
Audioor
Videoor
Fileor
MediaEmbedor
GIF ; content: string}
[For Reply] or {type:
Textor
Imageor
Audioor
Videoor
Fileor
MediaEmbedor
GIF ; content: string}[]
[For Composite]
-
Message Content
options.reference
*
string
-
Message reference hash ( Only available for Reaction & Reply Messages )
options.info
*
{ affected : string[]: arbitrary?: { [key: string]: any } }
-
Message reference hash ( Only available for Meta & UserActivity Messages )
* - Optional
Expected response
{
fromCAIP10 : 'eip155:0x84a9385e9b97df87b80c2e689997133703853874' ,
toCAIP10 : 'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562' ,
fromDID : 'eip155:0x84a9385e9b97df87b80c2e689997133703853874' ,
toDID : 'eip155:0x14727F96dF61105661E78275D1A03C4F8aeff562' ,
messageObj : 'U2FsdGVkX1/S1wljx7jN0NXJzSNoJCkg/6cw7gHwVibLsqyhpe/XgzJi7OUrXwUh' ,
messageContent : 'U2FsdGVkX19oSSMVZpQdw+jZRExfd1GvJkIwgWAGe5g=' ,
messageType : 'Text' ,
timestamp : 1693316104031 ,
encType : 'pgp' ,
encryptedSecret : '-----BEGIN PGP MESSAGE-----\n' +
'\n' +
'wcBMAytMqhuaZwVMAQf+KkUcX1rmNnorm0bCeGPknnjMBFn2wQ4nIAbQV5cW\n' +
'W7bCHneK0V0+kpronJwuPb8e8GUZiJEmJGdTJYf3XMVP8sJkVVVQEbvYvAJL\n' +
'tUEsdqgqRuqGB+u4k5shtlHN1ViTjjc1N97C0eQUqTCVFKa1Ul9eZirhDqiI\n' +
'C/rj8uxESy+NH7o/nnbGTlwQonOOLLHfGH2zCpl/F59CO2CcLnuecfDT0WxJ\n' +
'xi2hM/ovKgbsKVI8WOOde0sIV3MQEvxAFuPJ8gINpoDA28Ty+lf7x1bN9ONN\n' +
'RZl4yjLpA7KUojWyfjp1/UW635NY11aZYEXIygDppCCvf6AE7je+1FDaVR/B\n' +
'I8HATAN3fc/EzVLnXQEH/1H4r6FubywzPzRlDJzPgxyNpNGPZbexrWRQT5U4\n' +
'eHmh7EsOfEattUCHb8zChL8crnX0CCw9MiN/ryfs9PXXK2qP3lFU59GUHd9q\n' +
'Mz3RQwF76M9C8zbsoUymIPXUypBBma/qsF8MK54qYoVPody6T3u7bEfW6E8r\n' +
'nDtlz62+G6wk4sNE7iJsk6KhGmb1t9v/j1qgmJwuE7zGP0QjSuquJsfkzUot\n' +
'1eU85XnUTGdoYBR2u5F2TsjIHn1ex2R0sZYfdc9eRNSSvDHrce9m7R5p7Y5F\n' +
'sSs96Skx7wLuepGt/vY2cH9Mq3AEGaXREV2NSr453+gHeTupp3aIiQ2CDpFB\n' +
'/MzSQAHCPW1DUf8r1cFE1Y1RXU15gNBeFju/ZBnpDlTbj3xXi0shafcl59pe\n' +
'0LTGhdDSYPX0Rs6zqJgex20XBnfgPD0=\n' +
'=ycNl\n' +
'-----END PGP MESSAGE-----\n' ,
signature : '-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7fQICZASd4ccCgkrMhYhBGLo0VO3qtKBG9Y0eBJ3hxwK\n' +
'CSsyAACktggAr3mI2uwn4m4sI7m8A8wIRgjs6h8V7d2feLsdqV7QL6aUzYld\n' +
'bewZYKQjSXdnklRtnlCIG1jmqFOCycv++3O5jcWY+du8lR912Gkjn0PDN/wW\n' +
'jSBDTkH0IKmIrYqIDnfbxYoUfUxAWXzm8N0LgVnA+qgs1CYzcS8S38zAONvH\n' +
'GBl8ZXNTgY5HYN3Pk74wms5jhBF1J7mtfMCNN8k7VHFaoC6YVF1REhwrSlxx\n' +
'l4bajYkJJMWfKdiQWQ31kSHChzKXBhu2rIWJ6A7ijyoc7Ff0s4xgwm/3cLQc\n' +
'hrlBpkMKI2xCDnP10Sr1sgmG7ropd+tCOFwsoEWqFqt+kJ592+g1mw==\n' +
'=TVDb\n' +
'-----END PGP SIGNATURE-----\n' ,
sigType : 'pgpv2' ,
verificationProof : 'pgpv2:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7fQICZASd4ccCgkrMhYhBGLo0VO3qtKBG9Y0eBJ3hxwK\n' +
'CSsyAAA8/Qf/Qvcom0DtPUQAOWkM+FCeBttjkCiM/ekZa1Gxioyy7jT0Baoi\n' +
'oUi8y4BpmjKjCvUGCDovcvvnjeLW8gpqunN/LOx1c4mPsgFTU0IQFqZmTtZK\n' +
'KMa+p/uiTXNnwx9635FV8WLOWQoyJP+u76rTu8n2YU1+5+N7xan9Wl+yuu4d\n' +
'/WkFwAq/WQjW4cgIZ08OWfNGaOh6kt3ceCvR25XVbb8gdMPOj262d7RuWVqs\n' +
'L31XJ8U/EkKZN5AxIB7AP6HKhZhlV6qbgizVFskWefT4E3Qq+9WLn4ApHf2R\n' +
'OksjHVbukZNbXrWeMjbZE9RlswPCXM68WsxWe1zItjXs63w1mwoQZg==\n' +
'=e9QO\n' +
'-----END PGP SIGNATURE-----\n' ,
link : 'bafyreiewla5iyd7rnvjw2c5w6dbab4zkyf2desbowzouijoea2jzakxz6i' ,
cid : 'bafyreibhnilz634i55hdkrkp3j4vt76dnyegvmrezdiuykeizq7unvx7cy' ,
messageCategory : 'Chat' ,
messageOrigin : 'other'
}
Param
Type
Remarks
fromCAIP10
string
sender address
toCAIP10
string
receiver address
fromDID
string
sender did
toDID
string
receiver did
messageObject
string
message obejct
messageContent
string
message content ( deprecated )
messageType
string
message type ( deprecated )
timestamp
number
timestamp of the message
encType
string
encryption type
encryptedSecret
string
encrypted secret
signature
string
signature of the message ( deprecated )
sigType
string
signature type ( deprecated )
verificationProof
string
message verificationProof
link
string
identifier of the previous messages
cid
string
identifier of the message
messageCategory
string
Category of message ( Chat
or Request
)
messageOrigin
string
Self
or Other
depending on the receiver
// Accept Chat Request
const bobAcceptAliceRequest = await userBob . chat . accept ( aliceAddress ) ;
Param
Type
Default
Remarks
target
string
-
Target ( For Group Chats target is chatId, for 1 To 1 chat target is Push Account )
Expected response
// Combined DID for Chat
eip155:0x7a38D295786d1480BAab4a63b8d85B5a47bA4b78 + eip155 :0xcCC0Cc5081A135E4269E82907d2dAD6728ea4159
Param
Type
Remarks
combinedDID
string
Combined Chat DIDs
// Accept Chat Request
await userBob . chat . reject ( aliceAddress ) ;
Param
Type
Default
Remarks
target
string
-
Target ( For Group Chats target is chatId, for 1 To 1 chat target is Push Account )
// Block chat user
const AliceBlocksBob = await userAlice . chat . block ( [ bobAddress ] ) ;
Param
Type
Default
Remarks
users
string[]
-
Users to be blocked.
Expected response
{
did : 'eip155:0xdE3CA2cC2c91Cb9B3aDB80ac497662Dd9E57BFaA' ,
wallets : 'eip155:0xdE3CA2cC2c91Cb9B3aDB80ac497662Dd9E57BFaA' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGT29asBCADVtp8rHsmtqgUSHxutStJ8AO78jWFFerHJQQ7M/QRZ/1mg\n' +
'uDTt4QTsmhNPlyzQ/OztVDOddn3qqZg4/gLUpJclMmR3UmxmTGrv9PaL9IOv\n' +
'otdKrLlYKeXUHbaBWVgXHv6F7hrCx1Faiq4I5Ca8tdxhKyQc9WAA4f7TTxhg\n' +
'htDY3VfRnp1LFlXyx8GyqCBGpmQx3tSK0w6SoC0FdCq/DpaXD6ofIKH8kcjJ\n' +
'vpBXw6MLwymZrfzbUtYWykOZ7QWgDWF6Y0xjDjZvlajGeY7NfciQR+2ylb1r\n' +
'eOn1yGN0Fvw6+7gGZy85XaDoCnyDAws0Nn+2G9BqTKVH0UwweWKcqOtbABEB\n' +
'AAHNAMLAigQQAQgAPgWCZPb1qwQLCQcICZDxpr16PpcWmAMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBDqZlQ8vQkW6qMko3/GmvXo+lxaYAAC9AwgAy6nLLykcdRlW\n' +
'dPXUN/wTqowopbuRo5bMhz6+Q53Hf6qkjfknaswoBtE2bq/J54N0BN70Lv+j\n' +
'5klfjZWJF2stgMEyQfPbXp1yXQi9Rlmvg4qZvZRww5UNm6CuqxU/stXQK/Je\n' +
'N9eIqd+fTB1EMKwbFrFHfOSKWK7OGnb6fi6JqofJcGvA0Oj1Wkf3i6UohsZL\n' +
'XE8L1Ku2IXc4oUZH5UZD6vRYkQg6/EGq+WrHUXX2nifdK5b5tGZcfGe6Tudm\n' +
'KeYFGTGfgbA8ag67nD4Esr296Mjjm06TTvqdo2r28/zn5KcRPWtHNpPU+t2u\n' +
'kwq7UBvoroACgr3yZkdAFLt9E5NRTs7ATQRk9vWrAQgApfSeqUx3ob+kinzU\n' +
'opKC8L9qV6jqkYu80coITufcc4TUEYlNEZwSaMRA+vOk+bwWbc+zJG7zW8aq\n' +
'Tx0LyZqABgRsWOsNblepCzyejLmAwxl8kBEAMQvJ4Hjo55MGEjfsIFSqeEGt\n' +
'PkPZBpxYN0/sB+yYZDt+59L0GGLC0vrxvj9aLw1xRaTNCNLkawTa8vTCwSTY\n' +
'/833aJy6kevAXzj7V8hOGnY5JU6dx5Wbsi1HmzuhtW/lG2n0JtYokfpESnQ7\n' +
'La8I9PqpJC87iFEdt7MST2x687sf0vJI/QMRQ2kZF6Pi8LRYuMmrYTF2BIaH\n' +
'kmPafAoy8BYNfetl67EArGHckQARAQABwsB2BBgBCAAqBYJk9vWrCZDxpr16\n' +
'PpcWmAKbDBYhBDqZlQ8vQkW6qMko3/GmvXo+lxaYAABjFwf/epZQQVs6w3Fj\n' +
'JV2OhS5PYsNr7hWAgAVTgqBLOuPkWG+yfwmayqyQKJmr3a/e+1wKC+Mrz1D7\n' +
'cRpyiwyiCp01has6qMAledjGweg5wTz4axMSQn/KsLc7dsLOtccV05RkRPMZ\n' +
'vRDDJkfIVYILBikTcg5WEIulGuy7enQO+Mo239WrUxi2QjAkEMt2pxjp4qNM\n' +
'9vMEPo8uUiEj/+Tsq15kbE5NGpL+n69R1/PYpHp6R7acimsZlXqyhUVaTD67\n' +
'QDFLdR8nVToU2ACOvmJicTVHCiDbRfeUgMaaTu45degUEE7rbh+dNiJrkyFh\n' +
'GCHIKjRcKEpModMxiZSJBINcWI2hlA==\n' +
'=ktHx\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
encryptedPrivateKey : '{"ciphertext":"5d3b651b63db81767bd7b9387a085c0134a30d2c77545b4db528c15c429286620edf527b069d4f90fb7e7e769c6a0fff19f52676972765881cbb601e78f386cc492b6ff7a4739996148904dc09f4f95ebbd53ee4e0f17d17dac66aa5b11e09daecf307b120f5d1157465ef15114b0b20642d7b64d45a218307764bf48c819e05247db0d782745d458e5ca574f92e0479188d5ba557201d58d85753f2619fd1648a80f8153e4847b7fa455e50379b096b4e430fb49b3084441a08f715f3b99c722e5a6b730ca8c2160075594caf3fccc26bc9289c116751e4e8306cf33b96a60bbbe46bf4363dd3b25529ced93c67ec60a153331fb340d2344851ace937dc161dd9aeef20dc71a6afd7cf308d8f4c05e9c779bf5d684fbc4620b955b0aaa80f89287c197f2f4b00b5450b55770ca1d44c8a78583762c3740dc88fe122afbec422e64842ae9719d21334d0289718468d11a3cd12373583488da7631f924c9f1566c6eaabcfc9f146fa50e49986300f7e7a3d36d0056c381f6decb38b10ca291a747deb0d896168fee9279b5bbd0ffb7aa419843d1f69da632552aa885ad694fe8ab50fe0bbc79ca4980e522d4b001215bd267752340f02270d05a5ad8673ef998199b1b0e6930cc53c97a14245ea5355e10a438513a94bdcab49b4aa605277ad11ba0603ac59d6f2e1068791a61b4531d55c55837bf43299524e5c4ff454631eddcdab0f036b70985e49f155bed3bbbc36f9e69b6c411077051c2f3083354160146336f7d023b51b8091b32cec3b0d8e5dd67f3796e00472d1b305ad3f861b6ea863deeabad29bac8dad1ded1a59fdd965ff5903c7dfa1ad956a4264e2227ffe9bd9e15ce7eb48c0a6494c07a95865770adacc94703c19f4c1aba9bf885d6311490a285d42a6e8899de07709e176a30dff3e8988de3f22188d0adf03bb633607ffd4daa503b7121a5e5c3946bf3a48d62d511cf5518ad94b43839827af07faf9037bc959a7ef621df75ad965045dba6c89ae255d200ebcfaa0a2f652ffe630df57685eb471c4b089ec6e7d4c841f1e2e25bfc3b852cf79c4fdf66327a18302fdc10c6f044e42387bb89c45644643546e93324b8ef4d7ddb6016457f5098da369915ac6e1d2ef45fc9155cf13d165d7822bc6e463932cc69ac7b372a0e3b18c45b45bd275b38af4b29d665856dfbd6e6c6ecd9b6d02f4e61308273d76ba0baa0eaa03ad831adb428ec70a1dd29b3b2c4941adfddaa76ac99c47bf6eef92a361ab890c3e9bc714263a4f93289cad7344882886aa101685586a54e5da7d370449b91400e48c6a1ae8f6e2bcc06fe186d981399c28143a3faf1cf2c06342b82382c01096ff8542ef55c24175d052f199fe39a4ebf39c56bd30a8251c19745d1b9d0a1a96d81e6cff3c060d00d85d627a9344e1ae98cb42c1f05cd2dd9ae3d83b7974a7bf96980c33fcd76f96ec6c2ea11a2348026333424307f1568e5aa575c31f819260d52ad968e9a17cc46723ba1e129614d2a47ece4dde0e0cf4bce2be7ab25441255997d8bc659a194665090baf6e071dd4775b2e2f7974d26e0cd040df9890ab58c77732d6e33a8ce909e965c2f04a7f65ab5331c044cbbbe39184721310235a772b30a30071a8058b9941f42d85c2e63bbfece7d6116a507bf1612194ed17f430274e4053d2b8de761cd6c316f08c401c66f1650d0e83fcd0d69dc92763f8202748d8e40bacae6cfa264d8ab19ff86e1753d3a33c3ee9b4b9fa6ef64765e9d2b2ba52b28e61743aca96471e6c35143ac8238275b504e7d0ccf0c9cec095d02259849b5f382fd7eb0b7fa3ddc0c5dd91cc2be7829948852dc740d9227f17b2f960141f4807678a2dca6ee24a858a6f20874b1b8e35305106c77c38dbbe52d3e533a845dc8a0912c7d95218c6b820384de5c2693447529522df552383e35d126122801008aca30065c8f93c8556ceb09f5512e64dd481d5ae823675c201124759a80477b1be6ff4756e94e814b279f4de19b79a72acc52d0e1d1e9119abbcbaa1ef0c6dd50894db4ee5f4c005658416fa840f19e36b65c591e73ac8ae4d9e49ac13dfc40d754cc4f9eefd327876a94e5a72f6ebcc8bb4645f6da8a7505d64190ef400829be6455737fb60d595ab13cc9d8634514675803693402570ff869858943c4cfaf914402153a41bcbf417be30c8220ff994d48d85a2893991a5241d407e6acf8341d11bc72de3967720238b218052580d121c6d2d01e788d6cfb2bac26ae205e0e72198c40418bb6e3f25f0e14f03d237bde9efdccdcdb2659a40276ac760a4eeb0770bdff49513b88e51a649bccd82da5c82e6c50a91cf9145091f08bacf7aee46e80bdaeb320af371d6e6b6bc29fab41df2c4f09953c0efa3b92f0745c9480536680d60fa0badaaed85b8836b5e5e54c5aebfc99e2a3b32ad3a5c882829b55e9d80a33468b05e8196c408a9de4a13af00df4c9b632eb4d04372c99c8020fad56383cd4937088d2fb4e7a0c4edc15e3bd79214337e02fc72cfa703e12bebc396068da9eb6ef142a55f6eefd8d11a501c4c6610c808a75923e2b279a2809ca34c2da49731ce85756a7039b667cafcb081693375f4cf8e1b39aa5f29560d7ca003775ad5affc621c359198a4dfe484edb11853586c1c664459c996457454803fee7350786410b8b9d81bc0e31f4426760ef812ebb49b1a63612c3c3249a0dfea9b50b620a818654bc18bb3f411024ef9ef7fa21a494f359473bcb30c70070b78ea9106d5441dd89322ee2a31c945b884ee9008841ca8dc776aaa6c46526e6a21ead1831b20697b75905a13dd947ee53e6a105f0bccb3184f679b05c475f5294d96a16fc50dd9430967a1c7013c054f3fb0fe07c586c5835b048238fd1effb7bcb6ae6da40883f387dcf684ac20709c59a312507d125fbb65208a985f0a6f5e2e442330ce39c0503d27cd32d61541f99e1d20b2314e830f3d03918be89152a0547a45ba0a419ef6beccb83b444c8081fd12c79f8d88ace21c9057265b351a7ed8588560a9f549149b1e2fcacf99fa6cd045462122a4f60d969fdc7d780465349fa359c95a5b58a9e2b751e45301696407a1ddd17c32dc7bd5acc3ce09ff5ad20b9d91a9ac8eb3d142bb6907f19b789cbbe15a2a34469e90a652e5504228f12411a4ef54abc1c1d9a132ab85e42f1dbe2c14eab46532f22fbad0e912911f44510c10569a99a0a99f774070178776a970d83bdf50257cb6ba08ba6561b16535b1e05c16a06bf0e3b29b082f66b8336e676cb4c6e9bf98362b631173f683d251c4866e49860fb83f4053087f44c033198397ffb69b7053746ba150e16399c2f064967334f893125de76539730211f8c6edff3108db2c7e8641fc50ccb9946596b59fa425265ec86db50414218b494b5166399209a1d664d2157da0161d9786396dcf2d91f9433d39219d35f6974c96e4f1bf5f5e0a17db196e97dfff13e58131ffcbe3a8a647cb6a17754657b93e9b9cb458b9bd1d8cbbde72cdbccef7073ab2c290e237423b8053a5cbf358a88d1101e1f648c392c80704c7dc9d0509e186a11a9d90e9106bb1fee1883af0daeed804702b9e2384ab0c519129ae330914ade6c5080f6a2d17b716f71d81c352c07c2cca0c210e0d951b0fefecbb00ff0c3693fe262cf9125094b46329eed041d3801025ebb67722659b98d3e5da83ba5343a058540e868742ac36c852f26b3310bd33af4884d3e51e046c0ee17b714ce1f29df6442468791a469eb1e387cf9d366d24b00aec6a089a88c96a82a1ff71b1947a24015b1cc13be259be5bb75731a18ca58aa46609e2a2ee9fe0583588f0c453a2b99166831669547428941bda9a65ab82462de8add40f16976a13e36a0018886d27b4cba663369d13fb056a874f6d5e0e9ee6567ce7428d9e179790b44649a05aa8523fbda4b9db72873e9aba33892bc0677339332d5da9b3b4754e2b387597d8405de304d8b65ba6bba9b0558457431820582df5ae3577efba787ea3b4eea2515cfba590c7821d2d47ada99c612ed4e3b9d3ff9ced63e76379789da562f45f851bd10e8e6d2ef633984ef4bc6bfdb4c833175448c3c6f1f7735587b6e325866a21b8d02cda06e9520d18350e38b428b3949635dad18cccd4d840d9e4c872b32c527d2f521de3822565b7af6f5d8e254bc142029faa91effaaea2ce70de748eae946a2521d3b5952d5874e5bd6c4322a35660b51ff114d5cf6c5b5fbaacf834eb1eb68087ec06668dbe804d349b1d5bd3396099f3062982fdb9a6afe542c8529752c728501ddbed65a210a28f351f3f44ad40d3a6ce4995f2e6da7495dfa40a4838fd2d808b2e298a863a7475c2134a713cfe8a47fb5bd479891c2747f0db0005ee4a894b6e8b66cb5e1af8d938fb1f5f53c24aeacbcf25b57b83c5abc3a1adbf7853e0a6ed5904e19d5d824b1500296550589c4a3186359b72a1d482b02dfdc1874e64c78a9df7097696457832d6aa572102000c06af444c8ab83e6204ea920a2a847cb163efd9a4701148b4009b2f8053bd7d6408045f627df3f45b002d249a20dd829cc8ba18d9c468d816d451b7f3792e31f360c5932656aa7bfae55b75ae0c40af53ad33005d065d047926543d68e9548c51c3d5405a164b902825fa5ba8c8be5dbfe8632a94df6ae322425be86df9234140bbeeb707d45dfb4b64a09925499ddd2192ad1174776f006f3e91627768f60be59756b7a9b51e4e4e02c01a7fb8b06e63dc3e71951e0b426652b1796bf546da832ae70b055a4700b3d6e266f4af898f0f517277db75aac827d6c30f75c6a6fc9fe6ef67e6f3fbf9c21f731f1f5d89feeb1a76c7ac9923320eb56c517f937a32f3629a8fb4f134a499562f837515596508cf6b2ff3de5c536dedf2946b85505c5843d09bed34","salt":"7b0c5813b930a5ab6713f1572441734633ec845aaebf526f1daafbf89ef268c4","nonce":"bf2c1e6312caa6a32e95eee5","version":"eip191-aes256-gcm-hkdf-sha256","preKey":"fe71bd49335560367aee6772233e69316de48378df6ed104647068e8525d2c4e"}' ,
verificationProof : 'eip191v2:0xe58171978843f55fda11f3989ef8a2310a3366585cf3ba6c71dc260e362bea1b2b2667e287959f6f79628a03073d5757011b7161a2782c32290f924486f87e0a1b' ,
msgSent : 1 ,
maxMsgPersisted : 1000 ,
profile : {
name : 'Bob The Builder' ,
desc : null ,
picture : '' ,
blockedUsersList : [ 'eip155:0x30d45C4aAfDB894Dc529aE15e7A55fCf49184eCf' ] ,
verificationProof : 'pgpv2:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk9vWtCZDxpr16PpcWmBYhBDqZlQ8vQkW6qMko3/GmvXo+\n' +
'lxaYAAADJggAoSO2WXXxPtkFBMcM2Bqc9pzBFkklicmWj3Fjl+6FB3sDXt3V\n' +
'YGNDqSruqpqoiCpMATy9QC48zO9Bj/gbIzuIbLRvNs9M3D5e0si4/OHKIbSX\n' +
'3dBiaqaLdki7tUvtPioQ4Q1ZkdOATr3Wr/PyrHc0V00fE64qb0MlN4ouvYYf\n' +
'yG4WK/0x0iH/RPRyG60fkrsmZa/PPpRBzReZXwrsVbBoOCBSe6f9s3EYTfim\n' +
'4ThX4zrbwKXx7Wgv1lXw386jvlaqUze9A14DAq6OjwqAZEVmLZaq6r/OHmqM\n' +
'Jy4fZI2auG9uYDorCxP7n6RjOSEOCLG8k+WRDFn6LSPJpdrYoYi6MA==\n' +
'=d+/X\n' +
'-----END PGP SIGNATURE-----\n'
} ,
origin : null ,
name : 'Bob The Builder' ,
about : null ,
profilePicture : '' ,
numMsg : 1 ,
allowedNumMsg : 1000 ,
encryptionType : 'eip191-aes256-gcm-hkdf-sha256' ,
signature : '0xe58171978843f55fda11f3989ef8a2310a3366585cf3ba6c71dc260e362bea1b2b2667e287959f6f79628a03073d5757011b7161a2782c32290f924486f87e0a1b' ,
sigType : 'eip191v2' ,
encryptedPassword : null ,
nftOwner : null ,
linkedListHash : null ,
nfts : null
}
Parameter
Type
Remarks
did
string
user decentralized identity
wallets
string
all wallets associated to the did
publicKey
string
Public PGP key
encryptedPrivateKey
string
Encrypted PGP Private Key
verificationProof
string
Verification proof
msgSent
number
Number of messages sent
maxMsgPersisted
number
Maximum number of messages that can be persisted
profile
object
User profile information
origin
string
Origin information (source of the data)
name
string
Profile Name ( Deprecated )
about
string
Profile Description ( Deprecated )
profilePicture
string
Profile Picture ( Deprecated )
numMsg
number
Number of messages sent ( Deprecated )
allowedNumMsg
number
Maximum number of messages that can be persisted ( Deprecated )
encryptionType
string
Type of encryption used
signature
string
Account signature ( Deprecated )
sigType
string
Type of signature ( Dprecated )
encryptedPassword
null
Encrypted user password ( Deprecated )
nftOwner
null
Owner of NFT ( Deprecated )
linkedListHash
null
Deprecated
nfts
null
Information about owned NFTs( Dprecated )
// Unblock chat user
const AliceUnblocksBob = await userAlice . chat . unblock ( [ bobAddress ] ) ;
Param
Type
Default
Remarks
users
string[]
-
Users to be unblocked.
Expected response
{
did : 'eip155:0xd1790E37fe3459e3F48eEEe41a7708a3eC2148f7' ,
wallets : 'eip155:0xd1790E37fe3459e3F48eEEe41a7708a3eC2148f7' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGT291gBCADFq+sw1v0dNAqkG7bMUZy0tzo3E6iPZQ5UwlOvtzaen2md\n' +
'OHOTnvaCFRjRQZjrvlmbWwBELOTsHbmluA41MeayoJ7aA+o6+aflaa6PCUG5\n' +
'ugAfXjuQxPn+gK0hFdn6IYxvBQHdh+Hu0Obi4peol1GobzraVZt/fRrXdttA\n' +
'tLM7EmvX/l5440xO8+kZ9/uhMx5MR6fdD32AWPpGDy6tJin4awSdTN4eIwI4\n' +
'ueKUZ0+B4wWAiEkRwIRWY4vbCCfMeF+qNMGBaz69I+YS/2FvyqAXTkyKytt4\n' +
'U9efp+ObJsNGk8OA2JWZE+X/16eO8xvQSHhcoH5L2ahGTmG8+xr8bFoRABEB\n' +
'AAHNAMLAiQQQAQgAPgWCZPb3WAQLCQcICZDzsIc63rzcLQMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBLvWJU1IWhvs+frC7POwhzrevNwtAAD9Awf2KFgMZaNyYeMO\n' +
'DNojkd6YpwtXGp4zxxL4JrZwDBginbcba4oUyTAqIcJWe3BAGPXX4hi3AYjE\n' +
'BIERstIeb/YkcTyRgyZKDj7tDNPF0itxfiUXAETN7Z+ySkLWx+5rQ8B9VQv5\n' +
'0PLDDwBfwju2pp1/j8XTx/81PSjVKpFQoEsEPOj+WloOdonzx+SGcr5mjjYj\n' +
'rR9NpHVUxi3Xx40zJVVqWFbTdnqd1Wm5SGkrRWLJAe1hzHhYxtpEDGqPfxYo\n' +
'bBMe7bphBkh4DYWuemj/2PiZaS8NC1ed32YOwOSWJV+9wmUvIvq3Q08AE2yF\n' +
'tfeNnX6Gb6fDgvPa3Y1Qg/0S3wYvzsBNBGT291gBCACqFMmyuJkBkNwwpNE1\n' +
'L1bJLulRqEm/tCZ2HY58G9NGYgo6u9Ii8H+ia42bf9Ezq4fLBDzYH0T6Pe9Z\n' +
'zAQHudpId8SNfT15QdqYvHjovxk7jqucF/+W7+DilPXZn6eomrOKePCNP8Cg\n' +
'JXSoShkVaWkbkr2UkHGpcU7YIvooAtsxXMWWr1Z3hbk7tCf1uwXV4NlAGIXx\n' +
'7FSvWuQ5ow21GqM/6HyeOzbJRis0DNV5NHY6uUoFNUNzPPBBYx8DRDzjmmde\n' +
'KpjialSW5QK7g8KlWaSGnHFCd6eS7pHZURl1l299ONNJ5m/B9yibBKwHCQ3r\n' +
'V/8ByDlxzjU3wbgdZ7+LfjitABEBAAHCwHYEGAEIACoFgmT291gJkPOwhzre\n' +
'vNwtApsMFiEEu9YlTUhaG+z5+sLs87CHOt683C0AAGnNCACtFS+hJSnqZDmf\n' +
'XGSIw3FLkD7OsaOd/75BZ+cqXnfE4is4JlN7IceOHb/9+UlghAOfpjJYfn3Z\n' +
'HobaRnUZTm8unx0uVQZ4PEZgPGuIKjnwmU75xZVpYegXTE55faiDoQZp0Kir\n' +
'zyScqaIuxHGkuW5Ii4hcLXKBK5qKv8cydeOgZU4NJ7jb8DMQhWulx4PHOaMk\n' +
'JR/sRVuzkxfZQ6LPtnWoTmJLr4wJ4WD/nM77W7XmO8ZGoe2hE5V/OZJC+0uQ\n' +
'OPK4S3YmXcBZoz8L6/gdUQz6kaLtRzsP7vZfyn4jWhlbfad1R7KM1srRT+OT\n' +
'HDPpdh1b+4npYo8iTcJTnANQ5oAm\n' +
'=rs9R\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
encryptedPrivateKey : '{"ciphertext":"4bb789bbdaa33f355800c4b8d14e75f310050a0269961b1f4b64c820756ce3595ac737fba749f0b268c418b19cb32f5ccd476bddec8d252ea4cd8e7cf15423a03cc00e9a2064e4134aba89524fe2018fb5ef6b27024a4dbe519883e6f41b462608c33914e129fd651e88d0f14973b3305f8e9d1e3d95670263b1b36921a1b5052f43282768a7210c7b66d5f5886359526cb56f48c61fd3cb165ba15b36f47611d1af8c2aa6d34eec0966d1aaa5522bc2291a5a962585218b4cca7a8d4081aed274ca8ceef95596583683b212549f0568a78b9116a4847d94d32488a0c4ecb9a9b5045afcebc9bcf9d3406fbb4d7eba89f21efce27e3ac174941768008f9d67842efb65e1f3f658a9b366c5c164b5cde2c2db442421c39d46e6017be35bb5b73b06a1569b35e8c4814e0edc1f1be46a964b5a4d9a8245694e530c43e9dbfb9176c41731b315f53b46138c270b6faaec8562abfdf7b595284de89d75bfb87e977330e943788ff914636a2cb81da54dcbaaaa39bd06929020dddcd3b628c44a91a3985f527a9b4592bda19aee4da3e3ee6bc73f98d6de843315476b1f67f8b8174db7b985b94c88c0686b4fd42b45ba398a46638b8d0cde5caa22f45fa51c749377baf35358ee2c1c057dd85b550194f4436af0a43c7c5f36bd7620f28a5ccfa28f16732a4992ff9345a863f1a8f48e5312ef5927b2af2890fee50ad219b43a88781e4b007572e4b7abf5fc5b41e3b944bb164f6c9a397495c46da239b0d40aad8d5bd17a5d02a032212f6495c2f4b8287a0e2d4b7a7d4a56114becb7a26e87233ec3201c558e6f42bc74414b34ec39ada6ab64f7ba9c47e0ddbbe5a622045b236b4a137adbeeeea3559b7b8873d727f7707f75a60a3310a54080eb00e59d6fce88ffd079ac9bf3c85f4fcdb56355bdb8b0b844f42526f4b624591a1729d5b7bed31c1affb0a95266e1092afd45f5c2466a2a7234f8481b8526180ae854e6b9b5e2a2835aef5dfba36ede0c01a56eda4aea27dc415f3ef1440ed0b8f8ae805544d3f4e24d0c9ee8b4ed6def38c7a545cfdc32b3efcf3ad321fab80a15b19c5710198f97826321b69c7677bcf5cae6218279f4bf9192b4ea77e510b7409b31e7b50c4b2dee85857ecf42f3b12365ac73c41d7bbe0564c8d741128c0723619a48ac29760c1a9eff36c179b50e6be26b4e10432cf6b8f987838450189a9474e20bc10adfcaacd1199c026cecb9d8b905bf9a2216345ef532e7cf3b94bc6962b4ac1cf52ed86547aaac352d2ce3a294ccd7299221722cd2852b7c5120dad85e041b09709b49e29e2fa17e6e94c0a77c0508ae805f4ecd0fc70b3ff78cd38ada6d8ddb9b150677589ab5b77968bafdf9f8cbfb0c7ec85d35c004b7d74dab2b3c235069276422878d6c0967ed051b03f05ae70ee8f054eb25054ece32f548c48671aa2b0206f61261f3ce8f44e2754f505ea29d879a1842531e7f2c37333be6c34178c4ccde01fa79f344809e0bddf8aa07e4614e4ed31b4d2fb4dff0b97cb33305afaff864ded85b13a69de4b421f331471595df86e6a8a6bf0c64bd00a7b8521614d00e0120895ce81355285fbbdfde434df2846fb062d5e309fe58df0ebc568378ccee69d6f86aeaed2a65e3ff477812692316535f52b927da1ae3a3cd49ed49fc19988e2759f7252510af3d6f3b4b444d838c24df9627b3cbaef01707de84182c1440c736d5432da40a9ba9d493917c82f3b6475a2d2b82e77dc72111ed454b7cd6fe0d0b0f68512fe9538898060043dc9ed2995a1f8df00ac7b58fd8f9d169225c66b527b5447cf597a2c785b8777aeb2054e2c95106f701d1645bdbee9a1c48649e51dd7ceeb611a99cbd85f8e9f8fae2bdce1a46023eff7bf6748434117624a9002eaf2d1feee0b5d4519706a7fd04b7fa497a0f5e152d5387b010fce47b7df330c12b9091848976cc1aef5b50f93bc2332e320bc46d01c891fedce914141805e74c3f912dbf2991aa927eddec4ec2a80cd3acdb5946764ae5da7759f142420567cf51172b37a50d827e4f463c51a9fd6dd47139c8acba1dbd6036dd4ce6af0e5e37ddc6b2c37dfe3d1482d0f695268e842e980cdb2d6d3541856f7780b216012ac67363cdf9907626ac81fd498cd133150c95aa5832ad4119fbdab0bc8ac0012c7217558e52de5e9a0dc779cb7c013cb7a277849cb9e040d5b32d9c454317b59c8962a645540fa0d7ee59ce4468b697ffdd29c93d4db10bde567c9d2105553116860829e728e9510a4cf986a9857de09846fe78095a48787985ba2b95d2094798d9fa209b893e1874615b313b099550ad17f7050112ca81a8a3ef6c83f4c44a90b2ebe44c60d658f15ef773304ac2d715e7c061675c3abe58386a7a2803856009e5e8c495c7d3c97091ba82893899fd12fb127db0deb06aa5717c63a1f949b35be830c2a3f7731d3f41423aca7a3951c4b4ebc5e3d874c36b518276cb0c07c27952571691d4fc16655be7450b55b3587f0ce79695661d325bb6f736e20338556efc1191eab56f5a2479be34a4c7c8d58b1028def385eb0e60aed6b7e9dac35863aba918641eecb7d12cc55b858bfcaed15e330d6fc47c42e76a13e6671758d8f665aaea876191f51f335b48d1fca47dc3dbaf7a357eb3f1946d8b3073b925ba58b7886a68118d3fc5eea83c1650cb5842668f82eb3350efa6ae6f5002bef3c11c3e7f368489c5a93dec16b93817778941626f6ae7a14c6ce4e5512664b23845e0df4bb76aceb20931765106fdaefb0f749a5fee20cfe467b87dccc73dc66b652cf63ce97e8470b195ed7aec14a7c154f2a3563b8f5b3db7992499dc9795217be05148a21468b204cd025ead1cc1e4144728c9e910140d1d04225df4632fa71604bec728117791d4742c1e1006a0604601942f5852de872fef382378676f59fe6d704d1bd07b7ad0c797b6da17bd39d8b66f90d95d913d46686c3ce881c9136efe0445b1e87c2eb8cb2283532e617cf6a0c5f40fdff1fc25b8372c9d46295934a48ecb5d8a6bd5388b76a984d20a1934823501cc85b0b453bc8aa5a6f19502ca788f4ae5219e6470fd9cfc75a244cf2923cd05e1d9da40f21bdf3bbdeb4647cc82f5988d365dc2b4ae331db8e504cca746092c63f1e305b027e707c38e13c66f5d90553717f9f41cc2624d0c2cfbf814a2355d1e9dfeb06cee67b132425b4d0ec68bdc0fb058ce6c444fdd284995349379a2a17739f0859b7ce24e9b681aac2a78b5b65790aa0dc83aacc6607b15acbafcf7bf943cd3826ea64c765c6943fdbb11853abad1aa92aca6f34c0dd2002fac9f4293dc9cd776d882ccb6e1bc02eb1294e99a0cfadf3923fd9798927aa9754e0cc573ee57a20df72b08fd571ee093fac1cb074b9cc90d10ee909031fe0f3c0cd85f31871b7527d653f143cd71c2084c8a9d8354d98ca9e138eb9e813bb90bd71e58880f5b03da49218e77afc3a8802ae80770490233478c9ff149d1eda00df6af91a57f022e158d23f29c058c9183ee39c6dd86fdbdccc81851ad136fc2813c639e8b367dee11d7eb3efe8f57852f2629cdaa1586fd47150c8ecca8d1ac9cfbef23d2489a0cc515154a09b35717d029a5e7ff14d3969692281c71ebc1f8e21b6f77d724bfa60d75d3a77a54ff3043edf1339bc53fa4c2279c3068a47f8d57dea5481c6c1a3aea9938972dc00bf8b637dab25e7b01cffccce70ff15896e38bb160266370e58c61518b4de88ffa121d6f0c0c757c2585f89f456756176fcd2c18852b43231f9f3c439a338ba8052d1a498d92b9f329610f4a636abc3bec7e895b6244c2c013a1cb9c2661ea1679f2fcb931ab9ffc7d04674144a2012ecda09272d6bb83fe039cd472cd059d734137cc2cf017b1177a63b1c2db74c4b5a6ae9f65524b090c6857bfa9f05960b8dcbc6d4d340064ea6079cba74961dcb6a0f00b0de01863574158bc424cd3dcf14f43b067b3584aef99d5c4cd7831ed3e8608f3f31045c4c37d6b408f32d4590fef6435036164632698c880d22577bb1c521e01e96a57c5780665d97eb8c1b472f3a00c04362ce6f72bd9250958ed6970d411c38d616d90cdda53ab2a5621ad318cb5e23f923426c15c8dcf55d7f54a516fb0bf61fbca1e73ceb9d13742a200fa92bc06fdf8027f7fda8549cbc3f837cbf53f249225e2b7d11bb45f79ac946f9e236da16e080338bc0ec5cee88691dd9e5ea54c6079c325801e0ccc980443b652d8971bca1fd253f078da4390eef90d975460a1300a92936a2097b3529e3316efcc11b398ca5ca7128431f438b4756ca3f690844a4ebbc133f8ebcf030ad7839daebd8e9a10724754fb5d4ae289a9637932ae3dafc5b8d6017648305b1eb4d43b16e58eae02fb9501a56ba23f0c27bc9a800120b018cc69f1a070da2936a5af9cd25ba1aa64eae66b218c8964f2b38c371c8a25c04a353d228fc59f08602fbf74a98e61ba3d2a34a844bc829d5f1ee1eaf1bb1cacca386496e22eaf171f1145695f759062f9fa254c5d8c103ff26f1cd73b1c7fd0ced091c917cb63d2fc98ff2e1437b802fd60d6d72b146b695dc93d646913bb9ffc763d604ec61fa733aefd5f14c465cb1ac85a6a1bbc34fc2204876b76c631725690155eaa5d8f07648f22fe954b3b121c56046c24e99e3ab5b2bf10dbd85505d8f55a1cf985ecdf4a42b6d031ea322ac969f86acc6d3a8ba3f5361b6e05b86374bd43d707293c27993a5ac7595a0d5348332dc13c6b651b4a859702844cbded3c6bd35aa67c8fdfc4e913a8b8615ce28129aecf3217ecc4c2bfc48607b650c47bec3365e1af941b9046958b7c8b64bf45028760984336b6c27bc044a7ea69385805d089434190f0044d856ad2fbad4965846f59491e37f0256548d82145f571e18090b0fa91","salt":"d2deba0a43769862a0fbd80dd6fc867599706ca644920fe1bc05585f922b518e","nonce":"74e9fa0359646cdfbe86a7ad","version":"eip191-aes256-gcm-hkdf-sha256","preKey":"358718727d4b43422a7719176c09b66f633e52a47ee3879d1e19b85cc362938d"}' ,
verificationProof : 'eip191v2:0xd7f0bc7c3960f84280c1433e27c0110dea4b4af1a8c10f7531b8194625cada9456cb67117154f20e97a3d8764b8e3e276d0e6da44f36c4a89a06da9a76d3821a1c' ,
msgSent : 1 ,
maxMsgPersisted : 1000 ,
profile : {
name : 'Bob The Builder' ,
desc : null ,
picture : '' ,
blockedUsersList : [ ] ,
verificationProof : 'pgpv2:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk9vdaCZDzsIc63rzcLRYhBLvWJU1IWhvs+frC7POwhzre\n' +
'vNwtAAB5dAf/cDGsyD3YabE6iTIhNPDn+hvbHuZUjpNPnnSb+mjrvD/XBNYV\n' +
'ITTHhp3Xy4Kuk19BkgmPO3O5TZHVUXK7IwYJd7uutNJJyLEWZYI9ttfeJ9cY\n' +
'HQM3GjApAHycDkBAn5ZRDtmruyWipeE1II3omDUgChQOnQFoK/jWohoIOUvO\n' +
'zi+0V02z7uIGwgTjBLgOYehD8NloGxTjwaZHMqEN7xbr1mZqy82Aew1Bw+EY\n' +
'+JPMyiKTF6HXHYrJZL1yaNw/T7ukCI8ecGoql04xlOHU+SKUTz+8Kcg4tZQR\n' +
'0pp6Fz9Fy9ROUI8ieu5LytJwQq4c9VkH/SPUvkoODloXc0MbrY59tA==\n' +
'=A3pG\n' +
'-----END PGP SIGNATURE-----\n'
} ,
origin : null ,
name : 'Bob The Builder' ,
about : null ,
profilePicture : '' ,
numMsg : 1 ,
allowedNumMsg : 1000 ,
encryptionType : 'eip191-aes256-gcm-hkdf-sha256' ,
signature : '0xd7f0bc7c3960f84280c1433e27c0110dea4b4af1a8c10f7531b8194625cada9456cb67117154f20e97a3d8764b8e3e276d0e6da44f36c4a89a06da9a76d3821a1c' ,
sigType : 'eip191v2' ,
encryptedPassword : null ,
nftOwner : null ,
linkedListHash : null ,
nfts : null
}
Parameter
Type
Remarks
did
string
user decentralized identity
wallets
string
all wallets associated to the did
publicKey
string
Public PGP key
encryptedPrivateKey
string
Encrypted PGP Private Key
verificationProof
string
Verification proof
msgSent
number
Number of messages sent
maxMsgPersisted
number
Maximum number of messages that can be persisted
profile
object
User profile information
origin
string
Origin information (source of the data)
name
string
Profile Name ( Deprecated )
about
string
Profile Description ( Deprecated )
profilePicture
string
Profile Picture ( Deprecated )
numMsg
number
Number of messages sent ( Deprecated )
allowedNumMsg
number
Maximum number of messages that can be persisted ( Deprecated )
encryptionType
string
Type of encryption used
signature
string
Account signature ( Deprecated )
sigType
string
Type of signature ( Dprecated )
encryptedPassword
null
Encrypted user password ( Deprecated )
nftOwner
null
Owner of NFT ( Deprecated )
linkedListHash
null
Deprecated
nfts
null
Information about owned NFTs( Dprecated )
// Create a Group
const createdGroup = await userAlice . chat . group . create ( groupName , {
description : groupDescription ,
image : groupImage ,
members : [ walletAddress1 , walletAddress2 , walletAddress3 ] ,
admins : [ ] ,
private : false ,
} ) ;
Param
Type
Default
Remarks
name
string
-
The name of the group to be created.
options
*
object
-
Optional Configuration for creating group.
options.description
*
string
-
A description of the group.
options.image
*
string
-
Image for the group.
options.members
*
string[]
[]
An array of member DID.
options.admins
*
string[]
-
An array of admin DID.
options.private
*
boolean
false
Indicates if the group is private.
options.rules.entry.conditions
*
any[]
-
Conditions for entry to the group.
options.rules.chat.conditions
*
any[]
-
Conditions for chat within the group.
* - Optional
Expected response
{
members : [
{
wallet : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADeYpZfxgn1HoMUuWM42v8ZWfLPwglQYmzz5rY3PdPPoRFU\n' +
'v0AyPjYKpmLh2ZNfXjPaS9GuMdpXaomYSEwsV02hXZOQelo9cLop0Fc2i+l7\n' +
'70rYhePuOuQ+XD/xYzhngAgNJ9rX96YnSodldb8uJfxYmgoF0E9Z2o2fgZGj\n' +
'll2CPnOaLXZaBQlPS3x/461TmZ1n2ZePS/fwiC7taLz3PtyGtKaC0vo4isvI\n' +
'yf04fkjudG0XIns5CWjdR2HeDC8BzSl8OVj8AQAc5uVU8Abk+ejWVr4zfoox\n' +
'eaziDPgGdkckFiQ6Tdsg0tPwwOpSrCCtJocTmc/fWaBb0YlnyAAL88fJABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZBMYqhmfI2WQQMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAACxNQf/UrM/whR7vCs+\n' +
'ez8Y8Hz4WqIuXtfMh4l2nKVv5UUuAfQkBxEY5j6Ga2+JgKU3neQ34x/v6fm9\n' +
'CLcY38Tc4AWyEx8KC78J+xOs7RMfyNBeiaf8KdaFfQrP0nMmufE6TxkfV1Y5\n' +
'LJZZ8350rZVtYJppWtlH+gbyUmMObyWDWbL3aWtqa3xjv0kLsf7TnugiFwzB\n' +
'gHHtk8tlDSOxRt0VdNNd19+/zrBYNl07Ig24WD2ETaJiaqa651z24/6/MkGT\n' +
'MBoQh+679tuWWcTrNi4jIA8jhSQ5BOgbAapl3qXk0m9/Aexpe2s6ISLXe8YJ\n' +
'j4cObDLv/ZKKeLZYTq9lVCydLAQUbs7ATQRk7zWYAQgAmx36uefgUF4cCSYH\n' +
'WMWAOTyc8Awo+hxn6FktOLU1+9hfGrX2jwGLOoOwjNgbYJbiSvRglAX2b57/\n' +
'qkkltAg1ZYCLSUzfBUbbWYlJNBwpv7+52zHaLUZ3gmI5aE48ad+uzaadgpVT\n' +
'VqLbhdgkN6jkemPTlfMehyS49AAbmqeKfo2U72tm9ZqT2cPVCASMjN/Ux2qG\n' +
'3W8HTo0KIVFSbkTthl1zAlwAFksp0q437+pxbdJIecJ9mO6N4OQMnv+hVBDc\n' +
'WrPqBDJ0nas4JNgLxmLv0pheGg/TEfwS/p6xGRW5m08bj2l0cgqmEaM27jbi\n' +
'DEpOykRWsDMhheEfI2zV/Qam8QARAQABwsB2BBgBCAAqBYJk7zWYCZBMYqhm\n' +
'fI2WQQKbDBYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAAAnBggA1gkIopr9HJFP\n' +
'fO5SebcbowH4AG9M0qBqF4h1JIKbqvOnxLSsC5QmmzFcjS9ihyHBvzbRVGkC\n' +
'zEHYpLRedQ2AmQQfsf/VOoZJEOlb7tTk4+SpYtsGte5X/yLT5Bkls7Rp8ubK\n' +
'/V99muj1nA/OkasllXQUSGEweVz6ejzJ0oMm3Vewmw8PelsdAnfS7Ud1MnXQ\n' +
'h+O8TCR56F5gAMWxZmxFpZMZyUFOH6KM+vL7HJUBztUS2g0ELsHKy9ep2yhv\n' +
'iABIwx/gEuPr0NDAH9x9XFKg5m3rO64KTY4BRWBISwmQ25dM1s1bwDPLi5XI\n' +
'6Daw1glFxpPRrxgQGlVLzJOu5b8swQ==\n' +
'=9hCc\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0x119bb8ad40B1f94e2b30ae5f59eeaEB67cD0Bd6C' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0x6e0C509d14EbF26A529bf6DC5CC9bee7F5b8DBa4' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0xE3FDD0527a9F8418f9a7D9e970452827FbE202FF' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADouo4S2kPqA//+I7nDAk15/LcJ2TGvDhOYuPNUNMiNGOb4\n' +
'txusuKz6HOaG+K9hiUBpHjKrYEmCT2FEXxt8bfS3SpWb74RHSkWUNUkxk25y\n' +
'gE5gaCKyAdcnOUyVLmobVFFYtH6naK9bULaUtkVik1P0iuEevWHxtTpsjbyH\n' +
'bZtNpVTdprdLib4Wx6bb7VogsvjlvNJcVJ4sfPE0XgsQgAGIev7yJyU0DGzt\n' +
'/EbvFX4sv51Kb1dX9ctBcvzVbs9+qT6LTivsrQp+TNHUN4zEeMhnWFFP5K1d\n' +
'H445S6FWk53XvBudcOkFPtltU1MPCS6hmhevArBfYzy5eSlaKA/fH+kFABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZCrD2gy8Zu4awMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBKru9/u8wPcTeHibkasPaDLxm7hrAADa/Af+PbamVg/Ig2S2\n' +
'HgIy4w5x7ulSk1/49+AmuiUMiVUwJSVBhROsyDbLET56w4+1TIMYZFJaczW3\n' +
'8tCvAOUSauzc52I3zwGmaCupBJokIWp7ncPh0B8TFYrgThgXV7sLf3xy4roy\n' +
'y8oFz1Zla88krwtPe4Az7TF+WNdXoDsLNJ3GXRmNqs1GITmDqAXFWncl12NM\n' +
'ajUKWIKc/Gi1oKfz22mabJTtWBimDpA12LaGK3GjEK5CiWXT3Tzlqn6R14EZ\n' +
'6ohpKZldSJiMPL0Bu9iT52iHOsw1wTZNC1L5lKhOCi3c+/fLRcJZt3hdCjqy\n' +
'd/FSCa8/Ny/GrHBWoL49rSF4pDEA+s7ATQRk7zWYAQgAtNOoHCL7BCnjwp8O\n' +
'htTxEI5r7Q/1zKKHiz6QKjjrGBYyR6gcmPM3JNEcvzY4OsCFnKBv2suOgrqH\n' +
'8kXJzfpIQ7u7uJs+O3p/cn86RMANiEnO8NbB/0scpfZ7Vg3eOfoiWYE4I/1o\n' +
'FVDCyZ1YVqtbcmuW6D8i1djjeoUmkUDZyPo7Qs6hUsJeYA/Rfl8mH5sjy2cN\n' +
'WXf8cEtOUqJtwERXt5aRB/nBZiC0bsP6hf0HtAoNA8/96TkqrcQpODW/RckD\n' +
'fo4wkpEONHRH+LGX7GV0pwymHu42TUnULmED6BrMgMYG2sKpxMThxtAxRaiP\n' +
'nZ3DKXr8GCjTYnbEZpoi2zKCOQARAQABwsB2BBgBCAAqBYJk7zWYCZCrD2gy\n' +
'8Zu4awKbDBYhBKru9/u8wPcTeHibkasPaDLxm7hrAADGyQgA5NMUkoyDTPZa\n' +
'Znj1dB+17xBXCZ/u7pPQc1DukBefVke7/qYIicdnnEGIX3Zd7TckFRsDljR/\n' +
'3418Bne4WyL57fAF/GgYsegpJ9n1KT7oPxWzibIaYdj7R6bkDt5r61EDWC3N\n' +
'VBbnZu9cO15TYkObJIiyNvwbQyd6Dm313b39GnEE8sM709TWsI6Es6rRZAfC\n' +
'+sI8ezYxqVUbP7sW3jJZYzdPOhZPHvFd5iJ2EfygEOuk5tb7AimfNwF/CNcB\n' +
'weQGEU7feOSB9lXXA+Ag1duLM4B9bLbbHEQIPhKlBF1ED64e/W/5HNfoAkS4\n' +
'qhzOD5XWs6xs45nnYqUbBFLG9Xk+Jg==\n' +
'=qtAv\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7zWZCZBMYqhmfI2WQRYhBC9DyzhpX3ACb/yTq0xiqGZ8\n' +
'jZZBAADwAwgAq/6WjtwRt1aPTLWwtSx80Ng/Wxf97dkpebMXSj9T7f5ia1rM\n' +
'8wqsuNUDMEMPB9LM34f6Q5pD994oeN2YT7z34u20mskiNphZdx/DNvu8w9UZ\n' +
'rI3tyjfZULhARNVM34sSABnHtExbl4ZArhNDsT86ku0sZNjr9frn2mtgmlKN\n' +
'nQdGcLJSxbci0hFg3nE5mYNpwZNs2S/2uk11WHKxzMhII6AdePE77BKPqedu\n' +
'PiXDODO2dIvV8glLQoJPRPgc2ap+/xYIBUFljqHGPU/62VSLlHxBJv72p5s/\n' +
'kOxiqD42TmpaaMtfudqgsZsGoYpZDHcMKYGNZs+9qVRHPRD+s0QhEA==\n' +
'=c6IF\n' +
'-----END PGP SIGNATURE-----\n' ,
groupImage : '' ,
groupName : 'influential_maroon_gamefowl' ,
groupDescription : 'urgent_brown_butterfly' ,
isPublic : false ,
groupCreator : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
chatId : '5f769c881ffe328117dea3d3acd0b97ce7f4c163e440f75a96be3e33f7d2a000' ,
meta : null ,
scheduleAt : null ,
scheduleEnd : null ,
groupType : 'default' ,
status : null ,
rules : { } ,
eventType : 'create'
}
Parameter
Type
Remarks
members
Array<Object>
An array containing member objects.
members.wallet
string
The wallet address of the member.
members.publicKey
string
The member's public PGP key (if available).
members.isAdmin
boolean
Indicates whether the member is an admin.
members.image
string
Image associated with the member.
pendingMembers
Array<Object>
An array containing pending member objects.
pendingMembers.wallet
string
The wallet address of the pending member.
pendingMembers.publicKey
string
The pending member's public PGP key (if available).
pendingMembers.isAdmin
boolean
Indicates whether the pending member is an admin.
pendingMembers.image
string
Image associated with the pending member.
contractAddressERC20
string
or null
Contract address for ERC20 tokens (Used for tokenGating).
numberOfERC20
number
The number of ERC20 tokens associated. (Used for tokenGating).
contractAddressNFT
string
or null
Contract address for NFT tokens (Used for tokenGating)
numberOfNFTTokens
number
The number of NFT tokens associated. (Used for tokenGating)
verificationProof
string
Verification proof associated with group data.
groupImage
string
Group's image.
groupName
string
The name of the group.
groupDescription
string
Description of the group.
isPublic
boolean
Indicates whether the group is public or private.
groupCreator
string
Push Profile DID of the group creator.
chatId
string
Unique chat ID associated with the group.
meta
object
or null
Additional metadata (if available).
scheduleAt
timestamp
or null
Scheduled start time (if available).
scheduleEnd
timestamp
or null
Scheduled end time (if available).
groupType
string
Type of the group (default, spaces, live etc).
status
string
or null
Status information ( active, expired etc)
rules
Object
Group-specific moderation rules
eventType
string
The type of event (create, update etc)
// Fetch Group Info
const fetchGroupInfo = await userAlice . chat . group . info ( groupChatId ) ;
Param
Type
Default
Remarks
chatId
string
-
Group ChatId
// Fetch Group Permissions
const fetchGroupPermissions = await userAlice . chat . group . permissions (
groupChatId
) ;
Param
Type
Default
Remarks
chatId
string
-
Group ChatId
Expected response
{
entry : true ,
chat : true ,
rules : { entry : { conditions : [ ] } , chat : { conditions : [ ] } }
}
Param
Type
Remarks
entry
boolean
Refers if the Profile has access to enter the group
chat
boolean
Refers if the Profile has access to chat in the group
rules
object
Moderation rules of the group
// Update Group Info
const createdGroup = await userAlice . chat . group . create ( groupChatId , {
description : newGroupDescription ,
image : newGroupImage ,
} ) ;
Param
Type
Default
Remarks
chatId
string
-
Unique identifier of the group.
options
*
object
-
Optional Configuration for updating group.
options.name
*
string
-
Updated Group Name
options.description
*
string
-
Updated Description
options.image
*
string
-
Updated Image
options.scheduleAt
*
date
or null
-
Updated Start Schedule
options.scheduleEnd
*
date
or null
-
Updated End Schedule
options.status
*
string
or null
-
Updated group Status
options.meta
*
object
or null
-
Updated Group Meta
options.rules
*
object
-
Updated Group Moderation Rules
* - Optional
Expected response
{
members : [
{
wallet : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADeYpZfxgn1HoMUuWM42v8ZWfLPwglQYmzz5rY3PdPPoRFU\n' +
'v0AyPjYKpmLh2ZNfXjPaS9GuMdpXaomYSEwsV02hXZOQelo9cLop0Fc2i+l7\n' +
'70rYhePuOuQ+XD/xYzhngAgNJ9rX96YnSodldb8uJfxYmgoF0E9Z2o2fgZGj\n' +
'll2CPnOaLXZaBQlPS3x/461TmZ1n2ZePS/fwiC7taLz3PtyGtKaC0vo4isvI\n' +
'yf04fkjudG0XIns5CWjdR2HeDC8BzSl8OVj8AQAc5uVU8Abk+ejWVr4zfoox\n' +
'eaziDPgGdkckFiQ6Tdsg0tPwwOpSrCCtJocTmc/fWaBb0YlnyAAL88fJABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZBMYqhmfI2WQQMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAACxNQf/UrM/whR7vCs+\n' +
'ez8Y8Hz4WqIuXtfMh4l2nKVv5UUuAfQkBxEY5j6Ga2+JgKU3neQ34x/v6fm9\n' +
'CLcY38Tc4AWyEx8KC78J+xOs7RMfyNBeiaf8KdaFfQrP0nMmufE6TxkfV1Y5\n' +
'LJZZ8350rZVtYJppWtlH+gbyUmMObyWDWbL3aWtqa3xjv0kLsf7TnugiFwzB\n' +
'gHHtk8tlDSOxRt0VdNNd19+/zrBYNl07Ig24WD2ETaJiaqa651z24/6/MkGT\n' +
'MBoQh+679tuWWcTrNi4jIA8jhSQ5BOgbAapl3qXk0m9/Aexpe2s6ISLXe8YJ\n' +
'j4cObDLv/ZKKeLZYTq9lVCydLAQUbs7ATQRk7zWYAQgAmx36uefgUF4cCSYH\n' +
'WMWAOTyc8Awo+hxn6FktOLU1+9hfGrX2jwGLOoOwjNgbYJbiSvRglAX2b57/\n' +
'qkkltAg1ZYCLSUzfBUbbWYlJNBwpv7+52zHaLUZ3gmI5aE48ad+uzaadgpVT\n' +
'VqLbhdgkN6jkemPTlfMehyS49AAbmqeKfo2U72tm9ZqT2cPVCASMjN/Ux2qG\n' +
'3W8HTo0KIVFSbkTthl1zAlwAFksp0q437+pxbdJIecJ9mO6N4OQMnv+hVBDc\n' +
'WrPqBDJ0nas4JNgLxmLv0pheGg/TEfwS/p6xGRW5m08bj2l0cgqmEaM27jbi\n' +
'DEpOykRWsDMhheEfI2zV/Qam8QARAQABwsB2BBgBCAAqBYJk7zWYCZBMYqhm\n' +
'fI2WQQKbDBYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAAAnBggA1gkIopr9HJFP\n' +
'fO5SebcbowH4AG9M0qBqF4h1JIKbqvOnxLSsC5QmmzFcjS9ihyHBvzbRVGkC\n' +
'zEHYpLRedQ2AmQQfsf/VOoZJEOlb7tTk4+SpYtsGte5X/yLT5Bkls7Rp8ubK\n' +
'/V99muj1nA/OkasllXQUSGEweVz6ejzJ0oMm3Vewmw8PelsdAnfS7Ud1MnXQ\n' +
'h+O8TCR56F5gAMWxZmxFpZMZyUFOH6KM+vL7HJUBztUS2g0ELsHKy9ep2yhv\n' +
'iABIwx/gEuPr0NDAH9x9XFKg5m3rO64KTY4BRWBISwmQ25dM1s1bwDPLi5XI\n' +
'6Daw1glFxpPRrxgQGlVLzJOu5b8swQ==\n' +
'=9hCc\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0x119bb8ad40B1f94e2b30ae5f59eeaEB67cD0Bd6C' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0x6e0C509d14EbF26A529bf6DC5CC9bee7F5b8DBa4' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0xE3FDD0527a9F8418f9a7D9e970452827FbE202FF' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADouo4S2kPqA//+I7nDAk15/LcJ2TGvDhOYuPNUNMiNGOb4\n' +
'txusuKz6HOaG+K9hiUBpHjKrYEmCT2FEXxt8bfS3SpWb74RHSkWUNUkxk25y\n' +
'gE5gaCKyAdcnOUyVLmobVFFYtH6naK9bULaUtkVik1P0iuEevWHxtTpsjbyH\n' +
'bZtNpVTdprdLib4Wx6bb7VogsvjlvNJcVJ4sfPE0XgsQgAGIev7yJyU0DGzt\n' +
'/EbvFX4sv51Kb1dX9ctBcvzVbs9+qT6LTivsrQp+TNHUN4zEeMhnWFFP5K1d\n' +
'H445S6FWk53XvBudcOkFPtltU1MPCS6hmhevArBfYzy5eSlaKA/fH+kFABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZCrD2gy8Zu4awMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBKru9/u8wPcTeHibkasPaDLxm7hrAADa/Af+PbamVg/Ig2S2\n' +
'HgIy4w5x7ulSk1/49+AmuiUMiVUwJSVBhROsyDbLET56w4+1TIMYZFJaczW3\n' +
'8tCvAOUSauzc52I3zwGmaCupBJokIWp7ncPh0B8TFYrgThgXV7sLf3xy4roy\n' +
'y8oFz1Zla88krwtPe4Az7TF+WNdXoDsLNJ3GXRmNqs1GITmDqAXFWncl12NM\n' +
'ajUKWIKc/Gi1oKfz22mabJTtWBimDpA12LaGK3GjEK5CiWXT3Tzlqn6R14EZ\n' +
'6ohpKZldSJiMPL0Bu9iT52iHOsw1wTZNC1L5lKhOCi3c+/fLRcJZt3hdCjqy\n' +
'd/FSCa8/Ny/GrHBWoL49rSF4pDEA+s7ATQRk7zWYAQgAtNOoHCL7BCnjwp8O\n' +
'htTxEI5r7Q/1zKKHiz6QKjjrGBYyR6gcmPM3JNEcvzY4OsCFnKBv2suOgrqH\n' +
'8kXJzfpIQ7u7uJs+O3p/cn86RMANiEnO8NbB/0scpfZ7Vg3eOfoiWYE4I/1o\n' +
'FVDCyZ1YVqtbcmuW6D8i1djjeoUmkUDZyPo7Qs6hUsJeYA/Rfl8mH5sjy2cN\n' +
'WXf8cEtOUqJtwERXt5aRB/nBZiC0bsP6hf0HtAoNA8/96TkqrcQpODW/RckD\n' +
'fo4wkpEONHRH+LGX7GV0pwymHu42TUnULmED6BrMgMYG2sKpxMThxtAxRaiP\n' +
'nZ3DKXr8GCjTYnbEZpoi2zKCOQARAQABwsB2BBgBCAAqBYJk7zWYCZCrD2gy\n' +
'8Zu4awKbDBYhBKru9/u8wPcTeHibkasPaDLxm7hrAADGyQgA5NMUkoyDTPZa\n' +
'Znj1dB+17xBXCZ/u7pPQc1DukBefVke7/qYIicdnnEGIX3Zd7TckFRsDljR/\n' +
'3418Bne4WyL57fAF/GgYsegpJ9n1KT7oPxWzibIaYdj7R6bkDt5r61EDWC3N\n' +
'VBbnZu9cO15TYkObJIiyNvwbQyd6Dm313b39GnEE8sM709TWsI6Es6rRZAfC\n' +
'+sI8ezYxqVUbP7sW3jJZYzdPOhZPHvFd5iJ2EfygEOuk5tb7AimfNwF/CNcB\n' +
'weQGEU7feOSB9lXXA+Ag1duLM4B9bLbbHEQIPhKlBF1ED64e/W/5HNfoAkS4\n' +
'qhzOD5XWs6xs45nnYqUbBFLG9Xk+Jg==\n' +
'=qtAv\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7zWZCZBMYqhmfI2WQRYhBC9DyzhpX3ACb/yTq0xiqGZ8\n' +
'jZZBAADwAwgAq/6WjtwRt1aPTLWwtSx80Ng/Wxf97dkpebMXSj9T7f5ia1rM\n' +
'8wqsuNUDMEMPB9LM34f6Q5pD994oeN2YT7z34u20mskiNphZdx/DNvu8w9UZ\n' +
'rI3tyjfZULhARNVM34sSABnHtExbl4ZArhNDsT86ku0sZNjr9frn2mtgmlKN\n' +
'nQdGcLJSxbci0hFg3nE5mYNpwZNs2S/2uk11WHKxzMhII6AdePE77BKPqedu\n' +
'PiXDODO2dIvV8glLQoJPRPgc2ap+/xYIBUFljqHGPU/62VSLlHxBJv72p5s/\n' +
'kOxiqD42TmpaaMtfudqgsZsGoYpZDHcMKYGNZs+9qVRHPRD+s0QhEA==\n' +
'=c6IF\n' +
'-----END PGP SIGNATURE-----\n' ,
groupImage : '' ,
groupName : 'influential_maroon_gamefowl' ,
groupDescription : 'urgent_brown_butterfly' ,
isPublic : false ,
groupCreator : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
chatId : '5f769c881ffe328117dea3d3acd0b97ce7f4c163e440f75a96be3e33f7d2a000' ,
meta : null ,
scheduleAt : null ,
scheduleEnd : null ,
groupType : 'default' ,
status : null ,
rules : { } ,
eventType : 'update'
}
Parameter
Type
Remarks
members
Array<Object>
An array containing member objects.
members.wallet
string
The wallet address of the member.
members.publicKey
string
The member's public PGP key (if available).
members.isAdmin
boolean
Indicates whether the member is an admin.
members.image
string
Image associated with the member.
pendingMembers
Array<Object>
An array containing pending member objects.
pendingMembers.wallet
string
The wallet address of the pending member.
pendingMembers.publicKey
string
The pending member's public PGP key (if available).
pendingMembers.isAdmin
boolean
Indicates whether the pending member is an admin.
pendingMembers.image
string
Image associated with the pending member.
contractAddressERC20
string
or null
Contract address for ERC20 tokens (Used for tokenGating).
numberOfERC20
number
The number of ERC20 tokens associated. (Used for tokenGating).
contractAddressNFT
string
or null
Contract address for NFT tokens (Used for tokenGating)
numberOfNFTTokens
number
The number of NFT tokens associated. (Used for tokenGating)
verificationProof
string
Verification proof associated with group data.
groupImage
string
Group's image.
groupName
string
The name of the group.
groupDescription
string
Description of the group.
isPublic
boolean
Indicates whether the group is public or private.
groupCreator
string
Push Profile DID of the group creator.
chatId
string
Unique chat ID associated with the group.
meta
object
or null
Additional metadata (if available).
scheduleAt
timestamp
or null
Scheduled start time (if available).
scheduleEnd
timestamp
or null
Scheduled end time (if available).
groupType
string
Type of the group (default, spaces, live etc).
status
string
or null
Status information ( active, expired etc)
rules
Object
Group-specific moderation rules
eventType
string
The type of event (create, update etc)
// Add Member To Group
const addMemberToGroup = await userAlice . chat . group . add ( groupChatId , {
role : 'MEMBER'
accounts : [ account1 , account2 ]
} ) ;
// Add Admin To Group
const addAdminToGroup = await userAlice . chat . group . add ( groupChatId , {
role : 'ADMIN'
accounts : [ account1 , account2 ]
} ) ;
Param
Type
Default
Remarks
chatId
string
-
Unique identifier of the group.
options
object
-
Configuration for adding participants to group.
options.role
ADMIN
or MEMBER
-
Role of added participant
options.accounts
string[]
-
Added participant addresses
Expected response
{
members : [
{
wallet : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADeYpZfxgn1HoMUuWM42v8ZWfLPwglQYmzz5rY3PdPPoRFU\n' +
'v0AyPjYKpmLh2ZNfXjPaS9GuMdpXaomYSEwsV02hXZOQelo9cLop0Fc2i+l7\n' +
'70rYhePuOuQ+XD/xYzhngAgNJ9rX96YnSodldb8uJfxYmgoF0E9Z2o2fgZGj\n' +
'll2CPnOaLXZaBQlPS3x/461TmZ1n2ZePS/fwiC7taLz3PtyGtKaC0vo4isvI\n' +
'yf04fkjudG0XIns5CWjdR2HeDC8BzSl8OVj8AQAc5uVU8Abk+ejWVr4zfoox\n' +
'eaziDPgGdkckFiQ6Tdsg0tPwwOpSrCCtJocTmc/fWaBb0YlnyAAL88fJABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZBMYqhmfI2WQQMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAACxNQf/UrM/whR7vCs+\n' +
'ez8Y8Hz4WqIuXtfMh4l2nKVv5UUuAfQkBxEY5j6Ga2+JgKU3neQ34x/v6fm9\n' +
'CLcY38Tc4AWyEx8KC78J+xOs7RMfyNBeiaf8KdaFfQrP0nMmufE6TxkfV1Y5\n' +
'LJZZ8350rZVtYJppWtlH+gbyUmMObyWDWbL3aWtqa3xjv0kLsf7TnugiFwzB\n' +
'gHHtk8tlDSOxRt0VdNNd19+/zrBYNl07Ig24WD2ETaJiaqa651z24/6/MkGT\n' +
'MBoQh+679tuWWcTrNi4jIA8jhSQ5BOgbAapl3qXk0m9/Aexpe2s6ISLXe8YJ\n' +
'j4cObDLv/ZKKeLZYTq9lVCydLAQUbs7ATQRk7zWYAQgAmx36uefgUF4cCSYH\n' +
'WMWAOTyc8Awo+hxn6FktOLU1+9hfGrX2jwGLOoOwjNgbYJbiSvRglAX2b57/\n' +
'qkkltAg1ZYCLSUzfBUbbWYlJNBwpv7+52zHaLUZ3gmI5aE48ad+uzaadgpVT\n' +
'VqLbhdgkN6jkemPTlfMehyS49AAbmqeKfo2U72tm9ZqT2cPVCASMjN/Ux2qG\n' +
'3W8HTo0KIVFSbkTthl1zAlwAFksp0q437+pxbdJIecJ9mO6N4OQMnv+hVBDc\n' +
'WrPqBDJ0nas4JNgLxmLv0pheGg/TEfwS/p6xGRW5m08bj2l0cgqmEaM27jbi\n' +
'DEpOykRWsDMhheEfI2zV/Qam8QARAQABwsB2BBgBCAAqBYJk7zWYCZBMYqhm\n' +
'fI2WQQKbDBYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAAAnBggA1gkIopr9HJFP\n' +
'fO5SebcbowH4AG9M0qBqF4h1JIKbqvOnxLSsC5QmmzFcjS9ihyHBvzbRVGkC\n' +
'zEHYpLRedQ2AmQQfsf/VOoZJEOlb7tTk4+SpYtsGte5X/yLT5Bkls7Rp8ubK\n' +
'/V99muj1nA/OkasllXQUSGEweVz6ejzJ0oMm3Vewmw8PelsdAnfS7Ud1MnXQ\n' +
'h+O8TCR56F5gAMWxZmxFpZMZyUFOH6KM+vL7HJUBztUS2g0ELsHKy9ep2yhv\n' +
'iABIwx/gEuPr0NDAH9x9XFKg5m3rO64KTY4BRWBISwmQ25dM1s1bwDPLi5XI\n' +
'6Daw1glFxpPRrxgQGlVLzJOu5b8swQ==\n' +
'=9hCc\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0x119bb8ad40B1f94e2b30ae5f59eeaEB67cD0Bd6C' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0x6e0C509d14EbF26A529bf6DC5CC9bee7F5b8DBa4' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0xE3FDD0527a9F8418f9a7D9e970452827FbE202FF' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADouo4S2kPqA//+I7nDAk15/LcJ2TGvDhOYuPNUNMiNGOb4\n' +
'txusuKz6HOaG+K9hiUBpHjKrYEmCT2FEXxt8bfS3SpWb74RHSkWUNUkxk25y\n' +
'gE5gaCKyAdcnOUyVLmobVFFYtH6naK9bULaUtkVik1P0iuEevWHxtTpsjbyH\n' +
'bZtNpVTdprdLib4Wx6bb7VogsvjlvNJcVJ4sfPE0XgsQgAGIev7yJyU0DGzt\n' +
'/EbvFX4sv51Kb1dX9ctBcvzVbs9+qT6LTivsrQp+TNHUN4zEeMhnWFFP5K1d\n' +
'H445S6FWk53XvBudcOkFPtltU1MPCS6hmhevArBfYzy5eSlaKA/fH+kFABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZCrD2gy8Zu4awMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBKru9/u8wPcTeHibkasPaDLxm7hrAADa/Af+PbamVg/Ig2S2\n' +
'HgIy4w5x7ulSk1/49+AmuiUMiVUwJSVBhROsyDbLET56w4+1TIMYZFJaczW3\n' +
'8tCvAOUSauzc52I3zwGmaCupBJokIWp7ncPh0B8TFYrgThgXV7sLf3xy4roy\n' +
'y8oFz1Zla88krwtPe4Az7TF+WNdXoDsLNJ3GXRmNqs1GITmDqAXFWncl12NM\n' +
'ajUKWIKc/Gi1oKfz22mabJTtWBimDpA12LaGK3GjEK5CiWXT3Tzlqn6R14EZ\n' +
'6ohpKZldSJiMPL0Bu9iT52iHOsw1wTZNC1L5lKhOCi3c+/fLRcJZt3hdCjqy\n' +
'd/FSCa8/Ny/GrHBWoL49rSF4pDEA+s7ATQRk7zWYAQgAtNOoHCL7BCnjwp8O\n' +
'htTxEI5r7Q/1zKKHiz6QKjjrGBYyR6gcmPM3JNEcvzY4OsCFnKBv2suOgrqH\n' +
'8kXJzfpIQ7u7uJs+O3p/cn86RMANiEnO8NbB/0scpfZ7Vg3eOfoiWYE4I/1o\n' +
'FVDCyZ1YVqtbcmuW6D8i1djjeoUmkUDZyPo7Qs6hUsJeYA/Rfl8mH5sjy2cN\n' +
'WXf8cEtOUqJtwERXt5aRB/nBZiC0bsP6hf0HtAoNA8/96TkqrcQpODW/RckD\n' +
'fo4wkpEONHRH+LGX7GV0pwymHu42TUnULmED6BrMgMYG2sKpxMThxtAxRaiP\n' +
'nZ3DKXr8GCjTYnbEZpoi2zKCOQARAQABwsB2BBgBCAAqBYJk7zWYCZCrD2gy\n' +
'8Zu4awKbDBYhBKru9/u8wPcTeHibkasPaDLxm7hrAADGyQgA5NMUkoyDTPZa\n' +
'Znj1dB+17xBXCZ/u7pPQc1DukBefVke7/qYIicdnnEGIX3Zd7TckFRsDljR/\n' +
'3418Bne4WyL57fAF/GgYsegpJ9n1KT7oPxWzibIaYdj7R6bkDt5r61EDWC3N\n' +
'VBbnZu9cO15TYkObJIiyNvwbQyd6Dm313b39GnEE8sM709TWsI6Es6rRZAfC\n' +
'+sI8ezYxqVUbP7sW3jJZYzdPOhZPHvFd5iJ2EfygEOuk5tb7AimfNwF/CNcB\n' +
'weQGEU7feOSB9lXXA+Ag1duLM4B9bLbbHEQIPhKlBF1ED64e/W/5HNfoAkS4\n' +
'qhzOD5XWs6xs45nnYqUbBFLG9Xk+Jg==\n' +
'=qtAv\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7zWZCZBMYqhmfI2WQRYhBC9DyzhpX3ACb/yTq0xiqGZ8\n' +
'jZZBAADwAwgAq/6WjtwRt1aPTLWwtSx80Ng/Wxf97dkpebMXSj9T7f5ia1rM\n' +
'8wqsuNUDMEMPB9LM34f6Q5pD994oeN2YT7z34u20mskiNphZdx/DNvu8w9UZ\n' +
'rI3tyjfZULhARNVM34sSABnHtExbl4ZArhNDsT86ku0sZNjr9frn2mtgmlKN\n' +
'nQdGcLJSxbci0hFg3nE5mYNpwZNs2S/2uk11WHKxzMhII6AdePE77BKPqedu\n' +
'PiXDODO2dIvV8glLQoJPRPgc2ap+/xYIBUFljqHGPU/62VSLlHxBJv72p5s/\n' +
'kOxiqD42TmpaaMtfudqgsZsGoYpZDHcMKYGNZs+9qVRHPRD+s0QhEA==\n' +
'=c6IF\n' +
'-----END PGP SIGNATURE-----\n' ,
groupImage : '' ,
groupName : 'influential_maroon_gamefowl' ,
groupDescription : 'urgent_brown_butterfly' ,
isPublic : false ,
groupCreator : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
chatId : '5f769c881ffe328117dea3d3acd0b97ce7f4c163e440f75a96be3e33f7d2a000' ,
meta : null ,
scheduleAt : null ,
scheduleEnd : null ,
groupType : 'default' ,
status : null ,
rules : { } ,
eventType : 'update'
}
Parameter
Type
Remarks
members
Array<Object>
An array containing member objects.
members.wallet
string
The wallet address of the member.
members.publicKey
string
The member's public PGP key (if available).
members.isAdmin
boolean
Indicates whether the member is an admin.
members.image
string
Image associated with the member.
pendingMembers
Array<Object>
An array containing pending member objects.
pendingMembers.wallet
string
The wallet address of the pending member.
pendingMembers.publicKey
string
The pending member's public PGP key (if available).
pendingMembers.isAdmin
boolean
Indicates whether the pending member is an admin.
pendingMembers.image
string
Image associated with the pending member.
contractAddressERC20
string
or null
Contract address for ERC20 tokens (Used for tokenGating).
numberOfERC20
number
The number of ERC20 tokens associated. (Used for tokenGating).
contractAddressNFT
string
or null
Contract address for NFT tokens (Used for tokenGating)
numberOfNFTTokens
number
The number of NFT tokens associated. (Used for tokenGating)
verificationProof
string
Verification proof associated with group data.
groupImage
string
Group's image.
groupName
string
The name of the group.
groupDescription
string
Description of the group.
isPublic
boolean
Indicates whether the group is public or private.
groupCreator
string
Push Profile DID of the group creator.
chatId
string
Unique chat ID associated with the group.
meta
object
or null
Additional metadata (if available).
scheduleAt
timestamp
or null
Scheduled start time (if available).
scheduleEnd
timestamp
or null
Scheduled end time (if available).
groupType
string
Type of the group (default, spaces, live etc).
status
string
or null
Status information ( active, expired etc)
rules
Object
Group-specific moderation rules
eventType
string
The type of event (create, update etc)
// Remove Members To Group
const addMemberToGroup = await userAlice . chat . group . remove ( groupChatId , {
role : 'MEMBER'
accounts : [ account1 , account2 ] // these accounts should be a part of group
} ) ;
// Remove Admin To Group
const addAdminToGroup = await userAlice . chat . group . remove ( groupChatId , {
role : 'ADMIN'
accounts : [ account1 , account2 ] // // these accounts should be a part of group
} ) ;
Param
Type
Default
Remarks
chatId
string
-
Unique identifier of the group.
options
object
-
Configuration for adding participants to group.
options.role
ADMIN
or MEMBER
-
Role of added participant
options.accounts
string[]
-
Added participant addresses
Expected response
{
members : [
{
wallet : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADeYpZfxgn1HoMUuWM42v8ZWfLPwglQYmzz5rY3PdPPoRFU\n' +
'v0AyPjYKpmLh2ZNfXjPaS9GuMdpXaomYSEwsV02hXZOQelo9cLop0Fc2i+l7\n' +
'70rYhePuOuQ+XD/xYzhngAgNJ9rX96YnSodldb8uJfxYmgoF0E9Z2o2fgZGj\n' +
'll2CPnOaLXZaBQlPS3x/461TmZ1n2ZePS/fwiC7taLz3PtyGtKaC0vo4isvI\n' +
'yf04fkjudG0XIns5CWjdR2HeDC8BzSl8OVj8AQAc5uVU8Abk+ejWVr4zfoox\n' +
'eaziDPgGdkckFiQ6Tdsg0tPwwOpSrCCtJocTmc/fWaBb0YlnyAAL88fJABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZBMYqhmfI2WQQMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAACxNQf/UrM/whR7vCs+\n' +
'ez8Y8Hz4WqIuXtfMh4l2nKVv5UUuAfQkBxEY5j6Ga2+JgKU3neQ34x/v6fm9\n' +
'CLcY38Tc4AWyEx8KC78J+xOs7RMfyNBeiaf8KdaFfQrP0nMmufE6TxkfV1Y5\n' +
'LJZZ8350rZVtYJppWtlH+gbyUmMObyWDWbL3aWtqa3xjv0kLsf7TnugiFwzB\n' +
'gHHtk8tlDSOxRt0VdNNd19+/zrBYNl07Ig24WD2ETaJiaqa651z24/6/MkGT\n' +
'MBoQh+679tuWWcTrNi4jIA8jhSQ5BOgbAapl3qXk0m9/Aexpe2s6ISLXe8YJ\n' +
'j4cObDLv/ZKKeLZYTq9lVCydLAQUbs7ATQRk7zWYAQgAmx36uefgUF4cCSYH\n' +
'WMWAOTyc8Awo+hxn6FktOLU1+9hfGrX2jwGLOoOwjNgbYJbiSvRglAX2b57/\n' +
'qkkltAg1ZYCLSUzfBUbbWYlJNBwpv7+52zHaLUZ3gmI5aE48ad+uzaadgpVT\n' +
'VqLbhdgkN6jkemPTlfMehyS49AAbmqeKfo2U72tm9ZqT2cPVCASMjN/Ux2qG\n' +
'3W8HTo0KIVFSbkTthl1zAlwAFksp0q437+pxbdJIecJ9mO6N4OQMnv+hVBDc\n' +
'WrPqBDJ0nas4JNgLxmLv0pheGg/TEfwS/p6xGRW5m08bj2l0cgqmEaM27jbi\n' +
'DEpOykRWsDMhheEfI2zV/Qam8QARAQABwsB2BBgBCAAqBYJk7zWYCZBMYqhm\n' +
'fI2WQQKbDBYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAAAnBggA1gkIopr9HJFP\n' +
'fO5SebcbowH4AG9M0qBqF4h1JIKbqvOnxLSsC5QmmzFcjS9ihyHBvzbRVGkC\n' +
'zEHYpLRedQ2AmQQfsf/VOoZJEOlb7tTk4+SpYtsGte5X/yLT5Bkls7Rp8ubK\n' +
'/V99muj1nA/OkasllXQUSGEweVz6ejzJ0oMm3Vewmw8PelsdAnfS7Ud1MnXQ\n' +
'h+O8TCR56F5gAMWxZmxFpZMZyUFOH6KM+vL7HJUBztUS2g0ELsHKy9ep2yhv\n' +
'iABIwx/gEuPr0NDAH9x9XFKg5m3rO64KTY4BRWBISwmQ25dM1s1bwDPLi5XI\n' +
'6Daw1glFxpPRrxgQGlVLzJOu5b8swQ==\n' +
'=9hCc\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0x119bb8ad40B1f94e2b30ae5f59eeaEB67cD0Bd6C' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0x6e0C509d14EbF26A529bf6DC5CC9bee7F5b8DBa4' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0xE3FDD0527a9F8418f9a7D9e970452827FbE202FF' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADouo4S2kPqA//+I7nDAk15/LcJ2TGvDhOYuPNUNMiNGOb4\n' +
'txusuKz6HOaG+K9hiUBpHjKrYEmCT2FEXxt8bfS3SpWb74RHSkWUNUkxk25y\n' +
'gE5gaCKyAdcnOUyVLmobVFFYtH6naK9bULaUtkVik1P0iuEevWHxtTpsjbyH\n' +
'bZtNpVTdprdLib4Wx6bb7VogsvjlvNJcVJ4sfPE0XgsQgAGIev7yJyU0DGzt\n' +
'/EbvFX4sv51Kb1dX9ctBcvzVbs9+qT6LTivsrQp+TNHUN4zEeMhnWFFP5K1d\n' +
'H445S6FWk53XvBudcOkFPtltU1MPCS6hmhevArBfYzy5eSlaKA/fH+kFABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZCrD2gy8Zu4awMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBKru9/u8wPcTeHibkasPaDLxm7hrAADa/Af+PbamVg/Ig2S2\n' +
'HgIy4w5x7ulSk1/49+AmuiUMiVUwJSVBhROsyDbLET56w4+1TIMYZFJaczW3\n' +
'8tCvAOUSauzc52I3zwGmaCupBJokIWp7ncPh0B8TFYrgThgXV7sLf3xy4roy\n' +
'y8oFz1Zla88krwtPe4Az7TF+WNdXoDsLNJ3GXRmNqs1GITmDqAXFWncl12NM\n' +
'ajUKWIKc/Gi1oKfz22mabJTtWBimDpA12LaGK3GjEK5CiWXT3Tzlqn6R14EZ\n' +
'6ohpKZldSJiMPL0Bu9iT52iHOsw1wTZNC1L5lKhOCi3c+/fLRcJZt3hdCjqy\n' +
'd/FSCa8/Ny/GrHBWoL49rSF4pDEA+s7ATQRk7zWYAQgAtNOoHCL7BCnjwp8O\n' +
'htTxEI5r7Q/1zKKHiz6QKjjrGBYyR6gcmPM3JNEcvzY4OsCFnKBv2suOgrqH\n' +
'8kXJzfpIQ7u7uJs+O3p/cn86RMANiEnO8NbB/0scpfZ7Vg3eOfoiWYE4I/1o\n' +
'FVDCyZ1YVqtbcmuW6D8i1djjeoUmkUDZyPo7Qs6hUsJeYA/Rfl8mH5sjy2cN\n' +
'WXf8cEtOUqJtwERXt5aRB/nBZiC0bsP6hf0HtAoNA8/96TkqrcQpODW/RckD\n' +
'fo4wkpEONHRH+LGX7GV0pwymHu42TUnULmED6BrMgMYG2sKpxMThxtAxRaiP\n' +
'nZ3DKXr8GCjTYnbEZpoi2zKCOQARAQABwsB2BBgBCAAqBYJk7zWYCZCrD2gy\n' +
'8Zu4awKbDBYhBKru9/u8wPcTeHibkasPaDLxm7hrAADGyQgA5NMUkoyDTPZa\n' +
'Znj1dB+17xBXCZ/u7pPQc1DukBefVke7/qYIicdnnEGIX3Zd7TckFRsDljR/\n' +
'3418Bne4WyL57fAF/GgYsegpJ9n1KT7oPxWzibIaYdj7R6bkDt5r61EDWC3N\n' +
'VBbnZu9cO15TYkObJIiyNvwbQyd6Dm313b39GnEE8sM709TWsI6Es6rRZAfC\n' +
'+sI8ezYxqVUbP7sW3jJZYzdPOhZPHvFd5iJ2EfygEOuk5tb7AimfNwF/CNcB\n' +
'weQGEU7feOSB9lXXA+Ag1duLM4B9bLbbHEQIPhKlBF1ED64e/W/5HNfoAkS4\n' +
'qhzOD5XWs6xs45nnYqUbBFLG9Xk+Jg==\n' +
'=qtAv\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7zWZCZBMYqhmfI2WQRYhBC9DyzhpX3ACb/yTq0xiqGZ8\n' +
'jZZBAADwAwgAq/6WjtwRt1aPTLWwtSx80Ng/Wxf97dkpebMXSj9T7f5ia1rM\n' +
'8wqsuNUDMEMPB9LM34f6Q5pD994oeN2YT7z34u20mskiNphZdx/DNvu8w9UZ\n' +
'rI3tyjfZULhARNVM34sSABnHtExbl4ZArhNDsT86ku0sZNjr9frn2mtgmlKN\n' +
'nQdGcLJSxbci0hFg3nE5mYNpwZNs2S/2uk11WHKxzMhII6AdePE77BKPqedu\n' +
'PiXDODO2dIvV8glLQoJPRPgc2ap+/xYIBUFljqHGPU/62VSLlHxBJv72p5s/\n' +
'kOxiqD42TmpaaMtfudqgsZsGoYpZDHcMKYGNZs+9qVRHPRD+s0QhEA==\n' +
'=c6IF\n' +
'-----END PGP SIGNATURE-----\n' ,
groupImage : '' ,
groupName : 'influential_maroon_gamefowl' ,
groupDescription : 'urgent_brown_butterfly' ,
isPublic : false ,
groupCreator : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
chatId : '5f769c881ffe328117dea3d3acd0b97ce7f4c163e440f75a96be3e33f7d2a000' ,
meta : null ,
scheduleAt : null ,
scheduleEnd : null ,
groupType : 'default' ,
status : null ,
rules : { } ,
eventType : 'update'
}
Parameter
Type
Remarks
members
Array<Object>
An array containing member objects.
members.wallet
string
The wallet address of the member.
members.publicKey
string
The member's public PGP key (if available).
members.isAdmin
boolean
Indicates whether the member is an admin.
members.image
string
Image associated with the member.
pendingMembers
Array<Object>
An array containing pending member objects.
pendingMembers.wallet
string
The wallet address of the pending member.
pendingMembers.publicKey
string
The pending member's public PGP key (if available).
pendingMembers.isAdmin
boolean
Indicates whether the pending member is an admin.
pendingMembers.image
string
Image associated with the pending member.
contractAddressERC20
string
or null
Contract address for ERC20 tokens (Used for tokenGating).
numberOfERC20
number
The number of ERC20 tokens associated. (Used for tokenGating).
contractAddressNFT
string
or null
Contract address for NFT tokens (Used for tokenGating)
numberOfNFTTokens
number
The number of NFT tokens associated. (Used for tokenGating)
verificationProof
string
Verification proof associated with group data.
groupImage
string
Group's image.
groupName
string
The name of the group.
groupDescription
string
Description of the group.
isPublic
boolean
Indicates whether the group is public or private.
groupCreator
string
Push Profile DID of the group creator.
chatId
string
Unique chat ID associated with the group.
meta
object
or null
Additional metadata (if available).
scheduleAt
timestamp
or null
Scheduled start time (if available).
scheduleEnd
timestamp
or null
Scheduled end time (if available).
groupType
string
Type of the group (default, spaces, live etc).
status
string
or null
Status information ( active, expired etc)
rules
Object
Group-specific moderation rules
eventType
string
The type of event (create, update etc)
const joinGroup = await userAlice . chat . group . join ( groupChatId ) ;
Param
Type
Default
Remarks
chatId
string
-
Unique identifier of the group.
Expected response
{
members : [
{
wallet : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADeYpZfxgn1HoMUuWM42v8ZWfLPwglQYmzz5rY3PdPPoRFU\n' +
'v0AyPjYKpmLh2ZNfXjPaS9GuMdpXaomYSEwsV02hXZOQelo9cLop0Fc2i+l7\n' +
'70rYhePuOuQ+XD/xYzhngAgNJ9rX96YnSodldb8uJfxYmgoF0E9Z2o2fgZGj\n' +
'll2CPnOaLXZaBQlPS3x/461TmZ1n2ZePS/fwiC7taLz3PtyGtKaC0vo4isvI\n' +
'yf04fkjudG0XIns5CWjdR2HeDC8BzSl8OVj8AQAc5uVU8Abk+ejWVr4zfoox\n' +
'eaziDPgGdkckFiQ6Tdsg0tPwwOpSrCCtJocTmc/fWaBb0YlnyAAL88fJABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZBMYqhmfI2WQQMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAACxNQf/UrM/whR7vCs+\n' +
'ez8Y8Hz4WqIuXtfMh4l2nKVv5UUuAfQkBxEY5j6Ga2+JgKU3neQ34x/v6fm9\n' +
'CLcY38Tc4AWyEx8KC78J+xOs7RMfyNBeiaf8KdaFfQrP0nMmufE6TxkfV1Y5\n' +
'LJZZ8350rZVtYJppWtlH+gbyUmMObyWDWbL3aWtqa3xjv0kLsf7TnugiFwzB\n' +
'gHHtk8tlDSOxRt0VdNNd19+/zrBYNl07Ig24WD2ETaJiaqa651z24/6/MkGT\n' +
'MBoQh+679tuWWcTrNi4jIA8jhSQ5BOgbAapl3qXk0m9/Aexpe2s6ISLXe8YJ\n' +
'j4cObDLv/ZKKeLZYTq9lVCydLAQUbs7ATQRk7zWYAQgAmx36uefgUF4cCSYH\n' +
'WMWAOTyc8Awo+hxn6FktOLU1+9hfGrX2jwGLOoOwjNgbYJbiSvRglAX2b57/\n' +
'qkkltAg1ZYCLSUzfBUbbWYlJNBwpv7+52zHaLUZ3gmI5aE48ad+uzaadgpVT\n' +
'VqLbhdgkN6jkemPTlfMehyS49AAbmqeKfo2U72tm9ZqT2cPVCASMjN/Ux2qG\n' +
'3W8HTo0KIVFSbkTthl1zAlwAFksp0q437+pxbdJIecJ9mO6N4OQMnv+hVBDc\n' +
'WrPqBDJ0nas4JNgLxmLv0pheGg/TEfwS/p6xGRW5m08bj2l0cgqmEaM27jbi\n' +
'DEpOykRWsDMhheEfI2zV/Qam8QARAQABwsB2BBgBCAAqBYJk7zWYCZBMYqhm\n' +
'fI2WQQKbDBYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAAAnBggA1gkIopr9HJFP\n' +
'fO5SebcbowH4AG9M0qBqF4h1JIKbqvOnxLSsC5QmmzFcjS9ihyHBvzbRVGkC\n' +
'zEHYpLRedQ2AmQQfsf/VOoZJEOlb7tTk4+SpYtsGte5X/yLT5Bkls7Rp8ubK\n' +
'/V99muj1nA/OkasllXQUSGEweVz6ejzJ0oMm3Vewmw8PelsdAnfS7Ud1MnXQ\n' +
'h+O8TCR56F5gAMWxZmxFpZMZyUFOH6KM+vL7HJUBztUS2g0ELsHKy9ep2yhv\n' +
'iABIwx/gEuPr0NDAH9x9XFKg5m3rO64KTY4BRWBISwmQ25dM1s1bwDPLi5XI\n' +
'6Daw1glFxpPRrxgQGlVLzJOu5b8swQ==\n' +
'=9hCc\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0x119bb8ad40B1f94e2b30ae5f59eeaEB67cD0Bd6C' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0x6e0C509d14EbF26A529bf6DC5CC9bee7F5b8DBa4' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0xE3FDD0527a9F8418f9a7D9e970452827FbE202FF' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADouo4S2kPqA//+I7nDAk15/LcJ2TGvDhOYuPNUNMiNGOb4\n' +
'txusuKz6HOaG+K9hiUBpHjKrYEmCT2FEXxt8bfS3SpWb74RHSkWUNUkxk25y\n' +
'gE5gaCKyAdcnOUyVLmobVFFYtH6naK9bULaUtkVik1P0iuEevWHxtTpsjbyH\n' +
'bZtNpVTdprdLib4Wx6bb7VogsvjlvNJcVJ4sfPE0XgsQgAGIev7yJyU0DGzt\n' +
'/EbvFX4sv51Kb1dX9ctBcvzVbs9+qT6LTivsrQp+TNHUN4zEeMhnWFFP5K1d\n' +
'H445S6FWk53XvBudcOkFPtltU1MPCS6hmhevArBfYzy5eSlaKA/fH+kFABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZCrD2gy8Zu4awMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBKru9/u8wPcTeHibkasPaDLxm7hrAADa/Af+PbamVg/Ig2S2\n' +
'HgIy4w5x7ulSk1/49+AmuiUMiVUwJSVBhROsyDbLET56w4+1TIMYZFJaczW3\n' +
'8tCvAOUSauzc52I3zwGmaCupBJokIWp7ncPh0B8TFYrgThgXV7sLf3xy4roy\n' +
'y8oFz1Zla88krwtPe4Az7TF+WNdXoDsLNJ3GXRmNqs1GITmDqAXFWncl12NM\n' +
'ajUKWIKc/Gi1oKfz22mabJTtWBimDpA12LaGK3GjEK5CiWXT3Tzlqn6R14EZ\n' +
'6ohpKZldSJiMPL0Bu9iT52iHOsw1wTZNC1L5lKhOCi3c+/fLRcJZt3hdCjqy\n' +
'd/FSCa8/Ny/GrHBWoL49rSF4pDEA+s7ATQRk7zWYAQgAtNOoHCL7BCnjwp8O\n' +
'htTxEI5r7Q/1zKKHiz6QKjjrGBYyR6gcmPM3JNEcvzY4OsCFnKBv2suOgrqH\n' +
'8kXJzfpIQ7u7uJs+O3p/cn86RMANiEnO8NbB/0scpfZ7Vg3eOfoiWYE4I/1o\n' +
'FVDCyZ1YVqtbcmuW6D8i1djjeoUmkUDZyPo7Qs6hUsJeYA/Rfl8mH5sjy2cN\n' +
'WXf8cEtOUqJtwERXt5aRB/nBZiC0bsP6hf0HtAoNA8/96TkqrcQpODW/RckD\n' +
'fo4wkpEONHRH+LGX7GV0pwymHu42TUnULmED6BrMgMYG2sKpxMThxtAxRaiP\n' +
'nZ3DKXr8GCjTYnbEZpoi2zKCOQARAQABwsB2BBgBCAAqBYJk7zWYCZCrD2gy\n' +
'8Zu4awKbDBYhBKru9/u8wPcTeHibkasPaDLxm7hrAADGyQgA5NMUkoyDTPZa\n' +
'Znj1dB+17xBXCZ/u7pPQc1DukBefVke7/qYIicdnnEGIX3Zd7TckFRsDljR/\n' +
'3418Bne4WyL57fAF/GgYsegpJ9n1KT7oPxWzibIaYdj7R6bkDt5r61EDWC3N\n' +
'VBbnZu9cO15TYkObJIiyNvwbQyd6Dm313b39GnEE8sM709TWsI6Es6rRZAfC\n' +
'+sI8ezYxqVUbP7sW3jJZYzdPOhZPHvFd5iJ2EfygEOuk5tb7AimfNwF/CNcB\n' +
'weQGEU7feOSB9lXXA+Ag1duLM4B9bLbbHEQIPhKlBF1ED64e/W/5HNfoAkS4\n' +
'qhzOD5XWs6xs45nnYqUbBFLG9Xk+Jg==\n' +
'=qtAv\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7zWZCZBMYqhmfI2WQRYhBC9DyzhpX3ACb/yTq0xiqGZ8\n' +
'jZZBAADwAwgAq/6WjtwRt1aPTLWwtSx80Ng/Wxf97dkpebMXSj9T7f5ia1rM\n' +
'8wqsuNUDMEMPB9LM34f6Q5pD994oeN2YT7z34u20mskiNphZdx/DNvu8w9UZ\n' +
'rI3tyjfZULhARNVM34sSABnHtExbl4ZArhNDsT86ku0sZNjr9frn2mtgmlKN\n' +
'nQdGcLJSxbci0hFg3nE5mYNpwZNs2S/2uk11WHKxzMhII6AdePE77BKPqedu\n' +
'PiXDODO2dIvV8glLQoJPRPgc2ap+/xYIBUFljqHGPU/62VSLlHxBJv72p5s/\n' +
'kOxiqD42TmpaaMtfudqgsZsGoYpZDHcMKYGNZs+9qVRHPRD+s0QhEA==\n' +
'=c6IF\n' +
'-----END PGP SIGNATURE-----\n' ,
groupImage : '' ,
groupName : 'influential_maroon_gamefowl' ,
groupDescription : 'urgent_brown_butterfly' ,
isPublic : false ,
groupCreator : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
chatId : '5f769c881ffe328117dea3d3acd0b97ce7f4c163e440f75a96be3e33f7d2a000' ,
meta : null ,
scheduleAt : null ,
scheduleEnd : null ,
groupType : 'default' ,
status : null ,
rules : { } ,
eventType : 'update'
}
Parameter
Type
Remarks
members
Array<Object>
An array containing member objects.
members.wallet
string
The wallet address of the member.
members.publicKey
string
The member's public PGP key (if available).
members.isAdmin
boolean
Indicates whether the member is an admin.
members.image
string
Image associated with the member.
pendingMembers
Array<Object>
An array containing pending member objects.
pendingMembers.wallet
string
The wallet address of the pending member.
pendingMembers.publicKey
string
The pending member's public PGP key (if available).
pendingMembers.isAdmin
boolean
Indicates whether the pending member is an admin.
pendingMembers.image
string
Image associated with the pending member.
contractAddressERC20
string
or null
Contract address for ERC20 tokens (Used for tokenGating).
numberOfERC20
number
The number of ERC20 tokens associated. (Used for tokenGating).
contractAddressNFT
string
or null
Contract address for NFT tokens (Used for tokenGating)
numberOfNFTTokens
number
The number of NFT tokens associated. (Used for tokenGating)
verificationProof
string
Verification proof associated with group data.
groupImage
string
Group's image.
groupName
string
The name of the group.
groupDescription
string
Description of the group.
isPublic
boolean
Indicates whether the group is public or private.
groupCreator
string
Push Profile DID of the group creator.
chatId
string
Unique chat ID associated with the group.
meta
object
or null
Additional metadata (if available).
scheduleAt
timestamp
or null
Scheduled start time (if available).
scheduleEnd
timestamp
or null
Scheduled end time (if available).
groupType
string
Type of the group (default, spaces, live etc).
status
string
or null
Status information ( active, expired etc)
rules
Object
Group-specific moderation rules
eventType
string
The type of event (create, update etc)
// Leave Group
const leaveGrp = await userAlice . chat . group . leave ( groupChatId ) ;
Param
Type
Default
Remarks
chatId
string
-
Unique identifier of the group.
Expected response
{
members : [
{
wallet : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADeYpZfxgn1HoMUuWM42v8ZWfLPwglQYmzz5rY3PdPPoRFU\n' +
'v0AyPjYKpmLh2ZNfXjPaS9GuMdpXaomYSEwsV02hXZOQelo9cLop0Fc2i+l7\n' +
'70rYhePuOuQ+XD/xYzhngAgNJ9rX96YnSodldb8uJfxYmgoF0E9Z2o2fgZGj\n' +
'll2CPnOaLXZaBQlPS3x/461TmZ1n2ZePS/fwiC7taLz3PtyGtKaC0vo4isvI\n' +
'yf04fkjudG0XIns5CWjdR2HeDC8BzSl8OVj8AQAc5uVU8Abk+ejWVr4zfoox\n' +
'eaziDPgGdkckFiQ6Tdsg0tPwwOpSrCCtJocTmc/fWaBb0YlnyAAL88fJABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZBMYqhmfI2WQQMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAACxNQf/UrM/whR7vCs+\n' +
'ez8Y8Hz4WqIuXtfMh4l2nKVv5UUuAfQkBxEY5j6Ga2+JgKU3neQ34x/v6fm9\n' +
'CLcY38Tc4AWyEx8KC78J+xOs7RMfyNBeiaf8KdaFfQrP0nMmufE6TxkfV1Y5\n' +
'LJZZ8350rZVtYJppWtlH+gbyUmMObyWDWbL3aWtqa3xjv0kLsf7TnugiFwzB\n' +
'gHHtk8tlDSOxRt0VdNNd19+/zrBYNl07Ig24WD2ETaJiaqa651z24/6/MkGT\n' +
'MBoQh+679tuWWcTrNi4jIA8jhSQ5BOgbAapl3qXk0m9/Aexpe2s6ISLXe8YJ\n' +
'j4cObDLv/ZKKeLZYTq9lVCydLAQUbs7ATQRk7zWYAQgAmx36uefgUF4cCSYH\n' +
'WMWAOTyc8Awo+hxn6FktOLU1+9hfGrX2jwGLOoOwjNgbYJbiSvRglAX2b57/\n' +
'qkkltAg1ZYCLSUzfBUbbWYlJNBwpv7+52zHaLUZ3gmI5aE48ad+uzaadgpVT\n' +
'VqLbhdgkN6jkemPTlfMehyS49AAbmqeKfo2U72tm9ZqT2cPVCASMjN/Ux2qG\n' +
'3W8HTo0KIVFSbkTthl1zAlwAFksp0q437+pxbdJIecJ9mO6N4OQMnv+hVBDc\n' +
'WrPqBDJ0nas4JNgLxmLv0pheGg/TEfwS/p6xGRW5m08bj2l0cgqmEaM27jbi\n' +
'DEpOykRWsDMhheEfI2zV/Qam8QARAQABwsB2BBgBCAAqBYJk7zWYCZBMYqhm\n' +
'fI2WQQKbDBYhBC9DyzhpX3ACb/yTq0xiqGZ8jZZBAAAnBggA1gkIopr9HJFP\n' +
'fO5SebcbowH4AG9M0qBqF4h1JIKbqvOnxLSsC5QmmzFcjS9ihyHBvzbRVGkC\n' +
'zEHYpLRedQ2AmQQfsf/VOoZJEOlb7tTk4+SpYtsGte5X/yLT5Bkls7Rp8ubK\n' +
'/V99muj1nA/OkasllXQUSGEweVz6ejzJ0oMm3Vewmw8PelsdAnfS7Ud1MnXQ\n' +
'h+O8TCR56F5gAMWxZmxFpZMZyUFOH6KM+vL7HJUBztUS2g0ELsHKy9ep2yhv\n' +
'iABIwx/gEuPr0NDAH9x9XFKg5m3rO64KTY4BRWBISwmQ25dM1s1bwDPLi5XI\n' +
'6Daw1glFxpPRrxgQGlVLzJOu5b8swQ==\n' +
'=9hCc\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0x119bb8ad40B1f94e2b30ae5f59eeaEB67cD0Bd6C' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0x6e0C509d14EbF26A529bf6DC5CC9bee7F5b8DBa4' ,
publicKey : null ,
isAdmin : false ,
image : null
} ,
{
wallet : 'eip155:0xE3FDD0527a9F8418f9a7D9e970452827FbE202FF' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvNZgBCADouo4S2kPqA//+I7nDAk15/LcJ2TGvDhOYuPNUNMiNGOb4\n' +
'txusuKz6HOaG+K9hiUBpHjKrYEmCT2FEXxt8bfS3SpWb74RHSkWUNUkxk25y\n' +
'gE5gaCKyAdcnOUyVLmobVFFYtH6naK9bULaUtkVik1P0iuEevWHxtTpsjbyH\n' +
'bZtNpVTdprdLib4Wx6bb7VogsvjlvNJcVJ4sfPE0XgsQgAGIev7yJyU0DGzt\n' +
'/EbvFX4sv51Kb1dX9ctBcvzVbs9+qT6LTivsrQp+TNHUN4zEeMhnWFFP5K1d\n' +
'H445S6FWk53XvBudcOkFPtltU1MPCS6hmhevArBfYzy5eSlaKA/fH+kFABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO81mAQLCQcICZCrD2gy8Zu4awMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBKru9/u8wPcTeHibkasPaDLxm7hrAADa/Af+PbamVg/Ig2S2\n' +
'HgIy4w5x7ulSk1/49+AmuiUMiVUwJSVBhROsyDbLET56w4+1TIMYZFJaczW3\n' +
'8tCvAOUSauzc52I3zwGmaCupBJokIWp7ncPh0B8TFYrgThgXV7sLf3xy4roy\n' +
'y8oFz1Zla88krwtPe4Az7TF+WNdXoDsLNJ3GXRmNqs1GITmDqAXFWncl12NM\n' +
'ajUKWIKc/Gi1oKfz22mabJTtWBimDpA12LaGK3GjEK5CiWXT3Tzlqn6R14EZ\n' +
'6ohpKZldSJiMPL0Bu9iT52iHOsw1wTZNC1L5lKhOCi3c+/fLRcJZt3hdCjqy\n' +
'd/FSCa8/Ny/GrHBWoL49rSF4pDEA+s7ATQRk7zWYAQgAtNOoHCL7BCnjwp8O\n' +
'htTxEI5r7Q/1zKKHiz6QKjjrGBYyR6gcmPM3JNEcvzY4OsCFnKBv2suOgrqH\n' +
'8kXJzfpIQ7u7uJs+O3p/cn86RMANiEnO8NbB/0scpfZ7Vg3eOfoiWYE4I/1o\n' +
'FVDCyZ1YVqtbcmuW6D8i1djjeoUmkUDZyPo7Qs6hUsJeYA/Rfl8mH5sjy2cN\n' +
'WXf8cEtOUqJtwERXt5aRB/nBZiC0bsP6hf0HtAoNA8/96TkqrcQpODW/RckD\n' +
'fo4wkpEONHRH+LGX7GV0pwymHu42TUnULmED6BrMgMYG2sKpxMThxtAxRaiP\n' +
'nZ3DKXr8GCjTYnbEZpoi2zKCOQARAQABwsB2BBgBCAAqBYJk7zWYCZCrD2gy\n' +
'8Zu4awKbDBYhBKru9/u8wPcTeHibkasPaDLxm7hrAADGyQgA5NMUkoyDTPZa\n' +
'Znj1dB+17xBXCZ/u7pPQc1DukBefVke7/qYIicdnnEGIX3Zd7TckFRsDljR/\n' +
'3418Bne4WyL57fAF/GgYsegpJ9n1KT7oPxWzibIaYdj7R6bkDt5r61EDWC3N\n' +
'VBbnZu9cO15TYkObJIiyNvwbQyd6Dm313b39GnEE8sM709TWsI6Es6rRZAfC\n' +
'+sI8ezYxqVUbP7sW3jJZYzdPOhZPHvFd5iJ2EfygEOuk5tb7AimfNwF/CNcB\n' +
'weQGEU7feOSB9lXXA+Ag1duLM4B9bLbbHEQIPhKlBF1ED64e/W/5HNfoAkS4\n' +
'qhzOD5XWs6xs45nnYqUbBFLG9Xk+Jg==\n' +
'=qtAv\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isAdmin : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJk7zWZCZBMYqhmfI2WQRYhBC9DyzhpX3ACb/yTq0xiqGZ8\n' +
'jZZBAADwAwgAq/6WjtwRt1aPTLWwtSx80Ng/Wxf97dkpebMXSj9T7f5ia1rM\n' +
'8wqsuNUDMEMPB9LM34f6Q5pD994oeN2YT7z34u20mskiNphZdx/DNvu8w9UZ\n' +
'rI3tyjfZULhARNVM34sSABnHtExbl4ZArhNDsT86ku0sZNjr9frn2mtgmlKN\n' +
'nQdGcLJSxbci0hFg3nE5mYNpwZNs2S/2uk11WHKxzMhII6AdePE77BKPqedu\n' +
'PiXDODO2dIvV8glLQoJPRPgc2ap+/xYIBUFljqHGPU/62VSLlHxBJv72p5s/\n' +
'kOxiqD42TmpaaMtfudqgsZsGoYpZDHcMKYGNZs+9qVRHPRD+s0QhEA==\n' +
'=c6IF\n' +
'-----END PGP SIGNATURE-----\n' ,
groupImage : '' ,
groupName : 'influential_maroon_gamefowl' ,
groupDescription : 'urgent_brown_butterfly' ,
isPublic : false ,
groupCreator : 'eip155:0x140BE62b2177A975Bbef398DF8934b883E7d13f9' ,
chatId : '5f769c881ffe328117dea3d3acd0b97ce7f4c163e440f75a96be3e33f7d2a000' ,
meta : null ,
scheduleAt : null ,
scheduleEnd : null ,
groupType : 'default' ,
status : null ,
rules : { } ,
eventType : 'update'
}
Parameter
Type
Remarks
members
Array<Object>
An array containing member objects.
members.wallet
string
The wallet address of the member.
members.publicKey
string
The member's public PGP key (if available).
members.isAdmin
boolean
Indicates whether the member is an admin.
members.image
string
Image associated with the member.
pendingMembers
Array<Object>
An array containing pending member objects.
pendingMembers.wallet
string
The wallet address of the pending member.
pendingMembers.publicKey
string
The pending member's public PGP key (if available).
pendingMembers.isAdmin
boolean
Indicates whether the pending member is an admin.
pendingMembers.image
string
Image associated with the pending member.
contractAddressERC20
string
or null
Contract address for ERC20 tokens (Used for tokenGating).
numberOfERC20
number
The number of ERC20 tokens associated. (Used for tokenGating).
contractAddressNFT
string
or null
Contract address for NFT tokens (Used for tokenGating)
numberOfNFTTokens
number
The number of NFT tokens associated. (Used for tokenGating)
verificationProof
string
Verification proof associated with group data.
groupImage
string
Group's image.
groupName
string
The name of the group.
groupDescription
string
Description of the group.
isPublic
boolean
Indicates whether the group is public or private.
groupCreator
string
Push Profile DID of the group creator.
chatId
string
Unique chat ID associated with the group.
meta
object
or null
Additional metadata (if available).
scheduleAt
timestamp
or null
Scheduled start time (if available).
scheduleEnd
timestamp
or null
Scheduled end time (if available).
groupType
string
Type of the group (default, spaces, live etc).
status
string
or null
Status information ( active, expired etc)
rules
Object
Group-specific moderation rules
eventType
string
The type of event (create, update etc)
Reject Group Joining Request
// Reject Group Request
await userAlice . chat . group . reject ( groupChatId ) ;
Param
Type
Default
Remarks
chatId
string
-
Unique identifier of the group.
// Fetch Encryption Info
const aliceEncryptionInfo = await userAlice . encryption . info ( ) ;
Expected response
{
decryptedPgpPrivateKey : '-----BEGIN PGP PRIVATE KEY BLOCK-----\n' +
'\n' +
'xcLYBGTvQKUBCACgsuLM540Bq39fAbLRGoaRZR5/lETkpQSArzP4+B+wxcQe\n' +
'IItuLF9z1+OHilx/uAJ6yWH2En8QdlSBRMDCSwhLOXYnrB5dTvEM2nm+v59H\n' +
'sIRkRUogXSIgTrcVG7Tt0JsrjBV2avOki1L4vzPvHEDUtlKcxdJ5914W2lSu\n' +
'05xPG+ALRsYFki1ga6bt6kT1+v7GV+862hOHY/FugohLKdIZOo6CeI0ddnHF\n' +
'9jL3pu4aTRn11VIphju3KQ2oCxF/6843OrA4X/GtVtsoRq00RBLuv61ZmRpr\n' +
'qsOgEz009cDEWdUWs8wvf75TG/MfYM4g+9nSWflJGMSD3PfVHKTzOsYlABEB\n' +
'AAEAB/0d/GNPwuFP73VsAAAi/qUfmlPPkJYuaBBoBslW6s3XCYAn8wCxhTwm\n' +
'fKFrWEkcV/S2fr910Eu/gaURHggt+RxKFSXUD0z3MlTOhjHzgwQwt2Js53UG\n' +
'hvpoNuf421uuiJ97x771gs2F5a2M1vjU5FvAlWji8hLtSVhYQVNN8BSZuhkK\n' +
'Adq+/MsHmOvD6YkBW2xuAGo1ZVF4D8JUJDUWcjRJCMr0gJJv34c8f74EYW8b\n' +
'LhrLGZgPRBkJemmN08sVwW5NLlPwjHTrvZOcb9RQ/N3liBwamk13dIEMNil1\n' +
'GjGI6txtd04SXN0nTq2e+v+n8jk3HgwM3ypTAbaO+XQSBWyhBAC/mIv9OK7t\n' +
'RoNA42+nJU+SYLEFFDew6x0b6Yg8k44gSiWiYadRWpDRP/essz641W1Ksn0a\n' +
'02kx+m55tT6uQFFwly24FOaFexhfvhbKtmA+sfJtvQVNebgH/2EJn9QSti/y\n' +
'rGBStwDs48Psb2ZtcNNwhYajTACLioEF/vgx7FhKbQQA1reKmY5TefRFEK0b\n' +
'lBqkDyYZoLKxEAoXQ6IwrVbIdO2kvPVDjfAy1CqpCnDhzXdXYmHA3HHOPJgr\n' +
'PkLc8r0MeZR7ZI67JSSFoP2ixlxJjI06vXjQVvzrCigSJfL24LaBXBjQtd8t\n' +
'X+g4KpM+a5iGrE1dQ/dgCt/G97Ra2v7Ql5kD/01W5Q+NqXxb++YrTJOXaNhp\n' +
'yfSWYqtf62/xMoRBY8n/jtmyVD88i61aoqRsTDy+6Ugoi9QkrzhL7PSgn6Gl\n' +
'yy5whksUFHFIcXDGF0HtPLIuEUJ7V3tC9yZ8Q630o3Dirf1+tP6+aLoMLwb2\n' +
'5O+SZFQk4cAVvW4aKbyGPdhlDvYxPkPNAMLAigQQAQgAPgWCZO9ApQQLCQcI\n' +
'CZD+BWKBkBMI0AMVCAoEFgACAQIZAQKbAwIeARYhBEXCtUQEMuKbuZLzrv4F\n' +
'YoGQEwjQAAC0VAf/VNnQ5xfPHhm6JfZ+cH2lUfy65pZ+5GqXHanB9RcxZPHe\n' +
'9hzr0l1IJk4o48HUrIcwJhpBfXUsd9oLC81Un1io0uX37hE3in+ND4j11ZiR\n' +
'e8kQakH67/R7XKUaD3JTfXTshVpWhVTa1mjBZZcxOzr8ZxhnuaSQ7888t5cF\n' +
'0zBuOo6YPmqiNVudlXlhXuiAVqp+xK5yamqxW9drz767aXUAvE9GChE4+P0i\n' +
'a1wwvvA2wkZTE2+rJKvAWA8iit4TeOTTDJoja0zc2yKxytdeOy6PWr6lGjjb\n' +
'zJEq9uqs1tx8znRosDkb+Gw26CHdUo2uVUDGkcesqxNUv+C/4R9eubBVYMfC\n' +
'2ARk70ClAQgA38Hi0a1rqZAPdBaUnlqY4x4pIi2KyFPQ7TmW3Y/V1NgEm9Y8\n' +
'w3bx3TF8O8uDETn6U5ASUa2DG4gppcZrDqFsChnxhHOdJhEgh3X8LeyzuCHn\n' +
'qWQPbo2iCt3ve0fRsK/f0ZPABgCqlgTGkeVi7KppUqB1FtkRMfh0Eqr3fLC9\n' +
'pNRLtlnQT793rfavvXavK+0eeukZVPYbALuJq2tX0IBwr9+/6YEzSi7yo/1P\n' +
'pRZSRSM9KQwk/R2ohS2FAytUpTRp/4OFIJqv93PxS7MlHVfe/lhc9fXeTvH2\n' +
'sMQCfMsp16wP7Em+AjT5elJgXv3VrQ4whrr5yGfTvO9uQVoV7LKoWQARAQAB\n' +
'AAf7BXspAJiiTGQnYsE6WQIwYFDg8lHCBmv6MFNysQD43JbBjyUxdhrL7C6O\n' +
'A+N1dZaxXXpoHnjU/zfHyGQqw3AcFsfBqSxRV0lAXh0bZS8ZDGvFMlqtf5hn\n' +
'1aMP3pnY5r56Kba4M5Vw2E2r5Q9Ey/YVMCVW1O1SjOIwirQGLbdhH+BZMvcf\n' +
'iAJ2fbQ919cX3CuATJnMs1/4Q+7dzPcksE1SON6eGeixrzXAr1y/Ls04wx9/\n' +
'DXsXyPunzNDVdZPttEbpNcWv3gZ9MHpYIYbC3kbuopC7ICvW4pkSGkl+uiV8\n' +
'iqoi+AxjgCvXSq+eVI11sZJ+Rjqi7M9yW5qjxzw2Wy25sQQA6Jm1+nXwo0UX\n' +
'NagosTXSf++9CDraFdbbpz2HUX8B6Ls8HwTMQ7q/EZRqmjKqeT/BxVQVp+O6\n' +
'WNMtpnGMUQrbDI6Tcu6C3kVhZg/R9dWpRigsOHnsySrI74nYh9DBISAkabCf\n' +
'cqir7V7treB5vcIaS80ys1vFHgtuLtTgFisCfpEEAPZEb0rbQ5PR5yTBvE80\n' +
'0MW3OnNDqZ8905GHJ6IGJVOuQuDQfMoZ+06757IwrWrQ6mZk5WIyiHD31+tr\n' +
'd58MP351/0wv1/WUkPEcwuxWuTIK1kKtwQkcl75wZbnqvAGOigAFlvOTNPnD\n' +
'qZVODWmod1Yg0dLIB3HF/xV29nx5ngFJA/9ifa68aMeoZqd3CePMS3zUwyLy\n' +
'6ZZ2cnUuBLjf87Fl9Rl+OLPMryEwA24I6ybcaa01ZsUgG2SZIwkKAovEhgmJ\n' +
'll5mXY9GNpULHj9fr2KyLkweFnvyTwIpv0VlT7WzEthebIM0hC0eSJyNmu2C\n' +
'/SQTKvYUIcwP3v1RMFsCNPV1dTy+wsB2BBgBCAAqBYJk70ClCZD+BWKBkBMI\n' +
'0AKbDBYhBEXCtUQEMuKbuZLzrv4FYoGQEwjQAABMkAf/UKvQHe+oYH/hU0/p\n' +
'7OXUMCKIzSHD9c7lrb2nnP4CGyxF+FoZbQ9qnMVuT6FX6zPyZgDtOjp8Grvc\n' +
'ACBibxwujfnNdKBdA1r0XQGf2ht3BWYpgn9jGYw58bf3yaxr6/Dg1D7FzgbN\n' +
'FkaarU8C4fEAhiAHY4SpMUzqej/QfrwvasjyqPnbD+vCqyTivNmpTb6LYzXP\n' +
'BtXQW0A1B6EhmFwftGyNxIG1wEO+tWE4v4XLCyscAz8ZBMBPdfaRe26lnr6C\n' +
'UnTUwL+VecX2uIVRE9w9FhXuKeaPoDzPWnu0SZ6WCUV3DxQwMoUB/3vJ8sRK\n' +
'l2L+h0L32V6yjL0asut2G+qfvw==\n' +
'=o527\n' +
'-----END PGP PRIVATE KEY BLOCK-----\n' ,
pgpPublicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTvQKUBCACgsuLM540Bq39fAbLRGoaRZR5/lETkpQSArzP4+B+wxcQe\n' +
'IItuLF9z1+OHilx/uAJ6yWH2En8QdlSBRMDCSwhLOXYnrB5dTvEM2nm+v59H\n' +
'sIRkRUogXSIgTrcVG7Tt0JsrjBV2avOki1L4vzPvHEDUtlKcxdJ5914W2lSu\n' +
'05xPG+ALRsYFki1ga6bt6kT1+v7GV+862hOHY/FugohLKdIZOo6CeI0ddnHF\n' +
'9jL3pu4aTRn11VIphju3KQ2oCxF/6843OrA4X/GtVtsoRq00RBLuv61ZmRpr\n' +
'qsOgEz009cDEWdUWs8wvf75TG/MfYM4g+9nSWflJGMSD3PfVHKTzOsYlABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO9ApQQLCQcICZD+BWKBkBMI0AMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBEXCtUQEMuKbuZLzrv4FYoGQEwjQAAC0VAf/VNnQ5xfPHhm6\n' +
'JfZ+cH2lUfy65pZ+5GqXHanB9RcxZPHe9hzr0l1IJk4o48HUrIcwJhpBfXUs\n' +
'd9oLC81Un1io0uX37hE3in+ND4j11ZiRe8kQakH67/R7XKUaD3JTfXTshVpW\n' +
'hVTa1mjBZZcxOzr8ZxhnuaSQ7888t5cF0zBuOo6YPmqiNVudlXlhXuiAVqp+\n' +
'xK5yamqxW9drz767aXUAvE9GChE4+P0ia1wwvvA2wkZTE2+rJKvAWA8iit4T\n' +
'eOTTDJoja0zc2yKxytdeOy6PWr6lGjjbzJEq9uqs1tx8znRosDkb+Gw26CHd\n' +
'Uo2uVUDGkcesqxNUv+C/4R9eubBVYM7ATQRk70ClAQgA38Hi0a1rqZAPdBaU\n' +
'nlqY4x4pIi2KyFPQ7TmW3Y/V1NgEm9Y8w3bx3TF8O8uDETn6U5ASUa2DG4gp\n' +
'pcZrDqFsChnxhHOdJhEgh3X8LeyzuCHnqWQPbo2iCt3ve0fRsK/f0ZPABgCq\n' +
'lgTGkeVi7KppUqB1FtkRMfh0Eqr3fLC9pNRLtlnQT793rfavvXavK+0eeukZ\n' +
'VPYbALuJq2tX0IBwr9+/6YEzSi7yo/1PpRZSRSM9KQwk/R2ohS2FAytUpTRp\n' +
'/4OFIJqv93PxS7MlHVfe/lhc9fXeTvH2sMQCfMsp16wP7Em+AjT5elJgXv3V\n' +
'rQ4whrr5yGfTvO9uQVoV7LKoWQARAQABwsB2BBgBCAAqBYJk70ClCZD+BWKB\n' +
'kBMI0AKbDBYhBEXCtUQEMuKbuZLzrv4FYoGQEwjQAABMkAf/UKvQHe+oYH/h\n' +
'U0/p7OXUMCKIzSHD9c7lrb2nnP4CGyxF+FoZbQ9qnMVuT6FX6zPyZgDtOjp8\n' +
'GrvcACBibxwujfnNdKBdA1r0XQGf2ht3BWYpgn9jGYw58bf3yaxr6/Dg1D7F\n' +
'zgbNFkaarU8C4fEAhiAHY4SpMUzqej/QfrwvasjyqPnbD+vCqyTivNmpTb6L\n' +
'YzXPBtXQW0A1B6EhmFwftGyNxIG1wEO+tWE4v4XLCyscAz8ZBMBPdfaRe26l\n' +
'nr6CUnTUwL+VecX2uIVRE9w9FhXuKeaPoDzPWnu0SZ6WCUV3DxQwMoUB/3vJ\n' +
'8sRKl2L+h0L32V6yjL0asut2G+qfvw==\n' +
'=4XKH\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n'
}
Param
Type
Remarks
decryptedPgpPrivateKey
string
Push Profile's PGP Private key
pgpPublicKey
string
Push Profile's PGP Public key
decryptedPassword
string
or undefined
Push Profile's Password
// Update keys encryption
const aliceUpdateEncryption = await userAlice . encryption . update (
ENCRYPTION_VERSION . PGP_V3
) ;
Param
Type
Default
Remarks
updatedEncryptionType
ENCRYPTION_TYPE
-
New Encryption Scheme to which keys are to be updated
options
*
object
-
Optional Configuration for updating encryption
options.versionMeta
*
{ NFTPGP_V1 ?: { password : string} }
-
New Password ( In case of NFT Profile )
* - Optional
Expected response
{
did : 'eip155:0xEaC9c666570782E262f1E2a0b1d3BE4B95aFA7cd' ,
wallets : 'eip155:0xEaC9c666570782E262f1E2a0b1d3BE4B95aFA7cd' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGTu6YUBCACa7JaMqfhAnD/9ynE5Rhi8KNQ1tfdQe0ay/9jXX2naZIA+\n' +
'6WCi1uNcB2TTLfMuzsEl4u/26LTgtkr51snRt2QKgEqi5dXqbRD76wiRLd4h\n' +
'ktBb4WB28o+BWOHYYJQq8he+zu3mQWjKLb1e9DyS0cTzwPwWVKce9IsG3NOi\n' +
'eM7O5Kg5cU3qHXR+frF25peCBrzNXH+xuuTJPsX85h9dSz/u6dWXhk2LsX3s\n' +
'cmX5mFcFErnGvUBddDGZc11q+WzZAtENPCxQrNjpkMtzCj9UMwgsJdzBghZZ\n' +
'ZouGTG2uhfmIj3/KHOdwx/KGpTgC1iMVOb78kw9LmaxL6fGy4x9uvvI3ABEB\n' +
'AAHNAMLAigQQAQgAPgWCZO7phQQLCQcICZABDloJB8hpcgMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBMga3B8GDU79nd/0mAEOWgkHyGlyAAAbHAf/bJMPIyvNZNjO\n' +
'JK2xA1hYpzIGdbi3jMego6GXrmet3qY50zMKDccB2Ot399y/nmWMVEyfKYaP\n' +
'7N+mJbeAqIZ8TAHtpw++k/h8/hXoxb9iPsQyWYossuG499XyHnk+KEd4g0Wf\n' +
'mqPk/XJB3xLLgW820jOsRRbWLyYKJEdh1Q+GIM+D6oIJ9ZmyRPv25u6yCF2P\n' +
'2IQZErWeYD/LxqMDw+uHdRZJRiyFy/Y7A43clejN+p3my8oktXh2N4+tEl7i\n' +
'Hwxc5z9AOffuEyUerm0Rjwdn8rG8po7AfuXwmTiW1Sdc9TdJtAK/n6e9EFHV\n' +
'gHzArwyaydHHy80Wqa+UF591NkPi387ATQRk7umFAQgAs0ao+EFoKJirGHfI\n' +
'69vZg+eAAUUKG657BzNzTAF2r5Y+a61jdcCAL+DXBcfks+H0dqG36zjOZTCJ\n' +
'NirABp5RRPFty2VvUtOyezuKX/MBVg3st3t/yE3SncVaWMblAv3iegviNNpH\n' +
'cFKqpHoVBWDNdhFHNsKTjpJcq3BVohy2Dxh8Di8N/1+gEPxADvIuH9MQ8MJk\n' +
'6lB9XYXBmmqtlQ3sB916mvusUIl8Zxw1C76yY0PAXz055zJMiL1vwo5gKDiV\n' +
'iKyzry3wq7upPGJyeTKu7uUMifTPhJtyYvon2TIik5DIgHpqKziirCrolA+s\n' +
'7LhnFbawqDKleEdyCcL5mFCzXQARAQABwsB2BBgBCAAqBYJk7umFCZABDloJ\n' +
'B8hpcgKbDBYhBMga3B8GDU79nd/0mAEOWgkHyGlyAABIqQgAmK9ijEEvtWTm\n' +
'7/mhkuDEtfPfcMexfkaCcGL4SdZqVz/h+eIL8+4EbI9uq+YTzcjtX8FAEQta\n' +
'KWFACNEOPmSy6Sb9bDoNZUVpDaZzNNtqIK9Brt4zjJLEsDfmkuW3S/SgIYBQ\n' +
'yTkuNmmAf8dr7L4fG0JlxPyGaL1/w9UDAr7xdU7WcHuyPc0edDGeE7NwaGWp\n' +
'uBipXFw8AkikV3fCTDuOi3uhkIzZ5zlGCshD7m0aDSABwr4hbFzLFBDSrsiW\n' +
'GKhWGYgf5Vx8qzlwXYYnoW/rn3UXWpeTXjq46ZNaxjHJ4VxGMyn/tHZOEjDE\n' +
'vHapLIAgGyw2b+s+zZSqsXaMkH8WOw==\n' +
'=gPzx\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
encryptedPrivateKey : '{"ciphertext":"4f1243e1ffa76180f46ade2eb093867750c6bf72e8d6c71c7c0edca176c2f9fb32c603bb5e52d933730e0350292431b6e5287b8201f60ce9151b6a141bde98cdc3d9e5df8f84e00e5e4173bdf28b66e9590db10195fbd41ed241a65ab84fb5da251f613376bf78efe1af64613dd54fb05dced7cf8de0907d61489712ad42f06b5c775d97d15dee09b1c58cd79f596674e403353bc7e03297aa0d3fdaecac573c962409622ff8b1335b6fbb661bd2d5f5a076d9079f857849ba917662b40151041eca71385844160fc603c4d1beefbf71b26ac8968de52d6bb534ef6d6e2ea987170059d7d881dc684d28b5b2817804fba3b659e3ec0e802583e581b9f75d2f7e69e428cba91e62719e9ca6697588389db89b982370d23952120c0f972ab4b3a0da888d52b5055c60785d276152e43929df532bc7d5d68c6bc3cfdd1ca780df346113999a19d8e4a96c02f149d1ee4cde802277081ef339153872c00c9e9ddfe3ba8da8c68c0565752fea32258087e66aab37397a27b0228b5ed1aeb09a93b80778fd7f949409106c4cd82ff550aafb9d7bdce8727a76882f59ef2c54a137e51f04b6c27a0b1b92cd781dafb489a5e8203232669f5416454cc9cfe8c5b0fd8abc19d9ef16285a8da0aca2ed747adef7b49b8215790266d9c4791c250b0580e89c6429d10a1bcd45cf016a7ae30e1db948147d992722a7191e31852e6fd3c3679d868f34ebbe65f255be4b90dd64ceb52eaeee7d3356683b7fd511729493c887289ddb0f00c65ca2a95114f0e37d3b73d06333e2787c5fa6dd6f6c9e8334ff153dd63e30c81247efd497cf2c038843d8653edf23822eae07dd19d0be26a921673185bcf016533fdb59150ff46096419e6a6aeb1bd4293fc8146848d715d43afd04aa40f2b5ae9d058671677aad2413952a20b5214e18bbf3b4b033d936d673a0302967de3f74b05b74bc6c89f30ddeaab1bf6c567fcee355797b6cba17c3fcc8955bdf096e2dda2577b3374089d8c9d287552e5658c91e812bd0b8b63482c8de98fde216dd557eb34bafca2f8e73dc4582fa36332e8869f2717519921605915d8e1c75a37295e198ec0af75926d89a6832456304474a10c567334998226d9b6f709ebc216fb067d958e78a622040c91f46af202273d0b40307fb34cba5a6a57fbb196ac6e88c16d527b9bdb04b12fa7ed0bc771692712ccd146c41890b5caddbbb13b8ba77e632b2d7597256fb576ce87d2aff35a0e953b8227a5dcbf30f7d189ca7f77f6f8b2c4eb2752199a7a485ab52a6b65b6edd6cf65caaeb6f65544cc74c2fb3431fa484fb69adbda08d2402da953f20425832b6a2d712d56a5cc34095f25fb9524a478a71d387b7dea45b4bd41e79c61dceca332898dfeecf83999ed4fad892e2ede714b93f3969ad140f38bfa95d321ae5ef089cf0ce435d59f8b6611c0fd014c67ed38646f0771f1a74c1f950ee0900d883aca3ec4efbb2f7737e717007ae757d874573d4d70c9d7e38f8ff30a29b983036e684c4eaf35a7c03ed32a8e3fc62f0863c56830127a5f3c0e905a93e7466a4f43f0793cb6752b9be8d03d7be26170f694ecbb200f611bbf1dac4b6ec085deb8c3d8ee188d8c9c8c17ca720c0f0dee4d00e5866b5443b6af6e69ca64b8eb5a8f5fa1e1d27bfacbf1b0ae11241215358f5045b0d1a73d1b15dbd904709340c1e2b42a4ef78f76b8f901d6337849cff1052f06a8919255b596fb36d2fdf789fdf611813d20729c26d517dde6f11a3f6045ec5158652e128cf7c483a0fb8ab772cb5cdb56e42e6bf8c863f173307c3e053168e54e9e65bcacbb144413ff76d08a94929e6cdde2c5944246a4b344f3ca0ada3b403429750bdce76f04668b05ed79e9119f00901e7f7b4f1eea8a1b5b0186e3ed41277040a257601b0f3917db595f3f1808d92071a4e9521a251e9c5a66f2c8a57511f61b9fd88df77330aeb4bc15c043814b33610d60f6d0a13fd7977efaa1843913f6d3a79bc88020406c9979163684efe7b7ade9613221d06b52cd96abd31b77a707748d52e6e16c8c90821f29359b35307c10dafce5f35c0ff9802c23aef19f0a95b49a317cd6207002a5a9b822b4c056c4cbf9b27045dda8325d93060f358bb837f00954a6e281d1bdd1817a7cce8ed4a801f9164d32c52739c1ac650109868664be1fabab47c675222dc9ff9d75f9fb49531c832264aa5b55998675975f59e34829ce90b00092bd77e46328a6459d5c967d905b8e976611b839925ad742500231fa86cb5f7e6f39cb1e2e36b81c55269ea0f5fdcba5c8c0e38a899540d52be49c83efae5243998b926f029dc2980d4fdb1c125db409d015e0b36bc02272da1c688ee1f61d23cbde585064ab1e2164d0ca529774ec7797407ba5d988c58853e74a124a64dc24d0289b6a599354faf64790177c3032f5d660d7b76dfbf1c03388a7c75b2309c509c6a92144e124c8bd188274bc844e8f0aa7b5a06e79ad5776b5a62003b89aef194dcc03cd3c1b1f3ea541805cfc4e18aa159f9b5395185b573538c9bab16876dff91f365d16dcc56b339b01b86882ef8e52c51edd9c5b2f8a35713ed6eb43036e09f64f6e59ab417958faff974b6705400b341439fef4cba371c601927da7e0a8f23e1c6d3e070a19c2216da85f159d60303ab1321e479f4c371372845cef03daa7d2776c18face6cfa2ff9eed26f9f0a353a0f1c9a99b2556dccc1212fcb5c2078a3b0e58a7f3f7b3f346d624435ef94c95d40dc726d2e7400ae405e89473a934e7646124e34473dfe17f7f9cf481aa059ef422508ffe67f9b9276084973db0683269a046c1a0aafa7ab075b28008cbfb862b7e30c8b2afa1c2923d914b3d2469266e8e0182274a3d8d89642723820e61aa2d97a9370789ec4e89ebee05b6c0bef10778caf2a34c2d7622dde5fa64b012bea6205127c3c845229ef553f013b73823dc6631078fc628532e3e518bdc790ab8460078dedf0c5cb00492136813e2b91679bba82f3cf95169751933bee4358f84154014dbcc1de1a30613218039ebb2444429380fd283d3b60bd5d5b470e861f6ecc751c22aa467168512a0ef45755e6b59a7be591bd3b08fde874b166ccfbbedba10a0956d2d18cbda515341c2112d6094a746e9f562db6543e5bde2c4d4f7c06b7550400d66f7242a14f34cd8a7374372f0eea49a49b72909fc11ff81ea54a1e2c07225cdee856383a657b0f13c14b00ae3b7b2a32a22beaab8cfd18641dbfa82619fdcdddd3339e9423e71c487305e8aa932b694e94c37c7e418e4014c8bb264f47e8283e216eeeabf0fbdd2f5eb8d0ea979738d4f18b7bf72d7711f5d22653f217c7305314ec2c47a0ecbf1dc8f9bc1379ae38e2a04e736a1171b947609bb66f8d352ce57230d709f196953471c5504c7f9f40ed2f64bf3bd04bd57521a364ea03b5f0603cceec7851738d97c3fd73c16547d4d143b009a79832a1ed244937dce09edf2d5e32ae52ab0331c449325dce9e5e8ed1563c967a5f92031f4275e3179274ef3e0752ac01caf8a20aabb23d584d4d6607833f95cfc92832d936c37bb8b37222aa842f48944d06b37434c8dce5f19b450a7d1bd568672ef2c8eaa2afb7cff404b33377a61061f56b01849feb918521a7d63cfbe12466aedc7159c577f213f2c157586b8719164cd7108edfa9211287b43aadbad997bc62f8169eec4a6e02aeb535f670878e6af538b5281da04470d318f893102613977390a434e0557302a68ce42e532d350446d4d813b84c07b42bf22fbe4889096ec6303574c95040d8dcfed1b9bd26782c5033d7d1a491fece156cbc19a705204ed38a547e00a09b73bc7a702ef9c2e659171d1daab63958268148aba59766bc7a4ffb68c1ae047d1f0c5fb45fbacd07079f72af301c6aa00eebc0662c6792fc707d388b339d4f45afbf576bacf8730ec3e0f1e9dc0f9a6d58fd146b2293aed8d110da24336f9a4c01ae12c03ce214c6502f5fbc5224dd8b8b2e4edf2af16b811e5c8595fa76cafe34ba66199caaed48b5dfd5ae74a3e6b6d51a09c70afc30ebc0f40d51a15f1a8c2c41ec482eddf14bed3fd11a9e2aa4446268af25b49e429e2528d5df57797f6f3cd431eb5ded8f830c85cecde8012c31500ce9363903739a6759704fa87bfef984ed0285c8c0a5bf2f0985b1b511eb4145e4b27e2df6aa7b5c7a913b76b1ca869151b75c0717389b3d186f4e4637a5ceba3cef64809c3a06551a6a46be31af61c0ef78afb057f6cc625647dc04dcd74eb97f7aee0f5640e24b7662c799013efb83c80ec2851acda7c6328de789ae99ce296494225bd169e49c9a12dc7e281778f7fe275e72571cd5a3608733998d2f6b96c1d26c25223153fc5afc2f6e3d72f57fbcb2d087d718d3b6703b286f1e340c23cd3bc715797edf3ce6d5169bcf783ac9686233cc0358725143008b25bfbd329e1c30654e4b4c9461239d41ae77f706e64e5e60ce6de83becfd056f2678f17474ab9f4976b2d7d5d014d78f716d7d4edbf6ce4ed44ed677274d6b9b6e4bf4946dfd1ed8b821c81957b4bf5cd534ed6ca84dadd9d6380513dc6406b32dcd5c1bfa468a79e88a56656e71aed0c6675540e1617a31e1c122295427590e83b63e8da58a6c5c21a15703994bdc2b90d399b62679a4269224257f3ead5a2dd0980e6f5a45c5a9392929cc4743e106c7335136c9f8a3a29190462eef908eab02cda97dbcb71dff26b0ef4dae51de293b4cff0ebf37fce1391247c5ccf77dfb64974c4a1e6beeaf82041bb0d653e2e9b612f3442bba8480b86fd7b35514fc056d7429d5fb36199d4a6f632ea615d9acc961082d9d91aca416b57582bcd2f182f5f5be02b3f597c680b2e6b37ee4d133e51d077491cb536d6261808c42684d0912fd7bcc97dacdf32394e7b","salt":"da23dc7dbf23136dabc337a0caa170c0db7e4efec5f5c8a648dff9b7cd7df49f","nonce":"fe0e4ec3d40fb7de21a354bf","version":"eip191-aes256-gcm-hkdf-sha256","preKey":"b43efae4c92a35d9c0b5f6178cb8b8a6642c77d0a9281f61beb9f6e8f7b006a5"}' ,
verificationProof : 'eip191v2:0x97ca70a87ec658e0e488e8b9f71644ee23840d809803fcf5bdcd174c9f39cdeb27f6e3a8885fec5bede5f264b3996bc3fa019b0d52745a5573a972b7e79e321c1c' ,
msgSent : 0 ,
maxMsgPersisted : 1000 ,
profile : {
name : null ,
desc : null ,
picture : '' ,
profileVerificationProof : null
} ,
origin : null ,
name : null ,
about : null ,
profilePicture : '' ,
numMsg : 0 ,
allowedNumMsg : 1000 ,
encryptionType : 'eip191-aes256-gcm-hkdf-sha256' ,
signature : '0x97ca70a87ec658e0e488e8b9f71644ee23840d809803fcf5bdcd174c9f39cdeb27f6e3a8885fec5bede5f264b3996bc3fa019b0d52745a5573a972b7e79e321c1c' ,
sigType : 'eip191v2' ,
encryptedPassword : null ,
nftOwner : null ,
linkedListHash : null ,
nfts : null
}
Parameter
Type
Remarks
did
string
user decentralized identity
wallets
string
all wallets associated to the did
publicKey
string
Public PGP key
encryptedPrivateKey
string
Encrypted PGP Private Key
verificationProof
string
Verification proof
msgSent
number
Number of messages sent
maxMsgPersisted
number
Maximum number of messages that can be persisted
profile
object
User profile information
origin
string
Origin information (source of the data)
name
string
Profile Name ( Deprecated )
about
string
Profile Description ( Deprecated )
profilePicture
string
Profile Picture ( Deprecated )
numMsg
number
Number of messages sent ( Deprecated )
allowedNumMsg
number
Maximum number of messages that can be persisted ( Deprecated )
encryptionType
string
Type of encryption used
signature
string
Account signature ( Deprecated )
sigType
string
Type of signature ( Dprecated )
encryptedPassword
null
Encrypted user password ( Deprecated )
nftOwner
null
Owner of NFT ( Deprecated )
linkedListHash
null
Deprecated
nfts
null
Information about owned NFTs( Dprecated )
// recevive stream related to chat
userAlice . stream . on ( STREAM . CHAT , ( data : any ) => {
console . log ( data )
} )
Expected response (Chat Request Stream)
{
"event" : "chat.request" ,
"origin" : "other" ,
"timestamp" : "1696576961629" ,
"chatId" : "b6f53ac38d0698ea64e6c4b0f024437ac2271ca869413d5f779d7cda75de1aaa" ,
"from" : "eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05" ,
"to" : [
"eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899"
] ,
"message" : {
"type" : "Text" ,
"content" : "Hey There!!!"
} ,
"meta" : {
"group" : false
} ,
"reference" : "bafyreid7b7m5ub3ouybgp2nzu733vle73bem5jcz5lg5u2epknncfhfeuy" ,
"raw" : {
"fromCAIP10" : "eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05" ,
"toCAIP10" : "eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899" ,
"fromDID" : "eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05" ,
"toDID" : "eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899" ,
"encType" : "pgp" ,
"encryptedSecret" : "-----BEGIN PGP MESSAGE-----\n\nwcBMAyaG8qwtJd4vAQf+JbzXYRQZ4Tm+8P+igfgH5kHFxMdd6XD11+UgyX3o\nhvxIaH43AjtpAuhNCvVVnmmIjWHAnCye7IDrT5BFEYVI03FaxxMyAwxvROTe\nb1xn4R5TmXPzuZ2N0AGbD1iTAqvPjLj3UvHJJihilOOAs5rqUNmWns4+xWr6\n8Znl5J2RyyqxJ3+LnHn4N6Spwm1gFzJ0alS2gwp+Tdi7OEPRiiWTkIcrdRcw\nKUv1i3aJw4Jyd9wDz6jldNBsa3L8RHUf47Oo4b/17dEqeFkioKCuWyH/DlKO\nkxZRsZEGUDR8ILKCRxbQw7RwWjxQnUeP+4oRuGC6P34zxZEJofHFz/8VWjlG\necHATAOhR72eaWLr8wEIAJEP2F/ocesJWKafpUzIN33fTTIFBjIvVB5GXb/V\nRvtwgRqsrKoudQLUf3ybsH2jw5JOmA8nV4Kc/aB/DVtvSyfObLxxngXe4HnD\n4OlUBGH80Z/RC2p6egrxIQUu1AMhTpu9SJ3HApTHHkDtGetp9Lnax5AxEV2t\ntFQWgkfwYy0xz2UuU+f85skTDgHBn7cW4Hb8WAaXWptpoGIlxMaVQYcHzA8A\ny7opcoPJPlE7AtRVQDmrQDLMZTRjxPwu9+vOYSh9bC3QFXE8PQeaseK379BG\no8wL6lnfX9mOdX3xaXRBuccm5akT61UGHnFH1zZv+rhyM67/bVCsIHEsG2Mt\nSHrSQAG/I7P/KleW2A4iEKPW8LAV1hGFkZZj1YumMGqHocTLncC8QwKzzHzi\nKyO4PxEL0qhgP16ya+vzT0PazgQnYtA=\n=AmIG\n-----END PGP MESSAGE-----\n" ,
"signature" : "-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7XBCRCfItQMnVG/eBYhBKTq6JYHJG7fZv5Yop8i1Ayd\nUb94AACmjgf/XGx0k/OMCg7XNIb5DjPMtiDuSU9Gm5KSUGhoBDIatNhrgZsj\nhULiKdk0DG1tk6G6a1/IpxM17obw4q3OI6QrT5TdgNS5c4kNRJ65xN0smxLl\nZC9fM5GEoTNI9CMIghH+zTesmVxkq6cS5iwzFJNgV05MoCa+HBCSHR3oLKFU\nH2muI7veUj1/yF93OEqtsqUjsgVr+bsqSVhwD8hcjS4AlRmHgBCLdwMWSOnK\nqFFV/0X/SZXnq0Jy2NULGFGTuQSV6NhB448HMEToxGrVbkYhPxRazBbEaSxD\nDrYQ+8b6EQBSJlPCKO3MAV8CNMNbfwwGo1RtXm6+xZj3DCHEdiU96w==\n=BRdW\n-----END PGP SIGNATURE-----\n" ,
"sigType" : "pgpv2" ,
"verificationProof" : "pgpv2:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7XBCRCfItQMnVG/eBYhBKTq6JYHJG7fZv5Yop8i1Ayd\nUb94AAClEggAxIFP9BJNwHzqUlEB8UD7gK+wNJxx5Nc7b31y0edUiSL6MWGL\n/b82efqACFNi2yc8/3xreJZr5ZuyHHSuCAb6zRamBS4QYTD+cMhNwpUTPiQE\ngyGZejVP8o+ko4N//itioi43BC619iSs7OTCvXkWS+gLFvOeRrBBPfp/15NG\nbeTavruBfiIUBR3YGtlcY296LLmo2YCEz49B1q/nQ+Ant1UNdhmuVhqU6W5l\nBzV3mLkxnlxpey9JNnNjC6tiKDB34OI06aYc863mLphk0R3obzGyt3XQqgL2\noteUPdkfPsJb3DCdq9F/XRNNJtypnAWeuMk8T5OK44FfLnjo26lwHQ==\n=QPQd\n-----END PGP SIGNATURE-----\n" ,
"previousReference" : null
}
}
Expected response (Chat Request Stream)
{
"event" : "chat.accept" ,
"origin" : "self" ,
"timestamp" : "1696576962016" ,
"chatId" : "b6f53ac38d0698ea64e6c4b0f024437ac2271ca869413d5f779d7cda75de1aaa" ,
"from" : "eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899" ,
"to" : [
"eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05"
] ,
"message" : {
"type" : null ,
"content" : null
} ,
"meta" : {
"group" : false
} ,
"reference" : null ,
"raw" : {
"fromCAIP10" : "eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899" ,
"toCAIP10" : "eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05" ,
"fromDID" : "eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899" ,
"toDID" : "eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05" ,
"encType" : "" ,
"encryptedSecret" : null ,
"signature" : "-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7XBCRAMkuwWk00HQxYhBKHMQtCl0iVWLJla7QyS7BaT\nTQdDAAAE+Af/U8h9c2tBPq6PjvDvjjs+yL/qTadagegzLZN0Gd9pT1kAmZ50\n+J1+f05oLCFdFcVTFz8dFZpueh+0s/8daXJ1uKVTBPPpfvWRInkD2KxlRrMu\n6gry3Tr2Fb1k8nIulIB/GSs7A85jJZQaG5WShZmfvg03bMadNIYmgl3ACmEe\nX3VovLFM5VLzuzKJGTn+7OM1VrZlZdsMRa7nfIdMKafMEEJcr41bmXCeYfzN\nw24kEO9/tAGaHzSRLsoNYxYDjby45OU1AJUHaLwjInk0klugcw7GWfMM3r2u\nE8qDuDZ0eveI6yArosK9amBlGF26l4UhEVPbCpumMrBBoItU03MPRw==\n=InOB\n-----END PGP SIGNATURE-----\n" ,
"sigType" : "pgp" ,
"verificationProof" : "pgp-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7XBCRAMkuwWk00HQxYhBKHMQtCl0iVWLJla7QyS7BaT\nTQdDAAAE+Af/U8h9c2tBPq6PjvDvjjs+yL/qTadagegzLZN0Gd9pT1kAmZ50\n+J1+f05oLCFdFcVTFz8dFZpueh+0s/8daXJ1uKVTBPPpfvWRInkD2KxlRrMu\n6gry3Tr2Fb1k8nIulIB/GSs7A85jJZQaG5WShZmfvg03bMadNIYmgl3ACmEe\nX3VovLFM5VLzuzKJGTn+7OM1VrZlZdsMRa7nfIdMKafMEEJcr41bmXCeYfzN\nw24kEO9/tAGaHzSRLsoNYxYDjby45OU1AJUHaLwjInk0klugcw7GWfMM3r2u\nE8qDuDZ0eveI6yArosK9amBlGF26l4UhEVPbCpumMrBBoItU03MPRw==\n=InOB\n-----END PGP SIGNATURE-----\n" ,
"previousReference" : null
}
}
Expected response (Chat Message Stream)
{
"event" : "chat.message" ,
"origin" : "other" ,
"timestamp" : "1696576962232" ,
"chatId" : "b6f53ac38d0698ea64e6c4b0f024437ac2271ca869413d5f779d7cda75de1aaa" ,
"from" : "eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05" ,
"to" : [
"eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899"
] ,
"message" : {
"type" : "Text" ,
"content" : "Hey There!!!"
} ,
"meta" : {
"group" : false
} ,
"reference" : "bafyreich6wtnzojmgqft6eudx43y4xir2emfnhxqlvyy7rq6a73w7szywe" ,
"raw" : {
"fromCAIP10" : "eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05" ,
"toCAIP10" : "eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899" ,
"fromDID" : "eip155:0x0aF73cF3b072E39A46D78E6c4fbaA058A138Bc05" ,
"toDID" : "eip155:0x52C6050536a77A405F03b6Da3F98Db9Ca69ad899" ,
"encType" : "pgp" ,
"encryptedSecret" : "-----BEGIN PGP MESSAGE-----\n\nwcBMAyaG8qwtJd4vAQf9Fg4udBKFN/Pqd9+bi5dqGnLr/PJbRHaIljRlzt5R\nm+6sPUeGyVkXcFdGbSnUKG0M7rtwKVOg0LiCX/oFx//k6ULJWJNVpuZsy4QT\nGYZevcU6dEPMMw4KSG/KJb+sdTAqlRPegibfrfg7YK/Mr9xd0DbN8K9CFsqC\nW/CYz0AkgZS/wN2099cy9WEgesv9yHMd1tU+59A/gAjmI5qk1ge3PvReKGP/\ncSWCX4wz0lioviib7g9zdw79ecpJThmWXKWaW/dPikcNYUTCbK31gY9TuRsy\nS+z+7AdddGj0hqgQvZIfj4XHgHbpQrRisddbgc1AE1xV7eiiT2jtNPswtsat\n48HATAOhR72eaWLr8wEIAJ06+SdpAuQT6mdlIAo/Kttiyd71UkxgMlappQKQ\nM5e2aei/H/C93EFYIitVHobeH/Q8Y89k4E+Plopo23OS6TGGbWIUl0PSJkyg\nxAIyC8J4RfqylCp+k/d9ZxZP/l0WrrXo9SqGOfXnAVm/IITLl8hlG7dvSztI\ng8ndUrk8Af3Jwq4vbrbUOMr2ophzV027HVWQl53Dez/e+DfpuyvT2uDAevTw\nf82H0+2DIz3jzj3rNfkvyA6C3InhW37K4JNh+T3XlL7qWV77XTWFN0yLzZwP\nrW0hLWV5YGAj0kqpup5oY4H1ANPknRiNxP6hUrQH5ZkHPahEUo78gpP70qgc\nZafSQAHfRbVWZC7J+0OF15W+dR3iM8Ngrz/PjYEchVo73a8uBtNk4mSai8o7\nv1A2hx74RVX6yN05D8Bxpf6u7wQMXB8=\n=T81R\n-----END PGP MESSAGE-----\n" ,
"signature" : "-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7XCCRCfItQMnVG/eBYhBKTq6JYHJG7fZv5Yop8i1Ayd\nUb94AAB/NQf/bwUkzVHV6/ODTtnjeA0y0kqEv3OAzbYoG60QdgNf3zAEmFbk\nf4ULNghzvl3Nt3S7TYsF06xu4gzzsjaOt8glPxJCiZUa3lXdJH53X5+VCbZV\nSWJuip9tdljAv4zg27+ZAGrwyC4NrTHE8t1b8mDHLTgJeqae6dJHjScmCXKZ\ngBZb2mNeVYWklg1mpCuXxB8YJpeFKDgSYeZ3C+YNSGAmoCyICRpYvxYo038P\nDehkFMS3HHvSGjFslcDN0D9l8gWY/4H520Rfer4GHJoFMSZeKlyWkQRCNPNz\nFY3fjmPLuimbEnnzd9Nxw1kbx4P9SBEEa4xhEjJnxx/sAnQxJX72RQ==\n=1zuZ\n-----END PGP SIGNATURE-----\n" ,
"sigType" : "pgpv2" ,
"verificationProof" : "pgpv2:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7XCCRCfItQMnVG/eBYhBKTq6JYHJG7fZv5Yop8i1Ayd\nUb94AACE2wf9GQq+/lkGQ7HVVmLF3SnSRI0IM9s4OvLckwjyd1i3D1lLnwu5\nVaPj+VxKZSBe+GHHukd/gQ+qYr9fhfHNMQ019AfHfz81kCCai6KhExH3YVbE\nsrL+j2bwttfcRjRWy/MoHo1T6M9F8PR4jm4aaktTSliApRE0k92Igm8Gw5it\nUaP1/qDIOQRjlofa7wAyDz7Kf83/WkbS78+MJZP0JWL9znhdFH5em8RvVYpS\nMa7/Skl8BnCr46BIfcd4Urd9q/RECKA4WJaxpOosH42MJQ4DLJ2iRnzZKkyr\nyZBfXXyiMA5goy+uzJzVhA5tlsHZp3jUFEZSvofaMX6a5UopweHMGw==\n=Wp+E\n-----END PGP SIGNATURE-----\n" ,
"previousReference" : "bafyreid7b7m5ub3ouybgp2nzu733vle73bem5jcz5lg5u2epknncfhfeuy"
}
}
Expected response (Chat Rejection Stream)
```tsx
{
"event": "chat.reject",
"origin": "self",
"timestamp": "1696577053528",
"chatId": "e819ff24ee06d44927bdc0c0967bd55b6410d389c29c72c329dcce4dca9f413d",
"from": "eip155:0xd49F5038C4baA79DF1f1191d6B18FF55D06a4648",
"to": [
"eip155:0x1fd48A2697Bdfd5A63436cEf5548e095649B65a7"
],
"message": {
"type": null,
"content": null
},
"meta": {
"group": false
},
"reference": null,
"raw": {
"fromCAIP10": "eip155:0xd49F5038C4baA79DF1f1191d6B18FF55D06a4648",
"toCAIP10": "eip155:0x1fd48A2697Bdfd5A63436cEf5548e095649B65a7",
"fromDID": "eip155:0xd49F5038C4baA79DF1f1191d6B18FF55D06a4648",
"toDID": "eip155:0x1fd48A2697Bdfd5A63436cEf5548e095649B65a7",
"encType": "",
"encryptedSecret": null,
"signature": "-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7YdCRCAVGEKwfvuDBYhBDuMv0sczhcV+XqGZYBUYQrB\n++4MAACNGQf/UM17dLBNzMLEmhfThqnxdXo1w1n4U/1DCSmzavvJ2CmCXvTU\nfekuTaxEEGQ83yKeI85KEkHdKgYpNmNa7O5OfOekjum4kRLi8qo4yVH6uard\nEiV+r4i52gWAqdrZOuFqWOLpbtWzMXF3gl6f+Sq5VT/SIi2/g5lO/bYd4QFX\n7cm/J+M5MzDJvxDht29bwDMylJVJXYr93xsEsLUAG0xo71mzsnEc7aSCxY71\nGw+4/KstoSDT40pvoZLw7qRidmHOt5QLHI6wpcztdo8ALDByYpIifV/J7lao\ns4bDS0TOXCb8/F6MQt2SXRKD8pIvzQ3CZBBZSKg+29Muq7Gw8hDq/A==\n=lcfd\n-----END PGP SIGNATURE-----\n",
"sigType": "pgp",
"verificationProof": "pgp-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7YdCRCAVGEKwfvuDBYhBDuMv0sczhcV+XqGZYBUYQrB\n++4MAACNGQf/UM17dLBNzMLEmhfThqnxdXo1w1n4U/1DCSmzavvJ2CmCXvTU\nfekuTaxEEGQ83yKeI85KEkHdKgYpNmNa7O5OfOekjum4kRLi8qo4yVH6uard\nEiV+r4i52gWAqdrZOuFqWOLpbtWzMXF3gl6f+Sq5VT/SIi2/g5lO/bYd4QFX\n7cm/J+M5MzDJvxDht29bwDMylJVJXYr93xsEsLUAG0xo71mzsnEc7aSCxY71\nGw+4/KstoSDT40pvoZLw7qRidmHOt5QLHI6wpcztdo8ALDByYpIifV/J7lao\ns4bDS0TOXCb8/F6MQt2SXRKD8pIvzQ3CZBBZSKg+29Muq7Gw8hDq/A==\n=lcfd\n-----END PGP SIGNATURE-----\n",
"previousReference": null
}
}
```
Expected response (Group Chat Message)
{
"event" : "chat.message" ,
"origin" : "self" ,
"timestamp" : "1696576220066" ,
"chatId" : "a64abd4256a607e7bd2ab4068d9024ddb0d355687267c0e39eb31a3a7d245ab0" ,
"from" : "eip155:0x9d57759F2D0cbf19D6cfAf72C5A4c4B1A2443500" ,
"to" : [
"a64abd4256a607e7bd2ab4068d9024ddb0d355687267c0e39eb31a3a7d245ab0"
] ,
"message" : {
"type" : "Text" ,
"content" : "Hello"
} ,
"meta" : {
"group" : true
} ,
"reference" : "bafyreidheq2764lxdi2plbp4mik24ohtjfyvfbmkde2wsb2ahvwdjrwygq" ,
"raw" : {
"fromCAIP10" : "eip155:0x9d57759F2D0cbf19D6cfAf72C5A4c4B1A2443500" ,
"toCAIP10" : "a64abd4256a607e7bd2ab4068d9024ddb0d355687267c0e39eb31a3a7d245ab0" ,
"fromDID" : "eip155:0x9d57759F2D0cbf19D6cfAf72C5A4c4B1A2443500" ,
"toDID" : "a64abd4256a607e7bd2ab4068d9024ddb0d355687267c0e39eb31a3a7d245ab0" ,
"encType" : "PlainText" ,
"encryptedSecret" : "" ,
"signature" : "-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7LcCRBG3kV4UbDyWhYhBPyPo+yD4wbsNV5YNkbeRXhR\nsPJaAABWfAf+MQFE/qy3X8R19wQeQ90eu6rYtK1h5aVlLwezo4z8F/8KqK1S\nwr8tlrtlQ9TieNH6Q5xebM2K356R44QnmE3qZB52Ukww2hiyrrCu7+x55KzK\na1+P8bQh1bGiesBYOa3LqnFlnFyQgBFJvGQqI0m2QBDbkM5OTkQGUYSi4tnO\nYIxVplb/lhEYHt/ZRGu1xg0XMhgycsRESidNLldKRx+AooeGfWgNIws97Yaq\nBbGTEgNOul8XV8b7y2ORL74Dl18UMPRF91dyktm/y8FJp30rWHaeNMAgKzlX\nr/nSgXFtCkfxclQgbBlSit1PBHmhB/Sr0amZKelpiYdRT+lVluknLg==\n=/QXX\n-----END PGP SIGNATURE-----\n" ,
"sigType" : "pgpv2" ,
"verificationProof" : "pgpv2:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7LcCRBG3kV4UbDyWhYhBPyPo+yD4wbsNV5YNkbeRXhR\nsPJaAAAHQQf/eb4aaRUTbcAwLRWlI+55Ddd1PBeWXhTyDIZgsiFYUwSmtLLd\n/bFHnQzyplo+Tp8BuUB+wO5dH112ousWxOeTj8yAGUve6OhbP/8g9nJmHecJ\nmZwAHPhr4BVYomQRQChLp8FstLLjiI3CNdfarIYzBmlWGhrurXltjx69e+Ef\nyxtxRZ6zZavG56IHhOJru0p3y1nsbNI5eGsXG9Wq3FdAUXhbsOizxDCAdqN/\nfzOmqnZGMKsk6DNQ1471txAGujbg29i9o41lxYGcuNYYMal0CEceawfMXDH8\n8T2fbILXRZzpX/I+dlArPMDHqLdfNu2uLwYOmq+aTv7qUm3t1SkR0w==\n=+0T5\n-----END PGP SIGNATURE-----\n" ,
"previousReference" : null
}
}
Expected response (Group Chat Request)
{
"origin" : "self" ,
"timestamp" : 1696576021653 ,
"chatId" : "3781b4193166ec8f0a1fabe162ef3f2458cac28516d4d20f8dd7faf446815900" ,
"from" : "eip155:0x136E326b22ED48dbB665733eC024407d4fAA4F12" ,
"to" : [
"eip155:0x3AD7cf4Ef82dd7f4f040c5eD7352f12C662F21db" ,
"eip155:0x1b77273e527Ec5948995f395e3ADa41E708d617e" ,
"eip155:0x7711FED1Bc6B1E461aE7869959bdBf529335db5A"
] ,
"event" : "chat.request" ,
"meta" : {
"group" : true
} ,
"raw" : {
"verificationProof" : "pgp:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7IVCRAxpSc3atCeoBYhBGHp9Ifk8vvLrMzkYTGlJzdq\n0J6gAAD//wf/bTrC0LnwzcUIE10d3XQ2Y56jK6kRVGWKR/7i6CC+hGs5PGKu\nzefIGdtLVjAqTeKn6PbNnb1t2niLhmMeTbN+knGCzSqx/FN8OodLLmunLNAx\nWJ5thFyjZWNyIF7IoH2zUdc8zbsjXHzfd70yoxMZSwd5C7EPj/e17kyYHdj2\nzPQecbTsnCIjJKzi0PBa2YMNoF5fExP3hwTnP0k693r8oC5ivxj7Ht3Hwmu0\njsv+sGXk+XZPC/JQQfEEviEh3j9dEiNIeHutk/7cFdEnDfEy5dFMxubjf6oH\nY6vt0q2V2CZJHHw99JYeTHN/d3YDXc4RggoUINo1cysR904owgEsVw==\n=QTX8\n-----END PGP SIGNATURE-----\n:0x136E326b22ED48dbB665733eC024407d4fAA4F12"
}
}
Expected response (Group Chat Request Accepted)
{
"event" : "chat.accept" ,
"origin" : "other" ,
"timestamp" : "1696576021843" ,
"chatId" : "3781b4193166ec8f0a1fabe162ef3f2458cac28516d4d20f8dd7faf446815900" ,
"from" : "eip155:0x3AD7cf4Ef82dd7f4f040c5eD7352f12C662F21db" ,
"to" : null ,
"message" : {
"type" : null ,
"content" : null
} ,
"meta" : {
"group" : true
} ,
"reference" : null ,
"raw" : {
"fromCAIP10" : "eip155:0x3AD7cf4Ef82dd7f4f040c5eD7352f12C662F21db" ,
"toCAIP10" : "3781b4193166ec8f0a1fabe162ef3f2458cac28516d4d20f8dd7faf446815900" ,
"fromDID" : "eip155:0x3AD7cf4Ef82dd7f4f040c5eD7352f12C662F21db" ,
"toDID" : "3781b4193166ec8f0a1fabe162ef3f2458cac28516d4d20f8dd7faf446815900" ,
"encType" : "" ,
"encryptedSecret" : null ,
"signature" : "-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7IVCRA1c2iyC1q/7RYhBH5kgFyUQlfGEgbg0jVzaLIL\nWr/tAABinQf9E+7UUlPnAVu9VifNHS6GJuf/o1RJdE8gL4mi27+rdfr+Y2+Y\nzZaZbBEJK3BTJgT4op1yJKtg2GZDZUIMWSbkcouE+2YyyYsANS89z/blq/05\nYf6RFuUeHr3pGIyzkeb7Aj7VEHbUhrK5nHheTkO7K6Gpa9blNEYVrhsYrHbs\n7UhYKlq6tsoo1E8XXFWBhd+2rVPKF4zhIt9jPdqNPYTQSn7K7hjVvZueWd0Z\nD7Vr4RO4Af3a/5EiVAvOtxVGLpwhw+FKDOGJhRdNCNLqEc8gZ0q+l1cvglKp\nfAiqSZpnnTzIUloszJvNFAeQSR/nZQ9wjEihosDztVOOz5uyQ3XhZw==\n=kX/p\n-----END PGP SIGNATURE-----\n" ,
"sigType" : "pgp" ,
"verificationProof" : "pgp-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7IVCRA1c2iyC1q/7RYhBH5kgFyUQlfGEgbg0jVzaLIL\nWr/tAABinQf9E+7UUlPnAVu9VifNHS6GJuf/o1RJdE8gL4mi27+rdfr+Y2+Y\nzZaZbBEJK3BTJgT4op1yJKtg2GZDZUIMWSbkcouE+2YyyYsANS89z/blq/05\nYf6RFuUeHr3pGIyzkeb7Aj7VEHbUhrK5nHheTkO7K6Gpa9blNEYVrhsYrHbs\n7UhYKlq6tsoo1E8XXFWBhd+2rVPKF4zhIt9jPdqNPYTQSn7K7hjVvZueWd0Z\nD7Vr4RO4Af3a/5EiVAvOtxVGLpwhw+FKDOGJhRdNCNLqEc8gZ0q+l1cvglKp\nfAiqSZpnnTzIUloszJvNFAeQSR/nZQ9wjEihosDztVOOz5uyQ3XhZw==\n=kX/p\n-----END PGP SIGNATURE-----\n" ,
"previousReference" : null
}
}
Expected response (Group Chat Request Rejected)
{
"event" : "chat.reject" ,
"origin" : "other" ,
"timestamp" : "1696576601599" ,
"chatId" : "7a200d55cc76428e9938e935b604e993c5f6cb2f3e9a1dd7108a07dd32de0791" ,
"from" : "eip155:0x15d8a67c0B1eb61dA5901109DB4CA382E989aA13" ,
"to" : null ,
"message" : {
"type" : null ,
"content" : null
} ,
"meta" : {
"group" : true
} ,
"reference" : null ,
"raw" : {
"fromCAIP10" : "eip155:0x15d8a67c0B1eb61dA5901109DB4CA382E989aA13" ,
"toCAIP10" : "7a200d55cc76428e9938e935b604e993c5f6cb2f3e9a1dd7108a07dd32de0791" ,
"fromDID" : "eip155:0x15d8a67c0B1eb61dA5901109DB4CA382E989aA13" ,
"toDID" : "7a200d55cc76428e9938e935b604e993c5f6cb2f3e9a1dd7108a07dd32de0791" ,
"encType" : "" ,
"encryptedSecret" : null ,
"signature" : "-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7RZCRA8vrXKPfPlwRYhBECQe8HJcpH3IRX27jy+tco9\n8+XBAADl0Af7BumEnrIcSj/1H3LvxaqG4wK/G6iTP3iTvXUca0n7UBplXS8P\nbKV7XFhjollN6jJVZ53mmUHgNDAbfaQTvutm3SRJlFVJxV4zV9uL7UMZW+k4\nYAJM5XNbqqyn7+KjcLIwBpJ3YLMmmLfdrO4+WJAYswAAJGiS+KPDsU+oOsfm\nHMWc5aRqis0Epf3FLWELO0uDyydm75575bBe60FxfPjnd5GhUgmMWydNCZH1\ngeGMLZbhuQ+bvnLjTuWSmnW64cl+jlRCzs2Mpgwvrh0ZQIcPWjVDjNevNohu\n3l9VXhHuYPUCyGGIyhcPG3tubRcudY+U/uavhQ6XXgWPVdKZ/qwfAw==\n=0jOy\n-----END PGP SIGNATURE-----\n" ,
"sigType" : "pgp" ,
"verificationProof" : "pgp-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7RZCRA8vrXKPfPlwRYhBECQe8HJcpH3IRX27jy+tco9\n8+XBAADl0Af7BumEnrIcSj/1H3LvxaqG4wK/G6iTP3iTvXUca0n7UBplXS8P\nbKV7XFhjollN6jJVZ53mmUHgNDAbfaQTvutm3SRJlFVJxV4zV9uL7UMZW+k4\nYAJM5XNbqqyn7+KjcLIwBpJ3YLMmmLfdrO4+WJAYswAAJGiS+KPDsU+oOsfm\nHMWc5aRqis0Epf3FLWELO0uDyydm75575bBe60FxfPjnd5GhUgmMWydNCZH1\ngeGMLZbhuQ+bvnLjTuWSmnW64cl+jlRCzs2Mpgwvrh0ZQIcPWjVDjNevNohu\n3l9VXhHuYPUCyGGIyhcPG3tubRcudY+U/uavhQ6XXgWPVdKZ/qwfAw==\n=0jOy\n-----END PGP SIGNATURE-----\n" ,
"previousReference" : null
}
}
Expected response (Participant is Removed from a Group)
{
"origin" : "other" ,
"timestamp" : 1696576219688 ,
"chatId" : "a64abd4256a607e7bd2ab4068d9024ddb0d355687267c0e39eb31a3a7d245ab0" ,
"from" : "eip155:0x50bbFA4833e89389FE00a62D14E6eDDf1c155855" ,
"to" : [
"eip155:0x50bbFA4833e89389FE00a62D14E6eDDf1c155855"
] ,
"event" : "chat.group.participant.remove" ,
"raw" : {
"verificationProof" : "pgp:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7LbCRByYd40HdgiDBYhBLSq7nZZRBYzsnezMXJh3jQd\n2CIMAADNoAf/UxniQM/ZtzDuSmhIuvWiuGzl8vkeFbN2dOLW1a2yJO2Z8jDa\nDDuxyTcSt9d9YyCO/NojhbxmScE73gBysVt9OLdUn9hXlAKclYjXu4r7KvLk\nmrQyMlN3akDjpzH1gGiiCSi18vll07KRGSgWt3P13cA9vGpT+YV3A6uiCGUS\nE3CV16wdYTd0FUPJHckTJVVu3se1K3NfzzELMwIeN9bPJLxaZD3u3t074dN/\nc+jwUS1OC0sUQ5ptHCgfNIMgtueutKSPPZO6MKVBE/qQauKh81PHgzrhW0OE\n6gMkSDPjVbncjBSumofTWga7udk65RhwysCxx9qa3O/u6skBH0N+bg==\n=oqeR\n-----END PGP SIGNATURE-----\n:0x50bbFA4833e89389FE00a62D14E6eDDf1c155855"
}
}
Expected response (Participant Joins a Group)
{
"origin" : "other" ,
"timestamp" : 1696576531987 ,
"chatId" : "1032596dea9f24a7a0ee419668f7d39da32a2fb32003a27c6b293cc6668d2a82" ,
"from" : "eip155:0x8c1EAB3227250526f133681630c2B191969f8581" ,
"to" : null ,
"event" : "chat.group.participant.join" ,
"raw" : {
"verificationProof" : "pgp:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7QTCRCI26TZ8c3OJBYhBNDtmDIWimjDn9MUIIjbpNnx\nzc4kAAAfFwgAgQkKBS/W7e53maVOne1lob2Qk14gWfUQm/LaRlP0iO5YwPlg\njckyQaX0Ient3PmLSqUoykuKWH2wR53YJ6Wgb//EkOxdywkrDbAZCGnQgxaO\nakTU30mDaV06HLQjDQmRTHdeozwV+6PF+i71vZPNmsCSI8x/VSex/gMrs2nk\nhSAHnuhUcuEWHshc+FXEO70acz8nkhH7Pw0icDwb50yFZNuekrK4rjUPmXb2\nwBzwFDjpfS6n8JMQz4//jYXyFuDfzYlr97ymWdltR5h8QKs1iZsN++X/5FsA\nO2EltMRqhxcpPApcHB9QQe6CAZFG+1fB8FKOXx6MZMwHqjyEtrL27Q==\n=bDP5\n-----END PGP SIGNATURE-----\n:0x8c1EAB3227250526f133681630c2B191969f8581"
}
}
Expected response (Participant Leaves a Group)
{
"origin" : "other" ,
"timestamp" : 1696576531987 ,
"chatId" : "1032596dea9f24a7a0ee419668f7d39da32a2fb32003a27c6b293cc6668d2a82" ,
"from" : "eip155:0x8c1EAB3227250526f133681630c2B191969f8581" ,
"to" : null ,
"event" : "chat.group.participant.leave" ,
"raw" : {
"verificationProof" : "pgp:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7QTCRCI26TZ8c3OJBYhBNDtmDIWimjDn9MUIIjbpNnx\nzc4kAAAfFwgAgQkKBS/W7e53maVOne1lob2Qk14gWfUQm/LaRlP0iO5YwPlg\njckyQaX0Ient3PmLSqUoykuKWH2wR53YJ6Wgb//EkOxdywkrDbAZCGnQgxaO\nakTU30mDaV06HLQjDQmRTHdeozwV+6PF+i71vZPNmsCSI8x/VSex/gMrs2nk\nhSAHnuhUcuEWHshc+FXEO70acz8nkhH7Pw0icDwb50yFZNuekrK4rjUPmXb2\nwBzwFDjpfS6n8JMQz4//jYXyFuDfzYlr97ymWdltR5h8QKs1iZsN++X/5FsA\nO2EltMRqhxcpPApcHB9QQe6CAZFG+1fB8FKOXx6MZMwHqjyEtrL27Q==\n=bDP5\n-----END PGP SIGNATURE-----\n:0x8c1EAB3227250526f133681630c2B191969f8581"
}
}
// recevive stream realated to group creation and updation
userAlice . stream . on ( STREAM . CHAT_OPS , ( data : any ) => {
console . log ( data )
} )
Expected response (Group Created)
{
"event" : "chat.group.create" ,
"origin" : "self" ,
"timestamp" : 1696576020848 ,
"chatId" : "3781b4193166ec8f0a1fabe162ef3f2458cac28516d4d20f8dd7faf446815900" ,
"from" : "eip155:0x136E326b22ED48dbB665733eC024407d4fAA4F12" ,
"meta" : {
"name" : "test" ,
"description" : "test" ,
"image" : "test" ,
"owner" : "eip155:0x136E326b22ED48dbB665733eC024407d4fAA4F12" ,
"members" : [ ] ,
"admins" : [
{
"address" : "eip155:0x136E326b22ED48dbB665733eC024407d4fAA4F12" ,
"profile" : {
"image" : "" ,
"publicKey" : "-----BEGIN PGP PUBLIC KEY BLOCK-----\n\nxsBNBGUfshMBCADOFCC0uSjbBGbjJi5QWaEtDpv7PMGqA0kU+e2mHBvZgGM2\nimibNukifrDArM+oJL3/OnjQHwkF5L6W3oCnKwe1hwSiceLDf3uR0F5E+wWA\nEeFv3xPdYYpqbT9tdYXlOCJpoSJH2TM7mcvSECltpSOIYAWpD2E450kTTHCJ\nYDrnrMdPifrCTSrfh4X1pKkbdSDJIrHHeqVTDcUPZhZlbXdEypqK4u5wjEqe\nLc/AprwDyeDx+ltGAo4hmD3ojHGkckk7ctW9RmdqGBGCB/VaK35JT0Tp6AQ8\nrmKOejF4nxbH5eCzUX4vC6xz666gWGj2eGDnS5XCGaBtfWfvYvTCoe4HABEB\nAAHNAMLAigQQAQgAPgUCZR+yEwQLCQcICRAxpSc3atCeoAMVCAoEFgACAQIZ\nAQIbAwIeARYhBGHp9Ifk8vvLrMzkYTGlJzdq0J6gAABuBwgAvNkpwWQCoB8D\nFC56ir7s2tRlzpIUb+nnK5ygqpxp/Wvo1+TpFoWGkdUOC0ng9H98MrJmEh1k\nhLkaBv1VPQN6l+O7tjAyvWNA+JfKLaefxc6EB0KFUOZH1E/gFWc8b6+cciXZ\npAINmBW8+PPSlt1EYuo2UAXqEAOW4dlez8Z6OCf7c4L7+MZKVv2a5r3Cqfl2\nNHaI4lHQYabWt1tsoVyN7kyfZkENXQQv3LsJ7o98WK0FnfFEM/hA1I5jM8Ww\nf0qBukDmzOTxtgYDE7mo3xHNDpjptr8lk5oOFPsHCpOwgksAVKK4yHqy4aQe\nqXPBjBMmUBUuSlB/8KwI6FtX2JFm9s7ATQRlH7ITAQgAySkQBm6drDe5FJI1\nUe5QhoUXX8ugfXyCR7SoL4JMxVmhaO9/Fj/Swy1UoagONZYJZzcamJWnPzAR\nvfYBEzSEFGrkPKVdrJAM7Zf1sX5v+wpUtLTE6/gSCzAJMnK11pdgTHqEn+Rc\nfPuTnGYFZw3EybYMbhr/wBCyvFd49ES+8q3jrjHbMGS5lFCnVFYE/gyN9nqp\nSG0biMS7pl+w51bjIfJ9bRiUzrxpk5yvr9WDqMTVJA0N6ZRsD+xtkipc7XFe\nnsY0caCVVYFOH9YCiwuytC4ShU2VHjEPXcgzLTk9k5ecfE8AdwiYgLsWOHTn\nbz1JpwqYJx5Rndkb4vXdV6Pi7wARAQABwsB2BBgBCAAqBQJlH7ITCRAxpSc3\natCeoAIbDBYhBGHp9Ifk8vvLrMzkYTGlJzdq0J6gAACZvQgAyJrLhQ9/MsBU\n6E1ZwdKlKBWi62A4SBXRZJpRl2hBwagyNq7zbsX/yO7D7fW1FVLfcT28cmCe\nCUD6aa904dQ8GVDyuUqRsSXZZvZqFdddgNT7O8fCbIbMCihfz9Gg6mbxVHcy\nOby7nkOBbrKDBpIPab9yMHHYsycsPDo8/8cGI9RNZz06aAgOVGjfcMTuw8RR\nXWINBmTWn9I4xrylEtH7SQU9b0Alj2SxfV9N/+mMGGv/Zo3E99/a/p2DLExY\n/+dk0I9kxjxHkjtq49/tT00JYLDkHVtMgGxjl9n8Uv7KXFHkuGFg7gV9ivdN\n1phi4oalkdY5sqbd5GkUxM7M1VN6Xg==\n=nCF5\n-----END PGP PUBLIC KEY BLOCK-----\n"
}
}
] ,
"pending" : {
"members" : [ ] ,
"admins" : [ ]
} ,
"private" : false ,
"rules" : { }
} ,
"raw" : {
"verificationProof" : "pgp:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7IUCRAxpSc3atCeoBYhBGHp9Ifk8vvLrMzkYTGlJzdq\n0J6gAADrLAgAgDSQ7CJ3ZVOPye++rkpyR4Q9XSGnV3Z0bqO+HCqFDW/hTmJ+\n12kjrAQV43Q1fQviIMqh+RTA9WJHPA14vu/ZYHjmCM/HfPSxbY4zV/7FJF9C\nCaEgq+wGs+2vhixHX4Zoo4qrxdXQ6q8Wl4XXW3SVaw1sGxfIh+uMje54Tsil\nnaLNK+lIPdSAJDw1hOHIM3iMWaSzZasLaXkJ6KY9KefW52mhg112BZI94FxJ\n/wFQtlIaXGZHhCbaqiigjRPKo17KyW7PX6I0rTAQJlwHyIKS/vIH8Uahi2x3\ndzjonpXjjtsgcP+VhzEP1jxQkpo4mG47Fxkxzp/Q7ztdSGHnJGlXkQ==\n=HydQ\n-----END PGP SIGNATURE-----\n"
}
}
Expected response (Group Updated)
{
"event" : "chat.group.update" ,
"origin" : "self" ,
"timestamp" : 1696576021192 ,
"chatId" : "3781b4193166ec8f0a1fabe162ef3f2458cac28516d4d20f8dd7faf446815900" ,
"from" : "eip155:0x136E326b22ED48dbB665733eC024407d4fAA4F12" ,
"meta" : {
"name" : "test" ,
"description" : "Updated Description" ,
"image" : "test" ,
"owner" : "eip155:0x136E326b22ED48dbB665733eC024407d4fAA4F12" ,
"members" : [ ] ,
"admins" : [
{
"address" : "eip155:0x136E326b22ED48dbB665733eC024407d4fAA4F12" ,
"profile" : {
"image" : "" ,
"publicKey" : "-----BEGIN PGP PUBLIC KEY BLOCK-----\n\nxsBNBGUfshMBCADOFCC0uSjbBGbjJi5QWaEtDpv7PMGqA0kU+e2mHBvZgGM2\nimibNukifrDArM+oJL3/OnjQHwkF5L6W3oCnKwe1hwSiceLDf3uR0F5E+wWA\nEeFv3xPdYYpqbT9tdYXlOCJpoSJH2TM7mcvSECltpSOIYAWpD2E450kTTHCJ\nYDrnrMdPifrCTSrfh4X1pKkbdSDJIrHHeqVTDcUPZhZlbXdEypqK4u5wjEqe\nLc/AprwDyeDx+ltGAo4hmD3ojHGkckk7ctW9RmdqGBGCB/VaK35JT0Tp6AQ8\nrmKOejF4nxbH5eCzUX4vC6xz666gWGj2eGDnS5XCGaBtfWfvYvTCoe4HABEB\nAAHNAMLAigQQAQgAPgUCZR+yEwQLCQcICRAxpSc3atCeoAMVCAoEFgACAQIZ\nAQIbAwIeARYhBGHp9Ifk8vvLrMzkYTGlJzdq0J6gAABuBwgAvNkpwWQCoB8D\nFC56ir7s2tRlzpIUb+nnK5ygqpxp/Wvo1+TpFoWGkdUOC0ng9H98MrJmEh1k\nhLkaBv1VPQN6l+O7tjAyvWNA+JfKLaefxc6EB0KFUOZH1E/gFWc8b6+cciXZ\npAINmBW8+PPSlt1EYuo2UAXqEAOW4dlez8Z6OCf7c4L7+MZKVv2a5r3Cqfl2\nNHaI4lHQYabWt1tsoVyN7kyfZkENXQQv3LsJ7o98WK0FnfFEM/hA1I5jM8Ww\nf0qBukDmzOTxtgYDE7mo3xHNDpjptr8lk5oOFPsHCpOwgksAVKK4yHqy4aQe\nqXPBjBMmUBUuSlB/8KwI6FtX2JFm9s7ATQRlH7ITAQgAySkQBm6drDe5FJI1\nUe5QhoUXX8ugfXyCR7SoL4JMxVmhaO9/Fj/Swy1UoagONZYJZzcamJWnPzAR\nvfYBEzSEFGrkPKVdrJAM7Zf1sX5v+wpUtLTE6/gSCzAJMnK11pdgTHqEn+Rc\nfPuTnGYFZw3EybYMbhr/wBCyvFd49ES+8q3jrjHbMGS5lFCnVFYE/gyN9nqp\nSG0biMS7pl+w51bjIfJ9bRiUzrxpk5yvr9WDqMTVJA0N6ZRsD+xtkipc7XFe\nnsY0caCVVYFOH9YCiwuytC4ShU2VHjEPXcgzLTk9k5ecfE8AdwiYgLsWOHTn\nbz1JpwqYJx5Rndkb4vXdV6Pi7wARAQABwsB2BBgBCAAqBQJlH7ITCRAxpSc3\natCeoAIbDBYhBGHp9Ifk8vvLrMzkYTGlJzdq0J6gAACZvQgAyJrLhQ9/MsBU\n6E1ZwdKlKBWi62A4SBXRZJpRl2hBwagyNq7zbsX/yO7D7fW1FVLfcT28cmCe\nCUD6aa904dQ8GVDyuUqRsSXZZvZqFdddgNT7O8fCbIbMCihfz9Gg6mbxVHcy\nOby7nkOBbrKDBpIPab9yMHHYsycsPDo8/8cGI9RNZz06aAgOVGjfcMTuw8RR\nXWINBmTWn9I4xrylEtH7SQU9b0Alj2SxfV9N/+mMGGv/Zo3E99/a/p2DLExY\n/+dk0I9kxjxHkjtq49/tT00JYLDkHVtMgGxjl9n8Uv7KXFHkuGFg7gV9ivdN\n1phi4oalkdY5sqbd5GkUxM7M1VN6Xg==\n=nCF5\n-----END PGP PUBLIC KEY BLOCK-----\n"
}
}
] ,
"pending" : {
"members" : [ ] ,
"admins" : [ ]
} ,
"private" : false ,
"rules" : { }
} ,
"raw" : {
"verificationProof" : "pgp:-----BEGIN PGP SIGNATURE-----\n\nwsBzBAEBCAAnBQJlH7IVCRAxpSc3atCeoBYhBGHp9Ifk8vvLrMzkYTGlJzdq\n0J6gAACfBQgAgDYEX8fSjArginDEbjDmMxQxmieIMt3/N2wTjWU/r8muAnNb\nIpijtAvftEkCoVnefXH9rlILr0rUGLwFXTsc6YYO6u9Tr1iODQQZopD8Bqtc\ntKE5RzRT6qS6QUQQP8YNlh/iqtTWCzdY7aYKGNWkrSOUKhu+iHKLIsEqNSf2\nYV9S9qksGWhK9xfsExkHjR0Df3yo/BUwpDKW/duiwBPgl99aUYunjAQyRRun\njlXmX6W+bEAlEmJABq5C9Tw+M/+j4AiBy57kdrxAQ6aKHnfGJafH7Xo8/BuN\nG6XJdNELJKug/5Xb+eWjO3JggGOD90fetTKcVdzGJPhXaVyIhL0e/A==\n=+sdF\n-----END PGP SIGNATURE-----\n:0x136E326b22ED48dbB665733eC024407d4fAA4F12"
}
}
// pre-requisite API calls that should be made before
// need to get user and through that encryptedPvtKey of the user
const user = await PushAPI . user . get ( account : 'eip155:0xFe6C8E9e25f7bcF374412c5C81B2578aC473C0F7' , env : 'staging' ) ;
// need to decrypt the encryptedPvtKey to pass in the api using helper function
const pgpDecryptedPvtKey = await PushAPI . chat . decryptPGPKey ( encryptedPGPPrivateKey : user . encryptedPrivateKey , signer : _signer ) ;
// actual api
const response = await PushAPI . space . create ( {
spaceName :'wasteful_indigo_warbler' ,
spaceDescription : 'boring_emerald_gamefowl' ,
listeners : [ '0x9e60c47edF21fa5e5Af33347680B3971F2FfD464' , '0x3829E53A15856d1846e1b52d3Bdf5839705c29e5' ] ,
spaceImage : & lt ; space image link & gt ; ,
speakers : [ '0x3829E53A15856d1846e1b52d3Bdf5839705c29e5' ] ,
isPublic : true ,
account : '0xD993eb61B8843439A23741C0A3b5138763aE11a4' ,
env : 'staging' ,
pgpPrivateKey : pgpDecryptedPvtKey , //decrypted private key
scheduleAt : new Date ( "2024-07-15T14:48:00.000Z" ) ,
scheduleEnd : new Date ( "2024-07-15T15:48:00.000Z" )
} ) ;
To create a token gated space
// pre-requisite API calls that should be made before
// need to get user and through that encryptedPvtKey of the user
const user = await PushAPI . user . get ( account : 'eip155:0xFe6C8E9e25f7bcF374412c5C81B2578aC473C0F7' , env : 'staging' ) ;
// need to decrypt the encryptedPvtKey to pass in the api using helper function
const pgpDecryptedPvtKey = await PushAPI . chat . decryptPGPKey ( encryptedPGPPrivateKey : user . encryptedPrivateKey , signer : _signer ) ;
// actual api
const response = await PushAPI . space . create ( {
spaceName :'wasteful_indigo_warbler' ,
spaceDescription : 'boring_emerald_gamefowl' ,
listeners : [ '0x9e60c47edF21fa5e5Af33347680B3971F2FfD464' , '0x3829E53A15856d1846e1b52d3Bdf5839705c29e5' ] ,
spaceImage : & lt ; space image link & gt ; ,
speakers : [ '0x3829E53A15856d1846e1b52d3Bdf5839705c29e5' ] ,
rules : {
'spaceAccess' : {
'conditions' : [
{
'any' : [
{
'type' : 'PUSH' ,
'category' : 'ERC20' ,
'subcategory' : 'holder' ,
'data' : {
'contract' : 'eip155:5:0x2b9bE9259a4F5Ba6344c1b1c07911539642a2D33' ,
'amount' : 1000 ,
'decimals' : 18
}
} ,
{
'type' : 'GUILD' ,
'category' : 'guildRoles' ,
'subcategory' : 'specificRole' ,
'data' : {
'guildId' : '13468' ,
'guildRoleId' : '19924'
}
}
]
}
]
}
} ,
isPublic : true ,
account : '0xD993eb61B8843439A23741C0A3b5138763aE11a4' ,
env : 'staging' ,
pgpPrivateKey : pgpDecryptedPvtKey , //decrypted private key
scheduleAt : new Date ( "2024-07-15T14:48:00.000Z" ) ,
scheduleEnd : new Date ( "2024-07-15T15:48:00.000Z" )
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
account_
string
-
user address
spaceName*
string
-
group name
spaceDescription*
string
-
group description
spaceImage*
string
-
group image link
listeners*
Array
-
wallet addresses of all listeners except speakers and spaceCreator
speakers*
Array
-
wallet addresses of all speakers except listeners and spaceCreator
isPublic*
boolean
-
true for public space, false for private space
scheduleAt*
Date
-
Date time when the space is scheduled to start
scheduleEnd
Date
-
Date time when the space is scheduled to end
contractAddressERC20 (deprecated)
string
null
ERC20 Contract Address
numberOfERC20 (deprecated)
int
0
Minimum number of tokens required to join the group
contractAddressNFT (deprecated)
string
null
NFT Contract Address
numberOfNFTTokens (deprecated)
int
0
Minimum number of nfts required to join the group
rules
Rules
-
conditions for space access (see format below)
pgpPrivateKey
string
null
mandatory for users having pgp keys
env
string
'prod'
API env - 'prod', 'staging', 'dev'
export enum ConditionType {
PUSH = 'PUSH' ,
GUILD = 'GUILD' ,
}
export type Data = {
contract ?: string ;
amount ?: number ;
decimals ?: number ;
guildId ?: string ;
guildRoleId ?: string ;
guildRoleAction ?: 'all' | 'any' ;
url ?: string ;
comparison ?: '>' | '<' | '>=' | '<=' | '==' | '!=' ;
} ;
export type ConditionBase = {
type ?: ConditionType ;
category ?: string ;
subcategory ?: string ;
data ?: Data ;
access ?: Boolean ;
} ;
export type Condition = ConditionBase & {
any ?: ConditionBase [ ] ;
all ?: ConditionBase [ ] ;
} ;
export interface Rules {
entry ?: {
conditions : Array < Condition | ConditionBase > ;
} ;
chat ?: {
conditions : Array < Condition | ConditionBase > ;
} ;
}
Expected response (create space)
// PushAPI.space.create | Response - 200 OK
{
members : [ {
wallet : 'eip155:0x727C819feB2c7F99c66d71B8411521bca2010023' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSrssEBCACg3ZjrZB40Xqr5IKIEtFldaeQyJPNwDACMekY77yApav0B\n' +
'RwiqhFJDFJKcprSHg/vYdqalAIGRQ+J98VMBtHweurIubD/ODB6WknOms7ZY\n' +
'3ummaEzyFRombuq/C75o/0ImCi2v0PJBI3kdpwzOjiTt8S44yoAVOcTf9jyg\n' +
'vTEVCOM81yqCf0mDB4t0jqRYewlQuJegORXDKHKTfZcnQybBkDYUGgmxOcyF\n' +
'BaPMhSiWqAAqqb4gcFO2QKq69JoiE9dzSuF/7dvAq2QZRogC/GQW2Q9yQbq3\n' +
'CvMNO4H2KUZzegaq2s2nMPGMXPNf4GZcZVJE1phWgAnApxTf5kUFfKr1ABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKuywQQLCQcICZDwrCS5ulOLwQMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBFKpO7zcSRed+QmbIfCsJLm6U4vBAABZMwf+OIbBcFQ7x++1\n' +
'NINOYbP9v0PyJvpllDcUORbk3uiPMpvDuQYAe2Fd4dY2Y91l3VdpIm/w6HQy\n' +
'y81Y694w4E7PRVhDwHivv5D10VE9MF3h6qOHrLLpvdhpMaB5Ur8ts5rU2zOu\n' +
'64HR04/BVO9N0nrE9iywIgVMOy6IrS+OgK3r75PPX35bam/kbbmZHeygFaE9\n' +
'+mgQVdhwgF5borekIiz1Rc8CPA/P1yZy8QQl4KGmJEs+hOc5rPnUWwarvaAH\n' +
'mPb6H0/mG81eXBOjpJlSFu6d/uqKLpoAw5fkvFoIsNwovYpyQkSbhzwe4T2N\n' +
'jGqGd0+La03QdB5FbaiwcnJ96lU6oM7ATQRkq7LBAQgAxu9uK1+p62+/RvcF\n' +
'Mz7g3A8SJiN76NYxk29sjQ9gW74B/IdPv5TlUVhG6PGr2c3SucASlEHieagY\n' +
'CXM2+fpdu4rQ6EKRAe+30GFopfzhX1d0zv9d5BE6q1ML5mkrpDECH5iuqah7\n' +
'smmbRdWE7zRSGaHyEfVqAG3wfMzzN0BcchxxR4vMCNKYLs9v2Q09ecO7DgaY\n' +
'5CZqxaFlTo+auuDhE0XU7WRbNL77izocV1Sm+McRyo28PrFTcrRRznD1nP0V\n' +
'eZ4+aoulqyYA+gBBaIUdSA5kQXJiy67crB50yX3V6zLIfptD2ThHPjTY/inW\n' +
'wVHVug4jIWUQ1QQw/q9qvGxAzQARAQABwsB2BBgBCAAqBYJkq7LBCZDwrCS5\n' +
'ulOLwQKbDBYhBFKpO7zcSRed+QmbIfCsJLm6U4vBAADu6wf+NJDX/3NAxQKN\n' +
'Iigj0GkBm/y69iFmQvWJxxtiYCNu8VBhm8MkcghUJ8G2tWP9ueUOM8sMTEa+\n' +
'G+l+wSNwh/1yisF3FutDpy6l+fiy6kPPD4vl08jY3GrqSuWWfMxTJhMZ5D6v\n' +
'OW2EfdyET+oP5eOnCd6p0EXP2ic48rVHDdU2iWeg0RkGvZP3t2LljWFdLbvw\n' +
'h7+wSD1i4LY4slUIdbLdDSLN1gWFN1HXzX10mpX0grV2sBdfkNyHhF0WcIat\n' +
'sD9HpAx2M62yP2D9D9UZVrW7WfmOoyL1NrnXSJsI8CRFDzujvpIrr7875zSi\n' +
'VnxDVyt7twc7cYqRDHsNYuxAuE815A==\n' +
'=2jvb\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
} ] ,
pendingMembers : [ {
wallet : 'eip155:0x5f4e9e7Fcc17a943178c0b0881b09E8Ef9D34437' ,
publicKey : null ,
isSpeaker : false ,
image : null
} ,
{
wallet : 'eip155:0xFedfA2b276676C5c6ce753ddb4B05d00104E9236' ,
publicKey : null ,
isSpeaker : false ,
image : null
}
] ,
contractAddressERC20 : "0x8Afa8FDf9fB545C8412499E8532C958086608b30" ,
numberOfERC20 : 20 ,
contractAddressNFT : "0x42af3147f17239341477113484752D5D3dda997B" ,
numberOfNFTTokens : 2 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkq7LBCZDwrCS5ulOLwRYhBFKpO7zcSRed+QmbIfCsJLm6\n' +
'U4vBAAAAHwf+K4f0gxaP56X4Cv2zlPWB9iUPi/1FOnx8ZF7oEf9xJSv/xA7v\n' +
'9LHBTZ2Y9AQlJpy0WLB7KGF7mVV1MdUKHjn2SFQ+1h+8d+FIHXfmB7Ie4alP\n' +
'nnar6XjtMVKYyqXRzMzCq2F7Fjea1sUOXBxAeyJstAGG6nvsU51imaAtGQlQ\n' +
'u7ih8D9UkiOe719v5GyI1vtiS+hHGlYo0+A7WVImH6SuVyPZ3UyPvLxXpeKs\n' +
'1SeEfuvfmKHbswm1DDGOknyo7fJ/QgKqOfkwsBIrYRNGwPGEKt8pHdwNxsNn\n' +
'hNQtlFqtmtvieaxbhJQKXHbVgNv206xNsUBrK/U2nCakx7EMmxikFg==\n' +
'=tz9T\n' +
'-----END PGP SIGNATURE-----\n' ,
spaceImage : '' ,
spaceName : 'wasteful_indigo_warbler' ,
isPublic : true ,
spaceDescription : 'boring_emerald_gamefowl' ,
spaceCreator : 'eip155:0x727C819feB2c7F99c66d71B8411521bca2010023' ,
spaceId : 'spaces:e0553610da88dacac70b406d1222a6881c0bde2c5129e58b526b5ae729d82116' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'PENDING' ,
rules : {
'spaceAccess' : {
'conditions' : [
{
'any' : [
{
'type' : 'PUSH' ,
'category' : 'ERC20' ,
'subcategory' : 'holder' ,
'data' : {
'contract' : 'eip155:5:0x2b9bE9259a4F5Ba6344c1b1c07911539642a2D33' ,
'amount' : 1000 ,
'decimals' : 18
}
} ,
{
'type' : 'GUILD' ,
'category' : 'guildRoles' ,
'subcategory' : 'specificRole' ,
'data' : {
'guildId' : '13468' ,
'guildRoleId' : '19924'
}
}
]
}
]
}
}
}
To check user access of a token gated space
// actual api
const response = await PushAPI . space . getAccess ( {
spaceId :'8f7be0068a677df166c2e5b8a9030fe8a4341807150339e588853c0049df3106' ,
did : '0x9e60c47edF21fa5e5Af33347680B3971F2FfD464'
env : 'staging' ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId
string
-
space address
did
string
-
user address
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (space access)
// PushAPI_chat_getSpaceAccess | Response - 200 OK
{
'spaceAccess' : true ,
'rules' : {
'spaceAccess' : {
'conditions' : [
{
'any' : [
{
'type' : 'PUSH' ,
'category' : 'ERC20' ,
'subcategory' : 'holder' ,
'data' : {
'contract' : 'eip155:5:0x2b9bE9259a4F5Ba6344c1b1c07911539642a2D33' ,
'amount' : 1000 ,
'decimals' : 18
} ,
'access' : false
} ,
{
'type' : 'GUILD' ,
'category' : 'guildRoles' ,
'subcategory' : 'specificRole' ,
'data' : {
'guildId' : '13468' ,
'guildRoleId' : '19924'
} ,
'access' : true
} ,
{
'type' : 'PUSH' ,
'category' : 'ERC721' ,
'subcategory' : 'owner' ,
'data' : {
'contract' : 'eip155:5:0x42af3147f17239341477113484752D5D3dda997B' ,
'amount' : 1
} ,
'access' : true
}
]
}
]
}
}
Note - updateSpace is an idompotent call
// pre-requisite API calls that should be made before
// need to get user and through that encryptedPvtKey of the user
const user = await PushAPI . user . get ( account : 'eip155:0xFe6C8E9e25f7bcF374412c5C81B2578aC473C0F7' , env : 'staging' ) ;
// need to decrypt the encryptedPvtKey to pass in the api using helper function
const pgpDecryptedPvtKey = await PushAPI . chat . decryptPGPKey ( encryptedPGPPrivateKey : user . encryptedPrivateKey , signer : _signer ) ;
// actual api
const response = await PushAPI . space . update ( {
spaceId : 'spaces:e0553610da88dacac70b406d1222a6881c0bde2c5129e58b526b5ae729d82116' ,
spaceName : 'Push Space 3' ,
spaceDescription : 'This is the oficial space for Push Protocol' ,
listeners : [ '0x2e60c47edF21fa5e5A333347680B3971F1FfD456' , '0x3829E53A15856d1846e1b52d3Bdf5839705c29e5' ] ,
spaceImage : & lt ; group image link & gt ; ,
speakers : [ '0x3829E53A15856d1846e1b52d3Bdf5839705c29e5' ] ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : PushAPI . ChatStatus . PENDING ,
account : '0xD993eb61B8843439A23741C0A3b5138763aE11a4' ,
env : 'staging' ,
pgpPrivateKey : pgpDecryptedPvtKey , //decrypted private key
} ) ;
To update token gated space details
Note - updateSpace is an idompotent call
// pre-requisite API calls that should be made before
// need to get user and through that encryptedPvtKey of the user
const user = await PushAPI . user . get ( account : 'eip155:0xFe6C8E9e25f7bcF374412c5C81B2578aC473C0F7' , env : 'staging' ) ;
// need to decrypt the encryptedPvtKey to pass in the api using helper function
const pgpDecryptedPvtKey = await PushAPI . chat . decryptPGPKey ( encryptedPGPPrivateKey : user . encryptedPrivateKey , signer : _signer ) ;
// actual api
const response = await PushAPI . space . update ( {
spaceId : 'spaces:e0553610da88dacac70b406d1222a6881c0bde2c5129e58b526b5ae729d82116' ,
spaceName : 'Push Space 3' ,
spaceDescription : 'This is the oficial space for Push Protocol' ,
listeners : [ '0x2e60c47edF21fa5e5A333347680B3971F1FfD456' , '0x3829E53A15856d1846e1b52d3Bdf5839705c29e5' ] ,
spaceImage : & lt ; group image link & gt ; ,
speakers : [ '0x3829E53A15856d1846e1b52d3Bdf5839705c29e5' ] ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : PushAPI . ChatStatus . PENDING ,
rules : {
'entry' : {
'conditions' : [
{
'any' : [
{
'type' : 'PUSH' ,
'category' : 'ERC20' ,
'subcategory' : 'token_holder' ,
'data' : {
'address' : 'eip155:5:0x2b9bE9259a4F5Ba6344c1b1c07911539642a2D33' ,
'amount' : 1000 ,
'decimals' : 18
}
} ,
{
'type' : 'GUILD' ,
'category' : 'guildRoles' ,
'subcategory' : 'allRoles' ,
'data' : {
'guildId' : '13468'
}
}
]
}
]
} ,
'chat' : {
'conditions' : [
{
'all' : [
{
'type' : 'PUSH' ,
'category' : 'ERC20' ,
'subcategory' : 'token_holder' ,
'data' : {
'address' : 'eip155:5:0x2b9bE9259a4F5Ba6344c1b1c07911539642a2D33' ,
'amount' : 1000 ,
'decimals' : 18
}
} ,
{
'type' : 'GUILD' ,
'category' : 'guildRoles' ,
'subcategory' : 'specificRole' ,
'data' : {
'guildId' : '13468' ,
'guildRoleId' : '19924'
}
}
]
}
]
}
} ,
account : '0xD993eb61B8843439A23741C0A3b5138763aE11a4' ,
env : 'staging' ,
pgpPrivateKey : pgpDecryptedPvtKey , //decrypted private key
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId_
string
-
Id of the space
account*
string
-
user address
spaceName*
string
-
space name
spaceDescription*
string
-
space description
spaceImage*
string
-
space image
status*
string
-
space status - 'ACTIVE', 'PENDING', 'ENDED'
listeners*
Array
-
wallet addresses of all listeners except speakers and spaceCreator
speakers*
Array
-
wallet addresses of all speakers except listeners and spaceCreator
scheduleAt*
Date
-
Date time when the space is scheduled to start
scheduleEnd
Date
-
Date time when the space is scheduled to end
contractAddressERC20 (deprecated)
string
null
ERC20 Contract Address
numberOfERC20 (deprecated)
int
0
Minimum number of tokens required to join the space
contractAddressNFT (deprecated)
string
null
NFT Contract Address
numberOfNFTTokens (deprecated)
int
0
Minimum number of nfts required to join the space
rules
Rules
-
conditions for space and chat access (see format above)
pgpPrivateKey
string
null
mandatory for users having pgp keys
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (update space)
// PushAPI.space.update | Response - 200 OK
{
members : [
{
wallet : 'eip155:0x367c6555b2CAD9C2d2656066EC3996Ba12cD058d' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSr17UBCADhEXWz/lsg0sDA+QRygzl+4t84/YYa459nzFRNB36jkbU8\n' +
'FxRsE6oZTu0Leanup7aul4trJJ4qyA6xFfDjprDzrm1Gtp/gos46Lxk+br64\n' +
'lzgqTfSKpBs9UWqOcr4Vnoq9WeOiFZax0DhN//7ibIQDWIJ0E6iOc8uiSoGZ\n' +
's4AHTx7GtUvHxIUAk/hQY8UjjDNyhgCSrmdPeWt/SVbmFCHchdH/KhSK8JVq\n' +
'qs8/nKx2Tm/nmAdWFZDqIJxd5tVuXXMxTZYZADZfmBltR2F/8GkF7hfX/aOo\n' +
'gGQ/u2FPbCKRjtedfJi3WsPUKtyFg6QdwBnOQmYn0fGXlPGR7UVSsmIVABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKvXtQQLCQcICZD2NRrvru2XMgMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBM1nsbalDm3PtLAK2/Y1Gu+u7ZcyAADzuwgAmTBbnBQZ2w06\n' +
'RbLmcZf8cYTof1X3mpYBa1lprMltib2jZQdu8DxhZBapYIE1O0UzV2Dy8IXj\n' +
'zavtNFZiLR8FTwkrXQ3DGrZylnqjLkQ6m2jZsGIypb2OpTlBIBnjW98Dh99F\n' +
'egI/5wse59IfGhYXVcKluKDAW2ezUJx8BhacZCwf/S8iG9YKrZctS5cVZxQw\n' +
'SymXv88msoQrWhxmu2AT0rNsZ656ANMr/MuUjKMxQsoNCNIkp5kE0UTGfMwc\n' +
'c69Gabs9uOPOqAGeSBGVfw+uJig/RJ4MWDCbj6QIDsV5FFRvTmJmmSNLNH5y\n' +
'83pHxE+923z6NiPWRonbns3pFNvhnc7ATQRkq9e1AQgAxjGMkGhs2OTW8fW/\n' +
'4tloJOID0UIDrz/24uX4JU+qjTqMzFyNGaNagT8n0xDH2E63YFmketip4QA2\n' +
'6kUBICKR2Y5kNNzkJXK4NYfa5OXEIS+lw+X7oMXd9YJ/D1fig1XD4Bf0ofsZ\n' +
'QIxHOn6w3T/wQHOBpu+cqE3d0pW+6s6hZ4mkuPk6OXrkBSEtynk4ADQS+a3b\n' +
'PrCGU9rJy2OnbP+lMr3onv/6BR/DFE4qCIfQt0cLu4nhAuYVYrOupi3p9eBQ\n' +
'z/oWHCSNQVQSW2/vHp0YwMj2r3jSGdoZ3pcfy4iXOa7xEyeauOn/pHK+syOX\n' +
'Pv64DHncql4AJFj9tw4rZ2/kkQARAQABwsB2BBgBCAAqBYJkq9e1CZD2NRrv\n' +
'ru2XMgKbDBYhBM1nsbalDm3PtLAK2/Y1Gu+u7ZcyAADapwf/XF6I2NifyL/h\n' +
'2aVsr2lL2At732336je3WM6QnA/q1x9lmxX646c9eETUQvLLhT5RZmx1X8Fa\n' +
'X/qGMKJe+BWLFPy5k6LnOezvvOxHGV+dzRndlWbnC9d3AZhThciw/Rd8V9W6\n' +
'd6luo7+Apdd3rS17hG4gElhNX1drq5TuWR89yxA5oXcIqA+u3jBdpz0qo/ME\n' +
'+63r0AubixdM7rgV0skugaIXvqMKtfMC/V2A8mCL5AmRXCyfMBIsEA0L5YA1\n' +
'wsKlHIQAy3jiPdY/2q5KUWJsR9o/IFirjnTd5vywtYsscOq/KnfLKdc2cVOr\n' +
'e/vSkTOrD+dVTlxGhADoud4kvcOPtg==\n' +
'=6H2/\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0xB026B0A8BB1fea997a73c5a84fe7aF8cAab1AcF2' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x9b70FD7164ec0Ed3E1B3E318836522340dd2e125' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x1A050099a08D7faf3b5923669a0FAe42A0872D72' ,
publicKey : null ,
isSpeaker : false ,
image : null
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkq9e1CZD2NRrvru2XMhYhBM1nsbalDm3PtLAK2/Y1Gu+u\n' +
'7ZcyAAA0igf/Tgo/WU4C5g4UtHPCwU/jThQwjElzCa96bZU8bCXsgnoO1NMI\n' +
'fwI7FxIw8FmFrktHIWT10T/9vq2ItyUvpbWRhnD5zt5aRhJ1KA1z06iwkoUt\n' +
'DLiPfveoSDyIhUIjx5PUMN0r/tXmLhj3CrkHx1hiPBxEkhi9brfFcOvX57HS\n' +
'VOKOeeUa4G1cmk6dtzLHWT4p7ekrFhZPHXDtZUMZEU2wbMkB6bRqlZ7UYLbN\n' +
'7+0AvCu7uaCYG0zfbl3oZc6DkIm9jnBknsII6Hqv7Dc9NLAUBWo8tPrW2/KN\n' +
'8Bv/gk5HPb16tOihIUjs8v45wO3oTPAQYbJGdF6ta+HyiKO8JWipbw==\n' +
'=wkHz\n' +
'-----END PGP SIGNATURE-----\n' +
':null' ,
spaceImage : '' ,
spaceName : 'mobile_aquamarine_constrictor' ,
isPublic : true ,
spaceDescription : 'conventional_crimson_dove' ,
spaceCreator : 'eip155:0x367c6555b2CAD9C2d2656066EC3996Ba12cD058d' ,
spaceId : 'spaces:108f766a5053e2b985d0843e806f741da5ad754d128aff0710e526eebc127afc' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'PENDING' ,
rules : {
'spaceAccess' : {
'conditions' : [
{
'any' : [
{
'type' : 'PUSH' ,
'category' : 'ERC20' ,
'subcategory' : 'token_holder' ,
'data' : {
'address' : 'eip155:5:0x2b9bE9259a4F5Ba6344c1b1c07911539642a2D33' ,
'amount' : 1000 ,
'decimals' : 18
}
} ,
{
'type' : 'GUILD' ,
'category' : 'guildRoles' ,
'subcategory' : 'specificRole' ,
'data' : {
'guildId' : '13468' ,
'guildRoleId' : '19924'
}
} ,
{
'type' : 'PUSH' ,
'category' : 'ERC721' ,
'subcategory' : 'nft_owner' ,
'data' : {
'address' : 'eip155:5:0x42af3147f17239341477113484752D5D3dda997B' ,
'amount' : 1
}
}
]
}
]
}
}
}
To get space details by spaceId
const response = await PushAPI . space . get ( {
spaceId :
'spaces:108f766a5053e2b985d0843e806f741da5ad754d128aff0710e526eebc127afc' ,
env : 'staging' ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId_
string
-
space id
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (get space by space id)
// PushAPI_space_get | Response - 200 OK
{
members : [
{
wallet : 'eip155:0xd1ab5Af3Be78bB1492099CE568761F0e706352a0' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSr528BCADI8kQcWkaw9PKmSrwCtPBDWj+wzPhmok9jAzxzb2+qAjSV\n' +
'rYdIrnx6PAp1rMU6qoVg4cdDbCYPV+kCj8l3lUzH/a/SfPsDWpspA/ICWMeS\n' +
'dMdGYxHLk2gsu0wRz69qoddXMY1h5eMZEyRnr2fsX/cy15mxO2IEHYnC2/rp\n' +
'06iFpx1T8k5HWgFDpyleWyMSQ7Bnn7GutrlHYEVtIGVfXDSkea8IDLLkzBEV\n' +
'3jlBUFhpsrlcvDwDYcMYOrqSBEtg1a+GMK+2Ye/hF37KUYTAPleKXeN0cYIs\n' +
'Va8oleZK960XYfuy5SYCJav2kaAggNWQBie5G9C4H3h7FuFwWk8LH3DhABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKvnbwQLCQcICZBm9Bz6DvB6DwMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBPkdSvwnOBuAJaOWAGb0HPoO8HoPAAAkiQgAukm3owebckwr\n' +
'xAR42r/+CBx1uoqM2ZeEAUeYtBF7sdLEsdxFrxl8wHKAbglZwtgWcfG95v2R\n' +
'zLcBco3v9p0IuS6DZduIfhngZ49gpYwqFGyiCOvo+k14tuMbrbOZTTKp0uc6\n' +
'icpTyP8/1U0nZrQmmSXyfh6Hgmx1OnW3zTM7oUN1ZVvj3V6rOl+ktUPjAaYo\n' +
'CWJjth92xhDWEPZnC/4Gz2eRoTVtmx8u+/2vNPffQVgzzHznUxB+G5XeZmPk\n' +
'z8oxxSxII8PNiAs5LizqPjyq2gEv25GlCsMXTYz60n/t/4G7Yc94yu8xD8u3\n' +
'BpWluHC2eW0pYFcDfiNLfv0uJCrUcM7ATQRkq+dvAQgA7v7Zz4CZdPsd4jvB\n' +
'uDwjop/Gvoz+rbvAdS3Xrsi+OTyrWAqidnXChhwExlUNelZ9v52lGxe1twwr\n' +
'vxeQ4M0pv4oqSlZxhkqBCyj+E7ECR2WXG7ccLlzYOz3b5BXT+fEkmVsbVTjA\n' +
'Kttjosm7FtY4igY2Hu4UlZZW8M1tYL1R/UegFeMYGY7aO7dcKeiP0NsDwm3c\n' +
'0SiU6/JlOXAIi/ZSKDJ4b5BPK6GFj5pNWr92/V7LejlZfoHAVDbb91tiPGdP\n' +
'y3+r9T3IYsgUDLgOpPQn6o82Nctm6CnIZqAN12nJ1DEJP2JyLDedg9b5H+aa\n' +
'FDZFc7yQ3In/QPtjHImydLt9NwARAQABwsB2BBgBCAAqBYJkq+dvCZBm9Bz6\n' +
'DvB6DwKbDBYhBPkdSvwnOBuAJaOWAGb0HPoO8HoPAABRUQf+KoF4UXuseLBO\n' +
'd0PD0+hEcnsYbaPWmPZtJPWusxPl6kt421luymPiThDXwaMVzRrmxkz0dNZ3\n' +
'bUFYtS24t2BhlXZ6cGFNRjXrA9OV0kLg/kNm1vboQ1GL8qRV9CIjPVEpksQp\n' +
'tOiYN+X+/2XdPJkaQpITHIFV067qWQSAKIonvOI8OJYOovGRQTInz0VE71Yn\n' +
'SeiOilKBK+p2RN38jGr0PGWt740KJ6560FzfUwTAQzz9vrkYa+vEhWe+bzOd\n' +
'YBpxj/BRTGR19DrKlGcFPdTYz5ADxCjBuCxXgoRCbBiWwh+iIstk5qkT8uHK\n' +
'NQjzDvo3RO1cROQp0zsikladmzGZHQ==\n' +
'=q/e/\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0xaC6C69c657cF6022fa787B14BDdaA22936B56D65' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xEf532414907E8c631307c0d501cDe6D1694bAF5e' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x2F5f27B523C8888eA79b7FA80a9CbA6b6980784c' ,
publicKey : null ,
isSpeaker : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkq+dvCZBm9Bz6DvB6DxYhBPkdSvwnOBuAJaOWAGb0HPoO\n' +
'8HoPAAD5ywf/cvaGM0DzcB22Q2FMzUZG4/ZmkN4OknvSj0d4hB/sPUIb9176\n' +
'z+niFMjWZNFpIj8s36f16oMEZZ+Eleu9t6sECBxRDvO8pEwyByCXSmz8e/SH\n' +
'Y659cvg5/A3bSe0FqR0VTI1o+Uz2BpnXG/P38C6D46btaIaJcr4cIh88wQ9J\n' +
'lr05hOE7w/7Uo5OwyXala0NfB+8S4LIfpC2OlPOhyHQEJd2+WoFKb/6dO28D\n' +
'TLuvgYJXJfc4R3ElcgFfm1N9ylG0Pt1F3c0C/k9bNokR2PVXgX2XSTQsx1rD\n' +
'MCY/ePr93INyNZuTPcPlK87X6OTa2/gEW161vup2Xn2Did9HtL76Qw==\n' +
'=EkOP\n' +
'-----END PGP SIGNATURE-----\n' +
':null' ,
spaceImage : '' ,
spaceName : 'intellectual_green_bat' ,
isPublic : true ,
spaceDescription : 'sad_purple_pinniped' ,
spaceCreator : 'eip155:0xd1ab5Af3Be78bB1492099CE568761F0e706352a0' ,
spaceId : 'spaces:9dab226c7920fe06154d76f78dfe1187bdc4fda712cdd9a8b37cc6a99741a63b' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'PENDING'
}
const response = await PushAPI . space . start ( {
spaceId :
'spaces:108f766a5053e2b985d0843e806f741da5ad754d128aff0710e526eebc127afc' ,
env : 'staging' ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId_
string
-
space id
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (start space by space id)
// PushAPI_space_start | Response - 200 OK
{
members : [
{
wallet : 'eip155:0xd1ab5Af3Be78bB1492099CE568761F0e706352a0' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSr528BCADI8kQcWkaw9PKmSrwCtPBDWj+wzPhmok9jAzxzb2+qAjSV\n' +
'rYdIrnx6PAp1rMU6qoVg4cdDbCYPV+kCj8l3lUzH/a/SfPsDWpspA/ICWMeS\n' +
'dMdGYxHLk2gsu0wRz69qoddXMY1h5eMZEyRnr2fsX/cy15mxO2IEHYnC2/rp\n' +
'06iFpx1T8k5HWgFDpyleWyMSQ7Bnn7GutrlHYEVtIGVfXDSkea8IDLLkzBEV\n' +
'3jlBUFhpsrlcvDwDYcMYOrqSBEtg1a+GMK+2Ye/hF37KUYTAPleKXeN0cYIs\n' +
'Va8oleZK960XYfuy5SYCJav2kaAggNWQBie5G9C4H3h7FuFwWk8LH3DhABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKvnbwQLCQcICZBm9Bz6DvB6DwMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBPkdSvwnOBuAJaOWAGb0HPoO8HoPAAAkiQgAukm3owebckwr\n' +
'xAR42r/+CBx1uoqM2ZeEAUeYtBF7sdLEsdxFrxl8wHKAbglZwtgWcfG95v2R\n' +
'zLcBco3v9p0IuS6DZduIfhngZ49gpYwqFGyiCOvo+k14tuMbrbOZTTKp0uc6\n' +
'icpTyP8/1U0nZrQmmSXyfh6Hgmx1OnW3zTM7oUN1ZVvj3V6rOl+ktUPjAaYo\n' +
'CWJjth92xhDWEPZnC/4Gz2eRoTVtmx8u+/2vNPffQVgzzHznUxB+G5XeZmPk\n' +
'z8oxxSxII8PNiAs5LizqPjyq2gEv25GlCsMXTYz60n/t/4G7Yc94yu8xD8u3\n' +
'BpWluHC2eW0pYFcDfiNLfv0uJCrUcM7ATQRkq+dvAQgA7v7Zz4CZdPsd4jvB\n' +
'uDwjop/Gvoz+rbvAdS3Xrsi+OTyrWAqidnXChhwExlUNelZ9v52lGxe1twwr\n' +
'vxeQ4M0pv4oqSlZxhkqBCyj+E7ECR2WXG7ccLlzYOz3b5BXT+fEkmVsbVTjA\n' +
'Kttjosm7FtY4igY2Hu4UlZZW8M1tYL1R/UegFeMYGY7aO7dcKeiP0NsDwm3c\n' +
'0SiU6/JlOXAIi/ZSKDJ4b5BPK6GFj5pNWr92/V7LejlZfoHAVDbb91tiPGdP\n' +
'y3+r9T3IYsgUDLgOpPQn6o82Nctm6CnIZqAN12nJ1DEJP2JyLDedg9b5H+aa\n' +
'FDZFc7yQ3In/QPtjHImydLt9NwARAQABwsB2BBgBCAAqBYJkq+dvCZBm9Bz6\n' +
'DvB6DwKbDBYhBPkdSvwnOBuAJaOWAGb0HPoO8HoPAABRUQf+KoF4UXuseLBO\n' +
'd0PD0+hEcnsYbaPWmPZtJPWusxPl6kt421luymPiThDXwaMVzRrmxkz0dNZ3\n' +
'bUFYtS24t2BhlXZ6cGFNRjXrA9OV0kLg/kNm1vboQ1GL8qRV9CIjPVEpksQp\n' +
'tOiYN+X+/2XdPJkaQpITHIFV067qWQSAKIonvOI8OJYOovGRQTInz0VE71Yn\n' +
'SeiOilKBK+p2RN38jGr0PGWt740KJ6560FzfUwTAQzz9vrkYa+vEhWe+bzOd\n' +
'YBpxj/BRTGR19DrKlGcFPdTYz5ADxCjBuCxXgoRCbBiWwh+iIstk5qkT8uHK\n' +
'NQjzDvo3RO1cROQp0zsikladmzGZHQ==\n' +
'=q/e/\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0xaC6C69c657cF6022fa787B14BDdaA22936B56D65' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xEf532414907E8c631307c0d501cDe6D1694bAF5e' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x2F5f27B523C8888eA79b7FA80a9CbA6b6980784c' ,
publicKey : null ,
isSpeaker : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkq+dvCZBm9Bz6DvB6DxYhBPkdSvwnOBuAJaOWAGb0HPoO\n' +
'8HoPAAD5ywf/cvaGM0DzcB22Q2FMzUZG4/ZmkN4OknvSj0d4hB/sPUIb9176\n' +
'z+niFMjWZNFpIj8s36f16oMEZZ+Eleu9t6sECBxRDvO8pEwyByCXSmz8e/SH\n' +
'Y659cvg5/A3bSe0FqR0VTI1o+Uz2BpnXG/P38C6D46btaIaJcr4cIh88wQ9J\n' +
'lr05hOE7w/7Uo5OwyXala0NfB+8S4LIfpC2OlPOhyHQEJd2+WoFKb/6dO28D\n' +
'TLuvgYJXJfc4R3ElcgFfm1N9ylG0Pt1F3c0C/k9bNokR2PVXgX2XSTQsx1rD\n' +
'MCY/ePr93INyNZuTPcPlK87X6OTa2/gEW161vup2Xn2Did9HtL76Qw==\n' +
'=EkOP\n' +
'-----END PGP SIGNATURE-----\n' +
':null' ,
spaceImage : '' ,
spaceName : 'intellectual_green_bat' ,
isPublic : true ,
spaceDescription : 'sad_purple_pinniped' ,
spaceCreator : 'eip155:0xd1ab5Af3Be78bB1492099CE568761F0e706352a0' ,
spaceId : 'spaces:9dab226c7920fe06154d76f78dfe1187bdc4fda712cdd9a8b37cc6a99741a63b' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'ACTIVE'
}
const response = await PushAPI . space . stop ( {
spaceId :
'spaces:108f766a5053e2b985d0843e806f741da5ad754d128aff0710e526eebc127afc' ,
env : 'staging' ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId_
string
-
space id
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (stop space by space id)
// PushAPI_space_stop | Response - 200 OK
{
members : [
{
wallet : 'eip155:0xd1ab5Af3Be78bB1492099CE568761F0e706352a0' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSr528BCADI8kQcWkaw9PKmSrwCtPBDWj+wzPhmok9jAzxzb2+qAjSV\n' +
'rYdIrnx6PAp1rMU6qoVg4cdDbCYPV+kCj8l3lUzH/a/SfPsDWpspA/ICWMeS\n' +
'dMdGYxHLk2gsu0wRz69qoddXMY1h5eMZEyRnr2fsX/cy15mxO2IEHYnC2/rp\n' +
'06iFpx1T8k5HWgFDpyleWyMSQ7Bnn7GutrlHYEVtIGVfXDSkea8IDLLkzBEV\n' +
'3jlBUFhpsrlcvDwDYcMYOrqSBEtg1a+GMK+2Ye/hF37KUYTAPleKXeN0cYIs\n' +
'Va8oleZK960XYfuy5SYCJav2kaAggNWQBie5G9C4H3h7FuFwWk8LH3DhABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKvnbwQLCQcICZBm9Bz6DvB6DwMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBPkdSvwnOBuAJaOWAGb0HPoO8HoPAAAkiQgAukm3owebckwr\n' +
'xAR42r/+CBx1uoqM2ZeEAUeYtBF7sdLEsdxFrxl8wHKAbglZwtgWcfG95v2R\n' +
'zLcBco3v9p0IuS6DZduIfhngZ49gpYwqFGyiCOvo+k14tuMbrbOZTTKp0uc6\n' +
'icpTyP8/1U0nZrQmmSXyfh6Hgmx1OnW3zTM7oUN1ZVvj3V6rOl+ktUPjAaYo\n' +
'CWJjth92xhDWEPZnC/4Gz2eRoTVtmx8u+/2vNPffQVgzzHznUxB+G5XeZmPk\n' +
'z8oxxSxII8PNiAs5LizqPjyq2gEv25GlCsMXTYz60n/t/4G7Yc94yu8xD8u3\n' +
'BpWluHC2eW0pYFcDfiNLfv0uJCrUcM7ATQRkq+dvAQgA7v7Zz4CZdPsd4jvB\n' +
'uDwjop/Gvoz+rbvAdS3Xrsi+OTyrWAqidnXChhwExlUNelZ9v52lGxe1twwr\n' +
'vxeQ4M0pv4oqSlZxhkqBCyj+E7ECR2WXG7ccLlzYOz3b5BXT+fEkmVsbVTjA\n' +
'Kttjosm7FtY4igY2Hu4UlZZW8M1tYL1R/UegFeMYGY7aO7dcKeiP0NsDwm3c\n' +
'0SiU6/JlOXAIi/ZSKDJ4b5BPK6GFj5pNWr92/V7LejlZfoHAVDbb91tiPGdP\n' +
'y3+r9T3IYsgUDLgOpPQn6o82Nctm6CnIZqAN12nJ1DEJP2JyLDedg9b5H+aa\n' +
'FDZFc7yQ3In/QPtjHImydLt9NwARAQABwsB2BBgBCAAqBYJkq+dvCZBm9Bz6\n' +
'DvB6DwKbDBYhBPkdSvwnOBuAJaOWAGb0HPoO8HoPAABRUQf+KoF4UXuseLBO\n' +
'd0PD0+hEcnsYbaPWmPZtJPWusxPl6kt421luymPiThDXwaMVzRrmxkz0dNZ3\n' +
'bUFYtS24t2BhlXZ6cGFNRjXrA9OV0kLg/kNm1vboQ1GL8qRV9CIjPVEpksQp\n' +
'tOiYN+X+/2XdPJkaQpITHIFV067qWQSAKIonvOI8OJYOovGRQTInz0VE71Yn\n' +
'SeiOilKBK+p2RN38jGr0PGWt740KJ6560FzfUwTAQzz9vrkYa+vEhWe+bzOd\n' +
'YBpxj/BRTGR19DrKlGcFPdTYz5ADxCjBuCxXgoRCbBiWwh+iIstk5qkT8uHK\n' +
'NQjzDvo3RO1cROQp0zsikladmzGZHQ==\n' +
'=q/e/\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
}
] ,
pendingMembers : [
{
wallet : 'eip155:0xaC6C69c657cF6022fa787B14BDdaA22936B56D65' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xEf532414907E8c631307c0d501cDe6D1694bAF5e' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x2F5f27B523C8888eA79b7FA80a9CbA6b6980784c' ,
publicKey : null ,
isSpeaker : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkq+dvCZBm9Bz6DvB6DxYhBPkdSvwnOBuAJaOWAGb0HPoO\n' +
'8HoPAAD5ywf/cvaGM0DzcB22Q2FMzUZG4/ZmkN4OknvSj0d4hB/sPUIb9176\n' +
'z+niFMjWZNFpIj8s36f16oMEZZ+Eleu9t6sECBxRDvO8pEwyByCXSmz8e/SH\n' +
'Y659cvg5/A3bSe0FqR0VTI1o+Uz2BpnXG/P38C6D46btaIaJcr4cIh88wQ9J\n' +
'lr05hOE7w/7Uo5OwyXala0NfB+8S4LIfpC2OlPOhyHQEJd2+WoFKb/6dO28D\n' +
'TLuvgYJXJfc4R3ElcgFfm1N9ylG0Pt1F3c0C/k9bNokR2PVXgX2XSTQsx1rD\n' +
'MCY/ePr93INyNZuTPcPlK87X6OTa2/gEW161vup2Xn2Did9HtL76Qw==\n' +
'=EkOP\n' +
'-----END PGP SIGNATURE-----\n' +
':null' ,
spaceImage : '' ,
spaceName : 'intellectual_green_bat' ,
isPublic : true ,
spaceDescription : 'sad_purple_pinniped' ,
spaceCreator : 'eip155:0xd1ab5Af3Be78bB1492099CE568761F0e706352a0' ,
spaceId : 'spaces:9dab226c7920fe06154d76f78dfe1187bdc4fda712cdd9a8b37cc6a99741a63b' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'ENDED'
}
To approve a space request
const response = await PushAPI . space . approve ( {
status : 'Approved' ,
account : '0x18C0Ab0809589c423Ac9eb42897258757b6b3d3d' ,
senderAddress : '0x873a538254f8162377296326BB3eDDbA7d00F8E9' , // spaceId
env : 'staging' ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
status
'Approved'
'Approved'
flag for approving and rejecting space request, supports only approving for now
senderAddress_
string
-
space request sender's address or spaceId of a space
signer*
-
-
signer object
pgpPrivateKey
string
null
mandatory for users having pgp keys
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (approve space request for a spaceId)
// PushAPI_space_approve | Response - 204 OK
To add listeners to space
const response = await PushAPI . space . addListeners ( {
spaceId,
listeners : [
`eip155:0x65585D8D2475194A26C0B187e6bED494E5D68d5F` ,
`eip155:0xE99F29C1b2A658a478E7766D5A2bB28322326C45` ,
] ,
signer : signer ,
pgpPrivateKey : pgpDecrpyptedPvtKey ,
env : env as ENV ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId_
string
-
space id
listeners
Array
-
new listeners that needs to be added to the space. Don't add listeners which are already part of space
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (add Listeners to space)
// PushAPI_space_add_listeners | Response - 200 OK
{
members : [ {
wallet : 'eip155:0x4Be8cFD08B330853A530DEBB72a2DAf4d4F3D2Ba' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSs51IBCAC+y8oXbU2YvfI7Z4xnSRfcPecRR+nO/XVLDbt30mbn1NU8\n' +
'wHSXcuHLJTuU9yJy1t9AMB2SY8n/YWMFbeNICF0OQVINkvFS+8Ec/F42IIlb\n' +
'StUY8rLS9pxTQoI3k1LnQKNL1krGiEuDl2ZT3l304aPGkF1sowu5w6xnzl/o\n' +
'nb6cgc48jVqIgqoVUCnEoxc3GKdSORm35nl0RBDasFdFPJctnpg2n7hLofU1\n' +
'RGOIzf/cITY7AE3nta0cqaFgNsO4rO0fXRwgDBAu66CtBG4Px2X8hT7IYMum\n' +
'XJtCis3KvrmQAOhWrbAwmWjHbkSDSYigd39rmlht21GKf0/kfoILBgRfABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKznUgQLCQcICZDTsTetOyJa2gMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBHGBWhlF6JChmgQO7tOxN607IlraAADq/Af/XWeAagX5+JCX\n' +
'ChzadMaUtI6m2F7nT8sJcJep/a0Ldyz6kPmP9k6kmWO+QXJwl4FrP3e7HPer\n' +
'SjTeIWm0FJ2a+pRtF+lWk7xjIWJuZxbx79nOk98arde75fT+bebne1V0raUM\n' +
'gXPQIc60++okAPif6vJVLAaSMNbCkv8+Lsy0mJqsjY3b9iMVKWHKb8XVvTuN\n' +
'pobxVV4dLq53lrdNDIiwAWTlbxyuKLSEF4f+hIPJX3PAhquORinOubclUwTM\n' +
'+kEmE6VI3pW4VL1VRi10cDI6ruEVwqOwQyYcp9gSDKXFR6ZXz7t0hjUUhl+3\n' +
'z6T7yqAjExW1O4tETVSbt3jg6DjaAM7ATQRkrOdSAQgArRRrLZees3xCYyBO\n' +
'9WDzy7XCM2FxmaIJs/ibWwTtD1ZVoc9NKeOx07FYwGiYjigY6FxxJHdr20IQ\n' +
'3xieIyBLZM2XAIXrsxq4M9GLG8R6nhd35BenjcvSGiZH1Rq0aXtFt9Fd7gc6\n' +
'E8XpMcHPH8KEnf66sPz18vrVCdstVU4Qj2ZjH25ilfeGdMj2HHfDxVN8sRhl\n' +
'AXAcwblQ+IVXGjuKw19T4zN874bcAaOmXfzxu3+2PtxVSR5uV03x1ln3ji+b\n' +
'+GF8atJMMHCqE0FC/dEciS+BWSQtv0D93XWjzExJeyhd7Z+I3BG8JPuJT5Yj\n' +
'4PxktEgwUxQc83JFFwED9knzyQARAQABwsB2BBgBCAAqBYJkrOdSCZDTsTet\n' +
'OyJa2gKbDBYhBHGBWhlF6JChmgQO7tOxN607IlraAABLdggAhe1KLjtHTsUI\n' +
'SR0K25EJ+9gXC7wmebve9wNZL22/Ud9hnyS77/VUmMNBgdPyhm/9ITMhVtTt\n' +
'rRNo1AzsVKDn3/dW1kc+nSribOufxzMoBM7Bm918Zt/0/7wCegz0bp3EAoQ8\n' +
'KEa2KPY9lSh2WtEDoA87D8JB1xwIfcR98vg5/AZ7VdtE88foSqXAm+6F85hz\n' +
'nAASNBO9CCDvUofR28b4exT/aWX0qZxLAukgH7fnYC3KPVv+9ug6mdyJPsOZ\n' +
'LFjF327UKLrBuQ6VRlfKF+XULJbtNPxckgwO1V/oxycq/M67acGoXgc2MgP/\n' +
'2qOkbiQC0ZxcA+Ze5TNNhuGWKv6d9g==\n' +
'=S9Ba\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
} ] ,
pendingMembers : [ {
wallet : 'eip155:0x4d2eFB18383a48aCe19a198ae5228BB4bf854cec' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x8E50Bfb57f803814c242c5a25890f5F0c13304fF' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xaA6E4434D881D2bDEea891AE127313AE5515a06B' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xf6106dd699B6e40f1E822c38DDA459F533470b11' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xAF3d4989652a6ED5554b6191c555525977424Cc9' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x2ccBeEf6e30dF46D0A7Ee79Bc66FBF3beA7EeA5A' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x65585D8D2475194A26C0B187e6bED494E5D68d5F' ,
publicKey : null ,
isSpeaker : false ,
image : null
} ,
{
wallet : 'eip155:0xE99F29C1b2A658a478E7766D5A2bB28322326C45' ,
publicKey : null ,
isSpeaker : false ,
image : null
} ,
{
wallet : 'eip155:0xa145b34443e28C8f718Cd0691Dc41A81E0d0A857' ,
publicKey : null ,
isSpeaker : false ,
image : null
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkrOdUCZDTsTetOyJa2hYhBHGBWhlF6JChmgQO7tOxN607\n' +
'IlraAAAqUQf9FvAtNouG7+2YSyyx7eiHRJZroDPFohH/F2xyc+oJkgh40p2y\n' +
'hyKw+DSp0FA+IiT95/y8RbGDUrNFz+/kdMfZWCEYFim3Cy+c5k1/YNc8qxx6\n' +
'VLwef+2YZepC1pSS9K0zbu04uVPWrNmDa5lHXqzTx/mOxWlxLD0NfpI60csE\n' +
'iQx57duy2gMeW9MwOKSFjOSnWHKy7AySm/vBwZ9Rj4gnOhsvwbAfLprQQf4G\n' +
'cUaxG/HOb0c/8Ugews0Z1uDJFmGKjT5R5CR63vPo5qDGQwWkm+LYpshCIV+K\n' +
'ofLepDqQRuEFa7VyUlDOvMcF15LtlvAhwhkIVHvTGjXZC91e8/IUsQ==\n' +
'=UpR2\n' +
'-----END PGP SIGNATURE-----\n' +
':null' ,
spaceImage : '' ,
spaceName : 'weird_moccasin_alligator' ,
isPublic : true ,
spaceDescription : 'equivalent_blue_armadillo' ,
spaceCreator : 'eip155:0x4Be8cFD08B330853A530DEBB72a2DAf4d4F3D2Ba' ,
spaceId : 'spaces:d37c4e303a2ff194e546d3af94353ec829324a578ebffbeadebd1ba91ab88548' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'PENDING'
}
To remove listeners from space
const response = await PushAPI . space . removeListeners ( {
spaceId,
listeners : [
`eip155:0xB12869BD3a0F9109222D67ba71e8b109B46908f9` ,
`eip155:0x2E3af36E1aC6EEEA2C0d59E43Be1926aBB9eE0BD` ,
] ,
signer : signer ,
pgpPrivateKey : pgpDecrpyptedPvtKey ,
env : env as ENV ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId_
string
-
space id
listeners
Array
-
existing listeners that needs to be removed from the space. Don't add listeners which are not part of space
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (remove Listeners from space)
// PushAPI_space_from_speakers | Response - 200 OK
{
members : [ {
wallet : 'eip155:0x5908D89B1390ec5833001b86302B868A808D506D' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSs6YABCADC4ldJKGpZ0Z+JJwA1t/1JWp5+dnR98nr7RHPX8eEGxIhL\n' +
'gtx5TZmek2BcGzNcg66+GEyC4np9USaCZ4/YC9ZMLw8BQKzhOcd3ZILyGtGV\n' +
'BijBNwjPIbQcy5/cXVtfKCvf303BDYddPYuJ1xFAh7kpvhcR4a72CSpeyEjM\n' +
'UndteAVTIxqwdpnXIdqpwu6HrSJ089GpHV+XeaDo4Uhg+iHJsCRJy2VJ5m61\n' +
'CwGx55f3ror6rAXQd+hEx+keLxYINNJLLvfvE9IGsIbKRFZx+emjXQZusbJp\n' +
'zXYhJnEeHPLVDjWhzo8Q3/4gvOz8m6a+A9sl49sqodLdxVlXQ7d4CuylABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKzpgAQLCQcICZCaDezdj8j4SwMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBGZpOFBNtTj1Oqt695oN7N2PyPhLAACCLgf/dB412nDRcOxR\n' +
'dNSj2AYknJ+NKeX38KuksyR6wypnaJWpapmIeZCfFjeoBjuBCPd6unvN/IlZ\n' +
'zPwl66lO5GKJxDaDd1/infxM/dbtFQSESLXlweRLQ/v1+plsntrBUyvbY4uH\n' +
'Mh9PImYsLY+zo8P5mpBV5AGAMA6R9qmu3axH/MnKVdB0Ky6C/jP+7lPs/QVT\n' +
'qsISyyI1E9E6Oivzxmao1axfXLdEvICHb6uD0R4p5SUVqHJX41OwM8BFevhK\n' +
'07Hi+c7NhUWp0sxXEOs6dneJZwerCD3EahutpP1Oyt5T8MZitysn2yJ+s5ks\n' +
'SZza+x8OmCMcMZfZnIsJNnIUvPboP87ATQRkrOmAAQgAteDgsJJ0ftPD+P15\n' +
'rKgkLuSCD2iwQgm2k8/ZDaXJBsdm4sJYTt2y0ckx7MRpXgLuIyidOGctqVL6\n' +
'/Rl2Hfl30JQPok5cYmYLENVuFz94MEvgDOo8jacyfPdLGPMWZMLRojyM/Yvs\n' +
'nhDZ8if3zEstP4h3HcpdT+PWSmsJWjrq57la4vKbfILtKfTBaf8sibm5UuZA\n' +
'5Y/SIPxfVC+ybCPAjo4tpDYP901V+wxXDJ8BlZ4AaVvk20MYMzuAjBna+iwD\n' +
'f0j4CccEabd2EVtAQQcMCg2yTjOT22Dt0jfpDuohDNaXDhX2ZQlJIdlSLCEI\n' +
'a3c7g+uU9bnNqt7LHPgMzLYKnwARAQABwsB2BBgBCAAqBYJkrOmACZCaDezd\n' +
'j8j4SwKbDBYhBGZpOFBNtTj1Oqt695oN7N2PyPhLAAD2vQgAu9+sd4AT5b6c\n' +
'mWOaQBXz2XVfJXYQFNlBdOF23reycF9r7vDAKSRpeyMSyOfRAi0qdLynQ1dN\n' +
'MXV/gfO0G9dzFu513P/Y1sZxQi0uLRKL9hMcgEQ8FLo8/PGfVcoLfQASryGj\n' +
'Z8ybCFqiXocGpt2VkkK4wwgv+ZwZ8M1ubz0Boby6A1/kTYs/6ll+QekpB4ao\n' +
'kJKw3DWvVNR/xODFfMQcClvzAtqwfxhTZXBMbZ4vAG5m1ExGmA15cGXrAfwV\n' +
'nR2vOhPYDeZGbBKktM3xfDts75N2NF/TBpvazV2DTKpkLqvVitFHWvSMMpVd\n' +
'dwk9tEOmBlj2AoYATvQ9kKHRTD27Wg==\n' +
'=IXzf\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
} ] ,
pendingMembers : [ {
wallet : 'eip155:0xC1469cB7b59d16dC887D4C11faB3E3C0abBeA12C' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xccF7a3131E0E73F83Bc457C27494411a57f23248' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x052aD82D3a7b4DAb5b9BcFED771D28703a6faadf' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x956f73E5a3BF0D19299BF74bD6dc819D7f775eC7' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x19da526eD1a57E07D48aa25aDa6cbA7E41FF3129' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x77059B40Ec974883b98a23eef519b4076D1Cf9F1' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkrOmCCZCaDezdj8j4SxYhBGZpOFBNtTj1Oqt695oN7N2P\n' +
'yPhLAAD+iwf/dvaRCTwXKGH6iUe49NpyTHMaD6ZwaLerk+K4Ojehbdoo0mDf\n' +
'aOu/MR8wfqk49h2436rcMmyeM5avcMgmtGUmIdy/6hCZ6zxR/3E5t/vq5UfO\n' +
'3YFO1VLghR5cTYqR9bMLFkvvCB4P29rnaok2QVKTBZLfyAM4wu1h2DDBESoz\n' +
'SS+ZtQLPz6/y7gOQobO0zbwBPmy8MpVVu1wxht+sneOMvZX+5al679nQbwNL\n' +
'oCcU3UKrlqMhuFgMTCKx99VLcc4JbhBf2M+IHf78NtQ9mcQC/X+gxRfp6f+p\n' +
'2RePQzkmUH5vqXjzcUsNBWJPOyjl09/IZWWwaeiUjsPazjxqDtYNHg==\n' +
'=H4X4\n' +
'-----END PGP SIGNATURE-----\n' +
':null' ,
spaceImage : '' ,
spaceName : 'sheer_ivory_ox' ,
isPublic : true ,
spaceDescription : 'specific_green_alpaca' ,
spaceCreator : 'eip155:0x5908D89B1390ec5833001b86302B868A808D506D' ,
spaceId : 'spaces:bc96011f182e2c86ad68aaf4c95c4a916c808088370cb0ba294f9168e2ff6328' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'PENDING'
}
const response = await PushAPI . space . addSpeakers ( {
spaceId,
listeners : [
`eip155:0x65585D8D2475194A26C0B187e6bED494E5D68d5F` ,
`eip155:0xE99F29C1b2A658a478E7766D5A2bB28322326C45` ,
] ,
signer : signer ,
pgpPrivateKey : pgpDecrpyptedPvtKey ,
env : env as ENV ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId_
string
-
space id
speakers
Array
-
new speakers that needs to be added to the space. Don't add speakers which are already part of space
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (add Speakers to space)
// PushAPI_space_add_speakers | Response - 200 OK
{
members : [ {
wallet : 'eip155:0x4Be8cFD08B330853A530DEBB72a2DAf4d4F3D2Ba' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSs51IBCAC+y8oXbU2YvfI7Z4xnSRfcPecRR+nO/XVLDbt30mbn1NU8\n' +
'wHSXcuHLJTuU9yJy1t9AMB2SY8n/YWMFbeNICF0OQVINkvFS+8Ec/F42IIlb\n' +
'StUY8rLS9pxTQoI3k1LnQKNL1krGiEuDl2ZT3l304aPGkF1sowu5w6xnzl/o\n' +
'nb6cgc48jVqIgqoVUCnEoxc3GKdSORm35nl0RBDasFdFPJctnpg2n7hLofU1\n' +
'RGOIzf/cITY7AE3nta0cqaFgNsO4rO0fXRwgDBAu66CtBG4Px2X8hT7IYMum\n' +
'XJtCis3KvrmQAOhWrbAwmWjHbkSDSYigd39rmlht21GKf0/kfoILBgRfABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKznUgQLCQcICZDTsTetOyJa2gMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBHGBWhlF6JChmgQO7tOxN607IlraAADq/Af/XWeAagX5+JCX\n' +
'ChzadMaUtI6m2F7nT8sJcJep/a0Ldyz6kPmP9k6kmWO+QXJwl4FrP3e7HPer\n' +
'SjTeIWm0FJ2a+pRtF+lWk7xjIWJuZxbx79nOk98arde75fT+bebne1V0raUM\n' +
'gXPQIc60++okAPif6vJVLAaSMNbCkv8+Lsy0mJqsjY3b9iMVKWHKb8XVvTuN\n' +
'pobxVV4dLq53lrdNDIiwAWTlbxyuKLSEF4f+hIPJX3PAhquORinOubclUwTM\n' +
'+kEmE6VI3pW4VL1VRi10cDI6ruEVwqOwQyYcp9gSDKXFR6ZXz7t0hjUUhl+3\n' +
'z6T7yqAjExW1O4tETVSbt3jg6DjaAM7ATQRkrOdSAQgArRRrLZees3xCYyBO\n' +
'9WDzy7XCM2FxmaIJs/ibWwTtD1ZVoc9NKeOx07FYwGiYjigY6FxxJHdr20IQ\n' +
'3xieIyBLZM2XAIXrsxq4M9GLG8R6nhd35BenjcvSGiZH1Rq0aXtFt9Fd7gc6\n' +
'E8XpMcHPH8KEnf66sPz18vrVCdstVU4Qj2ZjH25ilfeGdMj2HHfDxVN8sRhl\n' +
'AXAcwblQ+IVXGjuKw19T4zN874bcAaOmXfzxu3+2PtxVSR5uV03x1ln3ji+b\n' +
'+GF8atJMMHCqE0FC/dEciS+BWSQtv0D93XWjzExJeyhd7Z+I3BG8JPuJT5Yj\n' +
'4PxktEgwUxQc83JFFwED9knzyQARAQABwsB2BBgBCAAqBYJkrOdSCZDTsTet\n' +
'OyJa2gKbDBYhBHGBWhlF6JChmgQO7tOxN607IlraAABLdggAhe1KLjtHTsUI\n' +
'SR0K25EJ+9gXC7wmebve9wNZL22/Ud9hnyS77/VUmMNBgdPyhm/9ITMhVtTt\n' +
'rRNo1AzsVKDn3/dW1kc+nSribOufxzMoBM7Bm918Zt/0/7wCegz0bp3EAoQ8\n' +
'KEa2KPY9lSh2WtEDoA87D8JB1xwIfcR98vg5/AZ7VdtE88foSqXAm+6F85hz\n' +
'nAASNBO9CCDvUofR28b4exT/aWX0qZxLAukgH7fnYC3KPVv+9ug6mdyJPsOZ\n' +
'LFjF327UKLrBuQ6VRlfKF+XULJbtNPxckgwO1V/oxycq/M67acGoXgc2MgP/\n' +
'2qOkbiQC0ZxcA+Ze5TNNhuGWKv6d9g==\n' +
'=S9Ba\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
} ] ,
pendingMembers : [ {
wallet : 'eip155:0x4d2eFB18383a48aCe19a198ae5228BB4bf854cec' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x8E50Bfb57f803814c242c5a25890f5F0c13304fF' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xaA6E4434D881D2bDEea891AE127313AE5515a06B' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xf6106dd699B6e40f1E822c38DDA459F533470b11' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xAF3d4989652a6ED5554b6191c555525977424Cc9' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x2ccBeEf6e30dF46D0A7Ee79Bc66FBF3beA7EeA5A' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x65585D8D2475194A26C0B187e6bED494E5D68d5F' ,
publicKey : null ,
isSpeaker : true ,
image : null
} ,
{
wallet : 'eip155:0xE99F29C1b2A658a478E7766D5A2bB28322326C45' ,
publicKey : null ,
isSpeaker : true ,
image : null
} ,
{
wallet : 'eip155:0xa145b34443e28C8f718Cd0691Dc41A81E0d0A857' ,
publicKey : null ,
isSpeaker : false ,
image : null
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkrOdUCZDTsTetOyJa2hYhBHGBWhlF6JChmgQO7tOxN607\n' +
'IlraAAAqUQf9FvAtNouG7+2YSyyx7eiHRJZroDPFohH/F2xyc+oJkgh40p2y\n' +
'hyKw+DSp0FA+IiT95/y8RbGDUrNFz+/kdMfZWCEYFim3Cy+c5k1/YNc8qxx6\n' +
'VLwef+2YZepC1pSS9K0zbu04uVPWrNmDa5lHXqzTx/mOxWlxLD0NfpI60csE\n' +
'iQx57duy2gMeW9MwOKSFjOSnWHKy7AySm/vBwZ9Rj4gnOhsvwbAfLprQQf4G\n' +
'cUaxG/HOb0c/8Ugews0Z1uDJFmGKjT5R5CR63vPo5qDGQwWkm+LYpshCIV+K\n' +
'ofLepDqQRuEFa7VyUlDOvMcF15LtlvAhwhkIVHvTGjXZC91e8/IUsQ==\n' +
'=UpR2\n' +
'-----END PGP SIGNATURE-----\n' +
':null' ,
spaceImage : '' ,
spaceName : 'weird_moccasin_alligator' ,
isPublic : true ,
spaceDescription : 'equivalent_blue_armadillo' ,
spaceCreator : 'eip155:0x4Be8cFD08B330853A530DEBB72a2DAf4d4F3D2Ba' ,
spaceId : 'spaces:d37c4e303a2ff194e546d3af94353ec829324a578ebffbeadebd1ba91ab88548' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'PENDING'
}
To remove speakers from space
const response = await PushAPI . space . removeSpeakers ( {
spaceId,
speakers : [
`eip155:0xB12869BD3a0F9109222D67ba71e8b109B46908f9` ,
`eip155:0x2E3af36E1aC6EEEA2C0d59E43Be1926aBB9eE0BD` ,
] ,
signer : signer ,
pgpPrivateKey : pgpDecrpyptedPvtKey ,
env : env as ENV ,
} ) ;
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
spaceId_
string
-
space id
speakers
Array
-
existing speakers that needs to be removed from the space. Don't add speakers which are not part of space
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Expected response (remove Speakers to space)
// PushAPI_space_remove_speakers | Response - 200 OK
{
members : [ {
wallet : 'eip155:0x5908D89B1390ec5833001b86302B868A808D506D' ,
publicKey : '-----BEGIN PGP PUBLIC KEY BLOCK-----\n' +
'\n' +
'xsBNBGSs6YABCADC4ldJKGpZ0Z+JJwA1t/1JWp5+dnR98nr7RHPX8eEGxIhL\n' +
'gtx5TZmek2BcGzNcg66+GEyC4np9USaCZ4/YC9ZMLw8BQKzhOcd3ZILyGtGV\n' +
'BijBNwjPIbQcy5/cXVtfKCvf303BDYddPYuJ1xFAh7kpvhcR4a72CSpeyEjM\n' +
'UndteAVTIxqwdpnXIdqpwu6HrSJ089GpHV+XeaDo4Uhg+iHJsCRJy2VJ5m61\n' +
'CwGx55f3ror6rAXQd+hEx+keLxYINNJLLvfvE9IGsIbKRFZx+emjXQZusbJp\n' +
'zXYhJnEeHPLVDjWhzo8Q3/4gvOz8m6a+A9sl49sqodLdxVlXQ7d4CuylABEB\n' +
'AAHNAMLAigQQAQgAPgWCZKzpgAQLCQcICZCaDezdj8j4SwMVCAoEFgACAQIZ\n' +
'AQKbAwIeARYhBGZpOFBNtTj1Oqt695oN7N2PyPhLAACCLgf/dB412nDRcOxR\n' +
'dNSj2AYknJ+NKeX38KuksyR6wypnaJWpapmIeZCfFjeoBjuBCPd6unvN/IlZ\n' +
'zPwl66lO5GKJxDaDd1/infxM/dbtFQSESLXlweRLQ/v1+plsntrBUyvbY4uH\n' +
'Mh9PImYsLY+zo8P5mpBV5AGAMA6R9qmu3axH/MnKVdB0Ky6C/jP+7lPs/QVT\n' +
'qsISyyI1E9E6Oivzxmao1axfXLdEvICHb6uD0R4p5SUVqHJX41OwM8BFevhK\n' +
'07Hi+c7NhUWp0sxXEOs6dneJZwerCD3EahutpP1Oyt5T8MZitysn2yJ+s5ks\n' +
'SZza+x8OmCMcMZfZnIsJNnIUvPboP87ATQRkrOmAAQgAteDgsJJ0ftPD+P15\n' +
'rKgkLuSCD2iwQgm2k8/ZDaXJBsdm4sJYTt2y0ckx7MRpXgLuIyidOGctqVL6\n' +
'/Rl2Hfl30JQPok5cYmYLENVuFz94MEvgDOo8jacyfPdLGPMWZMLRojyM/Yvs\n' +
'nhDZ8if3zEstP4h3HcpdT+PWSmsJWjrq57la4vKbfILtKfTBaf8sibm5UuZA\n' +
'5Y/SIPxfVC+ybCPAjo4tpDYP901V+wxXDJ8BlZ4AaVvk20MYMzuAjBna+iwD\n' +
'f0j4CccEabd2EVtAQQcMCg2yTjOT22Dt0jfpDuohDNaXDhX2ZQlJIdlSLCEI\n' +
'a3c7g+uU9bnNqt7LHPgMzLYKnwARAQABwsB2BBgBCAAqBYJkrOmACZCaDezd\n' +
'j8j4SwKbDBYhBGZpOFBNtTj1Oqt695oN7N2PyPhLAAD2vQgAu9+sd4AT5b6c\n' +
'mWOaQBXz2XVfJXYQFNlBdOF23reycF9r7vDAKSRpeyMSyOfRAi0qdLynQ1dN\n' +
'MXV/gfO0G9dzFu513P/Y1sZxQi0uLRKL9hMcgEQ8FLo8/PGfVcoLfQASryGj\n' +
'Z8ybCFqiXocGpt2VkkK4wwgv+ZwZ8M1ubz0Boby6A1/kTYs/6ll+QekpB4ao\n' +
'kJKw3DWvVNR/xODFfMQcClvzAtqwfxhTZXBMbZ4vAG5m1ExGmA15cGXrAfwV\n' +
'nR2vOhPYDeZGbBKktM3xfDts75N2NF/TBpvazV2DTKpkLqvVitFHWvSMMpVd\n' +
'dwk9tEOmBlj2AoYATvQ9kKHRTD27Wg==\n' +
'=IXzf\n' +
'-----END PGP PUBLIC KEY BLOCK-----\n' ,
isSpeaker : true ,
image : ''
} ] ,
pendingMembers : [ {
wallet : 'eip155:0xC1469cB7b59d16dC887D4C11faB3E3C0abBeA12C' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0xccF7a3131E0E73F83Bc457C27494411a57f23248' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x052aD82D3a7b4DAb5b9BcFED771D28703a6faadf' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x956f73E5a3BF0D19299BF74bD6dc819D7f775eC7' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x19da526eD1a57E07D48aa25aDa6cbA7E41FF3129' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
} ,
{
wallet : 'eip155:0x77059B40Ec974883b98a23eef519b4076D1Cf9F1' ,
publicKey : '' ,
isSpeaker : false ,
image : ''
}
] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof : 'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkrOmCCZCaDezdj8j4SxYhBGZpOFBNtTj1Oqt695oN7N2P\n' +
'yPhLAAD+iwf/dvaRCTwXKGH6iUe49NpyTHMaD6ZwaLerk+K4Ojehbdoo0mDf\n' +
'aOu/MR8wfqk49h2436rcMmyeM5avcMgmtGUmIdy/6hCZ6zxR/3E5t/vq5UfO\n' +
'3YFO1VLghR5cTYqR9bMLFkvvCB4P29rnaok2QVKTBZLfyAM4wu1h2DDBESoz\n' +
'SS+ZtQLPz6/y7gOQobO0zbwBPmy8MpVVu1wxht+sneOMvZX+5al679nQbwNL\n' +
'oCcU3UKrlqMhuFgMTCKx99VLcc4JbhBf2M+IHf78NtQ9mcQC/X+gxRfp6f+p\n' +
'2RePQzkmUH5vqXjzcUsNBWJPOyjl09/IZWWwaeiUjsPazjxqDtYNHg==\n' +
'=H4X4\n' +
'-----END PGP SIGNATURE-----\n' +
':null' ,
spaceImage : '' ,
spaceName : 'sheer_ivory_ox' ,
isPublic : true ,
spaceDescription : 'specific_green_alpaca' ,
spaceCreator : 'eip155:0x5908D89B1390ec5833001b86302B868A808D506D' ,
spaceId : 'spaces:bc96011f182e2c86ad68aaf4c95c4a916c808088370cb0ba294f9168e2ff6328' ,
scheduleAt : '2023-07-15T14:48:00.000Z' ,
scheduleEnd : '2023-07-15T15:48:00.000Z' ,
status : 'PENDING'
}
Fetching list of user spaces
const spaces = await PushAPI . space . spaces ( {
account : string;
pgpPrivateKey ?: string;
/**
* If true, the method will return decrypted message content in response
*/
toDecrypt ?: boolean;
/**
* Environment variable
*/
env ?: ENV ;
} ) ;
Param
Type
Default
Remarks
account
string
-
user address (Partial CAIP)
toDecrypt
boolean
false
if "true" the method will return decrypted message content in response
pgpPrivateKey
string
null
mandatory for users having pgp keys
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Example normal user:
// pre-requisite API calls that should be made before
// need to get user and through that encryptedPvtKey of the user
const user = await PushAPI . user . get ( {
account : 'eip155:0xFe6C8E9e25f7bcF374412c5C81B2578aC473C0F7' ,
env : ENV . STAGING ,
} )
// need to decrypt the encryptedPvtKey to pass in the api using helper function
const pgpDecryptedPvtKey = await PushAPI . chat . decryptPGPKey ( encryptedPGPPrivateKey : user . encryptedPrivateKey , signer : signer ) ;
// actual api
const spaces = await PushAPI . space . spaces ( {
account : 'eip155:0xFe6C8E9e25f7bcF374412c5C81B2578aC473C0F7' ,
toDecrypt : true ,
pgpPrivateKey : pgpDecryptedPvtKey ,
env : ENV . STAGING ,
} ) ;
Example NFT user:
// Fetch user
const user = await PushAPI . user . get ( {
account : `nft:eip155:${ nftChainId } :${ nftContractAddress } :${ nftTokenId } ` ,
env : env as ENV ,
} ) ;
// Decrypt PGP Key
const pgpDecrpyptedPvtKey = await PushAPI . chat . decryptPGPKey ( {
encryptedPGPPrivateKey : user . encryptedPrivateKey ,
signer : nftSigner ,
} ) ;
// Actual api
const spaces = await PushAPI . space . spaces ( {
account : `nft:eip155:${ nftChainId } :${ nftContractAddress } :${ nftTokenId } ` ,
toDecrypt : true ,
pgpPrivateKey : pgpDecrpyptedPvtKey ,
env : env as ENV ,
} ) ;
Expected response (Get spaces of a specific user)
// PushAPI_space_spaces | Response - 200 OK
// Array of spaces
[
{
spaceId :
'spaces:3aa43087b8c55ed9c534dd1d0a086a3340b0d829cda0a13592651cb59f284838' ,
about : null ,
did : null ,
intent :
'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A+eip155:0xF8aBe92d1d0706bF60509F8E9A64Ed6b8520E868' ,
intentSentBy : 'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
intentTimestamp : '2023-07-12T01:11:32.000Z' ,
publicKey : null ,
profilePicture : null ,
threadhash : null ,
wallets : null ,
combinedDID :
'eip155:0x12E429E3672a02E385F9f5F75E932cC1D566EEea_eip155:0x49D407CC9D0e966CD9B22BA40685083B49bd2315_eip155:0xF8aBe92d1d0706bF60509F8E9A64Ed6b8520E868_eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
name : null ,
spaceInformation : {
members : [ Array ] ,
pendingMembers : [ Array ] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof :
'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkrksbCZA3GHnYNke0AhYhBNp+D95LDfs4yU03LzcYedg2\n' +
'R7QCAACRdAf9ELAnCLXfBiAVdbgwj81xr+w9Yzw2wXLLrPLfYY7EXfyChLzQ\n' +
'rr9XBDdWMgtzEU1diSPMbLDh1METR7n71EjG0AoeX5A2pkHI7R1vIxXUJR3G\n' +
'fzHENsfGaKLnhrL1wLjBQACzEsIqPrHl9RItdtKEs9izLmc+wV0GFJ5OjbAs\n' +
'ty/1Q36nnMB7sQ7Ytb9Op+q0TtZPZ7jF9CjX8KGav3P1xDQex9nfsXiDHlLK\n' +
'MqDePaaMO6RJUWAP2xTo2k1DDJQ2dpUhs9XyjMlvFhVbIcT1/lVRCPC8V3C8\n' +
'fUKhUejvOjNFxf0QuR+E4xs+Q3zvR1+fXdJBxbH2Fp3kOTN1N9/LEw==\n' +
'=sLLC\n' +
'-----END PGP SIGNATURE-----\n' ,
spaceImage :
'' ,
spaceName : 'statutory_amber_roadrunner' ,
isPublic : true ,
spaceDescription : 'continued_bronze_pigeon' ,
spaceCreator : 'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
spaceId :
'spaces:3aa43087b8c55ed9c534dd1d0a086a3340b0d829cda0a13592651cb59f284838' ,
scheduleAt : '2023-07-12T06:51:32.000Z' ,
scheduleEnd : '2023-07-12T07:41:32.000Z' ,
status : 'PENDING' ,
} ,
msg : {
fromCAIP10 : 'eip155:0x1615d2D9ae82D5F0eE79298899962b237386feB7' ,
toCAIP10 : 'eip155:0x1C48fE875590f8e366447758b13982a3Ca7d9dBE' ,
fromDID : 'eip155:0x1615d2D9ae82D5F0eE79298899962b237386feB7' ,
toDID : 'eip155:0x1C48fE875590f8e366447758b13982a3Ca7d9dBE' ,
messageContent : "Gm gm! It's me... Mario" ,
messageType : 'Text' ,
signature :
'-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkWKQWCZB7dzg7q3axjBYhBJFuYslzDGbuE+3FMnt3ODur\n' +
'drGMAAAjtAf/TXjtm2qb6aSikFPKYXm0Ekws+65fisJGf7T48MYkkfcD4t2e\n' +
'HXd9LtohzGhcztbOQfAND3yME1GWuMBIksq9rlyEA0ezwsGzCJVhBnkAHBe3\n' +
'+1v4/mNSMmInU8y6sOiLiOcW7ameJvZvDdPDJ0YHhc9dKDCIh1UAZEPAgx+z\n' +
'Wc0DM6pW8bT70dfgnuW2LlLGF5Z23Z1vbHmeszt78+xYY3ez/hoMHXUIE25z\n' +
'Wrnt75nasBBahtJ0mwH10ATnsQNE9hTi6XPGYxRSNDM9nyRxTQUpjhNmGS/+\n' +
'7oFyq8xTcRSaL7d3h8URp9hgFWher5ZZDyMV0jvk+HPguUX54g6Kgw==\n' +
'=dcRD\n' +
'-----END PGP SIGNATURE-----\n' ,
timestamp : 1683530775648 ,
sigType : 'pgp' ,
encType : 'pgp' ,
encryptedSecret :
'-----BEGIN PGP MESSAGE-----\n' +
'\n' +
'wcBMA9aU+JGZVRn/AQgA1pIJHyeJinU21r6At5S5ZaWeN0OEKVB2TjpqZ0IW\n' +
'lHLKQrQ8k3M16bN+Vf0P+DzDVOL84QRkBD56qSNVHOOCox5wcQeR01CczenV\n' +
'LUVvVjBzR2hj7Sdw+Q+M//rgeZPPUDbNyiVmGijelhwDqWd7IOoZY26AGXlm\n' +
'7YQiElvHN2HcYXaTlLAOy36BcccwHu3Tn06F77ZXaf8FnGMWOUy7wh1/jugg\n' +
'D17jUZGLYbmw+u5l9BOfljbw2pb4vtjWht0I1b4GYlKb+bYg/NY0UNsq7mSh\n' +
'dGAmOhy5tC2NMjLRRLfD2qasxHoHN50onlB6HcYLl0RCf31ebOgO6rMhUnxt\n' +
'9cHATAMLWLG2xubrYAEH/2tVeq2j7nJALGSFxjJPboOY57aiFrhXNQ/e/oXH\n' +
'//TNJgGWx4Ta++OuF2Oexbh9DIZhl6DWld9adXDDtBS/fEyjNsYqwoYlNEJN\n' +
'kLvSmokNNrE4MKC1A0GkhSh2MGQDNk42GSgz1tep8XSVc98MHqfNXCHVb5Oa\n' +
'OBeWKLFyElT3+KuZxSkCsnoO5YjuCGbXPyG06tXMHXMTncpj1ri+vpjUSnhD\n' +
'wn3o0zpNWu0GaWXIgTqj2ZouVwV2S1+wAJQjE8uI1JvBiMhA+X63/GCcApBu\n' +
'C7rN0Cs5NGXCn9VWp8i1SCp2NuZ38POABwsXUUkjpF24txyUDX8dbXlkzpao\n' +
'g93SQAElYYmyKbGp1TKhAZl2u40mgf2yCYDv2DLRfAKMJDLvmjXoUGEg2UYO\n' +
'11w6LD0pIykdKJmFtRls/uMnlcoBgDA=\n' +
'=kzUH\n' +
'-----END PGP MESSAGE-----\n' ,
link : 'bafyreib34jgnpp573rwquejcq5avxvydis7fbykat6dd5z7uazobucoumm' ,
} ,
} ,
] ;
Parameter
Type
Description
msg
IMessageIPFS
message object
did
string
user DID
wallets
string
user wallets
profilePicture
string
user profile picture
publicKey
string
user public key
about
string
user description
threadhash
string
cid from the latest message sent on this conversation
intent
string
addresses concatenated from the users who have approved the intent
intentSentBy
string
address of the user who sent the intent
intentTimestamp
number
timestamp of the intent
combinedDID
string
concatenated addresses of the members of this space
cid
string
content identifier on IPFS
spaceId
string
space identifier
spaceInformation
SpaceDTO
all space information
Fetching list of user space requests
const spaces = await PushAPI . space . requests ( {
account : string;
pgpPrivateKey ?: string;
/**
* If true, the method will return decrypted message content in response
*/
toDecrypt ?: boolean;
/**
* Environment variable
*/
env ?: ENV ;
} ) ;
Param
Type
Default
Remarks
account
string
-
user address (Partial CAIP)
toDecrypt
boolean
false
if "true" the method will return decrypted message content in response
pgpPrivateKey
string
null
mandatory for users having pgp keys
env
string
'prod'
API env - 'prod', 'staging', 'dev'
Example normal user:
// pre-requisite API calls that should be made before
// need to get user and through that encryptedPvtKey of the user
const user = await PushAPI . user . get ( {
account : 'eip155:0xFe6C8E9e25f7bcF374412c5C81B2578aC473C0F7' ,
env : ENV . STAGING ,
} )
// need to decrypt the encryptedPvtKey to pass in the api using helper function
const pgpDecryptedPvtKey = await PushAPI . chat . decryptPGPKey ( encryptedPGPPrivateKey : user . encryptedPrivateKey , signer : signer ) ;
// actual api
const spaces = await PushAPI . space . requests ( {
account : 'eip155:0xFe6C8E9e25f7bcF374412c5C81B2578aC473C0F7' ,
toDecrypt : true ,
pgpPrivateKey : pgpDecryptedPvtKey ,
env : ENV . STAGING ,
} ) ;
Example NFT user:
// Fetch user
const user = await PushAPI . user . get ( {
account : `nft:eip155:${ nftChainId } :${ nftContractAddress } :${ nftTokenId } ` ,
env : env as ENV ,
} ) ;
// Decrypt PGP Key
const pgpDecrpyptedPvtKey = await PushAPI . chat . decryptPGPKey ( {
encryptedPGPPrivateKey : user . encryptedPrivateKey ,
signer : nftSigner ,
} ) ;
// Actual api
const spaces = await PushAPI . space . requests ( {
account : `nft:eip155:${ nftChainId } :${ nftContractAddress } :${ nftTokenId } ` ,
toDecrypt : true ,
pgpPrivateKey : pgpDecrpyptedPvtKey ,
env : env as ENV ,
} ) ;
Expected response (Get spaces requests of a specific user)
// PushAPI_space_requests | Response - 200 OK
// Array of spaces
[
{
spaceId :
'spaces:3aa43087b8c55ed9c534dd1d0a086a3340b0d829cda0a13592651cb59f284838' ,
about : null ,
did : null ,
intent :
'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A+eip155:0xF8aBe92d1d0706bF60509F8E9A64Ed6b8520E868' ,
intentSentBy : 'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
intentTimestamp : '2023-07-12T01:11:32.000Z' ,
publicKey : null ,
profilePicture : null ,
threadhash : null ,
wallets : null ,
combinedDID :
'eip155:0x12E429E3672a02E385F9f5F75E932cC1D566EEea_eip155:0x49D407CC9D0e966CD9B22BA40685083B49bd2315_eip155:0xF8aBe92d1d0706bF60509F8E9A64Ed6b8520E868_eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
name : null ,
spaceInformation : {
members : [ Array ] ,
pendingMembers : [ Array ] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof :
'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkrksbCZA3GHnYNke0AhYhBNp+D95LDfs4yU03LzcYedg2\n' +
'R7QCAACRdAf9ELAnCLXfBiAVdbgwj81xr+w9Yzw2wXLLrPLfYY7EXfyChLzQ\n' +
'rr9XBDdWMgtzEU1diSPMbLDh1METR7n71EjG0AoeX5A2pkHI7R1vIxXUJR3G\n' +
'fzHENsfGaKLnhrL1wLjBQACzEsIqPrHl9RItdtKEs9izLmc+wV0GFJ5OjbAs\n' +
'ty/1Q36nnMB7sQ7Ytb9Op+q0TtZPZ7jF9CjX8KGav3P1xDQex9nfsXiDHlLK\n' +
'MqDePaaMO6RJUWAP2xTo2k1DDJQ2dpUhs9XyjMlvFhVbIcT1/lVRCPC8V3C8\n' +
'fUKhUejvOjNFxf0QuR+E4xs+Q3zvR1+fXdJBxbH2Fp3kOTN1N9/LEw==\n' +
'=sLLC\n' +
'-----END PGP SIGNATURE-----\n' ,
spaceImage :
'' ,
spaceName : 'statutory_amber_roadrunner' ,
isPublic : true ,
spaceDescription : 'continued_bronze_pigeon' ,
spaceCreator : 'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
spaceId :
'spaces:3aa43087b8c55ed9c534dd1d0a086a3340b0d829cda0a13592651cb59f284838' ,
scheduleAt : '2023-07-12T06:51:32.000Z' ,
scheduleEnd : '2023-07-12T07:41:32.000Z' ,
status : 'PENDING' ,
} ,
msg : {
fromCAIP10 : 'eip155:0x1615d2D9ae82D5F0eE79298899962b237386feB7' ,
toCAIP10 : 'eip155:0x1C48fE875590f8e366447758b13982a3Ca7d9dBE' ,
fromDID : 'eip155:0x1615d2D9ae82D5F0eE79298899962b237386feB7' ,
toDID : 'eip155:0x1C48fE875590f8e366447758b13982a3Ca7d9dBE' ,
messageContent : "Gm gm! It's me... Mario" ,
messageType : 'Text' ,
signature :
'-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkWKQWCZB7dzg7q3axjBYhBJFuYslzDGbuE+3FMnt3ODur\n' +
'drGMAAAjtAf/TXjtm2qb6aSikFPKYXm0Ekws+65fisJGf7T48MYkkfcD4t2e\n' +
'HXd9LtohzGhcztbOQfAND3yME1GWuMBIksq9rlyEA0ezwsGzCJVhBnkAHBe3\n' +
'+1v4/mNSMmInU8y6sOiLiOcW7ameJvZvDdPDJ0YHhc9dKDCIh1UAZEPAgx+z\n' +
'Wc0DM6pW8bT70dfgnuW2LlLGF5Z23Z1vbHmeszt78+xYY3ez/hoMHXUIE25z\n' +
'Wrnt75nasBBahtJ0mwH10ATnsQNE9hTi6XPGYxRSNDM9nyRxTQUpjhNmGS/+\n' +
'7oFyq8xTcRSaL7d3h8URp9hgFWher5ZZDyMV0jvk+HPguUX54g6Kgw==\n' +
'=dcRD\n' +
'-----END PGP SIGNATURE-----\n' ,
timestamp : 1683530775648 ,
sigType : 'pgp' ,
encType : 'pgp' ,
encryptedSecret :
'-----BEGIN PGP MESSAGE-----\n' +
'\n' +
'wcBMA9aU+JGZVRn/AQgA1pIJHyeJinU21r6At5S5ZaWeN0OEKVB2TjpqZ0IW\n' +
'lHLKQrQ8k3M16bN+Vf0P+DzDVOL84QRkBD56qSNVHOOCox5wcQeR01CczenV\n' +
'LUVvVjBzR2hj7Sdw+Q+M//rgeZPPUDbNyiVmGijelhwDqWd7IOoZY26AGXlm\n' +
'7YQiElvHN2HcYXaTlLAOy36BcccwHu3Tn06F77ZXaf8FnGMWOUy7wh1/jugg\n' +
'D17jUZGLYbmw+u5l9BOfljbw2pb4vtjWht0I1b4GYlKb+bYg/NY0UNsq7mSh\n' +
'dGAmOhy5tC2NMjLRRLfD2qasxHoHN50onlB6HcYLl0RCf31ebOgO6rMhUnxt\n' +
'9cHATAMLWLG2xubrYAEH/2tVeq2j7nJALGSFxjJPboOY57aiFrhXNQ/e/oXH\n' +
'//TNJgGWx4Ta++OuF2Oexbh9DIZhl6DWld9adXDDtBS/fEyjNsYqwoYlNEJN\n' +
'kLvSmokNNrE4MKC1A0GkhSh2MGQDNk42GSgz1tep8XSVc98MHqfNXCHVb5Oa\n' +
'OBeWKLFyElT3+KuZxSkCsnoO5YjuCGbXPyG06tXMHXMTncpj1ri+vpjUSnhD\n' +
'wn3o0zpNWu0GaWXIgTqj2ZouVwV2S1+wAJQjE8uI1JvBiMhA+X63/GCcApBu\n' +
'C7rN0Cs5NGXCn9VWp8i1SCp2NuZ38POABwsXUUkjpF24txyUDX8dbXlkzpao\n' +
'g93SQAElYYmyKbGp1TKhAZl2u40mgf2yCYDv2DLRfAKMJDLvmjXoUGEg2UYO\n' +
'11w6LD0pIykdKJmFtRls/uMnlcoBgDA=\n' +
'=kzUH\n' +
'-----END PGP MESSAGE-----\n' ,
link : 'bafyreib34jgnpp573rwquejcq5avxvydis7fbykat6dd5z7uazobucoumm' ,
} ,
} ,
] ;
Parameter
Type
Description
msg
IMessageIPFS
message object
did
string
user DID
wallets
string
user wallets
profilePicture
string
user profile picture
publicKey
string
user public key
about
string
user description
threadhash
string
cid from the latest message sent on this conversation
intent
string
addresses concatenated from the users who have approved the intent
intentSentBy
string
address of the user who sent the intent
intentTimestamp
number
timestamp of the intent
combinedDID
string
concatenated addresses of the members of this space
cid
string
content identifier on IPFS
spaceId
string
space identifier
spaceInformation
SpaceDTO
all space information
Fetching list of trending spaces
const spaces = await PushAPI . space . trending ( {
env ?: ENV ;
} ) ;
Param
Type
Default
Remarks
env
string
'prod'
API env - 'prod', 'staging', 'dev'
page
number
1
page index of the results
limit
number
10
number of items in 1 page
Expected response (Get trending spaces)
// PushAPI_space_trending | Response - 200 OK
// Array of spaces
[
{
spaceId :
'spaces:3aa43087b8c55ed9c534dd1d0a086a3340b0d829cda0a13592651cb59f284838' ,
about : null ,
did : null ,
intent :
'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A+eip155:0xF8aBe92d1d0706bF60509F8E9A64Ed6b8520E868' ,
intentSentBy : 'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
intentTimestamp : '2023-07-12T01:11:32.000Z' ,
publicKey : null ,
profilePicture : null ,
threadhash : null ,
wallets : null ,
combinedDID :
'eip155:0x12E429E3672a02E385F9f5F75E932cC1D566EEea_eip155:0x49D407CC9D0e966CD9B22BA40685083B49bd2315_eip155:0xF8aBe92d1d0706bF60509F8E9A64Ed6b8520E868_eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
name : null ,
spaceInformation : {
members : [ Array ] ,
pendingMembers : [ Array ] ,
contractAddressERC20 : null ,
numberOfERC20 : 0 ,
contractAddressNFT : null ,
numberOfNFTTokens : 0 ,
verificationProof :
'pgp:-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkrksbCZA3GHnYNke0AhYhBNp+D95LDfs4yU03LzcYedg2\n' +
'R7QCAACRdAf9ELAnCLXfBiAVdbgwj81xr+w9Yzw2wXLLrPLfYY7EXfyChLzQ\n' +
'rr9XBDdWMgtzEU1diSPMbLDh1METR7n71EjG0AoeX5A2pkHI7R1vIxXUJR3G\n' +
'fzHENsfGaKLnhrL1wLjBQACzEsIqPrHl9RItdtKEs9izLmc+wV0GFJ5OjbAs\n' +
'ty/1Q36nnMB7sQ7Ytb9Op+q0TtZPZ7jF9CjX8KGav3P1xDQex9nfsXiDHlLK\n' +
'MqDePaaMO6RJUWAP2xTo2k1DDJQ2dpUhs9XyjMlvFhVbIcT1/lVRCPC8V3C8\n' +
'fUKhUejvOjNFxf0QuR+E4xs+Q3zvR1+fXdJBxbH2Fp3kOTN1N9/LEw==\n' +
'=sLLC\n' +
'-----END PGP SIGNATURE-----\n' ,
spaceImage :
'' ,
spaceName : 'statutory_amber_roadrunner' ,
isPublic : true ,
spaceDescription : 'continued_bronze_pigeon' ,
spaceCreator : 'eip155:0xf4c946D6bd5cF09713D27364bbEd42712Bdffa8A' ,
spaceId :
'spaces:3aa43087b8c55ed9c534dd1d0a086a3340b0d829cda0a13592651cb59f284838' ,
scheduleAt : '2023-07-12T06:51:32.000Z' ,
scheduleEnd : '2023-07-12T07:41:32.000Z' ,
status : 'PENDING' ,
} ,
msg : {
fromCAIP10 : 'eip155:0x1615d2D9ae82D5F0eE79298899962b237386feB7' ,
toCAIP10 : 'eip155:0x1C48fE875590f8e366447758b13982a3Ca7d9dBE' ,
fromDID : 'eip155:0x1615d2D9ae82D5F0eE79298899962b237386feB7' ,
toDID : 'eip155:0x1C48fE875590f8e366447758b13982a3Ca7d9dBE' ,
messageContent : "Gm gm! It's me... Mario" ,
messageType : 'Text' ,
signature :
'-----BEGIN PGP SIGNATURE-----\n' +
'\n' +
'wsBzBAEBCAAnBYJkWKQWCZB7dzg7q3axjBYhBJFuYslzDGbuE+3FMnt3ODur\n' +
'drGMAAAjtAf/TXjtm2qb6aSikFPKYXm0Ekws+65fisJGf7T48MYkkfcD4t2e\n' +
'HXd9LtohzGhcztbOQfAND3yME1GWuMBIksq9rlyEA0ezwsGzCJVhBnkAHBe3\n' +
'+1v4/mNSMmInU8y6sOiLiOcW7ameJvZvDdPDJ0YHhc9dKDCIh1UAZEPAgx+z\n' +
'Wc0DM6pW8bT70dfgnuW2LlLGF5Z23Z1vbHmeszt78+xYY3ez/hoMHXUIE25z\n' +
'Wrnt75nasBBahtJ0mwH10ATnsQNE9hTi6XPGYxRSNDM9nyRxTQUpjhNmGS/+\n' +
'7oFyq8xTcRSaL7d3h8URp9hgFWher5ZZDyMV0jvk+HPguUX54g6Kgw==\n' +
'=dcRD\n' +
'-----END PGP SIGNATURE-----\n' ,
timestamp : 1683530775648 ,
sigType : 'pgp' ,
encType : 'pgp' ,
encryptedSecret :
'-----BEGIN PGP MESSAGE-----\n' +
'\n' +
'wcBMA9aU+JGZVRn/AQgA1pIJHyeJinU21r6At5S5ZaWeN0OEKVB2TjpqZ0IW\n' +
'lHLKQrQ8k3M16bN+Vf0P+DzDVOL84QRkBD56qSNVHOOCox5wcQeR01CczenV\n' +
'LUVvVjBzR2hj7Sdw+Q+M//rgeZPPUDbNyiVmGijelhwDqWd7IOoZY26AGXlm\n' +
'7YQiElvHN2HcYXaTlLAOy36BcccwHu3Tn06F77ZXaf8FnGMWOUy7wh1/jugg\n' +
'D17jUZGLYbmw+u5l9BOfljbw2pb4vtjWht0I1b4GYlKb+bYg/NY0UNsq7mSh\n' +
'dGAmOhy5tC2NMjLRRLfD2qasxHoHN50onlB6HcYLl0RCf31ebOgO6rMhUnxt\n' +
'9cHATAMLWLG2xubrYAEH/2tVeq2j7nJALGSFxjJPboOY57aiFrhXNQ/e/oXH\n' +
'//TNJgGWx4Ta++OuF2Oexbh9DIZhl6DWld9adXDDtBS/fEyjNsYqwoYlNEJN\n' +
'kLvSmokNNrE4MKC1A0GkhSh2MGQDNk42GSgz1tep8XSVc98MHqfNXCHVb5Oa\n' +
'OBeWKLFyElT3+KuZxSkCsnoO5YjuCGbXPyG06tXMHXMTncpj1ri+vpjUSnhD\n' +
'wn3o0zpNWu0GaWXIgTqj2ZouVwV2S1+wAJQjE8uI1JvBiMhA+X63/GCcApBu\n' +
'C7rN0Cs5NGXCn9VWp8i1SCp2NuZ38POABwsXUUkjpF24txyUDX8dbXlkzpao\n' +
'g93SQAElYYmyKbGp1TKhAZl2u40mgf2yCYDv2DLRfAKMJDLvmjXoUGEg2UYO\n' +
'11w6LD0pIykdKJmFtRls/uMnlcoBgDA=\n' +
'=kzUH\n' +
'-----END PGP MESSAGE-----\n' ,
link : 'bafyreib34jgnpp573rwquejcq5avxvydis7fbykat6dd5z7uazobucoumm' ,
} ,
} ,
] ;
Parameter
Type
Description
msg
IMessageIPFS
message object
did
string
user DID
wallets
string
user wallets
profilePicture
string
user profile picture
publicKey
string
user public key
about
string
user description
threadhash
string
cid from the latest message sent on this conversation
intent
string
addresses concatenated from the users who have approved the intent
intentSentBy
string
address of the user who sent the intent
intentTimestamp
number
timestamp of the intent
combinedDID
string
concatenated addresses of the members of this space
cid
string
content identifier on IPFS
spaceId
string
space identifier
spaceInformation
SpaceDTO
all space information
Used to store the simple peer instance used for the webRTC connection.
private peerInstance: any = null ;
Used to store the signer of a user.
Used in the request, acceptRequest and disconnect methods to send notifications.
private signer : SignerType ;
The chain id of the chain on which the call is being conducted.
Used to store the PGP private key of a user.
Used in the request, acceptRequest and disconnect methods to send notifications.
private pgpPrivateKey: string ;
The environment on which the call is being conducted.
Stores data related to the video call.
export type IMediaStream = MediaStream | null ;
export enum VideoCallStatus {
UNINITIALIZED ,
INITIALIZED ,
RECEIVED ,
CONNECTED ,
DISCONNECTED ,
RETRY_INITIALIZED ,
RETRY_RECEIVED ,
}
export type PeerData = {
stream : IMediaStream ; // incoming media stream
audio : boolean | null ; // incoming audio status
video : boolean | null ; // incoming video status
address : string ; // incoming address
status : VideoCallStatus ; // status for the connection with incoming peer
retryCount : number ; // number of retires done
} ;
export type VideoCallData = {
meta : {
chatId : string ; // unique chatId for the corresponding push w2w chat
initiator : {
address : string ; // initiator's address
signal : any ; // initiator's signaling data for webRTC connection
} ;
broadcast ?: {
livepeerInfo : any ;
hostAddress : string ;
coHostAddress : string ;
} ;
} ;
local : {
stream : IMediaStream ; // local media stream
audio : boolean | null ; // local audio status
video : boolean | null ; // local video status
address : string ; // local address
} ;
incoming : [ PeerData ] ;
} ;
private data : VideoCallData ;
This function can be used to update the video call data
setData: ( fn : ( data : VideoCallData ) => VideoCallData ) => void ;
// usage
import { produce } from 'immer' ;
setData ( ( oldData ) => {
return produce ( oldData , ( draft ) => {
// update the draft object, example
draft . incoming . status = VideoCallStatus . INITIALIZED ;
} ) ;
} ) ;
constructor ( {
signer,
chainId,
pgpPrivateKey,
env,
setData,
} : {
signer : SignerType ;
chainId: number ;
pgpPrivateKey: string ;
env?: ENV ;
setData: ( fn : ( data : VideoCallData ) => VideoCallData ) => void ;
} ) { }
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
signer_
SignerType
-
signer object for a user
chainId*
number
-
chainId for the video call - Eth Mainnet: 1, Polygon Mainnet: 137
pgpPrivatekey*
string
-
PGP private key of the user, used while sending video call notifications
env
string
'prod'
API env - 'prod', 'staging', 'dev'
setData*
(fn: (data: VideoCallData) => VideoCallData) => void
-
Function to update video call data
This method is used to create a local stream
Assigns the local stream obtained from the navigator.mediaDevices.getUserMedia
to data.local.stream
state.
export type VideoCreateInputOptions = {
video ?: boolean ;
audio ?: boolean ;
} ;
async create ( options : VideoCreateInputOptions ) : Promise < void > { }
Allowed Options (params with * are mandatory)
Param
Type
Default
Remarks
video
boolean
true
video status for the local stream
audio
boolean
true
audio status for the local stream
Note - If audio, video aren't enabled in create() then they wont be available during the call respectively.
This method is used to request a push video call.
Will be triggered on the initiator's end.
export type VideoRequestInputOptions = {
senderAddress : string ;
recipientAddress : string ;
chatId : string ;
onReceiveMessage ?: ( message : string ) => void ;
retry ?: boolean ;
} ;
async request ( options : VideoRequestInputOptions ) : Promise < void > { }
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
senderAddress_
string
-
Local peer address
recipientAddress*
string
-
Incoming/remote peer address
chatId*
string
-
Unique identifier for every wallet-to-wallet push chat, will be used during verification proof generation
onReceiveMessage
(message: string) => void
(message: string) => {console.log('received a meesage', message);}
Function which will be called when the sender receives a message via webRTC data channel
retry
boolean
false
If we are retrying the call, only for internal use
This method is used to accept a push video call.
Will be triggered on the receiver's end.
export type VideoAcceptRequestInputOptions = {
signalData : any ;
senderAddress : string ;
recipientAddress : string ;
chatId : string ;
onReceiveMessage ?: ( message : string ) => void ;
retry ?: boolean ;
} ;
async acceptRequest ( options : VideoAcceptRequestInputOptions ) : Promise < void > { }
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
signalData_
any
-
Signal data received from the initiator peer via psuh notification upon call request
senderAddress*
string
-
Local peer address
recipientAddress*
string
-
Incoming/remote peer address
chatId*
string
-
Unique identifier for every wallet-to-wallet push chat, will be used during verification proof generation
onReceiveMessage
(message: string) => void
(message: string) => {console.log('received a meesage', message);}
Function which will be called when the sender receives a message via webRTC data channel
retry
boolean
false
If we are retrying the call, only for internal use
This is the final method which is used to connect a push video call.
Will be triggered on the initiator's end.
export type VideoConnectInputOptions = {
signalData : any ;
peerAddress ?: string ;
} ;
connect ( options : VideoConnectInputOptions ) : void { }
Allowed Options (params with _ are mandatory)
Param
Type
Default
Remarks
signalData_
any
-
Signal data received from the receiver peer via push notification upon call acceptRequest
peerAddress
string
data.incoming[0].address
Address of the receiver peer, received via push notification upon call acceptRequest
This method is used to end a push video call.
Can be triggered on the initiator as well as receivers end.
export type VideoDisconnectOptions = {
peerAddress : string ;
} | null ;
disconnect ( options : VideoDisconnectOptions ) : void { }
Allowed Options (params with * are mandatory)
Param
Type
Default
Remarks
peerAddress
string
data.incoming[0].address
Address of the peer to be disconnected from
This method is used to enable/disable the video (from data.local.stream
) for a push video call.
Can be triggered on the initiator as well as receivers end.
Note - If video was not enabled during create()
then it will always remain off.
export type EnableVideoInputOptions = {
state : boolean ;
}
enableVideo ( options : EnableVideoInputOptions ) : void
Allowed Options (params with * are mandatory)
Param
Type
Default
Remarks
state
boolean
-
true for enable and false for disable
This method is used to enable/disable the audio (from data.local.stream
) for a push video call.
Can be triggered on the initiator as well as receivers end.
Note - If audio was not enabled during create()
then it will always remain off.
export type EnableAudioInputOptions = {
state : boolean ;
}
enableAudio ( options : EnableAudioInputOptions ) : void
Allowed Options (params with * are mandatory)
Param
Type
Default
Remarks
state
boolean
-
true for enable and false for disable
This method is used to tell if the current peer is the initator of the push video call or not.
Can be triggered on the initiator as well as receivers end.