Skip to main content

Salesforce Data Connection with PHP

Sekedar untuk mengingat aja, contoh kelas untuk koneksi PHP ke Salesforce dengan API/SOAP.
/**
Class to handle connection to salesforce

*/
require_once("soapclient/SforcePartnerClient.php");
require_once("soapclient/BulkApiClient.php");

define('SOAP_PATH', "soapclient");
define('WSDL_XML_PARTNER', "partner.wsdl.xml");
define('WSDL_XML_ENTERPRISE', "enterprise.wsdl.xml");
define('WSDL_XML_METADATA', "metadata.wsdl.xml");

class SFConnectionClass
{
public $connection;
public $server = 'sand'; // option (sand or prod)
public $username = '';
public $password = '';
public $token = '';
public $sfSessionID = '';
public $sfLocation = '';

/*
constructor
// if parameter empty, use default
*/
public function SFConnectionClass($server = 'sand', $username = '', $password = '', $token = '')
{
if ($server != "") $this->server = $server;
if ($username != "") $this->username = $username;
if ($password != "") $this->password = $password;
if ($token != "") $this->token = $token;
$this->connection = $this->getConnectionSF();
}

/*
get database connection to salesforce
*/
public function getConnectionSF()
{
try {

$username = $this->username;
$password = $this->password;
$token = $this->token;

$SforceConnection = new SforcePartnerClient();
//$wsdl_xml = ($isEnterprise) ? WSDL_XML_ENTERPRISE : WSDL_XML_PARTNER;
$wsdl_xml = SOAP_PATH."/".$this->server."_".WSDL_XML_PARTNER;
$SforceConnection->createConnection($wsdl_xml);
$SforceConnection->login($username, $password.$token);
$this->connection = $SforceConnection;
$this->sfSessionID = $SforceConnection->getSessionID();
$this->sfLocation = $SforceConnection->getLocation();
return $SforceConnection; // soap salesforce
}
catch (Exception $e) {
print_r($e);
die();
}
return null;
}
/*
function to get query result in csv format
*/
public function fetchQueryCSV($strSQL)
{
$queryResult = $this->getQueryResultSF($strSQL);
$strRes = "";
if (isset($queryResult->records) && count($queryResult->records) > 0)
{
// generate header
$arrHeader = array();
$strHeader = "";
foreach($queryResult->records[0]->fields AS $strKey => $objV)
{
$arrHeader[$strKey] = $strKey;
$strHeader .= ($strHeader == "") ? $strKey : ",".$strKey;
}
if (isset($queryResult->records[0]->sobjects))
{
foreach($queryResult->records[0]->sobjects[0]->fields AS $strKey => $objV)
{
$strKey = $queryResult->records[0]->sobjects[0]->type .".".$strKey;
$arrHeader[$strKey] = $strKey;
$strHeader .= ($strHeader == "") ? $strKey : ",".$strKey;
}
}
// generate detail
foreach ($queryResult->records AS $i => $obj)
{
$arrTmp = array();
foreach ($obj->fields AS $strKey => $objV)
{
$arrTmp[$strKey] = (string)$objV;
}
if (isset($obj->sobjects))
{
foreach($obj->sobjects AS $j => $objSO)
{
foreach($objSO->fields AS $strKey => $objV)
$arrTmp[$objSO->type.".".$strKey] = (string)$objV;
}
}
$strDetail = "";
$x = 0;
foreach ($arrHeader AS $key)
{
$strVal = (isset($arrTmp[$key])) ? $arrTmp[$key] : "";
if (strstr($strVal, ",")) $strVal = '"'.$strVal.'"';
$strDetail .= ($x == 0) ? $strVal : ",".$strVal;
$x++;
}
if ($strRes != "") $strRes .= chr(13).chr(10);
$strRes .= $strDetail;
}
$strRes = $strHeader .chr(13).chr(10).$strRes;
}
return $strRes;
}

/*
function to get query result in array of fields=>value
*/
public function fetchQueryArray($strSQL)
{
$queryResult = $this->getQueryResultSF($strSQL);
$arrRes = array();
if (isset($queryResult->records))
{
foreach ($queryResult->records AS $i => $obj)
{
if (isset($obj->Id)) $arrRes[$i]['ID'] = $obj->Id;
if (isset($obj->Id)) $arrRes[$i]['OBJECT_NAME'] = $obj->type;
if (isset($obj->fields))
{
foreach($obj->fields AS $strKey => $objV)
$arrRes[$i][$strKey] = (string)$objV;
}
if (isset($obj->sobjects))
{
foreach($obj->sobjects AS $j => $objSO)
{
$arrRes[$i]['REFERENCES'] = array();
foreach($objSO->fields AS $strKey => $objV)
$arrRes[$i]['REFERENCES'][$objSO->type][$strKey] = (string)$objV;
}
}
}
}
return $arrRes;
}

/*
function to get query result - SOAP
*/
public function getQueryResultSF($strSQL)
{
$response = $this->connection->query($strSQL);
$queryResult = new QueryResult($response);

return $queryResult;
}
/* function to execute delete data based on result of the query
*/
public function deleteResultData($strSQL)
{
$arrData = $this->fetchQueryArray($strSQL);
$strCsv = "";
$strObjectName = "";
foreach ($arrData AS $i => $records)
{
if ($records['OBJECT_NAME'] != "") $strObjectName = $records['OBJECT_NAME'];
if ($records['ID'] != "")
{
if ($strCsv != "") $strCsv .= chr(13).chr(10);
$strCsv .= $records['ID'];
}
}
if ($strCsv == "" || $strObjectName == "") return "ERROR: No Data!";
$strCsv = "Id".chr(13).chr(10).$strCsv;
return $this->processBulkAPI("delete", $strObjectName, $strCsv);
}
/*
function to execute bulkAPI processing data
input : process type (insert/update/delete), object name, csv
output : result
*/
public function processBulkAPI($type, $strObject, $strCsv = '')
{
if ($strCsv == "") return false;
try {
// BulkAPI client
$myBulkApiConnection = new BulkApiClient($this->sfLocation, $this->sfSessionID);
$myBulkApiConnection->setLoggingEnabled(true);
$myBulkApiConnection->setCompressionEnabled(true);

// Hand oops Bulk Jobs :P
$job = new JobInfo();
$job->setObject($strObject);
$job->setOpertion($type);
$job->setContentType("CSV");
$job->setConcurrencyMode("Parallel");
$job = $myBulkApiConnection->createJob($job);

// Result
$result = $myBulkApiConnection->createBatch($job, $strCsv);
$tmp = $myBulkApiConnection->updateJobState($job->getId(), "Closed");
$resultBatch = $myBulkApiConnection->getBatchResults($job->getId(), $result->getId());
return $resultBatch;
}
catch (Exception $e)
{
return $e->getMessage();
}
}
// function to parse csv string to array
public function parseCsv($strCsv)
{
$arrResult = array();
$arrH = array();
$arr = explode("\n", $strCsv);
$i = 0;
foreach($arr AS $j => $str)
{
$arrD = explode(",", $str);
if ($i == 0)
{
$arrH = $arrD;
}
else
{
$arrTmp = array();
foreach($arrD AS $k=>$tmp)
{
$strKey = str_replace("\"", "", $arrH[$k]);
$arrTmp[$strKey] = str_replace("\"", "", $tmp);
}
$arrResult[] = $arrTmp;
}
$i++;
}
return $arrResult;
}

}
?>

Sapa tahu suatu saat berguna.
http://tinypaste.com/e4c5e

Comments

Popular posts from this blog

PostGreSQL :: Hitung Umur

Ternyata untuk menghitung umur dari data yang disimpan di PostGreSQL sangat gampang. PostGreSQL sendiri sudah menyediakan fungsi yang mendukung. Beberapa fungsi yang bisa dipakai adalah AGE dan EXTRACT. AGE dipakai untuk menghitung umur dari sebuah data, dibandingkan dengan hari ini, atau dengan data lain (tipenya timestamp). Misal: age(timestamp '1980-09-27'), akan menghasilkan nilai (bertipe interval) "24 years 1 mon 25 days". Nah, kalau mau mengambil nilai tahunnya saja, tinggal menggunakan EXTRACT Contoh: EXTRACT(year FROM AGE(timestamp '2001-09-27')), hasilnya akan jadi 24.

PHP :: Selisih Jam

Setelah kemarin kesulitan untuk melakukan increment ataupun decrement terhadap variabel waktu (date/time) di PHP, kali ini nemuin masalah untuk mencari selisih waktu (dari satu jam ke jam tertentu), yang perlu untuk ngitung lembur karyawan. Tadinya kepikiran untuk buat fungsi sendiri, yang flow -nya kira-kira begini: - masing-masing dipisah menjadi jam, menit, detik - bandingkan antara keduanya. - lakukan pengurangan terhadap masing-masing komponen (jam, menit dan detik) - gabungkan hasil perhitungan ... (selisih jam + selisih menit + selisih detik) Tapi waktu aku ingat kasus Next Date, ... muncul ide untuk menggunakan cara yang sama, yaitu memanfaatkan format UNIX timestamp, terus nyoba mencari selisihnya. TERNYATA BERHASIL !!! Flownya seperti ini: - masing-masing dipisah menjadi jam, menit,detik - ubah masing-masing ke format timestamp, gunakan fungsi mktime() - kurangkan kedua jam - hasilnya dibagi 60 (karena satuannya pakai menit), sementara selisih timestamp itu dalam detik Algori...

Delphi :: Split String

Akhirnya ketemu juga cara untuk melakukan split string. (Terbiasa pakai PHP sih, yang sangat memanjakan dalam pengelolaan string.) Di sini memanfaatkan TStringList, unit Classes. // procedure untuk split string procedure Split (const Delimiter: Char; // delimiter charachter Input: string; // input string const Strings: TStrings) ; // list of string result begin Assert(Assigned(Strings)) ; Strings.Clear; Strings.Delimiter := Delimiter; Strings.DelimitedText := Input; end; // contoh pemakaian procedure TForm1.Button1Click(Sender: TObject) ; var A: TStringList; begin A := TStringList.Create; try Split(' ', 'your delphi guide', A) ; ShowMessage(a[0]) ; //your ShowMessage(a[1]) ; //delphi ShowMessage(a[2]) ; //guide finally A.Free; end; end; Source : http://delphi.about.com/cs/adptips2002/a/bltip1102_5.htm Wheew .. akhirnya. One step ahead!!