diimpp / salesforce-rest-api
Experimental Salesforce rest & bulk api
Installs: 2 067
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: >=5.3.0
- guzzlehttp/guzzle: ~6
This package is not auto-updated.
Last update: 2025-01-04 20:04:18 UTC
README
Experimental Salesforce REST and Bulk API implementation, that designed in fashion of facebook php ads sdk.
Currently supports only bulk requests partially.
Installation
composer.phar require diimpp/salesforce-rest-api
Usage
$api = \Diimpp\Salesforce\Api::init($accessToken, $instanceUrl); // or // $api = \Diimpp\Salesforce\Api::initWithAuthentication($clientId, $clientSecret, $username, $password); // Example usage of bulk api query. $job = new Job($api); $job->create([ 'operation' => Job::OPERATION_QUERY, 'object' => 'Contact', 'contentType' => Job::CONTENT_TYPE_XML ]); $soql = 'select id, lastname, firstname, salutation, name from Contact'; $jobBatch = new JobBatch($job, $api); $jobBatch->create(['body' => $soql]); $job->close(); // Wait till job batch will be completed. while (JobBatch::STATE_QUEUED === $jobBatch->state || JobBatch::STATE_IN_PROGRESS === $jobBatch->state) { $jobBatch->read(); } if (JobBatch::STATE_COMPLETED !== $jobBatch->state) { throw new \RuntimeException(sprintf('Salesforce Job Batch request failed with reason: %s', print_r($jobBatch->getData(), true))); } $jobBatchResult = new JobBatchResult($jobBatch); $jobBatchResult->read(); // Salesforce API returns either ID as string or array of IDs of batch results. if (is_string($jobBatchResult->result)) { $data = $jobBatchResult->retrieveData($jobBatchResult->result)); } elseif (is_array($jobBatchResult->result)) { foreach ($jobBatchResult->result as $resultId) { $data[] = $jobBatchResult->retrieveData($resultId)); } }
Contributions
Patches and use cases are most welcome.