2014-01-30 19:15:10 -04:00
|
|
|
<?php
|
|
|
|
|
namespace ProcessMaker\Project;
|
|
|
|
|
|
|
|
|
|
use ProcessMaker\Util\Logger;
|
|
|
|
|
|
2014-02-10 13:09:50 -04:00
|
|
|
/**
|
|
|
|
|
* Class Handler
|
|
|
|
|
*
|
|
|
|
|
* @package ProcessMaker\Project
|
|
|
|
|
* @author Erik Amaru Ortiz <aortiz.erik@gmail.com, erik@colosa.com>
|
|
|
|
|
*/
|
2014-02-05 11:39:15 -04:00
|
|
|
abstract class Handler
|
2014-01-30 19:15:10 -04:00
|
|
|
{
|
2014-02-05 11:39:15 -04:00
|
|
|
public static function load($uid)
|
|
|
|
|
{ // This method must be implemented on children classes, this is not declared abstract since PHP 5.3.x
|
|
|
|
|
// don't allow any more static abstract methods.
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public abstract function create($data);
|
|
|
|
|
//public abstract function update();
|
|
|
|
|
public abstract function remove();
|
2014-01-30 19:15:10 -04:00
|
|
|
|
2014-02-06 11:00:15 -04:00
|
|
|
protected static function diffArrayByKey($key, $list, $targetList)
|
|
|
|
|
{
|
|
|
|
|
$uid = array();
|
|
|
|
|
$diff = array();
|
|
|
|
|
|
|
|
|
|
foreach ($list as $item) {
|
|
|
|
|
if (array_key_exists($key, $item)) {
|
|
|
|
|
$uid[] = $item[$key];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
foreach ($targetList as $item) {
|
|
|
|
|
if (! in_array($item[$key], $uid)) {
|
|
|
|
|
$diff[] = $item[$key];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $diff;
|
|
|
|
|
}
|
|
|
|
|
|
2014-01-30 19:15:10 -04:00
|
|
|
/**
|
|
|
|
|
* Log in ProcessMaker Standard Output if debug mode is enabled.
|
|
|
|
|
*
|
|
|
|
|
* @author Erik Amaru Ortiz <aortiz.erik at icloud dot com>
|
|
|
|
|
* @internal param $args this method receives N-Arguments dynamically with any type, string, array, object, etc
|
|
|
|
|
* it means that you ca use it by example:
|
|
|
|
|
*
|
|
|
|
|
* self::log("Beginning transaction");
|
|
|
|
|
* self::log("Method: ", __METHOD__, 'Returns: ', $result);
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
public static function log()
|
|
|
|
|
{
|
2014-02-06 12:10:35 -04:00
|
|
|
if (\System::isDebugMode()) {
|
2014-01-30 19:15:10 -04:00
|
|
|
|
|
|
|
|
$me = Logger::getInstance();
|
|
|
|
|
$args = func_get_args();
|
|
|
|
|
//array_unshift($args, 'Class '.__CLASS__.' ');
|
|
|
|
|
|
|
|
|
|
call_user_func_array(array($me, 'setLog'), $args);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|