Skip to content

Latest commit

 

History

History
264 lines (192 loc) · 9.22 KB

File metadata and controls

264 lines (192 loc) · 9.22 KB

IBM Cloud Mobile Services - Web Push SDK

Codacy Badge

Enable Safari, Chrome & Firefox web browser applications to receive IBM Cloud Push notifications and, send IBM Cloud Push notifications to these Chrome & Firefox web browser applications. This section describes how to install and use the client JavaScript Push SDK to further develop your Web applications.

Initialize SDK

Chrome & Firefox Websites

For installing the Javascript SDK in Chrome and Firefox Websites application follow the steps.

Download the BMSPushSDK.js,BMSPushServiceWorker.js and manifest_Website.json.

  1. Edit the manifest_Website.json file

    For Chrome browser do the following,

    • Change name to your Website's name

    • Change gcm_sender_id to your Google Cloud Messaging (GCM) sender_ID (How to get it ? Click here). The gcm_sender_id value contains only numbers.

       {
       	"name": "YOUR_WEBSITE_NAME",
       	"gcm_sender_id": "GCM_Sender_Id"
       }
      

    For Firefox browser add the following values in manifest_Website.json file.

    • Change name to your Website's name.

      {
      	"name": "YOUR_WEBSITE_NAME"
      }
      
  2. Change the manifest_Website.json file name to manifest.json.

  3. Add the BMSPushSDK.js,BMSPushServiceWorker.js and manifest.json to your root directory.

  4. Include the manifest.json in <head> tag of your html file .

      <link rel="manifest" href="manifest.json">
    
  5. Include IBM Cloud Web push SDK to the web application from github.

    <script src="BMSPushSDK.js" async></script>
    

Chrome App and Extensions.

For installing the Javascript SDK in Chrome and Firefox Websites application follow the steps.

Download the BMSPushSDK.js and manifest_Chrome_Ext.json (For chrome Extensions) or manifest_Chrome_App.json (for Chrome Apps).

  1. Configure manifest file,

    • For Chrome App in the manifest_Chrome_App.json file provide name, description , and icons.
    • Add the BMSPushSDK.js in the app.background.scripts.
    • Change the manifest_Chrome_App.json to manifest.json.

    • For Chrome Extensions in the manifest_Chrome_Ext.json file provide name, description , and icons.
    • Add the BMSPushSDK.js in the background.scripts.
    • Change the manifest_Chrome_Ext.json to manifest.json.
  2. In your Javascript file add the following to receive push notifications

    chrome.gcm.onMessage.addListener(BMSPushBackground.onMessageReceived)
    chrome.notifications.onClicked.addListener(BMSPushBackground.notification_onClicked);
    chrome.notifications.onButtonClicked.addListener(BMSPushBackground.notifiation_buttonClicked);
    

Note: For Chrome App add the above ocde in background.js

Initializing the Web Push SDK (Safari, Chrome, FireFox, Chrome Apps & Chrome Extensions)

Initialse the push SDK with IBM Cloud push notifications service app GUID and app Region.

To get your app GUID, select the Configuration option in the navigation pane of your push services and click Mobile Options.Modify the code snippet to use your IBM Cloud push notifications service appGUID parameter.

The App Region specifies the location where the Push service is hosted. You can use one of the following three values:

  • For US Dallas - .ng.bluemix.net
  • For US East - .us-east.bluemix.net
  • For UK - .eu-gb.bluemix.net
  • For Sydney - .au-syd.bluemix.net
  • For Germany - .eu-de.bluemix.net
    var bmsPush = new BMSPush()
    function callback(response) {
        alert(response.response)
    }
    var initParams = {
        "appGUID":"push app GUID",
        "appRegion":"Region where service hosted",
        "clientSecret":"push app client secret", // optional parameter. This value is needed for userId based notifications registration.
	      "websitePushIDSafari": "website Push ID for safari" // Optional parameter for Safari web push,
        "deviceId":"Optional deviceId for device registration"
    }
    bmsPush.initialize(params, callback)

Registering Web application.

Use the register() API to register the device with IBM Cloud Push Notifications service. For registering from Chrome , add the Google Cloud Messaging (GCM) API Key and Web Site URL in the IBM Cloud Push Notifications service web configuration dashboard under Chrome setup .

For registering from Firefox , add Web Site URL in the IBM Cloud Push Notifications service web configuration dashboard under Firefox setup.

Use the following code snippet to register in IBM Cloud push notifications service.

	var bmsPush = new BMSPush()
	function callback(response) {
		alert(response.response)
	}
	var initParams = {
		"appGUID":"push app GUID",
		"appRegion":"Region where service hosted",
    "clientSecret":"push app client secret"
	}
	bmsPush.initialize(initParams, callback)
	bmsPush.register(function(response) {
		alert(response.response)
	})

Note: Remember to keep custom DeviceId unique for each device. For Debugging use bmsPush.isDebugEnable(true).

For UserId based registration use the following code snippet,

  var bmsPush = new BMSPush()
  function callback(response) {
    alert(response.response)
  }
  var initParams = {
    "appGUID":"push app GUID",
    "appRegion":"Region where service hosted",
    "clientSecret":"push app client secret"
  }
  bmsPush.initialize(initParams, callback)
  bmsPush.registerWithUserId("your UserId",function(response) {
    alert(response.response)
  })

Subscribing for tags.

To get the available tags use the retrieveAvailableTags() method.

 bmsPush.retrieveAvailableTags(function(response) { //Retrieve available tags
    var jsonResponse = JSON.parse(response.response)
    var tagsArray = []
    for (i in jsonResponse.tags){
      tagsArray.push(jsonResponse.tags[i].name)
    }
    alert(tagsArray)
 })

The tag subscription is handled by the subscribe() method. Pass the array of tag names as the parameter.

  bmsPush.subscribe(tagsArray,function(response) {
    alert(response.response)
  })

To Un-subscribe for a tag or tags use the unSubscribe() method. Pass the array of tag names as the parameter.

  bmsPush.unSubscribe(tagsArray,function(response) {
    alert(response.response)
  }

Unregister from IBM Cloud Push notifications Service

To unregister the device from receiving push notification add the following unRegisterDevice() method.

  bmsPush.unRegisterDevice(function(response) {
    alert(response.response)
  }

Parameterize Push Notifications

Add the variables in the Push initialize params values.

var templateValues = {
  "userName":"testname",
  "accountNumber":"3564758697057869"
}

var initParams = {
  "appGUID":"push app GUID",
  "appRegion":"Region where service hosted",
  "clientSecret":"push app client secret",
  "pushVaribales":templateValues
}

bmsPush.initialize(initParams, callback)

While registering the device IBM Cloud Push Notifications Web SDK will pass these variables to IBM Cloud Push Notifications service.

While sending push notification add the varibale key in {{}}

  {
      "message": {
          "alert": "hello {{username}} , balance on your account {{accountNumber}} is $1200"
      }
  }

Samples & videos

Learning More

Connect with IBM Cloud

Twitter | YouTube | Blog | Facebook | Meetup

=======================

Copyright 2016-17 IBM Corp.

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.