2017 © Pedro Peláez
 

library salesforcery

A PHP Salesforce ORM, inspired by Eloquent's API.

image

stratease/salesforcery

A PHP Salesforce ORM, inspired by Eloquent's API.

  • Thursday, April 12, 2018
  • by stratease
  • Repository
  • 1 Watchers
  • 3 Stars
  • 21 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 6 Versions
  • 5 % Grown

The README.md

Latest Stable Version Total Downloads License, (*1)

A PHP ORM for Salesforce client applications, utilizing an OAuth2 REST client. Inspired by Eloquent's simple API., (*2)

Setup

1. Setting up a Connected App

You need to create a Connected App to generate the client_id and client_secret values for the OAuth2 connection. Once created use the credentials to register a connection., (*3)

2. Installation

composer require stratease/salesforcery

3. Connection

use Stratease\Salesforcery\Salesforce\Connection\REST\Authentication\PasswordAuthentication;
use Stratease\Salesforcery\Salesforce\Connection\REST\Client;
use Stratease\Salesforcery\Salesforce\Database\Model;


$authentication = new PasswordAuthentication([
     'grant_type' => 'password',
     'client_id' => 'your app ID',
     'client_secret' => 'your app secret',
     'username' => 'salesforce@user.com',
     'password' => 'password+token',
     'authorization_url' => 'https://test.salesforce.com/'
 ]);

// Typically https://login.salesforce.com, for testing use https://test.salesforce.com 
$authentication->setEndpoint('https://test.salesforce.com/');

$client = new Client($authentication);
$response = $client->query("SELECT Id FROM Account LIMIT 1");

// Should output a response with a 'records' key that conains an array of results.
print_r($response); 

// Register your connection so the ORM can connect
Model::registerConnection($client);

// Your model to connect to the Salesforce Account object
$account = Your/Models/Account::findOneBy('Id', 'abc123');

Examples

Defining a model

For a simple setup..., (*4)

use Stratease\Salesforcery\Salesforce\Database\Model;

class Account extends Model
{
    // Account maps to Account in Salesforce, nothing else required.
}

More advanced usage..., (*5)

use Stratease\Salesforcery\Salesforce\Database\Model;

class Product extends Model
{
    public static $resourceName = 'Product2';
}
  • Extend Stratease\Salesforcery\Salesforce\Database\Model and you're set! Sorta...
  • The model's Salesforce Object name is mapped by default via the {ClassName} -> {ObjectName}. You can override by defining the resourceName property.
  • Explicit field definitions allowed with option to override. get{Field}()
  • Will use SchemaInspector to discover fields for this resource and automatically hydrate instances with the fields

Query Objects

// Account is returned
$account = Account::findOneBy('Name', 'Acme Corp');
// An iterable Collection is returned
$accountCollection = Account::findBy(['OwnerId' => '123', 'Status' => 'Active']); // performs an AND expression on the associative array
foreach($accountCollection as $account) {
    echo "\n".$account->Name;
}

Modify Objects

// create
$account = new Account();
$account->Name = 'Acme Uber Corp';
$account->save(); 

// update
$account2 = Account::findOneBy('Name', 'Acme Uber Corp');
$account2->Name = 'Acme Uber Inc.';
$account2->save(); 

// delete
$account2->delete();

Salesforce

This library uses Salesforces REST API. Tested on version 39., (*6)

Todo

  • Object relations mapping, i.e. $contact->phone->isMobile
  • Add more REST endpoint support
  • Batch REST integration
  • Object -> field schema cache. As it stands it will request the schema n * Models times per run. So if you do a series of requests utilizing Account and User models, it will request the schema twice, once for each model.
  • Query builder object
  • Look into extended Eloquent more formally.
  • Test with other php versions. Was developed on 7.1
  • Docker environment for tests. As it stands now tests require a connection to a sandbox environment. Preferred setup for now in order to validate various Salesforce REST protocols are passing muster.
  • Currently only support for OAuth2 password grant type. Accepting pull requests for other authorization protocols.

The Versions

12/04 2018

dev-master

9999999-dev https://github.com/stratease/salesforcery

A PHP Salesforce ORM, inspired by Eloquent's API.

  Sources   Download

Apache-2.0

The Requires

 

The Development Requires

orm database php rest model client salesforce

12/04 2018

0.3.1

0.3.1.0 https://github.com/stratease/salesforcery

A PHP Salesforce ORM, inspired by Eloquent's API.

  Sources   Download

Apache-2.0

The Requires

 

The Development Requires

orm database php rest model client salesforce

12/04 2018

0.3.0

0.3.0.0 https://github.com/stratease/salesforcery

A PHP Salesforce ORM, inspired by Eloquent's API.

  Sources   Download

Apache-2.0

The Requires

 

The Development Requires

orm database php rest model client salesforce

23/03 2018

0.2.1

0.2.1.0 https://github.com/stratease/salesforcery

A PHP Salesforce ORM, inspired by Eloquent's API.

  Sources   Download

Apache-2.0

The Requires

 

The Development Requires

orm database php rest model client salesforce

09/03 2018

0.1.2

0.1.2.0 https://github.com/stratease/salesforcery

A PHP Salesforce ORM, inspired by Eloquent's API.

  Sources   Download

Apache-2.0

The Requires

 

The Development Requires

orm database php rest model client salesforce

09/03 2018

0.1.1

0.1.1.0 https://github.com/stratease/salesforcery

A PHP Salesforce ORM, inspired by Eloquent's API.

  Sources   Download

Apache-2.0

The Requires

 

The Development Requires

orm database php rest model client salesforce