-
Notifications
You must be signed in to change notification settings - Fork 7
Inbox
Inbox allows you to communicate with all active mobile users without dependency on possible poor push deliverability or users not paying attention to their push notifications.
Method for fetching the inbox uses authorization. Secure authorization is required for production applications. Read about the details of inbox authorization in the following article
Since React Native plugin version 12.0.0 Inbox is supported by default.
Inbox messages can be fetched only by personalized users (learn more about personalization here). It is important to mention that only personalization by External User Id is supported, however, since this Id can be any meaningful string, you can specify a unique users Phone number or Email as an External User Id but keep in mind that this is the case-sensitive data.
Mobile Messaging Inbox SDK provides API for fetching messages.
This API requires a securely signed JWT (JSON Web Token encoded in Base64 format) in order to pass authentication on Infobip's server side (See how to generate JWT). In order to enable this API, generate JSON Web Token (JWT) for inbox at App Profile configuration page by navigating to "JWT private keys for mobile app inbox" and press "Generate key".
mobileMessaging.fetchInboxMessages(
"<# token - your JWT in Base64 #>",
"<# externalUserId - some user Id #>",
filterOptions, // for more details about this field visit Filtering options section below
inbox => {
console.log('Successfully fetched inbox messages'),
console.log(inbox);
Alert.alert('Inbox Messages', JSON.stringify(inbox), [
{text: 'Ok', style: 'destructive'},
]);
},
error =>
console.log('Error fetching inbox messages: ' + error.description),
);
For Sandbox App Profiles we also provide API that does not require user to be authenticated (uses application code based authorization):
mobileMessaging.fetchInboxMessagesWithoutToken(
"<# externalUserId - some user Id #>",
filterOptions, // for more details about this field visit Filtering options section below
inbox => {
console.log('Successfully fetched inbox messages'),
console.log(inbox);
Alert.alert('Inbox Messages', JSON.stringify(inbox), [
{text: 'Ok', style: 'destructive'},
]);
},
error =>
console.log('Error fetching inbox messages: ' + error.description),
);
This API has no additional requirements authorization and simple to use, but can be used only for testing and demo purposes. In order to enable this API for your App Profile choose the "Application code" radio button in "Inbox authorization type" section on your App Profile's configuration page.
As a return for a call to fetchInboxMessages
or fetchInboxMessagesWithoutToken
you will get a JSON object with the following structure:
{
"messages": "<# list of messages #>",
"countTotal":1,
"countUnread":0
}
So, as a result, aside of list of messages, you will also receive two additional fields:
countTotal
and countUnread
.
You can access fields in response as:
mobileMessaging.fetchInboxMessages(
"<# token - your JWT in Base64 #>",
"<# externalUserId - some user Id #>",
filterOptions, // for more details about this field visit Filtering options section below
inbox => {
console.log('Successfully fetched inbox messages'),
inbox.messages.forEach(message => {});
},
error =>
console.log('Error fetching inbox messages: ' + error.description),
);
You need to be very cautious about the Infobip server response when fetching users messages using JWT token based authorization.
There are many reasons why you might get "UNAUTHORIZED" error response from Infobip backend. For security reasons, we don't disclose any details about the error, so you need to be even more cautious. One of the most common reasons for that error are:
- Expiration of the JWT token. You always have to use "fresh" token and reissue the new one in case of expiration happened or is about to happen.
- Invalid JWT token payload (missing mandatory claims or headers, typos).
- Wrong Application Code that is used to generate the JWT token. It's easy to make mistake when you have multiple App Profiles.
- Invalid secret key used for signing (a typo occurred or the key could have been revoked by you/your colleagues on App Profile page).
The complete information about the JWT token requirements and implementation details can be found here.
The following example demonstrates, how you can recognize and handle the "UNAUTHORIZED" error:
try {
mobileMessaging.fetchInboxMessages(
"<# token - your JWT in Base64 #>",
"<# externalUserId - some user Id #>",
filterOptions, // for more details about this field visit Filtering options section below
inbox => {
console.log('Successfully fetched inbox messages'),
inbox.messages.forEach(message => {});
},
error =>
console.log('Error fetching inbox messages: ' + error.description),
)
} catch (e) {
if (e.code == 'UNAUTHORIZED') {
//TODO: I'm pretty sure the JWT token payload is correct here,
// it's just the token got expired,
// I will call my backend to reissue the fresh token for me and try again.")
}
}
Another error response that you might face is "ACCESS_TOKEN_MISSING". This error means that in your App Profile page it has been set up to use "JSON Web Token (JWT)" for Inbox authorization, thus in your mobile app, you need to switch to the JWT token based Inbox API:
use mobileMessaging.fetchInboxMessages(<# token - your JWT in Base64 #>,<# externalUserId - some user Id #>)",
instead of mobileMessaging.fetchInboxMessagesWithoutToken(<# externalUserId - some user Id #>)
.
The complete information about the JWT token requirements and implementation details can be found here.
You can specify the following filtering options to fetch Inbox messages. Expected date format is yyyy-MM-dd'T'HH:mm:ssZZZZZ
:
- filtering by particular time interval to get messages with
sendDateTime
greater than or equalMobileInboxFilterOptions.fromDateTime
and less thanMobileInboxFilterOptions.toDateTime
. By default or in case ofnull
, filter by date/time is not applied. For example the followingfetchInboxMessages
call would return Inbox messages sent for one day:
let filterOptions = {
fromDateTime: "2024-03-11T12:00:00+01:00",
toDateTime: "2024-03-20T12:00:00+01:00",
topic: null,
limit: null,
};
mobileMessaging.fetchInboxMessages(
"<# token - your JWT in Base64 #>",
"<# externalUserId - some user Id #>",
filterOptions,
inbox => {
console.log('Successfully fetched inbox messages'),
inbox.messages.forEach(message => {});
},
error =>
console.log('Error fetching inbox messages: ' + error.description),
);
- filtering by a specific topic can be handy if you have a specific UI/UX approach to separate messages by different topics. By default or in case of
null
, filter by topic is not applied.
let filterOptions = {
fromDateTime: null,
toDateTime: null,
topic: "myPromoTopic",
limit: null,
};
mobileMessaging.fetchInboxMessages(
"<# token - your JWT in Base64 #>",
"<# externalUserId - some user Id #>",
filterOptions,
inbox => {
console.log('Successfully fetched inbox messages'),
inbox.messages.forEach(message => {});
},
error =>
console.log('Error fetching inbox messages: ' + error.description),
);
- limiting the maximum number of messages that will be returned by Infobip server. By default or in case of
null
, server returns 20 messages as maximum. This one together with filtering bytoDateTime
is useful when you need to implement pagination that might help reducing mobile data usage and fetch messages by chunks. For example, the following listing shows how to fetch whole inbox by chunks of 10 messages, one by one, from the most recent to the oldest:
let filterOptions = {
fromDateTime: null,
toDateTime: "2024-03-20T12:00:00+01:00",//for example: if we take as this date to be oldest message timestamp
topic: null,
limit: 10,
};
mobileMessaging.fetchInboxMessages(
"<# token - your JWT in Base64 #>",
"<# externalUserId - some user Id #>",
filterOptions,
inbox => {
console.log('Successfully fetched inbox messages'),
inbox.messages.forEach(message => {});
},
error =>
console.log('Error fetching inbox messages: ' + error.description),
);
You can mark Inbox messages as seen/read using the following API:
let messageIds = ['messageId_1', 'messageId_2', 'messageId_3']; //list of message Ids that you consider as seen by the end user
mobileMessaging.setInboxMessagesSeen(
"<# externalUserId - some user Id #>",
messageIds,
returnedMessageIds => {
console.log('Successfully set inbox messages as seen'),
console.log(returnedMessageIds);
},
error =>
console.log('Error setting messages as seen: ' + error.description));
If you have any questions or suggestions, feel free to send an email to [email protected] or create an issue.
- Library events
- Server errors
- Users and installations
- Messages and notifications management
- Inbox
- Privacy settings
- In‐app chat
- WebRTC Calls and UI
- Migration guides