Chat requests overview
You can send a message using chat.send API to either an existing chat connection or to initiate a new chat to a wallet you haven't chatted with before (which is called sending a chat request).
Any chat from a push user who is not your connection already to your wallet lands in your chat requests and you will need to accept, reject or block them accordingly. This enables a seamless UX and eliminates spam problems with chat.
Accept chat requests API
To accept an incoming chat requests. Only called once per chat request. Once chat request is accepted, the chat connection is marked as active and any chat you receive moving forward will also send push notifications driving re-engagement to your app.
- js
// userAlice.chat.accept(recipient)
// recipient - Can be wallet address, nft address or chatid | See Types of Recipient for more info
const bobAcceptAliceRequest = await userBob.chat.accept(aliceAddress);
Accept chat request parameters
Param | Type | Default | Remarks |
---|---|---|---|
recipient | string | - | Recipient supports a number of address format including wallet addresses, chain agnostic wallet addresses, NFT addresses or even chatid which is useful for groups |
Note: Parameters
in this style
are mandatory.
Expected response
Reject chat request API
To reject an incoming chat request. Once rejected, the user can still send you a message that will land in your chat request again.
- js
// userAlice.chat.reject(recipient)
// recipient - Can be wallet address, nft address or chatid | See Types of Recipient for more info
const bobAcceptAliceRequest = await userBob.chat.reject(aliceAddress);
Reject chat request parameters
Param | Type | Default | Remarks |
---|---|---|---|
recipient | string | - | Recipient supports a number of address format including wallet addresses, chain agnostic wallet addresses, NFT addresses or even chatid which is useful for groups |
Note: Parameters
in this style
are mandatory.
Expected response
Chat Info API
Chat Info API can be used to get the status of a chat between users, basically to check if a chat request is pending or if it has been accepted by the other user.
- js
// To check the status of a chat between userAlice and userBob
// userAlice.chat.info(chatId, bobAddress)
const statusOfChatWithBob = await userAlice.chat.info(chatId, bobAddress);
Chat Info parameters
Param | Type | Default | Remarks |
---|---|---|---|
chatId | string | - | The unique identifier of the chat between Alice and Bob |
address | string | - | The address of the user to check the status with. |
Note: Parameters
in this style
are mandatory.
Expected response (When Alice's chat request has already been accepted by Bob)
{
"meta": {
"group": false
},
"list": "CHATS"
}
Param | Type | Remarks |
---|---|---|
meta.group | boolean | returns true when the passed chatId is of a group chat and vice versa. |
list | string | returns CHATS when the chat request has been accepted by the other user. |
Expected response (When Alice's Chat request is pending or not yet accepted by Bob)
{
"meta": {
"group": false
},
"list": "REQUESTS"
}
Param | Type | Remarks |
---|---|---|
meta.group | boolean | returns true when the passed chatId is of a group chat and vice versa. |
list | string | returns REQUESTS when the chat request has been accepted by the other user. |
Block chat request API
To block an incoming chat requests. Once blocked, the user will not be able to send you DMs or invite you to a group.
- js
// userAlice.chat.block([recipient])
// recipient - Can be wallet address, nft address or chatid | See Types of Recipient for more info
const bobBlockAliceRequest = await userBob.chat.block([aliceAddress]);
Block chat request parameters
Param | Type | Default | Remarks |
---|---|---|---|
recipient | string[] | - | Recipient supports a number of address format including wallet addresses, chain agnostic wallet addresses, NFT addresses or even chatid which is useful for groups |
Note: Parameters
in this style
are mandatory.
Expected response
{
"did": "eip155:0xE95d1c080E72021d94Ef247d86897766C5807A98",
"wallets": "eip155:0xE95d1c080E72021d94Ef247d86897766C5807A98",
"publicKey": "-----BEGIN PGP PUBLIC KEY BLOCK-----...-----END PGP PUBLIC KEY BLOCK-----\n",
"encryptedPrivateKey": "{...}",
"verificationProof": "eip191v2:0x6f5fa197aaf6760ec7479b0512756224b57c7ff431c2f2c086e0730d30c4dec429615b619f4509cbcf36874ed507bc40161266eabe7d8516962199565309bc811b",
"msgSent": 0,
"maxMsgPersisted": 1000,
"profile": {
"name": null,
"desc": null,
"picture": "",
"blockedUsersList": [ "eip155:0x4Fc0F35B0ab1201ae9F8F8f589bea01f556022dF" ],
"profileVerificationProof": "pgpv2:-----BEGIN PGP SIGNATURE-----...-----END PGP SIGNATURE-----\n"
},
"origin": null,
"name": null,
"about": null,
"profilePicture": "",
"numMsg": 0,
"allowedNumMsg": 1000,
"encryptionType": "eip191-aes256-gcm-hkdf-sha256",
"signature": "0x6f5fa197aaf6760ec7479b0512756224b57c7ff431c2f2c086e0730d30c4dec429615b619f4509cbcf36874ed507bc40161266eabe7d8516962199565309bc811b",
"sigType": "eip191v2",
"encryptedPassword": null,
"nftOwner": null,
"linkedListHash": null,
"nfts": null
}
Unblock a user API
To unblock an user.
- js
// userAlice.chat.unblock([recipient])
// recipient - Can be wallet address, nft address or chatid | See Types of Recipient for more info
const bobUnblockAlice = await userBob.chat.unblock([aliceAddress]);
Unblock a user parameters
Param | Type | Default | Remarks |
---|---|---|---|
recipient | string[] | - | Recipient supports a number of address format including wallet addresses, chain agnostic wallet addresses, NFT addresses or even chatid which is useful for groups |
Note: Parameters
in this style
are mandatory.
Expected response
{
"did": "eip155:0xE95d1c080E72021d94Ef247d86897766C5807A98",
"wallets": "eip155:0xE95d1c080E72021d94Ef247d86897766C5807A98",
"publicKey": "-----BEGIN PGP PUBLIC KEY BLOCK-----...-----END PGP PUBLIC KEY BLOCK-----\n",
"encryptedPrivateKey": "{...}",
"verificationProof": "eip191v2:0x6f5fa197aaf6760ec7479b0512756224b57c7ff431c2f2c086e0730d30c4dec429615b619f4509cbcf36874ed507bc40161266eabe7d8516962199565309bc811b",
"msgSent": 0,
"maxMsgPersisted": 1000,
"profile": {
"name": null,
"desc": null,
"picture": "",
"blockedUsersList": [],
"profileVerificationProof": "pgpv2:-----BEGIN PGP SIGNATURE-----...-----END PGP SIGNATURE-----\n"
},
"origin": null,
"name": null,
"about": null,
"profilePicture": "",
"numMsg": 0,
"allowedNumMsg": 1000,
"encryptionType": "eip191-aes256-gcm-hkdf-sha256",
"signature": "0x6f5fa197aaf6760ec7479b0512756224b57c7ff431c2f2c086e0730d30c4dec429615b619f4509cbcf36874ed507bc40161266eabe7d8516962199565309bc811b",
"sigType": "eip191v2",
"encryptedPassword": null,
"nftOwner": null,
"linkedListHash": null,
"nfts": null
}