synergitech / laravel-salesforce
This package uses omniphx/forrest to provide an Eloquent-style way of querying sObjects from Salesforce.
Installs: 3 515
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 6
Forks: 0
Open Issues: 1
Requires
- php: ^8.0
- illuminate/collections: ^8.0 || ^9.0 || ^10.0
- illuminate/support: ^8.0 || ^9.0 || ^10.0
- omniphx/forrest: ^2.0
Requires (Dev)
- orchestra/testbench: ^6.0 || ^7.0 || ^8.0
- php-parallel-lint/php-parallel-lint: ^1.3
- phpstan/phpstan: ^1
- phpunit/phpunit: ^9.0
- squizlabs/php_codesniffer: ^3.6
This package is auto-updated.
Last update: 2024-12-13 12:38:24 UTC
README
This package uses omniphx/forrest to provide an Eloquent-style way of querying sObjects from Salesforce.
⚠️ This is an initial version that only allows for the selecting of data. Newer versions will aim to provide a more complete experience.
Getting Started
Follow the instructions provided at omniphx/forrest to connect to your Salesforce environment.
Once done, you can then use the SynergiTech\Salesforce\Facades\Salesforce
facade to perform queries against a particular table like so:
use SynergiTech\Salesforce\Facades\Salesforce; // Get an individual record by Id Salesforce::table('MyTable')->find('YourIdHere');
Available Methods
find
Allows you to directly pull an individual record as an array by Id. You can also specify another field name as the second parameter. If you specify a non-unique column and multiple records are returned then the first record is always returned.
Usage
Salesforce::table('MyTable')->find('YourIdHere');
findMany
Allows you to directly pull multiple records as a Laravel Collection by provide an array of their respective Id fields. You can also specify another field name as the second parameter.
Usage
Salesforce::table('MyTable')->findMany(['YourId1Here', 'YourId2Here']);
create
Allows you to create a new record on the specified table using an array of fields.
Usage
$response = Salesforce::table('MyTable')->create([ 'Name' => 'John Doe', ]);
Expected Response
[ 'id' => '', // Salesforce Id 'success' => true, 'errors' => [], 'data' => [ // Full record data ], ]
update
Allows you to update a record using it's Salesforce Id with an array of fields.
Usage
$response = Salesforce::table('MyTable')->update('Id', [ 'Name' => 'John Doe', ]);
Expected Response
See 'create' above
createOrUpdate
Allows you to upsert a record using an Id field and the associated value.
Usage
$response = Salesforce::table('MyTable')->createOrUpdate('My_External_Id__c', 'ExternalId', [ 'Name' => 'John Doe', ]);
Expected Response
[ 'id' => '', // Salesforce Id 'success' => true, 'errors' => [], 'created' => true, // True/False depending on whether the record was created or updated 'data' => [ // Full record data ], ]
delete
Allows you to delete a record by it's Id, returning true if successful.
Usage
Salesforce::table('MyTable')->delete('Id');
Query Builder
This package allows you to scope your get calls using query builder methods.
Query builders cannot currently be used in conjunction with the update
or delete
methods (sorry 🙏).
where
You can also scope your queries with where clauses.
// Basic where clause Salesforce::table('MyTable')->where('Name', 'John Doe')->get(); // You can also use any of the following operators // Equals and Not Equals Salesforce::table('MyTable')->where('Name', '=', 'John Doe')->get(); Salesforce::table('MyTable')->where('Name', '!=', 'John Doe')->get(); // Comparisons Salesforce::table('MyTable')->where('Age', '<', 30)->get(); Salesforce::table('MyTable')->where('Age', '<=', 30)->get(); Salesforce::table('MyTable')->where('Age', '>', 30)->get(); Salesforce::table('MyTable')->where('Age', '>=', 30)->get(); // Like Salesforce::table('MyTable')->where('Name', 'LIKE', 'John %')->get(); Salesforce::table('MyTable')->where('Name', 'LIKE', '% Middlename %')->get(); Salesforce::table('MyTable')->where('Name', 'LIKE', '% Doe')->get();
whereIn
You can provide an array of possible values to the whereIn
method to select any records that match any of the values.
Salesforce::table('MyTable')->whereIn('Country', ['United Kingdom', 'United States'])->get();
orderBy
You can order by a particular field in either ascending or descending order.
// Ascending (default) Salesforce::table('MyTable')->orderBy('Age')->get(); // Descending Salesforce::table('MyTable')->orderBy('Age', 'DESC')->get();
nullsLast
By default when chaining an orderBy null values are returned first.
You can chain on ->nullsLast()
to return null values last.
Salesforce::table('MyTable')->orderBy('LastLoginDate')->nullsLast()->get();
limit
You can limit the amount of records returned.
Salesforce::table('MyTable')->where('Name', 'LIKE', 'John%')->limit(20)->get();
Exceptions
By default omniphx/forrest typically throws a single exception with more detail contained within a JSON encoded string. We've wrapped some with our own exceptions to help with debugging.