KEMBAR78
RCS-e Stack API Specification: Reference NSM/FT/R&D/MAPS/DVC/xx-09 | PDF | Session Initiation Protocol | Application Programming Interface
0% found this document useful (0 votes)
209 views33 pages

RCS-e Stack API Specification: Reference NSM/FT/R&D/MAPS/DVC/xx-09

API offers high level interface to implement RCS applications (i.e. UI, Widget) document contains information that is the property of France Telecom R&D. Acceptance of this document by its recipient implies, on his part, recognition of the confidential nature of its content.
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
209 views33 pages

RCS-e Stack API Specification: Reference NSM/FT/R&D/MAPS/DVC/xx-09

API offers high level interface to implement RCS applications (i.e. UI, Widget) document contains information that is the property of France Telecom R&D. Acceptance of this document by its recipient implies, on his part, recognition of the confidential nature of its content.
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 33

internal Group

Reference NSM/FT/R&D/MAPS/DVC/xx-09
Checked by:

Edition 1.0 Date:

RCS-e stack API Specification


Approved by:

Author: AUFFRET Jean-Marc (ASC Devices) jeanmarc.auffret@orange-ftgroup.com Date :

Date: 2011-05-11

Summary:

Specification of the RCS API on top of the RCS-e stack. This API offers high level interface to implement RCS applications (i.e. UI, Widget).

The present document contains information that is the property of France Telecom R&D. Acceptance of this document by its recipient implies, on the latter's part, recognition of the confidential nature of its content and the undertaking not to proceed with the reproduction, transmission to third parties, disclosure or commercial utilisation without the prior written agreement of France Telecom R&D.

33 pages

RCS-e API for Android platform

CONTENTS 1. 1.1. 1.2. 1.3. 1.4. 2. 2.1. 2.2. 3. 3.1. 3.2. 3.3. 4. 4.1. 4.2. 4.3. 5. 5.1. 5.2. 5.3. 6. 6.1. 6.2. 7. 7.1. 7.2. 7.3. 8. 8.1. 8.2. 8.3. 9. 9.1. INTRODUCTION ........................................................................................................................................ 5 PURPOSE OF THE DOCUMENT ........................................................................................................... 5 REFERENCE DOCUMENTS .................................................................................................................. 5 ABBREVIATIONS .................................................................................................................................... 5 TERMINOLOGY ...................................................................................................................................... 5 RCS API ..................................................................................................................................................... 6 OVERALL DESCRIPTION ...................................................................................................................... 6 COMMON API DEFINITION .................................................................................................................... 6 COMMON API ............................................................................................................................................ 9 DESCRIPTION ........................................................................................................................................ 9 API ........................................................................................................................................................... 9 INTENTS DECLARATION ....................................................................................................................... 9 IMS API..................................................................................................................................................... 11 DESCRIPTION ...................................................................................................................................... 11 API ......................................................................................................................................................... 11 INTENTS ............................................................................................................................................... 11 CAPABILITY API ..................................................................................................................................... 12 DESCRIPTION ...................................................................................................................................... 12 API ......................................................................................................................................................... 12 INTENTS ............................................................................................................................................... 13 CONTACTS API ....................................................................................................................................... 14 DESCRIPTION ...................................................................................................................................... 14 API ......................................................................................................................................................... 14 PRESENCE API ....................................................................................................................................... 17 DESCRIPTION ...................................................................................................................................... 17 API ......................................................................................................................................................... 17 INTENTS ............................................................................................................................................... 19 RICH CALL API ....................................................................................................................................... 20 DESCRIPTION ...................................................................................................................................... 20 API ......................................................................................................................................................... 20 INTENTS ............................................................................................................................................... 22 MESSAGING API ..................................................................................................................................... 23 DESCRIPTION ...................................................................................................................................... 23

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

2 / 33

RCS-e API for Android platform

9.2. 9.3. 10. 10.1. 10.2. 11. 11.1. 11.2. 12. 12.1. 12.2. 12.3. 13.

API ......................................................................................................................................................... 23 INTENTS ............................................................................................................................................... 26 EVENT LOG API .................................................................................................................................... 27 DESCRIPTION .................................................................................................................................... 27 API ....................................................................................................................................................... 27 MEDIA API ............................................................................................................................................. 29 DESCRIPTION .................................................................................................................................... 29 API ....................................................................................................................................................... 29 RCS SETTINGS ..................................................................................................................................... 31 DESCRIPTION .................................................................................................................................... 31 PARAMETERS .................................................................................................................................... 31 API ....................................................................................................................................................... 32 NOTES.................................................................................................................................................... 33

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

3 / 33

RCS-e API for Android platform

FIGURES Figure 1: Common API architecture .................................................................................................................. 7 Figure 2: IMS connection monitoring ................................................................................................................. 8

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

4 / 33

RCS-e API for Android platform

1. Introduction
1.1. Purpose of the document
This document describes the RCS API of the RCS-e stack. This API offers high level interface to implement RCS applications (i.e. UI, Widget).

1.2. Reference documents


N 1 Title RCS-e specification release documents: http://www.gsmworld.com/our-work/mobile_lifestyle/rcs/index.htm Google Android SDK: http://developer.android.com/index.html Release 1.1

2.x

1.3. Abbreviations
Abbreviation IMS CSh EAB SIP RTP MSRP AIDL Name IP Multimedia Subsystem Content sharing Enhanced Address Book Session Initiation Protocol Real Time Protocol Media Session Relay Protocol Android Inter-process communication protocol

1.4. Terminology
Term Activity Service Intent Intent filter Broadcast receiver Early IMS Description Android UI application Android background process Android description of an operation to be performed Structured description of an intent to be matched An application class that listens for Intents that are broadcasted GIBA authentication

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

5 / 33

RCS-e API for Android platform

2. RCS API
2.1. Overall description
The RCS-e stack is implemented into an Android background service which offers a high level API: the RCS API. The RCS API is a client/server interface based on database providers, AIDL API & Intents. Several UI may be connected at a time to manage RCS events and to interact with the single stack instance running in background. The RCS API permits to implement RCS application (e.g. enhanced address book, content sharing, chat, widgets) by hiding RCS protocols complexity. The RCS API offers the following API: Capability API: contact capabilities discovery. Contacts API: RCS contact management and integration with the native address book. Presence API: social presence sharing, presence subscription & publishing, anonymous fetch. Rich call API: image sharing & video sharing during CS call. Messaging API: 1-1 chat, group chat and file transfer. Media API: media player & renderer. Events log API: chat & file transfer history, rich call history and aggregation with classic log (calls, SMS, MMS). RCS settings database provider: application and stack settings.

2.2. Common API definition


The RCS API uses the following Android concepts: Intents mechanism to broadcast incoming events (e.g. notification) and incoming invitations to any Android activity or broadcast receiver which are declared in the device. AIDL interfaces to initiate and to manage session in real time (start, session monitoring, stop). Session events are managed thanks to callback mechanism. Methods of the RCS API throw an exception if the IMS core layer is not initialized or not registered to the IMS platform. Note: Remote application exceptions are not yet supported by the AIDL SDK, a generic AIDL exception is thrown instead. How to use Intents? By dynamically registering an instance of a class with Context.registerReceiver() or by using the <receiver> tag in your AndroidManifest.xml. Then the type of requested event is fixed in the Intent filter associated to the receiver, each RCS API has its own list of available intents. How to use the AIDL interface? The AIDL interface is hidden by an interface which main goal is to connect to the AIDL server side and to monitor the connection with it.

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

6 / 33

RCS-e API for Android platform

Application new addApiEventListener connectApi

API

Server AIDL API

RCS Service

bindService(API)

API is ready to be used

onServiceConnected
handleApiConnected

Call any API method


Call any API method

API method implementation

API is no more available for any reason

handleApiDisconnected

onServiceDisconnected

Figure 1: Common API architecture Note: an exception is thrown if the API is not yet initialized when calling a method.

The RCS API has also API callbacks to monitor in real time the IMS connection status:

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

7 / 33

RCS-e API for Android platform

Application new addApiEventListener


Connect to API

API

Server AIDL API

RCS Service

connectApi

bindService(API)

No more connected to IMS: update UI menus

Data connection lost !

handleImsDisconnected

handleImsDisconnected

Figure 2: IMS connection monitoring

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

8 / 33

RCS-e API for Android platform

3. Common API
3.1. Description
This API is common to all other API offering an AIDL interface: Capability API, Presence API, Rich call API and messaging API. This API is used to manage the connection to the Android service implementing the RCS-e stack (.i.e server part of the RCS API). For example, this API may be useful: To detect if the Android service has been shutdown in order to disable a menu in UI part. To check if the API is well connected to the Android service. See classes: ClientApi ClientApiListener ClientApiIntents ClientApiException CoreServiceNotAvailableException

3.2. API
// Is service started: // - Parameter ctx: application context. // - Returns True if the service is running in background, else returns False. boolean isServiceStarted(Context ctx); // Add an API event listener: // - Parameter listener: API event listener. void addApiEventListener(ClientApiListener listener); // Remove an API event listener: // - Parameter listener: API event listener. void removeApiEventListener(ClientApiListener listener); // Remove all API event listeners: void removeAllApiEventListeners(); // Client API event listener: interface ClientApiListener { // API is disabled (e.g. server not started) public void handleApiDisabled(); // API is connected to the server public void handleApiConnected(); // API is disconnected from the server public void handleApiDisconnected(); }

3.3. Intents declaration


// Intent which permits to load the RCS settings application: com.orangelabs.rcs.SETTINGS

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

9 / 33

RCS-e API for Android platform

// Intent broadcasted when the RCS service status has changed: // - Parameter status: starting, started, stopping, stopped, failed com.orangelabs.rcs.SERVICE_STATUS

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

10 / 33

RCS-e API for Android platform

4. IMS API
4.1. Description
This API is common to all other API offering an AIDL interface: Capability API, Presence API, Rich call API and messaging API. This API is used to manage the connection with the IMS platform. For example, this API may be used: To detect an IMS disconnection in order to disable a menu in UI part. To get the current IMS connection status in order to enable or not a RCS menu. See classes: ImsApi ImsEventListener

4.2. API
// Add an IMS event listener: // - Parameter listener: IMS event listener. public void addImsEventListener(ImsEventListener listener) // Remove an IMS event listener: // - Parameter listener: IMS event listener. public void removeImsEventListener(ImsEventListener listener) // IMS event listener interface: public interface ImsEventListener { // Service is connected to the IMS public void handleImsConnected(); // Service is disconnected from the IMS public void handleImsDisconnected(); } // Is connected to IMS: // - Returns True if Service is registered to IMS, else returns False. public boolean isImsConnected();

4.3. Intents
// Intent broadcasted when the registration state has changed: // - Parameter status: connected, disconnected com.orangelabs.rcs.SERVICE_REGISTRATION

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

11 / 33

RCS-e API for Android platform

5. Capability API
5.1. Description
This API permits to discover capabilities supported by contacts of the address book. For example, this API may be used: To request capability update for a user when opening its contact card in the address book. To synchronize capabilities of all the contacts from the RCS account management menu. See classes: CapabilityApi Capabilities CapabilityApiIntents

5.2. API
// Connect API: void connectApi(); // Disconnect API: void disconnectApi(); // Get my capabilities: // - Returns current capabilities. Capabilities getMyCapabilities(); // Get contact capabilities: // - Parameter contact: remote contact. // - Returns current capabilities of a contact. Capabilities getContactCapabilities(String contact); // Request capabilities for a given contact: // - Parameter contact: remote contact. // - Returns current capabilities of a contact and request a new network update in background. Capabilities requestCapabilities(String contact); // Synchronize all contacts: public void synchronizeAll(); // Capabilities object: class Capabilities { // Image sharing support boolean imageSharing; // Video sharing support boolean videoSharing; // IM session support boolean imSession; // File transfer support boolean fileTransfer; // CS video support boolean csVideo;

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

12 / 33

RCS-e API for Android platform

// Presence discovery support boolean presenceDiscovery = false; // Social presence support boolean socialPresence; // List of supported extensions ArrayList<String> extensions; // Last capabilities update long timestamp; }

5.3. Intents
// Intent broadcasted when contact capabilities has changed: // - Parameter contact: remote contact. // - Parameter capabilities: object containing the capabilities. com.orangelabs.rcs.capability.CONTACT_CAPABILITIES

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

13 / 33

RCS-e API for Android platform

6. Contacts API
6.1. Description
This API is an abstraction of the internal RCS database which contains all the RCS info associated to each contact of the address book. A contact has the following RCS info: Type of contact (RCS-e compliant, Share presence, .etc). Supported Capabilities (Image share, Chat, .etc). Social presence info (fretext, photo-icon, .etc). The additional RCS info for contacts are linked into the native address book database thanks to the ContactContract API of the Android SDK (from 2.x). Note: this API is not based on an AIDL interface and may be used even if the RCS service is stopped. See classes: ContactsApi ContactInfo

6.2. API
// Get contact info: // - Parameter contact: remote contact. // - Returns contact info or null if not found. ContactInfo getContactInfo(String contact); // Get a list of all RCS contacts having social presence info: // - Returns a list of contacts. List<String> getRcsContactsWithSocialPresence(); // Get a list of all RCS contacts: // - Returns a list of contacts. List<String> getRcsContacts(); // Get a list of all RCS blocked contacts: // - Returns a list of contacts. List<String> getRcsBlockedContacts(); // Get a list of all RCS invited contacts: // - Returns a list of contacts. List<String> getRcsInvitedContacts(); // Get a list of all RCS willing contacts: // - Returns a list of contacts. List<String> getRcsWillingContacts(); // Get a list of all RCS cancelled contacts: // - Returns a list of contacts. List<String> getRcsCancelledContacts(); // Get the IM-blocked status of a contact: // - Parameter contact: remote contact. // - Returns True if the contact if blocked for IM, else returns False. boolean isContactImBlocked(String contact); // Is the number in the RCS blocked list:
Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

14 / 33

RCS-e API for Android platform

// - Parameter number: phone number. // - Returns True if the number in blocked list, else returns False. boolean isNumberBlocked(String number); // Is the number in the RCS buddy list: // - Parameter number: phone number. // - Returns True if the number in granted list, else returns False. boolean isNumberShared(String number); // Has the number been invited to RCS: // - Parameter number: phone number. // - Returns True if the number in invited list, else returns False. boolean isNumberInvited(String number); // Has the number invited us to RCS: // - Parameter number: phone number. // - Returns True if the number in willing list, else returns False. boolean isNumberWilling(String number); // Has the number invited us to RCS then be cancelled: // - Parameter number: phone number. // - Returns True if the number has been cancelled, else returns False. boolean isNumberCancelled(String number); // Set the IM-blocked status of a contact: // - Parameter contact: remote contact. // - Parameter status: blocked state. void setImBlockedForContact(String contact, boolean status); // Get list of blocked contacts for IM sessions: // - Returns a list of contacts. List<String> getBlockedContactsForIm(); // Get list of contacts that can use IM sessions: // - Returns a list of contacts. List<String> getImSessionCapableContacts(); // Get list of contacts that can do use rich call features: // - Returns a list of contacts. List<String> getRichcallCapableContacts(); // Set the weblink visited flag to true for given contact: // - contact: remote contact. void setWeblinkVisitedForContact(String contact); // Get the weblink visited flag: // - contact: remote contact. boolean hasWeblinkBeenUpdatedForContact(String contact); // Remove a cancelled presence invitation: // - contact: remote contact. void removeCancelledPresenceInvitation(String contact); // Contact info object class ContactInfo { // Capabilities Capabilities capabilities; // Presence info PresenceInfo presenceInfo; // Contact URI String contact;
Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

15 / 33

RCS-e API for Android platform

// Registration state boolean isRegistered; // RCS status (not RCS | RCS capable) String rcsStatus; // RCS status timestamp long rcsStatusTimestamp; } Note: Capabilities object is defined in the Capability API. Note: PresenceInfo object is defined in the Presence API.

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

16 / 33

RCS-e API for Android platform

7. Presence API
7.1. Description
This API permits to manage social presence info and relationships with its RCS community or RCS contacts. This API is optional since RCS-e. See classes: PresenceApi PresenceApiIntents PresenceInfo PhotoIcon FavoriteLink Geoloc

7.2. API
// Connect API: void connectApi(); // Disconnect API: void disconnectApi(); // Get my presence info: // - Returns social presence info. PresenceInfo getMyPresenceInfo(); // Set my presence info: // - Parameter info: social presence info. // - Returns True if successful, else returns False. boolean setMyPresenceInfo(PresenceInfo info); // Invite a contact to share its presence: // - contact: remote contact. // - Returns True if successful, else returns False. boolean inviteContact(String contact); // Accept the sharing invitation from a contact: // - contact: remote contact. // - Returns True if successful, else returns False. boolean acceptSharingInvitation(String contact); // Reject the sharing invitation from a contact: // - contact: remote contact. // - Returns True if successful, else returns False. boolean rejectSharingInvitation(String contact); // Ignore the sharing invitation from a contact: // - contact: remote contact. void ignoreSharingInvitation(String contact); // Revoke a shared contact: // - contact: remote contact. // - Returns True if successful, else returns False. boolean revokeContact(String contact); // Unrevoke a revoked contact:
Copyright France Telecom 2008 NSM/FT/R&D/MAPS/DVC/xx-08 17 / 33

RCS-e API for Android platform

// - contact: remote contact. // - Returns True if successful, else returns False. boolean unrevokeContact(String contact); // Unblock a blocked contact: // - contact: remote contact. // - Returns True if successful, else returns False. boolean unblockContact(String contact); // Get the list of granted contacts: // - Returns a list of contacts. List<String> getGrantedContacts(); // Get the list of revoked contacts: // - Returns a list of contacts. List<String> getRevokedContacts(); // Get the list of blocked contacts: // - Returns a list of contacts. List<String> getBlockedContacts(); // Presence info object class PresenceInfo { // Presence timestamp long timestamp; // Presence status (online, offline) String status; // Free text String freetext; // Favorite link FavoriteLink favoriteLink; // Photo icon PhotoIcon photo; // Geoloc Geoloc geoloc; } // Photo-icon object class PhotoIcon { // Photo content byte[] content; // Image type String type; // Width int width; // Height int height; // Etag String etag; } // Favorite link object class FavoriteLink { // Link
Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

18 / 33

RCS-e API for Android platform

String link; // Name String name; } // Geoloc object class Geoloc { // Latitude double latitude; // Longitude double longitude; // Altitude double altitude; }

7.3. Intents
// Intent broadcasted when a presence sharing invitation has been received: // - Parameter contact: remote contact. com.orangelabs.rcs.presence.PRESENCE_SHARING_INVITATION // Intent broadcasted when user presence info has changed: com.orangelabs.rcs.presence.MY_PRESENCE_INFO_CHANGED // Intent broadcasted when a contact info has changed: // - Parameter contact: remote contact. com.orangelabs.rcs.presence.CONTACT_INFO_CHANGED // Intent broadcasted when a contact photo-icon has changed: // - Parameter contact: remote contact. com.orangelabs.rcs.presence.CONTACT_PHOTO_CHANGED // Intent broadcasted when a presence sharing info has changed: // - Parameter contact: remote contact. // - Parameter status: sharing status. // - Parameter reason: reason associated to the status. com.orangelabs.rcs.presence.PRESENCE_SHARING_CHANGED

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

19 / 33

RCS-e API for Android platform

8. Rich call API


8.1. Description
The API permits to share contents during a CS call (i.e. rich call service). This API should be used in coordination with the Capability API to discover if the remote contact supports Image share and video share. The capability discovering is automatically initiated by the RCS stack when the call is established, then the rich call application has just to catch the result to update the button Share in the dialer application. See also the media API for video player and vide recorder. See classes: RichCallApi RichCallApiIntents IVideoSharingSession IVideoSharingEventListener IImageSharingSession IImageSharingEventListener

8.2. API
// Connect API: void connectApi(); // Disconnect API: void disconnectApi(); // Initiate a live video sharing session: // - Parameter contact: remote contact. // - Parameter player: media player. // - Returns a video sharing session. IVideoSharingSession initiateLiveVideoSharing(String contact, IMediaPlayer player); // Initiate a pre-recorded video sharing session: // - Parameter contact: remote contact. // - Parameter file: file to be streamed. // - Parameter player: media player. // - Returns a video sharing session. IVideoSharingSession initiateVideoSharing(String contact, String file, IMediaPlayer player); // Get a video sharing session from its session ID: // - Parameter id: session ID. // - Returns a video sharing session or null if not found. IVideoSharingSession getVideoSharingSession(String id); // Initiate an image sharing session with a contact: // - Parameter contact: remote contact. // - Parameter file: file to be transfered. // - Returns an image sharing session. IImageSharingSession initiateImageSharing(String contact, String file); // Get an image sharing session from its session ID: // - Parameter id: session ID. // - Returns an image sharing session or null if not found. IImageSharingSession getImageSharingSession(String id);

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

20 / 33

RCS-e API for Android platform

// Image sharing session: interface IImageSharingSession { // Get session ID String getSessionID(); // Get remote contact String getRemoteContact(); // Get filename String getFilename(); // Get filesize long getFilesize(); // Accept the session invitation void acceptSession(); // Reject the session invitation void rejectSession(); // Cancel the session void cancelSession(); // Add session listener void addSessionListener(IImageSharingEventListener listener); // Remove session listener void removeSessionListener(IImageSharingEventListener listener); } // Image sharing event listener: interface IImageSharingEventListener { // Session is started void handleSessionStarted(); // Session has been aborted void handleSessionAborted(); // Session has been terminated by remote void handleSessionTerminatedByRemote(); // Content sharing progress void handleSharingProgress(long currentSize, long totalSize); // Content sharing error void handleSharingError(int error); // Image has been transferred void handleImageTransfered(String filename); } // Video sharing session: interface IVideoSharingSession { // Get session ID String getSessionID(); // Get remote contact String getRemoteContact(); // Accept the session invitation void acceptSession(); // Reject the session invitation
Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

21 / 33

RCS-e API for Android platform

void rejectSession(); // Cancel the session void cancelSession(); // Set the media renderer (only used for incoming session) void setMediaRenderer(IMediaRenderer renderer); // Add session listener void addSessionListener(IVideoSharingEventListener listener); // Remove session listener void removeSessionListener(IVideoSharingEventListener listener); } // Video sharing event listener: interface IVideoSharingEventListener { // Session is started void handleSessionStarted(); // Session has been aborted void handleSessionAborted(); // Session has been terminated by remote void handleSessionTerminatedByRemote(); // Content sharing error void handleSharingError(int error); }

8.3. Intents
// Intent broadcasted when a new image sharing invitation has been received: // - Parameter contact: remote contact. // - Parameter sessionId: session ID of the incoming session. com.orangelabs.rcs.richcall.IMAGE_SHARING_INVITATION // Intent broadcasted when a new video sharing invitation has been received: // - Parameter contact: remote contact. // - Parameter sessionId: session ID of the incoming session. com.orangelabs.rcs.richcall.VIDEO_SHARING_INVITATION

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

22 / 33

RCS-e API for Android platform

9. Messaging API
9.1. Description
This API permits to offer chat (one-to-one chat and group chat) and file transfer services. The chat service supports: Delivery report (message has been delivered, message has been displayed). Is-composing features. Add one or several participants to the current conversation. Conference event monitoring (someone has joined the session, someone has left the session). Note: the subject used during chat initiation should be used as the first message in the converstation.

9.2. API
// Connect API: void connectApi(); // Disconnect API: void disconnectApi(); // Transfer a file to a contact: // - Parameter contact: remote contact. // - Parameter file: file to be transfered. // - Returns a file transfer session. IFileTransferSession transferFile(String contact, String file); // Get the file transfer session from its session ID: // - Parameter id: session ID. // - Returns a file transfer session or null if not found. IFileTransferSession getFileTransferSession(String id); // Get list of file transfer sessions with a contact: // - Parameter contact: remote contact. // - Returns a file transfer session or null if not found. List<IBinder> getFileTransferSessionWith(String contact); // Get list of current established file transfer sessions: // - Returns a list of sessions. List<IBinder> getFileTransferSessions(); // File transfer session: interface IFileTransferSession { // Get session ID String getSessionID(); // Accept the session invitation void acceptSession(); // Reject the session invitation void rejectSession(); // Cancel the session void cancelSession(); // Add session listener void addSessionListener(IFileTransferEventListener listener);

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

23 / 33

RCS-e API for Android platform

// Remove session listener void removeSessionListener(IFileTransferEventListener listener); } // File transfer event listener: interface IFileTransferEventListener { // Session is started void handleSessionStarted(); // Session has been aborted void handleSessionAborted(); // Session has been terminated by remote void handleSessionTerminatedByRemote(); // Data transfer progress void handleTransferProgress(long currentSize, long totalSize); // Transfer error void handleTransferError(int error); // File has been transfered void handleFileTransfered(String filename); } // Initiate a one-to-one chat session with a contact: // - Parameter contact: remote contact. // - Parameter subject: subject of the session (i.e. first message). // - Returns a chat session. IChatSession initiateOne2OneChatSession(String contact, String subject); // Initiate an ad-hoc group chat session with a list of participants: // - Parameter participants: list of participants. // - Parameter subject: subject of the session (i.e. first message). // - Returns a chat session. IChatSession initiateAdhocGroupChatSession(List<String> participants, String subject); // Get a chat session from its session ID: // - Parameter id: session ID. // - Returns a chat session or null if not found. IChatSession getChatSession(String id); // Get list of chat sessions with a contact: // - Parameter contact: remote contact. // - Returns a list of sessions. List<IBinder> getChatSessionsWith(String contact); // Get list of current established chat sessions: // - Returns a list of sessions. List<IBinder> getChatSessions(); // Chat session: interface IChatSession { // Get session ID String getSessionID(); // Get remote contact String getRemoteContact(); // Is chat group boolean isChatGroup();

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

24 / 33

RCS-e API for Android platform

// Get subject String getSubject(); // Accept the session invitation void acceptSession(); // Reject the session invitation void rejectSession(); // Cancel the session void cancelSession(); // Get list of participants in the session List<String> getParticipants(); // Add a participant to the session void addParticipant(String participant); // Add a list of participants to the session void addParticipants(List<String> participants); // Send a text message void sendMessage(String text); // Set the is composing status void setIsComposingStatus(boolean status); // Set message delivery status void setMessageDeliveryStatus(String msgId, String contact, String status); // Add session listener void addSessionListener(IChatEventListener listener); // Remove session listener void removeSessionListener(IChatEventListener listener); } // Chat event listener: interface IChatEventListener { // Session is started void handleSessionStarted(); // Session has been aborted void handleSessionAborted(); // Session has been terminated by remote void handleSessionTerminatedByRemote(); // New text message received void handleReceiveMessage(InstantMessage msg); // Chat error void handleImError(int error); // Conference event void handleConferenceEvent(String contact, String state); // Message delivery status void handleMessageDeliveryStatus(String msgId, String status); // Request to add participant is successful void handleAddParticipantSuccessful();

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

25 / 33

RCS-e API for Android platform

// Request to add participant has failed void handleAddParticipantFailed(String reason); // Is composing event void handleIsComposingEvent(String contact, boolean status); } // Instant message object: class InstantMessage { // Remote user String remote; // Text message String message; // Date of message Date date; // Message Id String msgId; }

9.3. Intents
// Intent broadcasted when a new file transfer invitation has been received: // - Parameter contact: remote contact. // - Parameter sessionId: session ID of the incoming session. // - Parameter name: file name to be transfered. // - Parameter size: file size to be transfered. com.orangelabs.rcs.messaging.FILE_TRANSFER_INVITATION // Intent broadcasted when a new chat invitation has been received: // - Parameter contact: remote contact. // - Parameter subject: subject of the conference. // - Parameter sessionId: session ID of the incoming session. // - Parameter isChatGroup: type of chat session. com.orangelabs.rcs.messaging.CHAT_INVITATION

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

26 / 33

RCS-e API for Android platform

10. Event log API


10.1. Description
This API permits to access to the following history: Rich call history. Chat history. File transfer history. Event history which is an aggregation of the previous history and the classic history (Call, SMS, and MMS). See class: EventsLogApi

10.2. API
// Clear history associated to a contact contact: // - Parameter contact: selected contact. void clearHistoryForContact(String contact); // Delete a given log entry: // - Parameter id: ID of the entry to be deleted. void deleteLogEntry(long id); // Delete a SMS entry: // - Parameter id: ID of the entry to be deleted. void deleteSmsEntry(long id); // Delete a MMS entry: // - Parameter id: ID of the entry to be deleted. void deleteMmsEntry(long id); // Delete a call entry: // - Parameter id: ID of the entry to be deleted. void deleteCallEntry(long id); // Delete rich call history associated to a contact: // - Parameter contact: selected contact. void deleteRichCallEntry(String contact); // Delete an IM entry: // - Parameter id: ID of the entry to be deleted. void deleteImEntry(long id); // Delete chat and file transfer history associated to a contact: // - Parameter contact: selected contact. void deleteMessagingLogForContact(String contact); // Delete an IM session: // - Parameter sessionId: session ID to be deleted. void deleteImSessionEntry(String sessionId); // Get a cursor on the given chat session: // - Parameter sessionId: session ID. // - Returns a database cursor. Cursor getChatSessionCursor(String sessionId); // Get cursor on the given chat contact:

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

27 / 33

RCS-e API for Android platform

// - Parameter contact: selected contact. // - Returns a database cursor. Cursor getChatContactCursor(String contact); // Get the events log URI: // - Parameter mode: filter mode (Call, Chat, FT, Richcall). // - Returns content provider URI. Uri getEventLogContentProviderUri(int mode); // Get one to one chat history URI: // - Returns content provider URI. Uri getOneToOneChatLogContentProviderUri(); // Get group chat history URI: // - Returns content provider URI. Uri getGroupChatLogContentProviderUri();

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

28 / 33

RCS-e API for Android platform

11. Media API


11.1. Description
The media API permits to connect the media player and media renderer to the RCS stack independently of the media itself. From this abstraction, the RCS stack manages (i.e. start, stop) the media stream thanks to the SIP call flow (e.g. the stack starts the media only after the SIP ACK). The media API permits also to forward media error to the stack in order to stop the session (e.g. SIP BYE). The supported video encodings are H.263+ and H.264 in low quality (QCIF). This API contains by default the following media entities which may be completely replaced by another implementation (e.g. native implementation using hardware codecs) without any impact in the RCS stack: A live video player using the Camera. A pre-recorder video player. A video renderer. The default video codec are software codecs implemented in C++ (source code from Android opencore framework) and integrated by using a JNI interface. Optimization from last API release: the RTP transport layer is part of the media player or renderer in order to avoid to pass each RTP sample via the AIDL interface to the RCS stack. See classes: IMediaPlayer IMediaRenderer IMediaEventListener LiveVideoPlayer PrerecordedVideoPlayer VideoPlayerEventListener

11.2. API
// Media RTP player: interface IMediaPlayer { // Open the player void open(String remoteHost, int remotePort); // Close the player void close(); // Start the player void start(); // Stop the player void stop(); // Returns the local RTP port int getLocalRtpPort(); // Add a media listener void addListener(IMediaEventListener listener); // Remove media listeners void removeAllListeners(); }

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

29 / 33

RCS-e API for Android platform

// Media RTP renderer: interface IMediaRenderer { // Open the renderer void open(String remoteHost, int remotePort); // Close the renderer void close(); // Start the renderer void start(); // Stop the renderer void stop(); // Returns the local RTP port int getLocalRtpPort(); // Add a media listener void addListener(IMediaEventListener listener); // Remove media listeners void removeAllListeners(); } // Media event listener: interface IMediaEventListener { // Media is opened void mediaOpened(); // Media is closed void mediaClosed(); // Media is started void mediaStarted(); // Media is stopped void mediaStopped(); // Media has failed void mediaError(String error); }

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

30 / 33

RCS-e API for Android platform

12. RCS settings


12.1. Description
This API permits to access to all the RCS stack parameters: Some parameters are read only and can be modified by the end user. Some parameters are only used by the UI part. Some parameters are only used by the RCS stack part. Some parameters may be changed via the OTA interface (e.g. P-CSCF address). See class: RcsSettings

12.2. Parameters
Parameters which can be modified by the end user. These parameters may be displayed at UI level (e.g. RCS settings application): Service activation parameter which indicates if the RCS service may be started or not Roaming authorization parameter which indicates if the RCS service may be used or not in roaming Ringtone which is played when a social presence sharing invitation is received Vibrate or not when a social presence sharing invitation is received Ringtone which is played when a content sharing invitation is received Vibrate or not when a content sharing invitation is received Make a beep or not when content sharing is available during a call Video format for video share Video size for video share Ringtone which is played when a file transfer invitation is received Vibrate or not when a file transfer invitation is received Ringtone which is played when a chat invitation is received Vibrate or not when a chat invitation is received Auto-accept mode for chat invitation Predefined freetexts

Parameters which CAN'T be modified by the end user, but used by UI application: Max photo-icon size Max length of the freetext Max number of participants in a group chat Max length of a chat message Idle duration of a chat session Max size of a file transfer Warning threshold for file transfer size Max size of an image share Max duration of a video share Max number of simultaneous chat sessions Max number of simultaneous file transfer sessions Activate or not SMS fallback service Display a warning if Store & Forward service is activated Parameters of the end user profile: IMS username or username part of the IMPU (for HTTP Digest only) IMS display name IMS private URI or IMPI (for HTTP Digest only) IMS password (for HTTP Digest only) IMS home domain (for HTTP Digest only) P-CSCF or outbound proxy address & port for mobile access
Copyright France Telecom 2008 NSM/FT/R&D/MAPS/DVC/xx-08 31 / 33

RCS-e API for Android platform

P-CSCF or outbound proxy address & port for Wi-Fi access XDM server address & port XDM server login (for HTTP Digest only) XDM server password (for HTTP Digest only) IM conference URI for group chat session Country code

Parameters which CAN'T be modified by the end user. These parameters are used by the stack only: Polling period used before each IMS connection attempt Polling period used before each IMS service check (e.g. test subscription state for presence service) Default SIP port Default SIP protocol SIP transaction timeout used to wait a SIP response Default TCP port for MSRP session Default UDP port for RTP session MSRP transaction timeout used to wait MSRP response Registration expire period Publish expire period Revoke timeout IMS authentication procedure for mobile access IMS authentication procedure for Wi-Fi access Activate or not Tel-URI format Ringing session period. At the end of the period the session is cancelled Subscribe expiration timeout "Is-composing" timeout for chat service SIP session refresh expire period Activate or not permanent state mode Activate or not the logger Logger trace level Activate or not the SIP trace Activate or not the media trace Capability refresh timeout used to avoid too many requests in a short time Capability refresh timeout used to decide when to refresh contact capabilities Polling period used to decide when to refresh contacts capabilities Presence service activation Rich call service activation CS video capability Image sharing capability Video sharing capability Instant Messaging session capability File transfer capability Presence discovery capability Social presence capability RCS extensions capability Instant messaging is always on (Store & Forward server) Instant messaging use report Network access SIP stack timer T1 SIP stack timer T2 SIP stack timer T4 Use SIP keep alive

12.3. API
There is one get method per parameter. There is one set method per parameter which may be updated from UI application (e.g. ringtone).

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

32 / 33

RCS-e API for Android platform

13. Notes
1. All the contact ID are formatted by the RCS stack, so from the API level any format may be used: Phone number: national or international, SIP-URI, Tel-URI.

Copyright France Telecom 2008

NSM/FT/R&D/MAPS/DVC/xx-08

33 / 33

You might also like