About Me

My photo
PLANO, Texas, United States
Showing posts with label #API. Show all posts
Showing posts with label #API. Show all posts

Saturday, September 19, 2020

Streaming API

What is the force.com streaming API?

  • Stream API exposes a near real-time stream of data from the force.com platform.
  • Using the API, notifications can be sent to Pages in salesforce application, Application servers outside salesforce or to external client.
  • Streaming API use for Applications that need to poll against Salesforce data frequently near real-time
  • Streaming API enables you to reduce the number of API calls and improve performance. For example- Applications like (Mulesoft) that have constant polling action against the Salesforce, consuming unnecessary API calls and processing time would benefit from Streaming API because it reduces the number of requests that return no data.

What is the basic technology behind the streaming API?

  • It uses Push Technology or Publish/Subscribe Model

What are the underlying mechanisms for the streaming API

To enable the publish/subscribe model, an active connection must be maintained between Salesforce and each client to enable the publish/subscribe model. Steaming API relies on the method Long Polling. Streaming API uses the Bayeux protocol and CometD for long polling.








Below are the three steps to connect the client:

  • CometD sends a handshake request.
  • The client subscribe to the channel
  • CometD maintains the connection by using long polling.
You can visualize the concept. Let's go to the workbench, when you go to Streaming push topic from the queries tab in workbench. 1st you see the Handshake success message and then you need to select a topic push topic to subscribe and if you will make any change in CRM associate your push topic, you will see notifications in workbench.













What is PushTopic?

PushTopic is a record that

  • Defines a channel
  • Determine what event will cause the notification
  • Describes the data the notification will contain.
An event is a modification of a field while creating, updating, deleting or undeleting the record whenever an event occurs it sent the notification. However, updates performed by the BULK API won’t generate the notifications, since such updates could flood a channel.

When multiple PushTopic notifications are generated for the same record within about one millisecond and in the same transaction, only the last notification is sent. 

notification is data sent as a result of an event to the clients who subscribe to the associate channel. 







What is the channel name?

  • Subscribers identify a channel using the name of assigned to the PushTopic.
  • In the above example pushTopic.Name='pushTopicForAccount';. The channel name will be '/topic/pushTopicForAccount'
  • The Channel name must match the PushTopic name exactly, including the casing of the letters.
  • If a Push Topic name is changed, live subscribers are not affected however, new subscribes must use the latest Push topic name. 

When will an event generate the notification?

Notifications are generated for record events based on how you configure your PushTopic. 

  • The Streaming API matching logic uses the NotifyForOperationCreate, NotifyForOperationUpdate, NotifyForOperationDelete, NotifyForOperationUndelete, and NotifyForFields fields in a PushTopic record to determine whether to generate a notification.
  • Clients must connect using the cometd/29.0 (or later) Streaming API endpoint to receive delete and undelete event notifications.

How to define what data to include in notification?
Data in the notification is determined by:
  • The select clause of the PushTopic
  • The Access the user has to data












How does security work with PushTopics?
To receive a record notification, the logged-in user must have:
  • API Enabled permission.
  • Streaming API permission.
  • Read access to the object specified in the query.
  • Field-level security access for the fields in query
  • Access to record by sharing rules
  • Data returned by the query will be limited to the fields that the user has permission to access 

What are the unsupported queries in PushTopics?

The following SOQL statements are not supported in PushTopic queries:

  • Queries without an Id in the selected fields list
  • Semi-joins and anti-joins
    • Example query: SELECT Id, Name FROM Account WHERE Id IN (SELECT AccountId FROM Contact WHERE Title = 'CEO')
    • Error message: INVALID_FIELD, semi/anti join sub-selects are not supported
  • Aggregate queries (queries that use AVG, MAX, MIN, and SUM
    • Example query: SELECT Id, AVG(AnnualRevenue) FROM Account
    • Error message: INVALID_FIELD, Aggregate queries are not supported
  •  COUNT
    • Example query: SELECT Id, Industry, Count(Name) FROM Account
    • Error message: INVALID_FIELD, Aggregate queries are not supported
  • LIMIT
    • Example query: SELECT Id, Name FROM Contact LIMIT 1
    • Error message: INVALID_FIELD, 'LIMIT' is not allowed
  • Relationships aren’t supported, but you can reference an ID:
    • Example query: SELECT Id, Contact.Account.Name FROM Contact
    • Error message: INVALID_FIELD, relationships are not supported
  • Searching for values in Text Area fields
  • ORDER BY
    • Example query: SELECT Id, Name FROM Account ORDER BY Name
    • Error message: INVALID_FIELD, 'ORDER BY' clause is not allowed
  • GROUP BY
    • Example query: SELECT Id, AccountId FROM Contact GROUP BY AccountId
    • Error message: INVALID_FIELD, 'Aggregate queries are not supported'
  • Formula fields in WHERE clauses (formula fields are supported in SELECT clauses though.)
  • NOT
    • Example query: SELECT Id FROM Account WHERE NOT Name = 'Salesforce.com
    • Error message: INVALID_FIELD, 'NOT' is not supported
    • To make this a valid query, change it to SELECT Id FROM Account WHERE Name != 'Salesforce.com'
What is returned in streaming API Notifications?

The response containing the notification is encoded in JSON.








How can you deactivate a PUSHTOPIC?

To deactivate a PushTopic:

  • Determine the ID of the PushTopic
  • Create Apex Code to deactivate the PushTopic as below:










Where can PUSHTOPIC code be executed?

PushTopic can be executed in two ways:
  1. Execute code using the Anonymous Window of the developer console
  2. Load the PushTopic data using Data loader
You can also create apex class passing all required parameters for pushtopic and be reused in different places within the org.

How do we handle error in Streaming API? 
There are different types of error in streaming API integration:
401 Authentication Errors-Client authentication can sometimes become invalid, for example, when the OAuth token is revoked or a Salesforce admin revokes the Salesforce session. An admin can revoke an OAuth token or delete a Salesforce session to prevent a client from receiving events. Sometimes a client can inadvertently invalidate its authentication by logging out from a Salesforce session. Streaming API regularly validates the OAuth token or session ID while the client is connected. If client authentication is not valid, the client is notified with an error. A Bayeux message is sent on the /meta/connect channel with an error value of 401:: Authentication invalid and an advice field containing reconnect=none. After receiving the error notification in the channel listener, the client must reauthenticate and reconnect to receive new events.
  1. 403 Unknown Client Error-If a long-lived connection is lost due to unexpected network disruption, the CometD server times out the client and deletes the client state. The CometD client attempts to reconnect but the connection is rejected with the 403:: Unknown client error because the client state doesn't exist anymore. The error response returned when the client attempts to reconnect after a timeout looks similar to the following message

  2. 503 Server Too Busy Error-If the Salesforce servers don’t have available resources to process your Streaming API request, a 503 error is returned in the ext/sfdc/failureReason field. This error is returned for a handshake or a connection request. For example, this response shows the 503 error on the /meta/connect channel.

To know more about the security aspect of integration, pls Click here
To know more other integration API at a glance, pls Click here

Thursday, September 17, 2020

REST API

What is REST (Representational State Transfer) API?

  • Force.com REST API lets you integrate with the force.com applications using simple HTTP methods.
  • The beauty of RESTful service is that it's very lightweight and easy to use as compared to SOAP-based services.











What are the Characteristics of the REST API?
  • Leverage HTTP- Users the existing feature of HTTP such as HTTP Caching and authentication, Native HTTP Method (GET, POST, PUT, Delete, PATCH)  therefore it makes integration with mobile devices and tablet simple
  •  Stateless- Each request from client to the server must contain all the information necessary to understand the request, and not use any stored context on the server.
  • Support XML and JSON format

What does an HTTP Request consist of?

HTTP Request consist:

  1. Request header
  2. Named URI
  3. Request Entity
  4. HTTP Method

How is Name URI (Uniform Resource Identifier) constructed?

The URI is composed of:

  • The root URL specifying
    • The instance of company org
    • The desired API Version
  • A resource path 






What different HTTP methods are available?

  • GET        - Retrieve data
  • POST     - Create record
  • DELETE - Delete record
  • PUT       - Upsert record

How can the data format be specified?

JSON is the default data exchange format

  • To modify the format: 
    • Use the HTTTP accept header to specify json or xml
    • Append .json or .xml to the URI
                

How is HTTP used to make a REST-based API Call?























To know about other integration API at a glance, pls Click here

Chatter REST API

What is the Chatter REST API?

The Chatter REST API:

  • Enables integration with Salesforce Chatter.
  • Provides programmatic access to Chatter feeds and social data (Users, followers, files, etc.)

Where to use chatter API?

  • Social applications for mobile devices.
  • Highly interactive websites.
  •  An integration from Salesforce Chatter into other applications(Facebook, Twitter, etc.)


What makes the chatter REST API Unique?

Unlike REST API, the chatter REST API support programs built on social media. The Key aspects of the API are:

  • Pre-aggregation of data from different object

  • Data automatically localized to the user time-zone and language
        
  • Build In pagination – Return results support the pagination when data has multiple entries. For example- News Feed. API return first 20 result and include NextPageURL, CurrentPageURL and previous page URL.

What are the examples of REST API?

  • Post a Feed Item
  • Get a Group Feed
  • Get My News Feed

To know about other integration API at a glance, pls Click here

Tooling API

What is the Tooling API?

  • Tooling API exposes metadata information of Org
  • We can access Metadata information using REST or SOAP.
  • A Simple use case of tooling api is deleting the debug log from the developer console 

What Can be fetch using Tooling API?

  • Fetch the metadata about Visualforce Pages, Apex Triggers, Apex classes.
  • Get the metadata about an object’s field.
  • Get the Code Coverage details of Apex Classes and Triggers.
  • Retrieve metadata of custom and standard object properties.
  • Retrieve metadata information about Validation Rules and Workflow Rules.
  • We can Create, Update Apex Classes and Apex Triggers.
  • We can get the RecentItems of our dev-org using Tooling API.

Where can Tooling API be used?

Because Tooling API allows you to change just one element within a complex type, it can be easier to use than Metadata API. Other use cases include:

  • Source control integration
  •  Continuous integration Ex- Jenkin used tooling api for code coverage validation.
  • Apex classes or trigger deployment

How can Tooling API consume?

Using Apex Code

Tooling API can be consumed using HTTP REST API and SOAP method

  1. HttpRequest req = new HttpRequest();
    req.setHeader('Authorization', 'Bearer ' + UserInfo.getSessionID()); //Get user Session ID
    req.setHeader('Content-Type', 'application/json');
    String SFdomainUrl=URL.getSalesforceBaseUrl().toExternalForm();
    String query='Select+id,FullName,createdDate,TableEnumOrId,ValidationName,Metadata+from+ValidationRule';
    req.setEndpoint(SFdomainUrl+'/services/data/v33.0/tooling/query/?q='+query);
    req.setMethod('GET');
    Http h = new Http();
    HttpResponse response = h.send(req);

Using Workbench












Using the Developer Console

Check Use tooling API while querying the Apex Test class or Debug log 












To know about other integration API at a glance, pls Click here

Wednesday, September 16, 2020

Security Model for Integration

Integration Security

Security is the main concern of any customer or client and it becomes more serious when there is any integration involved in different applications with Salesforce. However, no need to worry, salesforce is not let you down in terms of security. Salesforce provides a different kind of ways to ensure security. Either salesforce is being called from an external application or salesforce call to an external application, we can also ensure the security as below:

Force.com Security: Inbound- 

For all external services which are consuming salesforce API, we can provide security as per the below process:

  1. User Authentication-determines who can log in. If any external service is calling to salesforce, a user must have user name and password to use Salesforce API. (Salesforce has passport expiration. Consider setting the “Password Never Expires” option for API user. 
    • Integration user should have API Enabled permission to access the salesforce through api. You can also set this user as “API Only” so that he can not login to salesforce via browser.
    • Limits on the number of attempts 
  2. Network Security-determines when and where user can log in
    • Login hours and IP ranges by Profile 
    • Organization-wide trusted IP Address
  3. Session Security- 
    • Session Timeout can be enabled in salesforce.

  4. Data Security-
    • API user profiles can ensure data security. 
    • Always consider to have API user profile a custom profile and should have access to relevant fields and objects.
  5. Transport layer Security 
    • SSL (Secure sockets layer) provide secure transport for HTTP/HTTP

Force.com security: Outbound

Salesforce also ensures security when salesforce calling external services as below:
  1. Two-way SSL
    • Both client and server present a certificate to provide their identity to the other party
  2. The site must be whitelisted by authenticating the external URL in a remote site setting.   
  3. Outbound Ports restrictions
    • Port 80: HTTP Only
    • Port 443: HTTPS Only
    • Port 1024-6652 inclusive- HTTP or HTPPs
To know about other integrations API at a glance, pls Click here

Inbound Vs Outbound Web Service in Salesforce

Salesforce may call the other system or external system can call to salesforce.

Inbound Web Service

Inbound web service is when Salesforce exposes SOAP/REST web service, and any external/third party application consumes it to get data from your Salesforce org. It is an Inbound call to Salesforce, but outbound call to the external system. Here, Salesforce is the publisher, and external system is the consumer of web services.

For Inbound integration, the Salesforce developer is responsible to provide the REST URL and Request format to 3rd party in case of REST API, and WSDL file in case of SOAP API and external application will consume the services.

Outbound Web Service

Outbound web service is when Salesforce consumes any external/third party application web service, a call needs to send to the external system. It is an Inbound call to the external system, but an outbound call to Salesforce. Here, the external system is the publisher of web services and Salesforce is the consumer.

For Outbound integration, Salesforce developer will get REST URL or WSDL file from external application and will hit the REST URL by HTTP request in case of REST API, generate the apex class from WSDL file for SOAP API





 







 


To know more about the security aspect of integration, pls Click here

To know about integration API at a glance, pls Click here

Integration Patterns

Integration Patterns

In the real world, no standalone application can fulfill customer need and one system is always rely on other system and hence Salesforce also needs to talk to another system for different purposes. Although each integration scenario is unique, but each must be solved with one kind of patters.

List of Patterns-The following are the patterns that cover all strategies to connect Salesforce with external applications:

  1. Request & Reply - Salesforce invokes the process to the remote system, waits for completion and reply, track state based on the response.
  2. Fire & Forget- Salesforce invokes a process to a remote system, receives acknowledgment (doesn't wait for completion), and hands-off control back to Salesforce
  3. Batch data Synchronization- Data stored in force.com should be created/refreshed to reflect updated by an external system, also changes in force.com data sent to the external system (bi-directional batch).
  4. Remote Call-in- Data stored in force.com is created, updated, or deleted by the external system.
  5. UI Update Based on Data Changes- Salesforce UI to automatically update based on salesforce data change.
  6. Data Virtualization-Salesforce accesses external data in real-time.
Pattern Approach-The integration patterns in this article are classified into three categories:
  • Data Integration—These patterns address the requirement to synchronize data that resides in two or more systems so that both systems always contain timely and meaningful data.
  • Process Integration—The patterns in this category address the need for a business process to leverage two or more applications to complete its task.
  • Virtual Integration—The patterns in this category address the need for a user to view, search, and modify data that are stored in an external system.
Request & Reply –



  • Salesforce calling remote system to perform an action waits for the reply synchronously and updates the response back in Salesforce
  • Example - Salesforce collection order info and sends to the Order processing system (SAP ECC) and waits for the Order status/number and updates in salesforce.
Forces- 
  • Is sync call necessary?
  • Do Salesforce need to process the response in same transaction
  • Message size (small/large)
  • Is UI based event or DML based data change event that triggers this invocation?
Solution:
  • Vf page to initiate APEX SOAP callout in sync manner (UI initiated action)
  • Salesforce consumes system WSDL and generate Apex proxy classes to call remote service. Vf page calls this proxy class to invoke remote service
  • Vf page to initiate APEX HTTP callout in sync manner (UI initiated action)
  • RESTful http services will be called by vf pages to invoke remote service
Additional Considerations:
  •  Salesforce has a configurable timeout up to 60 seconds for calls from Apex. Completed of apex process should be within this time or proper message should be handled.
  • This pattern is primarily for small volume real-time activities.
  • If Salesforce is the master, external system should store the Salesforce Id as external key. If Remote system is master, Salesforce should store the external id from the remote sytem
Limits:
  • Only 10 callouts per execution context
  • Max 60 seconds per callout. Max 120 seconds for all callouts
  • Max message size = 3MB (for request/response)
Fire & Forget


  • As the name suggests fire the call and forget. Salesforce invokes a process to the external system, receives acknowledgment but doesn't wait for completion and hands-off control back to Salesforce
  • Example - Salesforce collection order info and sends to Order processing system (SAP ECC) and lets it handle for Order completion. Also optionally Order status/number is updated in salesforce.
Forces:
  • Is sync call necessary?
  • Is the message size small?
  • Is the integration based on the occurrence of a specific event, such as a button click in the Salesforce user interface, or DML-based events?
  • Is guaranteed message delivery from Salesforce to the remote system a requirement?
  • Does the endpoint or the Enterprise Service Bus (ESB) support long polling?
  • Are declarative configuration methods preferred over custom Apex development? In this case, solutions such as platform events are preferred over Apex callouts.
Solution:
  • Platform events- Best
  • Outbound messaging
  • Calls to a remote system can be performed from a batch job.
  • Vf page with async callout Not the best fit. Also, it needs to handle guaranteed delivery by custom code.
Additional Considerations:
  • The remote system must handle subsequent errors when the initial invocation is handed off for asynchronous processing.
  • Workflow rules can't track deletion of a record, only inserts or update of a record. To send an outbound message for deletion - develop trigger to create new record in custom object for deleted ids. Implement workflow outbound on custom object send delete the message
Calling Mechanisms-
  • Process Builder(Used for platform event)
  • Lightning component or Visualforce and Apex controllers (Used to invoke a remote process asynchronously using an Apex callout.)
  • Workflow rules (Used only for the outbound messaging solution)
  • Apex triggers (Used for platform event)
Limits:
  • Waits for acknowledgment upto 10 seconds, after 10 seconds salesforce tries to resend message for up to 24 hours. The retry frequency increases exponentially starting at 15 sec interval and ending with 60min interval. Admin can retry manually (monitoring from the queue after 24hr period)
  •  Single outbound message can have upto 100 records
  • Only 10 call-outs per execution context
  • Max 60 seconds per callout . Max 120 seconds for all callouts
  • Max message size  = 3MB (for request/response)
Batch data Synchronization



  • Extract and transform object data from/to Salesforce with from/to external system for one time or ongoing basis.
  • Example - ETL billing data into salesforce from remote system on a weekly basis
Forces:
  • Aync Data Integration = Batch
  • Should Data stored in salesforce?
  • Should data be refreshed in salesforce if remote system changes data (on a scheduled basis?)
  • Data support primary biz process/analytics requirements?
Solution:
  • 3rd party ETL that uses Bulk API / SOAP API from remote to salesforce for change data capture
  • 3rd party ETL that uses Bulk API / SOAP API from Salesforce to remote change data capture
Additional Considerations:
  • If multiple database is consolidated to Salesforce, maintain Control tables in an intermediate on-premise database
  • Maintain LastRunTime in control table and other needed values from Control table and use it for next execution
  •  If processing is successful, update the control values in control table
  • If processing failed, update the control vlaues that enable a restart and exit
  • If importing child records of Master-detail relationship, group the imported data using its parent key at the source to avoid locking. Ex - If importing contact data for account, group all contacts per account, so you can load in bulk.
  • Timeliness - Running batch during normal biz operation might lead to data contention either on user side or batch fail if same record is accessed. Use Data segmentation by record type to minimize the effect or run the batch on non-biz hours if possible

Remote Call-in

  • As name suggestion remote application makes the call to salesforce. Invoking Salesforce for updating/querying the Salesforce from remote system
  • Example - Order processing system (SAP ECC) update order status in salesforce after processing the order
Forces:

  • Is sync call necessary? 
  • Do Salesforce need to process the response in same transaction?
  • Message size (small/large)?
  •  Is transaction processing required?
  • If the remote system is SOAP-capable, is the remote system able to participate in a contract-first approach, where Salesforce dictates the contract? This is required where our SOAP API is used, for which a predefined WSDL is supplied.
Solution:
  • SOAP API - Generate WSDL (using Partner/Enterprise),  Synchronous API, Query and DML operations, Bulk processing (for 500K or more records use Bulk API)
  •  REST API -  Synchronous HTTP api for query and dml ops,
  • Apex web services
  • Apex REST services
  • Bulk API

 Limits:

  • Session timeout -
  • Query timeout - each query has a individual timeout of 120 seconds.
    • runs 200 records / request.
    • Default batch size = 500 records (max 2000 records). Use queryMore() for fetching additional records if max reached
  • Bulk API
    • Max 10k records per batch
    • Max 5000 batches / 24 hr period

UI Update Based on Data Change

  • Real-time update of CRM data changes in Salesforce UI
  • Ex - Call center agent wants to see the payment processing record while on a call with customer when customer pays it to the payment center
Forces
  • Does the data being acted on need to be stored in Salesforce?
  • Can a custom user interface layer be built for viewing this data?

Solution

  • Salesforce Streaming API to update Salesforce UI
  • PushTopic with query defn for what data is needed with filter conditions
  • Javascript based implementation of Bayeux protocol
  • Visualforce page
  • JS library in static resource
Additional Considerations

  • Delivery and order of notification is not guaranteed
  • No notifications for changes made from Bulk 
Data Virtualization

  • In Salesforce, how do you view, search, and modify data that’s stored outside of Salesforce, without moving the data from the external system into Salesforce?
  • Orders are managed by an external (remote) system. But sales reps want to view and update real-time order information in Salesforce without having to learn or use the external system.

Forces

  • Do you want to build a declarative/point-and-click outbound integration or UI mashup in Salesforce?
  • Do you have a large amount of data that you don’t want to copy into your Salesforce org?
  • Do you need to access small amounts of remote system data at any one time?
  • Do you need real-time access to the latest data?
  • Do you store your data in the cloud or in a back-office system, but want to display or process that data in your Salesforce org?
  • Do you have data residency concerns for storing certain types of data in Salesforce?

Solution-

  • Salesforce Connect

To know more about the security aspect of integration, pls Click here

To know about integration API at a glance, pls Click here  

Wednesday, January 13, 2016

Salsforce API

API stands for Application Programming Interface. With the help of API, we can connect two or more applications altogether. 

To understand the concept of API, let's consider the example of a restaurant. If you go there, you will get a Menu list, and there will be a separate kitchen. You just select the item from the menu list and the waiter will take the order and send it to the chef in the kitchen and once the order is ready, he will deliver to you.  You know need to worry about how the order will come. You just order and you get it from the waiter. Here waiter is working as an API.

There are the following APIs in the Salesforce:

REST API

  • Force.com REST API lets you integrate with the force.com applications using simple HTTP methods.
  • The request/response would be in the form of xml or JSON.
  • Useful in light weighted application like mobile application
  • Click for more detail

SOAP API

  • SOAP API works on SOAP (WSDL) protocol. 
  • The request/response would be in the form of xml.
  • We can use SOAP API to integrate Salesforce with your organization’s ERP and finance systems.
  • Click for more detail

Tooling API

  • As the name itself suggests, use tooling API to build custom development tools for Force.com applications.
  • You can get the code coverage information with the help of Tooling API.

Streaming API

  • Use Streaming API to receive notifications for changes to data that match a SOQL query that you define.
  • Streaming API is useful when you want notifications to be pushed from the server to the client.
  • Streaming API enables you to reduce the number of API calls and improve performance.
  • Click for more detail

Chatter REST API

  • Access Chatter feeds and social data such as users, groups, followers, and files using REST.
  • Click for more detail

Bulk API

  • Bulk API is based on REST principles and is optimized for loading or deleting large sets of data.
  • You can use it to query, insert, update, upsert, or delete many records asynchronously by submitting batches. Salesforce processes batches in the background.
  • SOAP API, in contrast, is optimized for real-time client applications that update a few records at a time. SOAP API can be used for processing many records, but when the data sets contain hundreds of thousands of records, SOAP API is less practical. Bulk API is designed to make it simple to process data from a few thousand to millions of records.
  • The easiest way to use Bulk API is to enable it for processing records in Data Loader using CSV files. Using Data Loader avoids the need to write your own client application.
  • Click for more details

Metadata API

  • Use Metadata API to retrieve, deploy, create, update, or delete customization for your organization. 
  • The most common use is to migrate changes from a sandbox or testing organization to your production environment. 
  • Metadata API is intended for managing customization and for building tools that can manage the metadata model, not the data itself. Like The Force.com Migration Tool, Force.com IDE
  • Click for more detail

Apex REST API

Apex SOAP API
  • Use Apex SOAP API when you want to expose Apex methods as SOAP Web service APIs so that external applications can access your code through SOAP.
  • Click for more detail
To know more about the security aspect of integration, pls Click here

Saturday, May 18, 2013

WebService Fuctions

Apex Web Service

Apex class methods can be exposed as custom Force.com Web services API calls. This allows an external application to invoke an Apex web service to perform an action in Salesforce.com. Use the Webservice keyword to define these methods. For
Example:
global class MyWebService {
webService static Id makeContact(String lastName, Account a) {
Contact c = new Contact(lastName = 'Weissman', AccountId = a.Id);
insert c;
return c.id;
}
}
A developer of an external application can integrate with an Apex class containing webService methods by generating a WSDL for the class.To generate a WSDL from an Apex class detail page:
1. In the application navigate to Your Name  Setup  Develop  Apex Classes.
2. Click the name of a class that contains web Service methods.
3. Click Generate WSDL.

Considerations for Using the WebService Keyword:

  • You cannot use the webService keyword when defining a class. However, you can use it to define top-level, outer class methods, and methods of an inner class.
  • You cannot use the webService keyword to define an interface, or to define an interface's methods and variables.
  • System-defined enums cannot be used in Web service methods.
  • You cannot use the webService keyword in a trigger because you cannot define a method in a trigger.
  • All classes that contain methods defined with the webService keyword must be declared as global. If a method or inner class is declared as global, the outer, top-level class must also be defined as global.
  • Methods defined with the webService keyword are inherently global. These methods can be used by any Apex script that has access to the class. You can consider the webService keyword as a type of access modifier that enables more access than global.
  • You must define any method that uses the webService keyword as static.
  • You cannot deprecate web Service methods or variables in managed package code.
  • Because there are no SOAP analogs for certain Apex elements, methods defined with the webService keyword cannot take the following elements as  parameters.While these elements can be used within the method, they also cannot be marked as return values.
    • Maps
    • Sets
    • Pattern objects
    • Matcher objects
    • Exception objects
  • You must use the webService keyword with any member variables that you want to expose as part of a Web service. You should not mark these member variables as static.
  • Salesforce.com denies access to Web service and execute anonymous requests from an AppExchange package that has restricted access.
  • Apex classes and triggers saved (compiled) using API version 15.0 and higher produce a runtime error if you assign a String value that is too long for the field.
To know about other integration API at a glance, pls Click here
To know more about the security aspect of integration, pls Click here