Python API
Salesforce
- class RPA.Salesforce.Salesforce(sandbox: bool = False, domain: str = 'login')
Salesforce is a library for accessing Salesforce using REST API. The library extends simple-salesforce library.
More information available at Salesforce REST API Developer Guide.
Dataloader
The keyword execute_dataloader_import can be used to mimic Salesforce Dataloader import behaviour.
input_object can be given in different formats. Below is an example where input is in RPA.Table format in method a and list format in method b.
*** Settings *** Library RPA.Salesforce Library RPA.Database Task Setup Authorize Salesforce *** Tasks *** # Method a ${orders}= Database Query Result As Table ... SELECT * FROM incoming_orders ${status}= Execute Dataloader Insert ... ${orders} ${mapping_dict} Tilaus__c # Method b ${status}= Execute Dataloader Insert ... ${WORKDIR}${/}orders.json ${mapping_dict} Tilaus__c
Example file orders.json
[ { "asiakas": "0015I000002jBLIQA2" }, { "asiakas": "0015I000002jBLDQA2" }, ]
mapping_object describes how the input data fields are mapped into Salesforce object attributes. In the example, the mapping defines that asiakas attribute in the input object is mapped into Tilaaja__c attribute of Tilaus__c custom Salesforce object.
{ "Tilaus__c": { "asiakas": "Tilaaja__c" }, }
Object type could be, for example, Tilaus__c.
Salesforce object operations
Following operations can be used to manage Salesforce objects:
Get Salesforce Object By Id
Create Salesforce Object
Update Salesforce Object
Upsert Salesforce Object
Delete Salesforce Object
Get Salesforce Object Metadata
Describe Salesforce Object
There are two ways to set the Salesforce domain. You can set the domain at time of library import or using the Set Domain keyword.
There are several ways to declare a domain at time of library import:
*** Settings *** Library RPA.Salesforce sandbox=${TRUE}
Or using the domain to your Salesforce My domain:
*** Settings *** Library RPA.Salesforce domain="robocorp"
The domain can also be set using the keyword Set Domain:
*** Settings *** Library RPA.Salesforce *** Tasks *** # Sets the domain for a sandbox environment Set Domain sandbox # Sets the domain to a Salseforce My domain Set Domain robocorp # Sets to domain to the default of 'login' Set Domain
Examples
Robot Framework
*** Settings *** Library RPA.Salesforce Task Setup Authorize Salesforce *** Variables *** ${ACCOUNT_NOKIA} 0015I000002jBLDQA2 *** Tasks *** Change account details in Salesforce &{account}= Get Salesforce Object By Id Account ${ACCOUNT_NOKIA} &{update_obj}= Create Dictionary Name=Nokia Ltd BillingStreet=Nokia bulevard 1 ${result}= Update Salesforce Object Account ${ACCOUNT_NOKIA} ${update_obj} *** Keywords *** Authorize Salesforce ${secrets}= Get Secret salesforce Auth With Token ... username=${secrets}[USERNAME] ... password=${secrets}[PASSWORD] ... api_token=${secrets}[API_TOKEN]
Python
import pprint from RPA.Salesforce import Salesforce from RPA.Robocorp.Vault import FileSecrets pp = pprint.PrettyPrinter(indent=4) filesecrets = FileSecrets("secrets.json") secrets = filesecrets.get_secret("salesforce") sf = Salesforce() sf.auth_with_token( username=secrets["USERNAME"], password=secrets["PASSWORD"], api_token=secrets["API_TOKEN"], ) nokia_account_id = "0015I000002jBLDQA2" account = sf.get_salesforce_object_by_id("Account", nokia_account_id) pp.pprint(account) billing_information = { "BillingStreet": "Nokia Bulevard 1", "BillingCity": "Espoo", "BillingPostalCode": "01210", "BillingCountry": "Finland", } result = sf.update_salesforce_object("Account", nokia_account_id, billing_information) print(f"Update result: {result}")
- ROBOT_LIBRARY_DOC_FORMAT = 'REST'
- ROBOT_LIBRARY_SCOPE = 'GLOBAL'
- account = {'Id': None, 'Name': None}
- add_product_into_opportunity(product_name: str, quantity: int, opportunity_id: str | None = None, pricebook_name: str | None = None, custom_total_price: float | None = None) bool
Add Salesforce Product into Opportunity.
- Parameters:
product_name – type of the product in the Pricelist
quantity – number of products to add
opportunity_id – identifier of Opportunity, default None
pricebook_name – name of the pricelist, default None
custom_total_price – price that overrides quantity and product price, default None
- Returns:
True is operation is successful or False
- auth_with_connected_app(username: str, password: str, api_token: str, consumer_key: str, consumer_secret: str, embed_api_token: bool = False) None
Authorize to Salesforce with security token, username, password, connected app key, and connected app secret creating instance.
- Parameters:
username – Salesforce API username
password – Salesforce API password
api_token – Salesforce API security token
consumer_key – Salesforce connected app client ID
consumer_secret – Salesforce connected app client secret
embed_api_token – Embed API token to password (default: False)
Python
from RPA.Salesforce import Salesforce from RPA.Robocorp.Vault import Vault SF = Salesforce(domain="robocorp-testing-stuff.develop.my") VAULT = Vault() secrets = VAULT.get_secret("salesforce") SF.auth_with_connected_app( username=secrets["USERNAME"], password=secrets["PASSWORD"], api_token=secrets["API_TOKEN"], consumer_key=secrets["CONSUMER_KEY"], consumer_secret=secrets["CONSUMER_SECRET"], )
Robot Framework
*** Settings *** Library RPA.Salesforce domain=robocop-testing-stuff.develop.my Library RPA.Robocorp.Vault *** Tasks *** Authenticate to Salesforce using connected app ${secrets}= Get Secret salesforce Auth with connected app ... username=${secrets}[USERNAME] ... password=${secrets}[PASSWORD] ... api_token=${secrets}[API_TOKEN] ... consumer_key=${secrets}[CONSUMER_KEY] ... consumer_secret=${secrets}[CONSUMER_SECRET]
- auth_with_token(username: str, password: str, api_token: str) None
Authorize to Salesforce with security token, username and password creating instance.
- Parameters:
username – Salesforce API username
password – Salesforce API password
api_token – Salesforce API security token
- create_new_opportunity(close_date: str, opportunity_name: str, stage_name: str = 'Closed Won', account_name: str | None = None) Any
Create Salesforce Opportunity object.
- Parameters:
close_date – closing date for the Opportunity, format ‘YYYY-MM-DD’
opportunity_name – as string
stage_name – needs to be one of the defined stages, defaults to “Closed Won”
account_name – by default uses previously set account, defaults to None
- Returns:
created opportunity or False
- create_salesforce_object(object_type: str, object_data: Any) dict
Create Salesforce object by type and data.
- Parameters:
object_type – Salesforce object type
object_data – Salesforce object data
- Raises:
SalesforceDataNotAnDictionary – when object_data is not dictionary
- Returns:
resulting object as dictionary
- delete_salesforce_object(object_type: str, object_id: str) bool
Delete Salesfoce object by type and id.
- Parameters:
object_type – Salesforce object type
object_id – Salesforce object id
- Returns:
True if successful
- describe_salesforce_object(object_type: str) dict
Get Salesfoce object description by type.
- Parameters:
object_type – Salesforce object type
- Returns:
object description as dictionary
- execute_apex(apex: str, apex_data: Dict | None = None, apex_method: str = 'POST', **kwargs)
Execute APEX operation.
The APEX classes can be added via Salesforce Developer console (from menu: File > New > Apex Class).
Permissions for the APEX classes can be set via Salesforce Setup (Apex Classes -> Security).
- Parameters:
apex – endpoint of the APEX operation
apex_data – data to be sent to the APEX operation
apex_method – operation method
kwargs – additional arguments to be passed to the APEX request
- Returns:
result of the APEX operation
Python
from RPA.Salesforce import Salesforce SF = Salesforce(domain="robocorp-testing-stuff.develop.my") # authenticate to Salesforce SF.execute_apex(apex="MyClass", apex_data={"data": "value"}) result = SF.execute_apex( apex="getAccount/?id=0017R00002xmXB1QAM", apex_method="GET")
Robot Framework
*** Settings *** Library RPA.Salesforce domain=robocop-testing-stuff.develop.my *** Tasks *** Executing APEX operations # Authenticate to Salesforce &{apex_data}= Create Dictionary data=value ${result}= Execute APEX MyClass apex_data=${apex_data} ${result}= Execute APEX ... apex=getAccount/?id=0017R00002xmXB1QAM ... apex_method=GET
- execute_dataloader_insert(input_object: Any, mapping_object: Any, object_type: str) bool
Keyword mimics Salesforce Dataloader ‘insert’ behaviour by taking in a input_object`representing dictionary of data to input into Salesforce, a `mapping_object representing dictionary mapping the input keys into Salesforce keys, an object_type representing Salesforce object which Datahandler will handle with operation type.
Stores operation successes into Salesforce.dataloader_success array. Stores operation errors into Salesforce.dataloader_errors.
These can be retrieved with keywords get_dataloader_success_table and get_dataloader_error_table which return corresponding data as RPA.Table.
- Parameters:
input_object – filepath or list of dictionaries
mapping_object – filepath or dictionary
object_type – Salesforce object type
- Returns:
True if operation is successful
- get_dataloader_error_table() Table
Return Dataloader error entries as RPA.Table
- get_dataloader_success_table() Table
Return Dataloader success entries as RPA.Table
- get_domain() str
Used to determine the current domain that has been set
- Returns:
string of the currently set domain
- get_opportunity_id(opportunity_name: str) Any
Get ID of an Opportunity linked to set account.
- Parameters:
opportunity_name – opportunity to query
- Returns:
Id of the opportunity or False
- get_pricebook_entries() dict
Get all pricebook entries.
- Returns:
query result
- get_pricebook_id(pricebook_name: str) Any
Get ID of a pricelist.
Returns False if unique Id is not found.
- Parameters:
pricebook_name – pricelist to query
- Returns:
Id of the pricelist or False
- get_products_in_pricelist(pricebook_name: str) dict
Get all products in a pricelist.
- Parameters:
pricebook_name – pricelist to query
- Returns:
products in dictionary
- get_salesforce_object_by_id(object_type: str, object_id: str) dict
Get Salesforce object by id and type.
- Parameters:
object_type – Salesforce object type
object_id – Salesforce object id
- Returns:
dictionary of object attributes
- get_salesforce_object_metadata(object_type: str) dict
Get Salesfoce object metadata by type.
- Parameters:
object_type – Salesforce object type
- Returns:
object metadata as dictionary
- property instance
- read_dictionary_from_file(mapping_file: str) dict
Read dictionary from file.
- Parameters:
mapping_file – path to the file
- Returns:
file content as dictionary
- salesforce_query(sql_string: str, as_table: bool = False) dict | Table
Perform SQL query and return result as dict or Table.
- Parameters:
sql_string – SQL clause to perform.
as_table – Set to True if the result should be of RPA.Tables.Table type. (dictionary is returned by default)
- Returns:
Result of the SQL query.
- salesforce_query_result_as_table(sql_string: str) Table
Shorthand for
Salesforce Query ${sql_string} as_table=${True}
.- Parameters:
sql_string – SQL clause to perform.
- Returns:
Result of the SQL query as RPA.Tables.Table.
- property session_id
- set_account(account_name: str = '', account_id: str = '') bool
Set account name and id by giving either parameter.
- Can be used together with keywords:
get_opportunity_id
create_new_opportunity
- Parameters:
account_name – string, defaults to “”
account_id – string, defaults to “”
- Returns:
True if account was found from Salesforce, else False
- set_domain(domain: str = 'login') None
Used to set the domain the Auth With Token keyword will use. To set the domain to ‘test’ or if using a sandbox environment use “sandbox” as the domain. If you have a Salsesforce My domain you may also input that name. If the domain argument is not used the default domain is “login”.
- Parameters:
domain – “sandbox” or the name of the Salesforce My domain; if no argument provided defaults to “login”
- set_pricebook(pricebook_name: str) None
Sets Pricebook to be used in Salesforce operations.
- Parameters:
pricebook_name – pricelist to use
- update_salesforce_object(object_type: str, object_id: str, object_data: Any) bool
Update Salesfoce object by type, id and data.
- Parameters:
object_type – Salesforce object type
object_id – Salesforce object id
object_data – Salesforce object data
- Raises:
SalesforceDataNotAnDictionary – when object_data is not dictionary
- Returns:
True if successful
- upsert_salesforce_object(object_type: str, object_id: str, object_data: Any) bool
Upsert Salesfoce object by type, id and data.
- Parameters:
object_type – Salesforce object type
object_id – Salesforce object id
object_data – Salesforce object data
- Raises:
SalesforceDataNotAnDictionary – when object_data is not dictionary
- Returns:
True if successful