If you're new to mobile development, or the force.com 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.
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
For the rest of this document, we'll assume that
forcedroid is on your path.
forcedroid with no arguments gives you a breakdown of the usage:
$ forcedroid Usage: 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)] OR forcedroid createWithTemplate --templaterepouri=<Template repo URI> (e.g. https://github.com/forcedotcom/SmartSyncExplorerReactNative) --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)] OR forcedroid version OR forcedroid
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.
App Type: The type of application you wish to develop:
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 salesforce.com. This is the entry point of your remote application, though it's only the path, not the server portion of the URL. For instance,
Output Directory: ( Optional ) The folder where you want your app to be created.
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 force.com 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.