Skip to content

Latest commit

 

History

History
128 lines (78 loc) · 7.96 KB

File metadata and controls

128 lines (78 loc) · 7.96 KB

Use Microsoft Azure to push notifications to Cordova apps

This sample shows how to use Microsoft Azure with the Apache Cordova Tools for Visual Studio 2013 to enable push notifications to your Cordova apps running on iOS or Android devices. The sample supports the MSDN Magazine Article Use Microsoft Azure to Push Notifications to Cordova Apps. The Mobile Services client is used to register for template-based push notifications with Azure Notification Hubs, which is then used to send push notifications from a platform notification service (PNS) to your Cordova app running on iOS or Android.

Note: Push notifications to Cordova apps running on Windows Phone and Windows platforms are not supported by the Mobile Services client library at this time. If you need to also support your Cordova app on Windows Phone using MPNS, see this blog post.

This sample is based on the BackboneJS sample for Apache Cordova. However, regardless of the JavaScript framework you use for your app (if any), the same basic concepts apply. These steps differ somewhat from the steps in the MSDN Magazine article (which does only cover Android). The steps in the article use Visual Studio to configure Mobile Services, whereas the steps in this readme use the Azure Management portal to configure your Azure services.

Prerequisites

To run this Apache Cordova for Visual Studio sample app on one or more of the supported client platforms, you must have the following:

  • An Active Microsoft Azure subscription. You can sign-up for a trial account here.

  • The Visual Studio Tools for Apache Cordova. See the topic Install Visual Studio Tools for Apache Cordova for the complete list of prerequisites for these tools.

  • For a given client platform, you must also meet these platform-specific requirements:

    iOS:

    • A physical iOS device, iPhone or iPad.
    • Xcode v6.0 or a later version running on a MacOSX environment (required by the Visual Studio Tools for Apache Cordova).
    • iOS Developer Program registration (required to configure push notifications).

    Android

    • (Optional) A physical Android device. The emulator is supported, but your experience is better using the device.
    • Android Developer Tools. Android 4.4.2 (API 19) only has been tested (installed by the Visual Studio Tools for Apache Cordova).
    • Google Play Services and Google APIs must also be installed (installed by the Visual Studio Tools for Apache Cordova).
    • Google account that has a verified email address. To create a new Google account, go to accounts.google.com.

##Configure platform-specific push notifications

  1. Complete the steps to register your app to authenticate for push notifications with each platform-specific push service:

  2. Log on to the Azure Management Portal, click Mobile Services.

    If you already created your mobile service and TodoItem table, skip down to step 5.

  3. (Optional) If you haven't already created a Mobile Service, you can follow the steps at How to create a new mobile service.

  4. (Optional) If you don't already have a TodoItem table, click the Data tab, click the Create button, supply a Table Name of TodoItem, then click the check button.

  5. Select your mobile service, click the Push tab, then supply the authentication credentials for the supported push notification platforms:

    • APNS

      Upload the .p12 certificate obtained in step 1.

    • GCM

      Set the API key value obtained in step 1.

    PNS registration in the Azure portal

    At this point, Notification Hubs can send push notifications on behalf of your app.

  6. Click the Data tab, click the TodoItem table, click Script and replace the existing insert script with the following code, which you can also find in the \service\table\todoitem.insert.js file:

     function insert(item, user, request) {
         // Execute the request and send notifications.
         request.execute({
             success: function () {
                 // Create a template-based payload.
                 var payload = '{ "message" : "New item added: ' + item.text + '" }';
     
                 // Write the default response and send a template notification
                 // to all registered devices on all platforms.            
                 push.send(null, payload, {
                     success: function (pushResponse) {
                         console.log("Sent push:", pushResponse);
                         // Send the default response.
                         request.respond();
                     },
                     error: function (pushResponse) {
                         console.log("Error Sending push:", pushResponse);
                         // Send the an error response.
                         request.respond(500, { error: pushResponse });
                     }
                 });
             }
         });
     }
    

    This sends a push notification to all registered devices when a new item is inserted.

##Update the Cordova project for your Azure services

Now that you have push notifications configured, you need to update the sample app to point to your mobile service and notification hub.

  1. In the management portal, click the Dashboard tab and make a note of the value of your Mobile Service URL.

  2. Click Manage Keys and make a note of the Application Key for your mobile service.

  3. In the Solution Explorer in Visual Studio, navigate to the \services\mobileservices\settings project subfolder and open the services.js file.

  4. Replace the values of the MOBILE_SERVICE_URL and MOBILE_SERVICE_APP_KEY variables with the values you just obtained for your mobile service.

  5. For Android, replace the value of the GCM_SENDER_ID variable with the project number value assigned when you registered your app in the Google Developers Console.

##Build and test the app

  1. Make sure that Visual Studio debugging is configured for the desired platforms.

  2. Follow the instructions to run your app on one of the supported platforms:

    The Apache Ripple emulator does not support push notifications.

    After launching the app in one of the mobile emulators above, you will see a registration success alert.

  3. Type some text into the textbox and then click Add.

    This sends a POST request to the new mobile service hosted in Azure. Data from the request is inserted into the TodoItem table and a push notification is generated and sent to all registered devices.