Working on a small feedly+salesforce.com integration for a demo scheduled at the end of this week. Going back into the enterprise world for a few days. I thought I would document the experience in case others are looking at taking the jump.
Step 1: Getting a free developer account.
You can get one here: http://wiki.apexdevnet.com/events/regular/registration.php?d=70130000000DJmf. The registration process is straight forward.
Step 2: Get familiar with Salesforce.com as a user
At the first glance, Salesforce.com = a rich schema and a set of tabs for performing operations on that schema. The account comes with a default org and some sample data.
Step 3: Getting the dev environment ready
Force.com (the name of the salesforce.com platform) offers a nice eclipse plug-in, given that eclipse is my IDE, I decided to install and configure that extension: it is a very nice way to look at the Force.com schema from a developer perspective. note 1 : Eclipse update URL: http://www.adnsandbox.com/eclipsetoolkit/release note 2: I had to reset my security token and set it in eclipse to be able to create the project.
I also went to Setup > Manage Users and edited my user to turn on Development Mode. This allows developers to edit their classes and templates live and benefit from enhanced debugging.
Step 4: Breaking down the problem
The first use case for the demo it to be able, given a company name, to determine information about the account based on the information contained in salesforce.com. Here is a picture of how that problem can be decomposed using the Force.com concepts of visual page and apex component:
So to get the job done, we need to first write an apex component which using the apex query language can perform a set of queries against the Force.com database and assemble the information needed by feedly. Then we just need to write an visual force page to serialize that information into a simple JSON “document” format.
Step 5: Creating my first APEX class
Here is an example of what the apex component looks like for a simpler query (see setup > develop > apex classes):
Note 1: It is really nice to be able to deal with data at a very high level of abstraction.
Note 2: The eclipse plug-in makes browsing the schema, building the query and testing it in real-time a breeze – very impressive!
Step 4: Creating a VisualForce page to generate a JSON output
Here is an example of what a visual force page looks like for a simpler query (see setup > develop > pages):
Note 1: Here again a nice abstraction that will be familiar to people who have used templates or tag libraries in the past.
Note 2: For more advanced templating directive (like repeat, etc..), see: http://www.salesforce.com/us/developer/docs/pages/index.htm
Step 5: Unit testing
We are now ready to unit test this scenario. Point your browser to:
Note: because we enabled “Development Mode” in step 3, we can actually edit both the page and the apex component and see the result update in real-time! very impressive.
The numbers speak for themselves: in a little less than 2 1/2 hours and some coaching from Ron Hess, we went from zero knowledge of Salesforce.com to a live/deployed JSON service, all that in about 20 lines of code, most of which can be generated using the Force.com eclipse IDE. The result: I am very impressed by both the cleanness of the concepts and the ease of use of the tools!
(Special thanks to Ron Hess for the coaching and Anshu Sharma for the support!)