1. Go to this page and download the library: Download phpbook/etl library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
phpbook / etl example snippets
class Customer extends \PHPBook\ETL\Mapper {
public function getValuesHashByExternalEntity($externalEntity) {
//return a hash of data values based on the external entity.
//equals local and external entity values must return same hash
//do not use id in this hash
return md5($externalEntity->name . $externalEntity->description);
}
public function getNewExternalEntity($localEntity) {
//new external entity. Do not need pass the external value to the external entity
$externalEntity = new \Customer\ETL\ERP\Entity\Customer();
$externalEntity->name = $localEntity->name;
$externalEntity->description = $localEntity->description;
return $externalEntity;
}
public function getUpdatedExternalEntity($externalEntity, $localEntity) {
//edit external entity. Do not need pass the external value to the external entity
$externalEntity->name = $localEntity->name;
$externalEntity->description = $localEntity->description;
return $externalEntity;
}
public function getValuesHashByLocalEntity($localEntity) {
//return a hash of data values based on the local entity.
//equals local and external entity values must return same hash
//do not use id, integration id/hash in this hash
return md5($localEntity->name . $localEntity->description);
}
public function getNewLocalEntity($externalEntity) {
//new local entity. Do not need pass the external value key/hash in this time because the bind method will be called
$localEntity = new \Customer\Entity\Customer();
$localEntity->name = $localEntity->name;
$localEntity->description = $localEntity->description;
return $localEntity;
}
public function getUpdatedLocalEntity($localEntity, $externalEntity) {
//edit local entity. Do not need pass the external value key/hash in this time because the bind method will be called
$localEntity->name = $externalEntity->name;
$localEntity->description = $externalEntity->description;
return $localEntity;
}
public function getBindedLocalEntityWithExternalEntityKeyValue($localEntity, $externalEntityKeyValue) {
//$externalEntityKeyValue string or integer value
//set the external key value in the local entity row
$localEntity->external_key = $externalEntityKeyValue;
return $localEntity;
}
public function getBindedLocalEntityWithExternalEntityHashValue($localEntity, $externalEntityHashValue) {
//$externalEntityHashValue string value
//set the external hash value in the local entity row
$localEntity->external_hash = $externalEntityHashValue;
return $localEntity;
}
}
\PHPBook\ETL\Configuration\Setup::setSetup((new \PHPBook\ETL\Setup())
->setFiles(['schema json file path 1', 'schema json file path 2'])
->setExceptionCatcher(function(String $message) {
//the PHPBook ETL does not throw exceptions, but you can take it here
//you can store $message in database or something else
}));
$routine = new \PHPBook\ETL\Routine('myETL');
//PRIORITY_EXTERNAL: when changes are detected in the local database and the external database, use external data
//PRIORITY_LOCAL: when changes are detected in the local database and the external database, use local data
$routine->priority(\PHPBook\ETL\Routine::$PRIORITY_EXTERNAL); //default
$routine->priority(\PHPBook\ETL\Routine::$PRIORITY_LOCAL);
//run the routine
$routine->run();
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.