SFDClib is a Salesforce.com Metadata API and Tooling API client built for Python 2.7, 3.3 and 3.4.
To use API classes one needs to create a session first by instantiating SfdcSession class and passing login details to the constructor.
One method is to pass in the username, password, and token:
from sfdclib import SfdcSession
s = SfdcSession(
'username': '[email protected]',
'password': 'Pa$sw0rd',
'token': 'TOKEN',
'is_sandbox': True
)
s.login()
A second method, if you've already logged in elsewhere, is to pass in the instance and session_id. This method does not require calling login().
from sfdclib import SfdcSession
s = SfdcSession(
'session_id': 'thiswillbeaverylongstringofcharactersincludinglettersspacesandsymbols',
'instance': 'custom-sf-site.my'
)
# Notice we are not calling the login() method for this example.
Then create an instance of corresponding API class passing session object.
from sfdclib import SfdcToolingApi
tooling = SfdcToolingApi(s)
r = tooling.anon_query("SELECT Id, Name FROM User LIMIT 10")
login() - establishes a session with Salesforce
is_connected() - returns True if session has been established
get_session_id() - returns Salesforce session ID
get_server_url() - returns url to the login server (
https://test.salesforce.com when not connected and
https://instance_name.salesforce.com when connected)
get_api_version() - returns API version being used (36.0, 37.0, ...)
deploy(zipfile, options) - submits deploy request
check_deploy_status(id) - returns 3-tuple containing state, state detail and test result errors
retrieve(options) - submits retrieve request
check_retrieve_status(id) - retrieves retrieve call status. returns 3-tuple containing state, state detail and warning/error messages
retrieve_zip(id) - retrieves resulting ZIP file for the specified Id of retrieve call. returns 4-tuple containing state, state detail, warning/error messages and ZIP file
anon_query(query) - executes anonymous SOQL query and returns results in a form of
requests.Response
get(uri) - sends GET request to specified URI
post(uri, data) - sends passed data in a POST request to specified URI
delete(uri) - sends DELETE request to specified URI
anon_apex(apex) - executes anonymous apex with a success or error message
**execute_AnonApex(apex) ** - executes anonymous apex and returns the System output information in the form of a text body
apexLog_Q(auditlog_id) - queries for and returns the AuditLog body of the AuditLog Id given to it.
set_Traceflag(user_id) - sets a traceflag for the supplied user Id
delete_Traceflag(traceflag_id) - deletes the TraceFlag associated with the provided TraceFlag Id
export(object_name, query=None) - exports data of specified object. If query is not passed only Id field will be exported
upsert(object_name, csv_data, external_id_field) - upserts data to specified object. Records will be matched by external id field
update(object_name, csv_data) - updates data in specified object. Records will be matched by Id field
delete(object_name, csv_data) - deletes data from specified object. Records will be matched by Id field
To use the execute_AnonApex function you will need to provide a DebugLevelId to the traceFlagPL located in the function set_Traceflag().
To get your DebugLevelId log onto the Salesforce environment, open the developer console, and execute select Id, LogType, ExpirationDate, DebugLevelId from TraceFlag.
This package is released under the MIT license.