Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/realtime-framework/RCTRealtimeMessagingAndroid
Realtime Cloud Messaging React Native SDK for Android
https://github.com/realtime-framework/RCTRealtimeMessagingAndroid
android push-notifications react-native realtime-messaging
Last synced: about 2 months ago
JSON representation
Realtime Cloud Messaging React Native SDK for Android
- Host: GitHub
- URL: https://github.com/realtime-framework/RCTRealtimeMessagingAndroid
- Owner: realtime-framework
- License: mit
- Created: 2015-09-21T11:24:49.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2017-11-23T15:59:42.000Z (about 7 years ago)
- Last Synced: 2024-11-29T10:36:27.135Z (about 2 months ago)
- Topics: android, push-notifications, react-native, realtime-messaging
- Language: Java
- Size: 49.8 KB
- Stars: 52
- Watchers: 7
- Forks: 13
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-react-native - react-native-realtimemessaging-android ★53 - The Realtime Framework Cloud Messaging Pub/Sub client for React-Native Android (Components / Integrations)
- awesome-react-native - react-native-realtimemessaging-android ★53 - The Realtime Framework Cloud Messaging Pub/Sub client for React-Native Android (Components / Integrations)
- awesome-react-native - react-native-realtimemessaging-android ★53 - The Realtime Framework Cloud Messaging Pub/Sub client for React-Native Android (Components / Integrations)
- awesome-react-native-ui - react-native-realtimemessaging-android ★45 - The Realtime Framework Cloud Messaging Pub/Sub client for React-Native Android (Components / Integrations)
- awesome-react-native - react-native-realtimemessaging-android ★53 - The Realtime Framework Cloud Messaging Pub/Sub client for React-Native Android (Components / Integrations)
README
# Realtime Messaging SDK for React-Native Android
[Realtime Cloud Messaging](http://framework.realtime.co/messaging) is a highly-scalable pub/sub message broker, allowing you to broadcast messages to millions of users, reliably and securely. It's all in the cloud so you don't need to manage servers.
[React Native](http://facebook.github.io/react-native/) enables you to build world-class application experiences on native platforms using a consistent developer experience based on JavaScript and React.
More information can be found on the
[Realtime native Android SDK reference documentation](http://messaging-public.realtime.co/documentation/android/2.1.0/index.html?ibt/ortc/api/Ortc.html).## Installation
* Create a new react-native project. [Check react-native getting started](http://facebook.github.io/react-native/docs/getting-started.html#content)
* Execute
npm install --save react-native-realtimemessaging-android
* In `android/settings.gradle`
...
include ':react-native-realtime-messaging-android'
project(':react-native-realtime-messaging-android').projectDir = new File(settingsDir,'../node_modules/react-native-realtimemessaging-android/reactnativemessagingandroid')* In `android/app/build.gradle`
...
dependencies {
...
compile project(':react-native-realtime-messaging-android')
}* Add `new RealtimeMessagingPackage()` to the `getPackages()` method return list in `MainApplication.java`.
import co.realtime.reactnativemessagingandroid.RealtimeMessagingPackage; //<-- import
public class MainApplication extends Application implements ReactApplication {
...
@Override
protected List getPackages() {
return Arrays.asList(
new MainReactPackage(),
new RealtimeMessagingPackage() // <-- add RealtimeMessagingPackage object
);
}
...* Drag `PROJECT_DIR/node_modules/react-native-realtimemessaging-android/RCTRealtimeMessagingAndroid.js` to the root of your project.
* **If you want to use push notifications**, set `MainActivity` extending `RealtimePushNotificationActivity`.
import co.realtime.reactnativemessagingandroid.RealtimePushNotificationActivity;
public class MainActivity extends RealtimePushNotificationActivity {
...
}You are ready to go.
---
## RealtimeMessagingAndroid class reference
### Import RealtimeMessaging to your project
import realtime from './RCTRealtimeMessagingAndroid';
var RCTRealtimeMessaging = new realtime();### Event handling
In order to get event notifications from the native SDK, the JavaScript interface has two methods for adding and removing event registration.
**RTEventListener(notification, callBack: Function)**
RTEventListener registers a given event name on the ***notification*** field and a given ***callback function*** to be fired when the event occurs.
***Example:***
import realtime from './RCTRealtimeMessagingAndroid';
var RCTRealtimeMessaging = new realtime();RCTRealtimeMessaging.RTEventListener("onConnected",this._onConnected),
**RTRemoveEventListener(notification)**
RTRemoveEventListener removes an event registration. After this method when the event occurs the ***callback*** will not be fired.
***Example:***
import realtime from './RCTRealtimeMessagingAndroid';
var RCTRealtimeMessaging = new realtime();RCTRealtimeMessaging.RTEventListener("onConnected",this._onConnected),
RCTRealtimeMessaging.RTRemoveEventListener("onConnected"),***Complete event list:***
* onConnected - Occurs when the client connects
* onDisconnect - Occurs when the client disconnects
* onReconnect - Occurs when the client reconnects
* onReconnecting - Occurs when the client is attempting to reconnect
* onSubscribed - Occurs when the client has successfully subscribed a channel. The event notification data is `{"channel":channel}`
* onUnSubscribed - Occurs when the client has successfully unsubscribed a channel. The event notification data is `{"channel":channel}`
* onException - Occurs when there is an exception. The event notification data is `{"error":error.localizedDescription}`
* onMessage - Occurs when a message is received. The event notification data is `{"message": message,"channel": channel}`
* onMessageWithFilter - Occurs when a message is received using `RTSubscribeWithFilter`. The event notification data is `{"message": message,"channel": channel, "filtered":true}`, where the filtered property indicates wheter the server was able to successfully filter the message.
* onMessageWithBuffer - Fired when a message was received in the specified channel subscribed with the `RTSubscribeWithBuffer`.
- channel - The channel where the message was received
- seqId - The message sequence id
- message - The message received* onMessageWithOptions - Fired when a message was received in the specified channel subscribed with the `RTSubscribeWithOptions`
- msgOptions - Dictionary where the message data was received
-
msgOptions = {
channel, // Channel where the message was received
seqId, // The message sequence id property
filtered, // Indicates if server has filtered the message
message // Content of the received message
}* onPresence - Gets the subscriptions in the specified channel and if active the first 100 unique connection metadata:
- On success -> `{"result": result}`
- On error -> `{"error": error}`* onEnablePresence - Enables presence for the specified channel with the first 100 unique connection metadata:
- On success -> `{"result": result}`
- On error -> `{"error": error}`* onDisablePresence - Disables presence for the specified channel:
- On success -> `{"result": result}`
- On error -> `{"error": error}`### Push notification handling
#### Configure your project for push notifications handling
To configure your react-native project to receive push notifications you must follow [this guide](http://messaging-public.realtime.co/documentation/starting-guide/mobilePushGCM.html) for the Android platform.
#### Handling push notifications through javascript
For handling push notifications ( sent using the Realtime mobile push notifications REST API) we added the following event listener:
* RTPushNotificationListener(callBack: Function)
***Example:***
componentDidMount: function(){
RCTRealtimeMessaging.RTCPushNotificationListener(this._onNotification);
},_onNotification: function(data)
{
this._log("Received notification: " + JSON.stringify(data));
},----------
### Methods
##### RTConnect(config)
Connects the client to Realtime server with the given configuration.
**Parameters**
* appkey - Realtime application key
* token - Authentication token
* connectionMetadata - Connection metadata string
* clusterUrl or url - The Realtime Messaging cluster or server URL
* projectId - The GCM project number, only required for push notifications usage***Example:***
RCTRealtimeMessaging.RTEventListener("onConnected",function(){
console.log('Connected to Realtime Messaging');
}),RCTRealtimeMessaging.RTConnect(
{
appKey:this.state.appKey,
token:this.state.token,
connectionMetadata:this.state.connectionMetadata,
clusterUrl:this.state.clusterUrl
});----------
##### RTDisconnect()
Disconnects the client from the Realtime server.
***Example:***
RCTRealtimeMessaging.RTEventListener("onDisconnect", function(){
console.log('Disconnected from Realtime Messaging');
}),RCTRealtimeMessaging.RTDisconnect();
----------
##### RTSubscribe(channel, subscribeOnReconnect: boolean)
Subscribes a pub/sub channel to receive messages.
**Parameters**
* channel - Channel name
* subscribeOnReconnected -
Indicates whether the client should subscribe the channel when reconnected (if it was previously subscribed when connected).***Example:***
RCTRealtimeMessaging.RTEventListener("onSubscribed", function(subscribedEvent){
console.log('Subscribed channel: ' + subscribedEvent.channel);
}),RCTRealtimeMessaging.RTSubscribe("MyChannel", true);
----------
##### RTSubscribeWithFilter(channel, subscribeOnReconnect: boolean, filter)
Subscribes a channel using a filter, to receive only messages that validate the filter.
**Parameters**
* channel - Channel name
* subscribeOnReconnected -
Indicates whether the client should subscribe to the channel when reconnected (if it was previously subscribed when connected).* filter - Filter to apply to messages
***Example:***
RCTRealtimeMessaging.RTSubscribeWithFilter("MyChannel", true, "message.a = 1");
----------
##### RTSubscribeWithOptions(options)
Subscribes to a channel to receive messages sent to it with given options.
**Parameters**
* options - The subscription options dictionary, EX:
options = {
channel,
subscribeOnReconnected, // optional, default = true,
withNotifications (Bool), // optional, default = false, use push notifications as in subscribeWithNotifications
filter, // optional, default = "", the subscription filter as in subscribeWithFilter
subscriberId // optional, default = "", the subscriberId as in subscribeWithBuffer
}***Example:***
var options = {
"channel":"YOUR_CHANNEL_NAME",
"subscriberId":"CLIENT_SUBSCRIBER_ID",
"filter":"MESSAGE_FILTER"
}
RCTRealtimeMessaging.RTSubscribeWithOptions(options);----------
##### RTSubscribeWithBuffer(channel, subscriberId)
Subscribes to a channel to receive messages published to it.
**Parameters**
* channel - The channel name.
* subscriberId - The subscriberId associated to the channel.***Example:***
RCTRealtimeMessaging.RTSubscribeWithBuffer("MyChannel", "CLIENT_SUBSCRIBER_ID");
----------
##### RTSubscribeWithNotifications(channel, subscribeOnReconnect: boolean)
Subscribes a pub/sub channel with Push Notifications Service, to receive messages even if the app is not running.
**Parameters**
* channel - Channel name
* subscribeOnReconnected -
Indicates whether the client should subscribe to the channel when reconnected (if it was previously subscribed when connected).***Example:***
RCTRealtimeMessaging.RTSubscribeWithNotifications("MyChannel", true);
----------
##### RTUnsubscribe(channel)
Unsubscribes a channel.
**Parameters**
* channel - Channel name.
***Example:***
RCTRealtimeMessaging.RTUnsubscribe("MyChannel");
----------
##### RTSendMessage(message, channel)
Sends a message to a pub/sub channel.
**Parameters**
* channel - Channel name
* message - The message to send (a string/stringified JSON object)
***Example:***
RCTRealtimeMessaging.RTSendMessage("Hello World","MyChannel");
----------
##### RTPublishMessage(channel, message, ttl, onPublishResultCallback)
Publish a message to a channel.
**Parameters**
* channel - The channel name.
* message - The message to publish.
* ttl - The message expiration time in seconds (0 for maximum allowed ttl).
* onPublishResultCallback - callback returns error if message publish was not successful or published message unique id (seqId) if sucessfully published
***Example:***RCTRealtimeMessaging.RTPublishMessage("MyChannel", "Hello World", ttl, function(error, seqId){
});
----------
##### RTEnablePresence(aPrivateKey, channel, aMetadata:boolean)
Enables presence for the specified channel with first 100 unique connection metadata.
**Parameters**
* privateKey - The Realtime application private key
* channel - Channel to enable presence
* metadata - Sets to return metadata info
***Example:***
RCTRealtimeMessaging.RTEventListener("onEnablePresence", function(event){
if(event.result){
console.log('Realtime enablePresence result: ' + event.result);
}else{
console.log('Realtime enablePresence error: ' + event.error);
}
}),RCTRealtimeMessaging.RTEnablePresence(aPrivateKey, channel, aMetadata);
----------
##### RTDisablePresence(aPrivateKey, channel)
Disables presence for the specified channel.
**Parameters**
* privateKey - The Realtime application private key
* channel - Channel to disable presence
***Example:***
RCTRealtimeMessaging.RTEventListener("onDisablePresence", function(event){
if(event.result){
console.log('Realtime disablePresence result: ' + event.result);
}else{
console.log('Realtime disablePresence error: ' + event.error);
}
}),RCTRealtimeMessaging.RTDisablePresence(aPrivateKey, channel);
----------
##### RTPresence(channel)
Gets a dictionary with the total number of subscriptions in the specified channel and if active the first 100 unique connection metadata of the subscribers.
**Parameters**
* channel - Channel with presence data active
***Example:***
RCTRealtimeMessaging.RTEventListener("onPresence", function(event){
if(event.result){
console.log('Realtime presence result: ' + JSON.stringify(event.result));
}else{
console.log('Realtime presence error: ' + event.error);
}
}),RCTRealtimeMessaging.RTPresence(channel);
----------
##### RTIsSubscribed(channel, callBack: function)
Indicates whether a given channel is currently subscribed.
**Parameters**
* channel - Channel name.
* callback - Callback function to be called with the result (true or false).
***Example:***
RCTRealtimeMessaging.RTIsSubscribed("MyChannel", function(result){
if(result == true){
console.log('channel is subscribed');
}else{
console.log('channel is not subscribed');
}
});----------
##### RTGetHeartbeatTime(callBack: function)
Get the client heartbeat interval.
**Parameters**
* callback -
Callback function with the heartbeat interval value***Example:***
RCTRealtimeMessaging.RTGetHeartbeatTime(function(result){
console.log('HeartbeatTime for this client is: ' + result);
});----------
##### RTSetHeartbeatTime(newHeartbeatTime)
Sets the client heartbeat interval.
**Parameters**
* newHeartbeatTime - The new heartbeat interval
***Example:***
RCTRealtimeMessaging.RTSetHeartbeatTime(10);
----------
##### RTGetHeartbeatFails(callBack: function)
Number of times the heartbeat can fail before the connection is reconnected
**Parameters**
* callBack - The callback function to get the HeartbeatFails value
***Example:***
RCTRealtimeMessaging.RTGetHeartbeatFails(function(result){
console.log('HeartbeatFails Time for this client is: ' + result);
});----------
##### RTSetHeartbeatFails(newHeartbeatFails)
Sets the number of times the heartbeat can fail before the connection is reconnected
**Parameters**
* newHeartbeatFails - The new heartbeat fails value
***Example:***
RCTRealtimeMessaging.RTSetHeartbeatFails(3);
----------
##### RTIsHeartbeatActive(callBack: function)
Indicates whether the client heartbeat is active or not.
**Parameters**
* callBack - The callback function with the result
***Example:***
RCTRealtimeMessaging.RTIsHeartbeatActive(function(result){
if(result == true){
console.log('heartbeat active');
}else{
console.log('heartbeat inactive');
}
});----------
##### RTEnableHeartbeat()
Enables the client heartbeat.
***Example:***
RCTRealtimeMessaging.RTEnableHeartbeat()
----------
##### RTDisableHeartbeat()
Disables the client heartbeat.
***Example:***
RCTRealtimeMessaging.RTDisableHeartbeat()
## Full example ( index.android.js )
'use strict';
import React, { Component } from 'react';
import realtime from './RCTRealtimeMessagingAndroid';
var RCTRealtimeMessaging = new realtime();var messages = [];
import {
AppRegistry,
Image,
StyleSheet,
Text,
Navigator,
TextInput,
ScrollView,
TouchableHighlight,
ListView,
View
} from 'react-native';var RealtimeRCT = React.createClass({
doConnect: function(){
this._log('Trying to connect!');RCTRealtimeMessaging.RTEventListener("onConnected",this._onConnected),
RCTRealtimeMessaging.RTEventListener("onDisconnected",this._onDisconnected),
RCTRealtimeMessaging.RTEventListener("onSubscribed",this._onSubscribed),
RCTRealtimeMessaging.RTEventListener("onUnSubscribed",this._onUnSubscribed),
RCTRealtimeMessaging.RTEventListener("onException",this._onException),
RCTRealtimeMessaging.RTEventListener("onMessage",this._onMessage),
RCTRealtimeMessaging.RTEventListener("onPresence",this._onPresence);RCTRealtimeMessaging.RTConnect(
{
appKey:this.state.appKey,
token:this.state.token,
connectionMetadata:this.state.connectionMetadata,
clusterUrl:this.state.clusterUrl,
projectId:''
});
},componentDidMount: function(){
RCTRealtimeMessaging.RTPushNotificationListener(this._onNotification);
},_onNotification: function(data) {
this._log("Received push notification: " + JSON.stringify(data));
},componentWillUnmount: function() {
RCTRealtimeMessaging.RTDisconnect();
},doDisconnect:function(){
RCTRealtimeMessaging.RTDisconnect();
},doSubscribe: function(){
RCTRealtimeMessaging.RTSubscribe(this.state.channel, true);
// To subscribe using push notifications use the RTSubscribeWithNotifications method
},doUnSubscribe: function(){
RCTRealtimeMessaging.RTUnsubscribe(this.state.channel);
},doSendMessage: function(){
RCTRealtimeMessaging.RTSendMessage(this.state.message, this.state.channel);
},doPresence: function(){
RCTRealtimeMessaging.RTPresence(
this.state.channel
);
},_onException: function(exceptionEvent){
this._log("Exception:" + exceptionEvent.error);
},_onConnected: function()
{
this._log("connected");
},_onDisconnected: function(){
this._log("disconnected");
},_onSubscribed: function(subscribedEvent)
{
this._log("subscribed channel " + subscribedEvent.channel);
},_onUnSubscribed: function(unSubscribedEvent)
{
this._log("unsubscribed channel " + unSubscribedEvent.channel);
},_onMessage: function(messageEvent)
{
this._log("received message: ["+messageEvent.message+"] on channel [" + messageEvent.channel+"]");
},_onPresence: function(presenceEvent){
if (presenceEvent.error) {
this._log("Error getting presence: " + presenceEvent.error);
}else
{
this._log("Presence data: " + JSON.stringify(presenceEvent.result));
};
},getInitialState: function() {
return {
clusterUrl: "http://ortc-developers.realtime.co/server/2.1/",
token: "SomeAuthenticatedToken",
appKey: "YOUR_APP_KEY",
channel: "yellow",
connectionMetadata: "clientConnMeta",
message: "some message",
dataSource: new ListView.DataSource({
rowHasChanged: (row1, row2) => row1 !== row2,
}),
};
},_renderRow: function(rowData: string, sectionID: number, rowID: number) {
return (
{rowData}
);
},_log: function(message: string)
{
var time = this.getFormattedDate();
time += " - " + message
var temp = [];
temp[0] = time;for (var i = 0; i < messages.length; i++) {
temp[i+1] = messages[i];
};
messages = temp;this.setState({
dataSource: this.getDataSource(messages)
});
},getFormattedDate: function() {
var date = new Date();
var str = date.getHours() + ":" + date.getMinutes() + ":" + date.getSeconds();
return str;
},getDataSource: function(messages: Array): ListView.DataSource {
return this.state.dataSource.cloneWithRows(messages);
},render: function() {
return (
clusterUrl:
this.setState({server: text})}
/>
Authentication Token:
this.setState({token: text})}
/>
Application Key:
this.setState({appKey: text})}
/>
Channel:
this.setState({channel: text})}
/>
Connection Metadata:
this.setState({connectionMetadata: text})}
/>
Message:
this.setState({message: text})}
/>
Connect
Disconnect
Subscribe
Unsubscribe
Send
Presence
)}
});var styles = StyleSheet.create({
container: {
marginTop: 30,
margin: 5,
backgroundColor: '#FFFFFF',
},
list: {
flexDirection: 'column',
backgroundColor: '#F6F6F6',
height:150,
},
rowView:{
alignItems: 'stretch',
flexDirection: 'row',
flexWrap: 'wrap',
justifyContent:'center',
},
button:{
margin: 5,
},
margin:{},
custom:{
flexDirection: 'row',
flexWrap: 'wrap',
justifyContent:'space-between',
},
textInput:{
height: 30,
borderColor: 'gray',
borderWidth: 1,
borderRadius: 4,
padding: 5,
fontSize: 15,
},halfTextInput:{
height: 30,
borderColor: 'gray',
borderWidth: 1,
borderRadius: 4,
padding: 5,
fontSize: 15,
width: 153,
},
tryAgain: {
backgroundColor: '#336699',
padding: 13,
borderRadius: 5,
},
tryAgainText: {
color: '#ffffff',
fontSize: 14,
fontWeight: '500',
},
welcome: {
fontSize: 20,
textAlign: 'center',
margin: 10,
},
instructions: {
textAlign: 'center',
color: '#333333',
},
row: {
flexDirection: 'row',
justifyContent: 'center',
padding: 10,
backgroundColor: '#F6F6F6',
},
separator: {
height: 1,
backgroundColor: '#CCCCCC',
},
thumb: {
width: 64,
height: 64,
},
text: {
flex: 1,
fontSize: 13,
},
});AppRegistry.registerComponent('RealtimeRCT', () => RealtimeRCT);
## Example
Checkout the example at [https://github.com/realtime-framework/RealtimeMessaging-ReactNativeAndroidExample](https://github.com/realtime-framework/RealtimeMessaging-ReactNativeAndroidExample)
## Authors
Realtime.co