node package manager


Salesforce Mobile SDK for Android Package

The forcedroid npm package allows users to create Android mobile applications to interface with the Salesforce Platform, leveraging the Salesforce Mobile SDK for Android.

Getting Started

If you're new to mobile development, or the platform, you may want to start at the Mobile SDK landing page. This page offers a variety of resources to help you determine the best technology path for creating your app, as well as many guides and blog posts detailing how to work with the Mobile SDK.

But assuming you're all read up, here's how to get started with the forcedroid package to create the starting point for your mobile application.

Install the forcedroid Package

Because forcedroid is a command-line utility, we recommend installing it globally, so that it's easily accessible on your path:

    sudo npm install forcedroid -g

You're of course welcome to install it locally as well:

    npm install forcedroid

In this case, you can access the forcedroid app at [Install Directory]/node_modules/.bin/forcedroid.

Using forcedroid

For the rest of this document, we'll assume that forcedroid is on your path.

Typing forcedroid with no arguments gives you a breakdown of the usage:

    $ forcedroid
    forcedroid create
        --apptype=<Application Type> (native, react_native, hybrid_local, hybrid_remote)
        --appname=<Application Name>
        --packagename=<App Package Identifier> (com.mycompany.myapp)
        --organization=<Organization Name> (Your company\'s/organization\'s name)
        --startpage=<App Start Page> (The start page of your remote app. Only required for hybrid_remote)
        [--outputdir=<Output directory> (Leave empty for current directory)]


    forcedroid createWithTemplate
        --templaterepouri=<Template repo URI> (e.g.
        --appname=<Application Name>
        --packagename=<App Package Identifier> (com.mycompany.myapp)
        --organization=<Organization Name> (Your company\'s/organization\'s name)
        [--outputdir=<Output directory> (Leave empty for current directory)]


    forcedroid version



Note: You can specify any or all of the arguments as command line options as specified in the usage. If you run forcedroid create with missing arguments, it prompts you for each missing option interactively.

Once the creation script completes, you'll have a fully functioning basic application of the type you specified. The new application will be configured as an Eclipse project in your target directory, alongside the Mobile SDK libraries it consumes.

forcedroid create options

App Type: The type of application you wish to develop:

  • native — A fully native Android application
  • react_native — An application built on ReactNative
  • hybrid_local — A hybrid application, based on the Cordova framework, that runs in a native container. The app contents are developed locally in the Eclipse project, and are deployed to the device itself when the app is built
  • hybrid_remote — A hybrid application, based on the Cordova framework, that runs in a native container. The app contents live in the cloud as a Visualforce application

App Name: The name of your application

App Package Identifier: The Java package identifier for your app (e.g. com.acme.mobile_apps). Note: Your package name must be formatted as a valid Java package name, or you will receive an error.

Organization: The name of your company or organization. For example, Acme Widgets, Inc.

App Start Page: ( Required for hybrid_remote apps only ) The starting page of your application on This is the entry point of your remote application, though it's only the path, not the server portion of the URL. For instance, /apex/MyVisualforceStartPage.

Output Directory: ( Optional ) The folder where you want your app to be created.

More information

  • After your app has been created, you will see some on-screen instructions for next steps, such as building and running your app, importing the project into an Eclipse workspace, and changing the default Connected App (sample) configuration values to match your own Connected App. Note that if you intend to work with your app in Eclipse, you are not required to go through the steps to build and run your app from the command line, and vice versa.

  • You can find the forceios npm package here, to develop Mobile SDK apps for iOS.

  • The Salesforce Mobile SDK for iOS source repository lives here.

  • See our developerforce site for more information about how you can leverage the Salesforce Mobile SDK with the platform.

  • If you would like to make suggestions, have questions, or encounter any issues, we'd love to hear from you. Post any feedback you have on our Google+ Community.