Merge remote branch 'upstream/master'

This commit is contained in:
jennylee
2012-10-19 16:54:43 -04:00
26 changed files with 8611 additions and 9859 deletions

File diff suppressed because it is too large Load Diff

View File

@@ -1,6 +1,7 @@
<?php <?php
/** /**
* CalendarDefinition.php * CalendarDefinition.php
*
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
@@ -20,448 +21,435 @@ require_once 'classes/model/CalendarAssignments.php';
* *
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
class CalendarDefinition extends BaseCalendarDefinition { class CalendarDefinition extends BaseCalendarDefinition
{
public $calendarLog = ''; public $calendarLog = '';
function getCalendarList($onlyActive = false, $arrayMode = false) {
$Criteria = new Criteria ( 'workflow' );
$Criteria->clearSelectColumns ();
$Criteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_UID ); public function getCalendarList ($onlyActive = false, $arrayMode = false)
$Criteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_NAME ); {
$Criteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_CREATE_DATE ); $Criteria = new Criteria( 'workflow' );
$Criteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_UPDATE_DATE ); $Criteria->clearSelectColumns();
$Criteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_DESCRIPTION );
$Criteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_STATUS ); $Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_UID );
$Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_NAME );
$Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_CREATE_DATE );
$Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_UPDATE_DATE );
$Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_DESCRIPTION );
$Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_STATUS );
// $Criteria->addAsColumn('DELETABLE', "IF (CALENDAR_UID <> '00000000000000000000000000000001', '".G::LoadTranslation('ID_DELETE')."','') "); // $Criteria->addAsColumn('DELETABLE', "IF (CALENDAR_UID <> '00000000000000000000000000000001', '".G::LoadTranslation('ID_DELETE')."','') ");
$Criteria->addAsColumn('DELETABLE', "CASE WHEN CALENDAR_UID <> '00000000000000000000000000000001' THEN '".G::LoadTranslation('ID_DELETE')."' ELSE '' END "); $Criteria->addAsColumn( 'DELETABLE', "CASE WHEN CALENDAR_UID <> '00000000000000000000000000000001' THEN '" . G::LoadTranslation( 'ID_DELETE' ) . "' ELSE '' END " );
// Note: This list doesn't show deleted items (STATUS = DELETED) // Note: This list doesn't show deleted items (STATUS = DELETED)
if ($onlyActive) { // Show only active. Used on assignment lists if ($onlyActive) {
$Criteria->add ( calendarDefinitionPeer::CALENDAR_STATUS, "ACTIVE", CRITERIA::EQUAL ); // Show only active. Used on assignment lists
} else { // Show Active and Inactive calendars. USed in main list $Criteria->add( calendarDefinitionPeer::CALENDAR_STATUS, "ACTIVE", CRITERIA::EQUAL );
$Criteria->add ( calendarDefinitionPeer::CALENDAR_STATUS, array ("ACTIVE", "INACTIVE" ), CRITERIA::IN ); } else {
// Show Active and Inactive calendars. USed in main list
$Criteria->add( calendarDefinitionPeer::CALENDAR_STATUS, array ("ACTIVE","INACTIVE"), CRITERIA::IN );
} }
$Criteria->add ( calendarDefinitionPeer::CALENDAR_UID, "xx", CRITERIA::NOT_EQUAL ); $Criteria->add( calendarDefinitionPeer::CALENDAR_UID, "xx", CRITERIA::NOT_EQUAL );
if (! $arrayMode) { if (! $arrayMode) {
return $Criteria; return $Criteria;
} else { } else {
$oDataset = calendarDefinitionPeer::doSelectRS ( $Criteria ); $oDataset = calendarDefinitionPeer::doSelectRS( $Criteria );
$oDataset->setFetchmode ( ResultSet::FETCHMODE_ASSOC ); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$oDataset->next (); $oDataset->next();
$calendarA = array (0 => 'dummy' ); $calendarA = array (0 => 'dummy');
$calendarCount = 0; $calendarCount = 0;
while ( is_array ( $aRow = $oDataset->getRow () ) ) { while (is_array( $aRow = $oDataset->getRow() )) {
$calendarCount ++; $calendarCount ++;
$calendarA [$calendarCount] = $aRow; $calendarA[$calendarCount] = $aRow;
$oDataset->next (); $oDataset->next();
} }
$return ['criteria'] = $Criteria; $return['criteria'] = $Criteria;
$return ['array'] = $calendarA; $return['array'] = $calendarA;
return $return; return $return;
} }
} }
//Added by qennix //Added by qennix
//Gets criteria for listing //Gets criteria for listing
function getCalendarCriterias($filter, $start, $limit){ public function getCalendarCriterias ($filter, $start, $limit)
$Criteria = new Criteria ( 'workflow' ); {
$Criteria->clearSelectColumns (); $Criteria = new Criteria( 'workflow' );
$Criteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_UID ); $Criteria->clearSelectColumns();
if ($filter !=''){ $Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_UID );
$Criteria->add( if ($filter != '') {
$Criteria->getNewCriterion(CalendarDefinitionPeer::CALENDAR_NAME,'%'.$filter.'%',Criteria::LIKE)->addOr( $Criteria->add( $Criteria->getNewCriterion( CalendarDefinitionPeer::CALENDAR_NAME, '%' . $filter . '%', Criteria::LIKE )->addOr( $Criteria->getNewCriterion( CalendarDefinitionPeer::CALENDAR_DESCRIPTION, '%' . $filter . '%', Criteria::LIKE ) ) );
$Criteria->getNewCriterion(CalendarDefinitionPeer::CALENDAR_DESCRIPTION,'%'.$filter.'%',Criteria::LIKE)));
} }
$Criteria->add(CalendarDefinitionPeer::CALENDAR_STATUS,'DELETED',Criteria::NOT_EQUAL); $Criteria->add( CalendarDefinitionPeer::CALENDAR_STATUS, 'DELETED', Criteria::NOT_EQUAL );
$oCriteria = new Criteria ( 'workflow' ); $oCriteria = new Criteria( 'workflow' );
$oCriteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_UID ); $oCriteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_UID );
$oCriteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_NAME ); $oCriteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_NAME );
$oCriteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_CREATE_DATE ); $oCriteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_CREATE_DATE );
$oCriteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_UPDATE_DATE ); $oCriteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_UPDATE_DATE );
$oCriteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_DESCRIPTION ); $oCriteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_DESCRIPTION );
$oCriteria->addSelectColumn ( CalendarDefinitionPeer::CALENDAR_STATUS ); $oCriteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_STATUS );
if ($filter !=''){ if ($filter != '') {
$oCriteria->add( $oCriteria->add( $oCriteria->getNewCriterion( CalendarDefinitionPeer::CALENDAR_NAME, '%' . $filter . '%', Criteria::LIKE )->addOr( $oCriteria->getNewCriterion( CalendarDefinitionPeer::CALENDAR_DESCRIPTION, '%' . $filter . '%', Criteria::LIKE ) ) );
$oCriteria->getNewCriterion(CalendarDefinitionPeer::CALENDAR_NAME,'%'.$filter.'%',Criteria::LIKE)->addOr(
$oCriteria->getNewCriterion(CalendarDefinitionPeer::CALENDAR_DESCRIPTION,'%'.$filter.'%',Criteria::LIKE)));
} }
$oCriteria->add(CalendarDefinitionPeer::CALENDAR_STATUS,'DELETED',Criteria::NOT_EQUAL); $oCriteria->add( CalendarDefinitionPeer::CALENDAR_STATUS, 'DELETED', Criteria::NOT_EQUAL );
$oCriteria->setLimit($limit); $oCriteria->setLimit( $limit );
$oCriteria->setOffset($start); $oCriteria->setOffset( $start );
$criterias = array(); $criterias = array ();
$criterias['COUNTER'] = $Criteria; $criterias['COUNTER'] = $Criteria;
$criterias['LIST'] = $oCriteria; $criterias['LIST'] = $oCriteria;
return $criterias; return $criterias;
} }
function getCalendarInfo($CalendarUid) {
public function getCalendarInfo ($CalendarUid)
{
//if exists the row in the database propel will update it, otherwise will insert. //if exists the row in the database propel will update it, otherwise will insert.
$tr = CalendarDefinitionPeer::retrieveByPK ( $CalendarUid ); $tr = CalendarDefinitionPeer::retrieveByPK( $CalendarUid );
$defaultCalendar ['CALENDAR_UID'] = "00000000000000000000000000000001"; $defaultCalendar['CALENDAR_UID'] = "00000000000000000000000000000001";
$defaultCalendar ['CALENDAR_NAME'] = "Default"; $defaultCalendar['CALENDAR_NAME'] = "Default";
$defaultCalendar ['CALENDAR_CREATE_DATE'] = date ( "Y-m-d" ); $defaultCalendar['CALENDAR_CREATE_DATE'] = date( "Y-m-d" );
$defaultCalendar ['CALENDAR_UPDATE_DATE'] = date ( "Y-m-d" ); $defaultCalendar['CALENDAR_UPDATE_DATE'] = date( "Y-m-d" );
$defaultCalendar ['CALENDAR_DESCRIPTION'] = "Default"; $defaultCalendar['CALENDAR_DESCRIPTION'] = "Default";
$defaultCalendar ['CALENDAR_STATUS'] = "ACTIVE"; $defaultCalendar['CALENDAR_STATUS'] = "ACTIVE";
$defaultCalendar ['CALENDAR_WORK_DAYS'] = "1|2|3|4|5"; $defaultCalendar['CALENDAR_WORK_DAYS'] = "1|2|3|4|5";
$defaultCalendar ['CALENDAR_WORK_DAYS'] = explode ( "|", "1|2|3|4|5" ); $defaultCalendar['CALENDAR_WORK_DAYS'] = explode( "|", "1|2|3|4|5" );
$defaultCalendar ['BUSINESS_DAY'] [1] ['CALENDAR_BUSINESS_DAY'] = 7; $defaultCalendar['BUSINESS_DAY'][1]['CALENDAR_BUSINESS_DAY'] = 7;
$defaultCalendar ['BUSINESS_DAY'] [1] ['CALENDAR_BUSINESS_START'] = "09:00"; $defaultCalendar['BUSINESS_DAY'][1]['CALENDAR_BUSINESS_START'] = "09:00";
$defaultCalendar ['BUSINESS_DAY'] [1] ['CALENDAR_BUSINESS_END'] = "17:00"; $defaultCalendar['BUSINESS_DAY'][1]['CALENDAR_BUSINESS_END'] = "17:00";
$defaultCalendar ['HOLIDAY'] = array (); $defaultCalendar['HOLIDAY'] = array ();
if ((is_object ( $tr ) && get_class ( $tr ) == 'CalendarDefinition')) { if ((is_object( $tr ) && get_class( $tr ) == 'CalendarDefinition')) {
$fields ['CALENDAR_UID'] = $tr->getCalendarUid (); $fields['CALENDAR_UID'] = $tr->getCalendarUid();
$fields ['CALENDAR_NAME'] = $tr->getCalendarName (); $fields['CALENDAR_NAME'] = $tr->getCalendarName();
$fields ['CALENDAR_CREATE_DATE'] = $tr->getCalendarCreateDate (); $fields['CALENDAR_CREATE_DATE'] = $tr->getCalendarCreateDate();
$fields ['CALENDAR_UPDATE_DATE'] = $tr->getCalendarUpdateDate (); $fields['CALENDAR_UPDATE_DATE'] = $tr->getCalendarUpdateDate();
$fields ['CALENDAR_DESCRIPTION'] = $tr->getCalendarDescription (); $fields['CALENDAR_DESCRIPTION'] = $tr->getCalendarDescription();
$fields ['CALENDAR_STATUS'] = $tr->getCalendarStatus (); $fields['CALENDAR_STATUS'] = $tr->getCalendarStatus();
$fields ['CALENDAR_WORK_DAYS'] = $tr->getCalendarWorkDays (); $fields['CALENDAR_WORK_DAYS'] = $tr->getCalendarWorkDays();
$fields ['CALENDAR_WORK_DAYS_A'] = explode ( "|", $tr->getCalendarWorkDays () ); $fields['CALENDAR_WORK_DAYS_A'] = explode( "|", $tr->getCalendarWorkDays() );
} else { } else {
$fields=$defaultCalendar; $fields = $defaultCalendar;
$this->saveCalendarInfo ( $fields ); $this->saveCalendarInfo( $fields );
$fields ['CALENDAR_WORK_DAYS'] = "1|2|3|4|5"; $fields['CALENDAR_WORK_DAYS'] = "1|2|3|4|5";
$fields ['CALENDAR_WORK_DAYS_A'] = explode ( "|", "1|2|3|4|5" ); $fields['CALENDAR_WORK_DAYS_A'] = explode( "|", "1|2|3|4|5" );
$tr = CalendarDefinitionPeer::retrieveByPK ( $CalendarUid ); $tr = CalendarDefinitionPeer::retrieveByPK( $CalendarUid );
} }
$CalendarBusinessHoursObj = new CalendarBusinessHours ( ); $CalendarBusinessHoursObj = new CalendarBusinessHours();
$CalendarBusinessHours = $CalendarBusinessHoursObj->getCalendarBusinessHours ( $CalendarUid ); $CalendarBusinessHours = $CalendarBusinessHoursObj->getCalendarBusinessHours( $CalendarUid );
$fields ['BUSINESS_DAY'] = $CalendarBusinessHours; $fields['BUSINESS_DAY'] = $CalendarBusinessHours;
$CalendarHolidaysObj = new CalendarHolidays();
$CalendarHolidaysObj = new CalendarHolidays ( ); $CalendarHolidays = $CalendarHolidaysObj->getCalendarHolidays( $CalendarUid );
$CalendarHolidays = $CalendarHolidaysObj->getCalendarHolidays ( $CalendarUid ); $fields['HOLIDAY'] = $CalendarHolidays;
$fields ['HOLIDAY'] = $CalendarHolidays; $fields = $this->validateCalendarInfo( $fields, $defaultCalendar );
$fields=$this->validateCalendarInfo($fields, $defaultCalendar); //******************** //********************
return $fields; return $fields;
} }
//for edit //for edit
function getCalendarInfoE($CalendarUid) { public function getCalendarInfoE ($CalendarUid)
{
//if exists the row in the database propel will update it, otherwise will insert. //if exists the row in the database propel will update it, otherwise will insert.
$tr = CalendarDefinitionPeer::retrieveByPK ( $CalendarUid ); $tr = CalendarDefinitionPeer::retrieveByPK( $CalendarUid );
$defaultCalendar['CALENDAR_UID'] = "00000000000000000000000000000001";
$defaultCalendar['CALENDAR_NAME'] = "Default";
$defaultCalendar['CALENDAR_CREATE_DATE'] = date( "Y-m-d" );
$defaultCalendar['CALENDAR_UPDATE_DATE'] = date( "Y-m-d" );
$defaultCalendar['CALENDAR_DESCRIPTION'] = "Default";
$defaultCalendar['CALENDAR_STATUS'] = "ACTIVE";
$defaultCalendar['CALENDAR_WORK_DAYS'] = "1|2|3|4|5";
$defaultCalendar['CALENDAR_WORK_DAYS'] = explode( "|", "1|2|3|4|5" );
$defaultCalendar['BUSINESS_DAY'][1]['CALENDAR_BUSINESS_DAY'] = 7;
$defaultCalendar['BUSINESS_DAY'][1]['CALENDAR_BUSINESS_START'] = "09:00";
$defaultCalendar['BUSINESS_DAY'][1]['CALENDAR_BUSINESS_END'] = "17:00";
$defaultCalendar['HOLIDAY'] = array ();
$defaultCalendar ['CALENDAR_UID'] = "00000000000000000000000000000001"; if ((is_object( $tr ) && get_class( $tr ) == 'CalendarDefinition')) {
$defaultCalendar ['CALENDAR_NAME'] = "Default"; $fields['CALENDAR_UID'] = $tr->getCalendarUid();
$defaultCalendar ['CALENDAR_CREATE_DATE'] = date ( "Y-m-d" ); $fields['CALENDAR_NAME'] = $tr->getCalendarName();
$defaultCalendar ['CALENDAR_UPDATE_DATE'] = date ( "Y-m-d" ); $fields['CALENDAR_CREATE_DATE'] = $tr->getCalendarCreateDate();
$defaultCalendar ['CALENDAR_DESCRIPTION'] = "Default"; $fields['CALENDAR_UPDATE_DATE'] = $tr->getCalendarUpdateDate();
$defaultCalendar ['CALENDAR_STATUS'] = "ACTIVE"; $fields['CALENDAR_DESCRIPTION'] = $tr->getCalendarDescription();
$defaultCalendar ['CALENDAR_WORK_DAYS'] = "1|2|3|4|5"; $fields['CALENDAR_STATUS'] = $tr->getCalendarStatus();
$defaultCalendar ['CALENDAR_WORK_DAYS'] = explode ( "|", "1|2|3|4|5" ); $fields['CALENDAR_WORK_DAYS'] = $tr->getCalendarWorkDays();
$defaultCalendar ['BUSINESS_DAY'] [1] ['CALENDAR_BUSINESS_DAY'] = 7; $fields['CALENDAR_WORK_DAYS_A'] = explode( "|", $tr->getCalendarWorkDays() );
$defaultCalendar ['BUSINESS_DAY'] [1] ['CALENDAR_BUSINESS_START'] = "09:00";
$defaultCalendar ['BUSINESS_DAY'] [1] ['CALENDAR_BUSINESS_END'] = "17:00";
$defaultCalendar ['HOLIDAY'] = array ();
if ((is_object ( $tr ) && get_class ( $tr ) == 'CalendarDefinition')) {
$fields ['CALENDAR_UID'] = $tr->getCalendarUid ();
$fields ['CALENDAR_NAME'] = $tr->getCalendarName ();
$fields ['CALENDAR_CREATE_DATE'] = $tr->getCalendarCreateDate ();
$fields ['CALENDAR_UPDATE_DATE'] = $tr->getCalendarUpdateDate ();
$fields ['CALENDAR_DESCRIPTION'] = $tr->getCalendarDescription ();
$fields ['CALENDAR_STATUS'] = $tr->getCalendarStatus ();
$fields ['CALENDAR_WORK_DAYS'] = $tr->getCalendarWorkDays ();
$fields ['CALENDAR_WORK_DAYS_A'] = explode ( "|", $tr->getCalendarWorkDays () );
} else { } else {
$fields=$defaultCalendar; $fields = $defaultCalendar;
$this->saveCalendarInfo ( $fields ); $this->saveCalendarInfo( $fields );
$fields ['CALENDAR_WORK_DAYS'] = "1|2|3|4|5"; $fields['CALENDAR_WORK_DAYS'] = "1|2|3|4|5";
$fields ['CALENDAR_WORK_DAYS_A'] = explode ( "|", "1|2|3|4|5" ); $fields['CALENDAR_WORK_DAYS_A'] = explode( "|", "1|2|3|4|5" );
$tr = CalendarDefinitionPeer::retrieveByPK ( $CalendarUid ); $tr = CalendarDefinitionPeer::retrieveByPK( $CalendarUid );
} }
$CalendarBusinessHoursObj = new CalendarBusinessHours ( ); $CalendarBusinessHoursObj = new CalendarBusinessHours();
$CalendarBusinessHours = $CalendarBusinessHoursObj->getCalendarBusinessHours ( $CalendarUid ); $CalendarBusinessHours = $CalendarBusinessHoursObj->getCalendarBusinessHours( $CalendarUid );
$fields ['BUSINESS_DAY'] = $CalendarBusinessHours; $fields['BUSINESS_DAY'] = $CalendarBusinessHours;
$CalendarHolidaysObj = new CalendarHolidays();
$CalendarHolidaysObj = new CalendarHolidays ( ); $CalendarHolidays = $CalendarHolidaysObj->getCalendarHolidays( $CalendarUid );
$CalendarHolidays = $CalendarHolidaysObj->getCalendarHolidays ( $CalendarUid ); $fields['HOLIDAY'] = $CalendarHolidays;
$fields ['HOLIDAY'] = $CalendarHolidays;
// $fields=$this->validateCalendarInfo($fields, $defaultCalendar); //******************** // $fields=$this->validateCalendarInfo($fields, $defaultCalendar); //********************
return $fields; return $fields;
} }
//end for edit //end for edit
function validateCalendarInfo($fields,$defaultCalendar){ public function validateCalendarInfo ($fields, $defaultCalendar)
{
try { try {
//Validate if Working days are Correct //Validate if Working days are Correct
//Minimun 3 ? //Minimun 3 ?
$workingDays=explode ( "|", $fields['CALENDAR_WORK_DAYS'] ); $workingDays = explode( "|", $fields['CALENDAR_WORK_DAYS'] );
if(count($workingDays)<3){ if (count( $workingDays ) < 3) {
throw (new Exception ( "You must define at least 3 Working Days!" )); throw (new Exception( "You must define at least 3 Working Days!" ));
} }
//Validate that all Working Days have Bussines Hours //Validate that all Working Days have Bussines Hours
if(count($fields ['BUSINESS_DAY'])<1){ if (count( $fields['BUSINESS_DAY'] ) < 1) {
throw (new Exception ( "You must define at least one Business Day for all days" )); throw (new Exception( "You must define at least one Business Day for all days" ));
} }
$workingDaysOK=array(); $workingDaysOK = array ();
foreach($workingDays as $key => $day){ foreach ($workingDays as $key => $day) {
$workingDaysOK[$day]=false; $workingDaysOK[$day] = false;
} }
$sw_all=false; $sw_all = false;
foreach($fields ['BUSINESS_DAY'] as $keyB => $businessHours){ foreach ($fields['BUSINESS_DAY'] as $keyB => $businessHours) {
if(($businessHours['CALENDAR_BUSINESS_DAY']==7)){ if (($businessHours['CALENDAR_BUSINESS_DAY'] == 7)) {
$sw_all=true; $sw_all = true;
}elseif((in_array($businessHours['CALENDAR_BUSINESS_DAY'],$workingDays))){ } elseif ((in_array( $businessHours['CALENDAR_BUSINESS_DAY'], $workingDays ))) {
$workingDaysOK[$businessHours['CALENDAR_BUSINESS_DAY']]=true; $workingDaysOK[$businessHours['CALENDAR_BUSINESS_DAY']] = true;
} }
} }
$sw_days=true; $sw_days = true;
foreach($workingDaysOK as $day =>$sw_day){ foreach ($workingDaysOK as $day => $sw_day) {
$sw_days=$sw_days && $sw_day; $sw_days = $sw_days && $sw_day;
} }
if(!($sw_all || $sw_days)){ if (! ($sw_all || $sw_days)) {
throw (new Exception ( "Not all working days have their correspondent business day" )); throw (new Exception( "Not all working days have their correspondent business day" ));
} }
//Validate Holidays //Validate Holidays
return $fields; return $fields;
} catch (Exception $e) { } catch (Exception $e) {
//print $e->getMessage(); //print $e->getMessage();
$this->addCalendarLog("!!!!!!! BAD CALENDAR DEFINITION. ".$e->getMessage()); $this->addCalendarLog( "!!!!!!! BAD CALENDAR DEFINITION. " . $e->getMessage() );
$defaultCalendar ['CALENDAR_WORK_DAYS'] = "1|2|3|4|5"; $defaultCalendar['CALENDAR_WORK_DAYS'] = "1|2|3|4|5";
$defaultCalendar ['CALENDAR_WORK_DAYS_A'] = explode ( "|", "1|2|3|4|5" ); $defaultCalendar['CALENDAR_WORK_DAYS_A'] = explode( "|", "1|2|3|4|5" );
return $defaultCalendar; return $defaultCalendar;
} }
} }
function saveCalendarInfo($aData) {
$CalendarUid = $aData ['CALENDAR_UID']; public function saveCalendarInfo ($aData)
$CalendarName = $aData ['CALENDAR_NAME']; {
$CalendarDescription = $aData ['CALENDAR_DESCRIPTION']; $CalendarUid = $aData['CALENDAR_UID'];
$CalendarStatus = isset ( $aData ['CALENDAR_STATUS'] ) ? $aData ['CALENDAR_STATUS'] : "INACTIVE"; $CalendarName = $aData['CALENDAR_NAME'];
$defaultCalendars [] = '00000000000000000000000000000001'; $CalendarDescription = $aData['CALENDAR_DESCRIPTION'];
if (in_array ( $aData ['CALENDAR_UID'], $defaultCalendars )) { $CalendarStatus = isset( $aData['CALENDAR_STATUS'] ) ? $aData['CALENDAR_STATUS'] : "INACTIVE";
$defaultCalendars[] = '00000000000000000000000000000001';
if (in_array( $aData['CALENDAR_UID'], $defaultCalendars )) {
$CalendarStatus = 'ACTIVE'; $CalendarStatus = 'ACTIVE';
$CalendarName = 'Default'; $CalendarName = 'Default';
} }
$CalendarWorkDays = isset ( $aData ['CALENDAR_WORK_DAYS'] ) ? implode ( "|", $aData ['CALENDAR_WORK_DAYS'] ) : ""; $CalendarWorkDays = isset( $aData['CALENDAR_WORK_DAYS'] ) ? implode( "|", $aData['CALENDAR_WORK_DAYS'] ) : "";
//if exists the row in the database propel will update it, otherwise will insert. //if exists the row in the database propel will update it, otherwise will insert.
$tr = CalendarDefinitionPeer::retrieveByPK ( $CalendarUid ); $tr = CalendarDefinitionPeer::retrieveByPK( $CalendarUid );
if (! (is_object ( $tr ) && get_class ( $tr ) == 'CalendarDefinition')) { if (! (is_object( $tr ) && get_class( $tr ) == 'CalendarDefinition')) {
$tr = new CalendarDefinition ( ); $tr = new CalendarDefinition();
$tr->setCalendarCreateDate ( 'now' ); $tr->setCalendarCreateDate( 'now' );
} }
$tr->setCalendarUid ( $CalendarUid ); $tr->setCalendarUid( $CalendarUid );
$tr->setCalendarName ( $CalendarName ); $tr->setCalendarName( $CalendarName );
$tr->setCalendarUpdateDate( 'now' );
$tr->setCalendarDescription( $CalendarDescription );
$tr->setCalendarStatus( $CalendarStatus );
$tr->setCalendarWorkDays( $CalendarWorkDays );
$tr->setCalendarUpdateDate ( 'now' ); if ($tr->validate()) {
$tr->setCalendarDescription ( $CalendarDescription );
$tr->setCalendarStatus ( $CalendarStatus );
$tr->setCalendarWorkDays ( $CalendarWorkDays );
if ($tr->validate ()) {
// we save it, since we get no validation errors, or do whatever else you like. // we save it, since we get no validation errors, or do whatever else you like.
$res = $tr->save (); $res = $tr->save();
//Calendar Business Hours Save code. //Calendar Business Hours Save code.
//First Delete all current records //First Delete all current records
$CalendarBusinessHoursObj = new CalendarBusinessHours ( ); $CalendarBusinessHoursObj = new CalendarBusinessHours();
$CalendarBusinessHoursObj->deleteAllCalendarBusinessHours ( $CalendarUid ); $CalendarBusinessHoursObj->deleteAllCalendarBusinessHours( $CalendarUid );
//Save all the sent records //Save all the sent records
foreach ( $aData ['BUSINESS_DAY'] as $key => $objData ) { foreach ($aData['BUSINESS_DAY'] as $key => $objData) {
$objData ['CALENDAR_UID'] = $CalendarUid; $objData['CALENDAR_UID'] = $CalendarUid;
$CalendarBusinessHoursObj->saveCalendarBusinessHours ( $objData ); $CalendarBusinessHoursObj->saveCalendarBusinessHours( $objData );
} }
//Holiday Save code. //Holiday Save code.
//First Delete all current records //First Delete all current records
$CalendarHolidayObj = new CalendarHolidays ( ); $CalendarHolidayObj = new CalendarHolidays();
$CalendarHolidayObj->deleteAllCalendarHolidays ( $CalendarUid ); $CalendarHolidayObj->deleteAllCalendarHolidays( $CalendarUid );
//Save all the sent records //Save all the sent records
foreach ( $aData ['HOLIDAY'] as $key => $objData ) { foreach ($aData['HOLIDAY'] as $key => $objData) {
if (($objData ['CALENDAR_HOLIDAY_NAME'] != "") && ($objData ['CALENDAR_HOLIDAY_START'] != "") && ($objData ['CALENDAR_HOLIDAY_END'] != "")) { if (($objData['CALENDAR_HOLIDAY_NAME'] != "") && ($objData['CALENDAR_HOLIDAY_START'] != "") && ($objData['CALENDAR_HOLIDAY_END'] != "")) {
$objData ['CALENDAR_UID'] = $CalendarUid; $objData['CALENDAR_UID'] = $CalendarUid;
$CalendarHolidayObj->saveCalendarHolidays ( $objData ); $CalendarHolidayObj->saveCalendarHolidays( $objData );
} }
} }
} else { } else {
// Something went wrong. We can now get the validationFailures and handle them. // Something went wrong. We can now get the validationFailures and handle them.
$msg = ''; $msg = '';
$validationFailuresArray = $tr->getValidationFailures (); $validationFailuresArray = $tr->getValidationFailures();
foreach ( $validationFailuresArray as $objValidationFailure ) { foreach ($validationFailuresArray as $objValidationFailure) {
$msg .= $objValidationFailure->getMessage () . "<br/>"; $msg .= $objValidationFailure->getMessage() . "<br/>";
} }
//return array ( 'codError' => -100, 'rowsAffected' => 0, 'message' => $msg ); //return array ( 'codError' => -100, 'rowsAffected' => 0, 'message' => $msg );
} }
//return array ( 'codError' => 0, 'rowsAffected' => $res, 'message' => ''); //return array ( 'codError' => 0, 'rowsAffected' => $res, 'message' => '');
//to do: uniform coderror structures for all classes //to do: uniform coderror structures for all classes
//if ( $res['codError'] < 0 ) { //if ( $res['codError'] < 0 ) {
// G::SendMessageText ( $res['message'] , 'error' ); // G::SendMessageText ( $res['message'] , 'error' );
//} //}
} }
function deleteCalendar($CalendarUid) {
//if exists the row in the database propel will update it, otherwise will insert.
$tr = CalendarDefinitionPeer::retrieveByPK ( $CalendarUid );
if (! (is_object ( $tr ) && get_class ( $tr ) == 'CalendarDefinition')) { public function deleteCalendar ($CalendarUid)
{
//if exists the row in the database propel will update it, otherwise will insert.
$tr = CalendarDefinitionPeer::retrieveByPK( $CalendarUid );
if (! (is_object( $tr ) && get_class( $tr ) == 'CalendarDefinition')) {
// //
return false; return false;
} }
$defaultCalendars [] = '00000000000000000000000000000001'; $defaultCalendars[] = '00000000000000000000000000000001';
if (in_array ( $tr->getCalendarUid(), $defaultCalendars )) { if (in_array( $tr->getCalendarUid(), $defaultCalendars )) {
return false; return false;
} }
$tr->setCalendarStatus ( 'DELETED' ); $tr->setCalendarStatus( 'DELETED' );
$tr->setCalendarUpdateDate ( 'now' ); $tr->setCalendarUpdateDate( 'now' );
if ($tr->validate ()) { if ($tr->validate()) {
// we save it, since we get no validation errors, or do whatever else you like. // we save it, since we get no validation errors, or do whatever else you like.
$res = $tr->save (); $res = $tr->save();
} else { } else {
// Something went wrong. We can now get the validationFailures and handle them. // Something went wrong. We can now get the validationFailures and handle them.
$msg = ''; $msg = '';
$validationFailuresArray = $tr->getValidationFailures (); $validationFailuresArray = $tr->getValidationFailures();
foreach ( $validationFailuresArray as $objValidationFailure ) { foreach ($validationFailuresArray as $objValidationFailure) {
$msg .= $objValidationFailure->getMessage () . "<br/>"; $msg .= $objValidationFailure->getMessage() . "<br/>";
} }
G::SendMessage ( "ERROR", $msg ); G::SendMessage( "ERROR", $msg );
//return array ( 'codError' => -100, 'rowsAffected' => 0, 'message' => $msg ); //return array ( 'codError' => -100, 'rowsAffected' => 0, 'message' => $msg );
} }
//return array ( 'codError' => 0, 'rowsAffected' => $res, 'message' => ''); //return array ( 'codError' => 0, 'rowsAffected' => $res, 'message' => '');
//to do: uniform coderror structures for all classes //to do: uniform coderror structures for all classes
//if ( $res['codError'] < 0 ) { //if ( $res['codError'] < 0 ) {
// G::SendMessageText ( $res['message'] , 'error' ); // G::SendMessageText ( $res['message'] , 'error' );
//} //}
} }
function getCalendarFor($userUid, $proUid, $tasUid, $sw_validate=true) {
$Criteria = new Criteria ( 'workflow' );
public function getCalendarFor ($userUid, $proUid, $tasUid, $sw_validate = true)
{
$Criteria = new Criteria( 'workflow' );
//Default Calendar //Default Calendar
$calendarUid = "00000000000000000000000000000001"; $calendarUid = "00000000000000000000000000000001";
$calendarOwner = "DEFAULT"; $calendarOwner = "DEFAULT";
//Load User,Task and Process calendars (if exist) //Load User,Task and Process calendars (if exist)
$Criteria->addSelectColumn ( CalendarAssignmentsPeer::CALENDAR_UID ); $Criteria->addSelectColumn( CalendarAssignmentsPeer::CALENDAR_UID );
$Criteria->addSelectColumn ( CalendarAssignmentsPeer::OBJECT_UID ); $Criteria->addSelectColumn( CalendarAssignmentsPeer::OBJECT_UID );
$Criteria->addSelectColumn ( CalendarAssignmentsPeer::OBJECT_TYPE ); $Criteria->addSelectColumn( CalendarAssignmentsPeer::OBJECT_TYPE );
$Criteria->add ( CalendarAssignmentsPeer::OBJECT_UID, array($userUid, $proUid, $tasUid), CRITERIA::IN ); $Criteria->add( CalendarAssignmentsPeer::OBJECT_UID, array ($userUid,$proUid,$tasUid), CRITERIA::IN );
$oDataset = CalendarAssignmentsPeer::doSelectRS ( $Criteria ); $oDataset = CalendarAssignmentsPeer::doSelectRS( $Criteria );
$oDataset->setFetchmode ( ResultSet::FETCHMODE_ASSOC ); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$oDataset->next (); $oDataset->next();
$calendarArray=array(); $calendarArray = array ();
while(is_array($aRow = $oDataset->getRow ())){ while (is_array( $aRow = $oDataset->getRow() )) {
if($aRow['OBJECT_UID']==$userUid){ if ($aRow['OBJECT_UID'] == $userUid) {
$calendarArray['USER']=$aRow ['CALENDAR_UID']; $calendarArray['USER'] = $aRow['CALENDAR_UID'];
} }
if($aRow['OBJECT_UID']==$proUid){ if ($aRow['OBJECT_UID'] == $proUid) {
$calendarArray['PROCESS']=$aRow ['CALENDAR_UID']; $calendarArray['PROCESS'] = $aRow['CALENDAR_UID'];
} }
if($aRow['OBJECT_UID']==$tasUid){ if ($aRow['OBJECT_UID'] == $tasUid) {
$calendarArray['TASK']=$aRow ['CALENDAR_UID']; $calendarArray['TASK'] = $aRow['CALENDAR_UID'];
} }
$oDataset->next (); $oDataset->next();
} }
if(isset($calendarArray['USER'])){
if (isset( $calendarArray['USER'] )) {
$calendarUid = $calendarArray['USER']; $calendarUid = $calendarArray['USER'];
$calendarOwner = "USER"; $calendarOwner = "USER";
}elseif (isset($calendarArray['PROCESS'])){ } elseif (isset( $calendarArray['PROCESS'] )) {
$calendarUid = $calendarArray['PROCESS']; $calendarUid = $calendarArray['PROCESS'];
$calendarOwner = "PROCESS"; $calendarOwner = "PROCESS";
}elseif (isset($calendarArray['TASK'])){ } elseif (isset( $calendarArray['TASK'] )) {
$calendarUid = $calendarArray['TASK']; $calendarUid = $calendarArray['TASK'];
$calendarOwner = "TASK"; $calendarOwner = "TASK";
} }
//print "<h1>$calendarUid</h1>"; //print "<h1>$calendarUid</h1>";
if($sw_validate){ if ($sw_validate) {
$calendarDefinition = $this->getCalendarInfo ( $calendarUid ); $calendarDefinition = $this->getCalendarInfo( $calendarUid );
}else{ } else {
$calendarDefinition = $this->getCalendarInfoE ( $calendarUid ); $calendarDefinition = $this->getCalendarInfoE( $calendarUid );
} }
$calendarDefinition ['CALENDAR_APPLIED'] = $calendarOwner; $calendarDefinition['CALENDAR_APPLIED'] = $calendarOwner;
$this->addCalendarLog ( "--=== Calendar Applied: " . $calendarDefinition ['CALENDAR_NAME'] . " -> $calendarOwner" ); $this->addCalendarLog( "--=== Calendar Applied: " . $calendarDefinition['CALENDAR_NAME'] . " -> $calendarOwner" );
return $calendarDefinition; return $calendarDefinition;
} }
function assignCalendarTo($objectUid, $calendarUid, $objectType) { public function assignCalendarTo ($objectUid, $calendarUid, $objectType)
{
//if exists the row in the database propel will update it, otherwise will insert. //if exists the row in the database propel will update it, otherwise will insert.
$tr = CalendarAssignmentsPeer::retrieveByPK ( $objectUid ); $tr = CalendarAssignmentsPeer::retrieveByPK( $objectUid );
if ($calendarUid != "") { if ($calendarUid != "") {
if (! (is_object ( $tr ) && get_class ( $tr ) == 'CalendarAssignments')) { if (! (is_object( $tr ) && get_class( $tr ) == 'CalendarAssignments')) {
$tr = new CalendarAssignments ( ); $tr = new CalendarAssignments();
} }
$tr->setObjectUid ( $objectUid ); $tr->setObjectUid( $objectUid );
$tr->setCalendarUid ( $calendarUid ); $tr->setCalendarUid( $calendarUid );
$tr->setObjectType ( $objectType ); $tr->setObjectType( $objectType );
if ($tr->validate ()) { if ($tr->validate()) {
// we save it, since we get no validation errors, or do whatever else you like. // we save it, since we get no validation errors, or do whatever else you like.
$res = $tr->save (); $res = $tr->save();
} else { } else {
// Something went wrong. We can now get the validationFailures and handle them. // Something went wrong. We can now get the validationFailures and handle them.
$msg = ''; $msg = '';
$validationFailuresArray = $tr->getValidationFailures (); $validationFailuresArray = $tr->getValidationFailures();
foreach ( $validationFailuresArray as $objValidationFailure ) { foreach ($validationFailuresArray as $objValidationFailure) {
$msg .= $objValidationFailure->getMessage () . "<br/>"; $msg .= $objValidationFailure->getMessage() . "<br/>";
} }
//return array ( 'codError' => -100, 'rowsAffected' => 0, 'message' => $msg ); //return array ( 'codError' => -100, 'rowsAffected' => 0, 'message' => $msg );
} }
} else { //Delete record } else {
if ((is_object ( $tr ) && get_class ( $tr ) == 'CalendarAssignments')) { //Delete record
$tr->delete (); if ((is_object( $tr ) && get_class( $tr ) == 'CalendarAssignments')) {
$tr->delete();
} }
} }
} }
//Added by Qennix //Added by Qennix
//Counts all users,task,process by calendar //Counts all users,task,process by calendar
function getAllCounterByCalendar($type){ public function getAllCounterByCalendar ($type)
$oCriteria = new Criteria('workflow'); {
$oCriteria->addSelectColumn(CalendarAssignmentsPeer::CALENDAR_UID); $oCriteria = new Criteria( 'workflow' );
$oCriteria->addSelectColumn('COUNT(*) AS CNT'); $oCriteria->addSelectColumn( CalendarAssignmentsPeer::CALENDAR_UID );
$oCriteria->addGroupByColumn(CalendarAssignmentsPeer::CALENDAR_UID); $oCriteria->addSelectColumn( 'COUNT(*) AS CNT' );
$oCriteria->add(CalendarAssignmentsPeer::OBJECT_TYPE,$type); $oCriteria->addGroupByColumn( CalendarAssignmentsPeer::CALENDAR_UID );
$oDataset = CalendarAssignmentsPeer::doSelectRS($oCriteria); $oCriteria->add( CalendarAssignmentsPeer::OBJECT_TYPE, $type );
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC); $oDataset = CalendarAssignmentsPeer::doSelectRS( $oCriteria );
$aCounter = Array(); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
while($oDataset->next()){ $aCounter = Array ();
while ($oDataset->next()) {
$row = $oDataset->getRow(); $row = $oDataset->getRow();
$aCounter[$row['CALENDAR_UID']] = $row['CNT']; $aCounter[$row['CALENDAR_UID']] = $row['CNT'];
} }
return $aCounter; return $aCounter;
} }
function loadByCalendarName($calendarName) public function loadByCalendarName ($calendarName)
{ {
$Criteria = new Criteria('workflow'); $Criteria = new Criteria( 'workflow' );
$Criteria->addSelectColumn(CalendarDefinitionPeer::CALENDAR_UID); $Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_UID );
$Criteria->addSelectColumn(CalendarDefinitionPeer::CALENDAR_NAME); $Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_NAME );
$Criteria->addSelectColumn(CalendarDefinitionPeer::CALENDAR_CREATE_DATE); $Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_CREATE_DATE );
$Criteria->addSelectColumn(CalendarDefinitionPeer::CALENDAR_UPDATE_DATE); $Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_UPDATE_DATE );
$Criteria->addSelectColumn(CalendarDefinitionPeer::CALENDAR_DESCRIPTION); $Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_DESCRIPTION );
$Criteria->addSelectColumn(CalendarDefinitionPeer::CALENDAR_STATUS); $Criteria->addSelectColumn( CalendarDefinitionPeer::CALENDAR_STATUS );
$Criteria->add(calendarDefinitionPeer::CALENDAR_NAME, $calendarName, CRITERIA::EQUAL); $Criteria->add( calendarDefinitionPeer::CALENDAR_NAME, $calendarName, CRITERIA::EQUAL );
$oDataset = calendarDefinitionPeer::doSelectRS ($Criteria); $oDataset = calendarDefinitionPeer::doSelectRS( $Criteria );
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$oDataset->next(); $oDataset->next();
return $oDataset->getRow(); return $oDataset->getRow();
} }
} // CalendarDefinition }
// CalendarDefinition

View File

@@ -1,6 +1,7 @@
<?php <?php
/** /**
* Content.php * Content.php
*
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
* *
* ProcessMaker Open Source Edition * ProcessMaker Open Source Edition
@@ -37,8 +38,8 @@ require_once 'classes/model/om/BaseContent.php';
* *
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
class Content extends BaseContent { class Content extends BaseContent
{
public $langs; public $langs;
public $rowsProcessed; public $rowsProcessed;
public $rowsInserted; public $rowsInserted;
@@ -50,16 +51,18 @@ class Content extends BaseContent {
* @param string $sUID * @param string $sUID
* @return variant * @return variant
*/ */
function load($ConCategory, $ConParent, $ConId, $ConLang) { public function load ($ConCategory, $ConParent, $ConId, $ConLang)
$content = ContentPeer::retrieveByPK ( $ConCategory, $ConParent, $ConId, $ConLang ); {
if (is_null ( $content )) { $content = ContentPeer::retrieveByPK( $ConCategory, $ConParent, $ConId, $ConLang );
//we dont find any value for this field and language in CONTENT table if (is_null( $content )) {
$ConValue = Content::autoLoadSave ( $ConCategory, $ConParent, $ConId, $ConLang ); //we dont find any value for this field and language in CONTENT table;
$ConValue = Content::autoLoadSave( $ConCategory, $ConParent, $ConId, $ConLang );
} else { } else {
//krumo($content); //krumo($content);
$ConValue = $content->getConValue (); $ConValue = $content->getConValue();
if ($ConValue == "") { //try to find a valid translation if ($ConValue == "") {
$ConValue = Content::autoLoadSave ( $ConCategory, $ConParent, $ConId, $ConLang ); //try to find a valid translation
$ConValue = Content::autoLoadSave( $ConCategory, $ConParent, $ConId, $ConLang );
} }
} }
return $ConValue; return $ConValue;
@@ -72,29 +75,28 @@ class Content extends BaseContent {
* @return string * @return string
* *
*/ */
function getDefaultContentLang($ConCategory, $ConParent, $ConId, $destConLang) { public function getDefaultContentLang ($ConCategory, $ConParent, $ConId, $destConLang)
$Criteria = new Criteria ( 'workflow' ); {
$Criteria->clearSelectColumns ()->clearOrderByColumns (); $Criteria = new Criteria( 'workflow' );
$Criteria->clearSelectColumns()->clearOrderByColumns();
$Criteria->addSelectColumn ( ContentPeer::CON_CATEGORY ); $Criteria->addSelectColumn( ContentPeer::CON_CATEGORY );
$Criteria->addSelectColumn ( ContentPeer::CON_PARENT ); $Criteria->addSelectColumn( ContentPeer::CON_PARENT );
$Criteria->addSelectColumn ( ContentPeer::CON_ID ); $Criteria->addSelectColumn( ContentPeer::CON_ID );
$Criteria->addSelectColumn ( ContentPeer::CON_LANG ); $Criteria->addSelectColumn( ContentPeer::CON_LANG );
$Criteria->addSelectColumn ( ContentPeer::CON_VALUE ); $Criteria->addSelectColumn( ContentPeer::CON_VALUE );
$Criteria->add ( ContentPeer::CON_CATEGORY, $ConCategory, CRITERIA::EQUAL ); $Criteria->add( ContentPeer::CON_CATEGORY, $ConCategory, CRITERIA::EQUAL );
$Criteria->add ( ContentPeer::CON_PARENT, $ConParent, CRITERIA::EQUAL ); $Criteria->add( ContentPeer::CON_PARENT, $ConParent, CRITERIA::EQUAL );
$Criteria->add ( ContentPeer::CON_ID, $ConId, CRITERIA::EQUAL ); $Criteria->add( ContentPeer::CON_ID, $ConId, CRITERIA::EQUAL );
$Criteria->add( ContentPeer::CON_LANG, $destConLang, CRITERIA::NOT_EQUAL );
$Criteria->add ( ContentPeer::CON_LANG, $destConLang, CRITERIA::NOT_EQUAL ); $rs = ContentPeer::doSelectRS( $Criteria );
$rs->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$rs = ContentPeer::doSelectRS ( $Criteria ); $rs->next();
$rs->setFetchmode ( ResultSet::FETCHMODE_ASSOC );
$rs->next ();
if (is_array ( $row = $rs->getRow () )) {
$defaultLang = $row ['CON_LANG'];
if (is_array( $row = $rs->getRow() )) {
$defaultLang = $row['CON_LANG'];
} else { } else {
$defaultLang = ""; $defaultLang = "";
} }
@@ -109,35 +111,38 @@ class Content extends BaseContent {
* @return string * @return string
* if the row doesn't exist, it will be created automatically, even the default 'en' language * if the row doesn't exist, it will be created automatically, even the default 'en' language
*/ */
function autoLoadSave($ConCategory, $ConParent, $ConId, $destConLang) { public function autoLoadSave ($ConCategory, $ConParent, $ConId, $destConLang)
{
//search in 'en' language, the default language //search in 'en' language, the default language
$content = ContentPeer::retrieveByPK ( $ConCategory, $ConParent, $ConId, 'en' ); $content = ContentPeer::retrieveByPK( $ConCategory, $ConParent, $ConId, 'en' );
if ((is_null ( $content )) || ($content->getConValue () == "")) { if ((is_null( $content )) || ($content->getConValue() == "")) {
$differentLang = Content::getDefaultContentLang ( $ConCategory, $ConParent, $ConId, $destConLang ); $differentLang = Content::getDefaultContentLang( $ConCategory, $ConParent, $ConId, $destConLang );
$content = ContentPeer::retrieveByPK ( $ConCategory, $ConParent, $ConId, $differentLang ); $content = ContentPeer::retrieveByPK( $ConCategory, $ConParent, $ConId, $differentLang );
} }
//to do: review if the $destConLang is a valid language/ //to do: review if the $destConLang is a valid language/
if (is_null ( $content )) if (is_null( $content )) {
$ConValue = ''; //we dont find any value for this field and language in CONTENT table $ConValue = '';
else //we dont find any value for this field and language in CONTENT table
$ConValue = $content->getConValue (); } else {
$ConValue = $content->getConValue();
}
try { try {
$con = ContentPeer::retrieveByPK ( $ConCategory, $ConParent, $ConId, $destConLang ); $con = ContentPeer::retrieveByPK( $ConCategory, $ConParent, $ConId, $destConLang );
if (is_null ( $con )) { if (is_null( $con )) {
$con = new Content ( ); $con = new Content();
} }
$con->setConCategory ( $ConCategory ); $con->setConCategory( $ConCategory );
$con->setConParent ( $ConParent ); $con->setConParent( $ConParent );
$con->setConId ( $ConId ); $con->setConId( $ConId );
$con->setConLang ( $destConLang ); $con->setConLang( $destConLang );
$con->setConValue ( $ConValue ); $con->setConValue( $ConValue );
if ($con->validate ()) { if ($con->validate()) {
$res = $con->save (); $res = $con->save();
} }
} catch ( Exception $e ) { } catch (Exception $e) {
throw ($e); throw ($e);
} }
@@ -153,37 +158,40 @@ class Content extends BaseContent {
* @param string $ConValue * @param string $ConValue
* @return variant * @return variant
*/ */
function addContent($ConCategory, $ConParent, $ConId, $ConLang, $ConValue) { public function addContent ($ConCategory, $ConParent, $ConId, $ConLang, $ConValue)
{
try { try {
if ($ConLang != 'en') { if ($ConLang != 'en') {
$baseLangContent = ContentPeer::retrieveByPk($ConCategory, $ConParent, $ConId, 'en'); $baseLangContent = ContentPeer::retrieveByPk( $ConCategory, $ConParent, $ConId, 'en' );
if ($baseLangContent === null) { if ($baseLangContent === null) {
Content::addContent($ConCategory, $ConParent, $ConId, 'en', $ConValue); Content::addContent( $ConCategory, $ConParent, $ConId, 'en', $ConValue );
} }
} }
$con = ContentPeer::retrieveByPK ( $ConCategory, $ConParent, $ConId, $ConLang ); $con = ContentPeer::retrieveByPK( $ConCategory, $ConParent, $ConId, $ConLang );
if (is_null ( $con )) { if (is_null( $con )) {
$con = new Content ( ); $con = new Content();
} else { } else {
if ($con->getConParent () == $ConParent && $con->getConCategory () == $ConCategory && $con->getConValue () == $ConValue && $con->getConLang () == $ConLang && $con->getConId () == $ConId) if ($con->getConParent() == $ConParent && $con->getConCategory() == $ConCategory && $con->getConValue() == $ConValue && $con->getConLang() == $ConLang && $con->getConId() == $ConId) {
return true; return true;
} }
$con->setConCategory ( $ConCategory ); }
if ($con->getConParent () != $ConParent) $con->setConCategory( $ConCategory );
$con->setConParent ( $ConParent ); if ($con->getConParent() != $ConParent) {
$con->setConId ( $ConId ); $con->setConParent( $ConParent );
$con->setConLang ( $ConLang ); }
$con->setConValue ( $ConValue ); $con->setConId( $ConId );
if ($con->validate ()) { $con->setConLang( $ConLang );
$res = $con->save (); $con->setConValue( $ConValue );
if ($con->validate()) {
$res = $con->save();
return $res; return $res;
} else { } else {
$e = new Exception ( "Error in addcontent, the row $ConCategory, $ConParent, $ConId, $ConLang is not Valid" ); $e = new Exception( "Error in addcontent, the row $ConCategory, $ConParent, $ConId, $ConLang is not Valid" );
throw ($e); throw ($e);
} }
} catch ( Exception $e ) { } catch (Exception $e) {
throw ($e); throw ($e);
} }
} }
@@ -197,22 +205,23 @@ class Content extends BaseContent {
* @param string $ConValue * @param string $ConValue
* @return variant * @return variant
*/ */
function insertContent($ConCategory, $ConParent, $ConId, $ConLang, $ConValue) { public function insertContent ($ConCategory, $ConParent, $ConId, $ConLang, $ConValue)
{
try { try {
$con = new Content ( ); $con = new Content();
$con->setConCategory ( $ConCategory ); $con->setConCategory( $ConCategory );
$con->setConParent ( $ConParent ); $con->setConParent( $ConParent );
$con->setConId ( $ConId ); $con->setConId( $ConId );
$con->setConLang ( $ConLang ); $con->setConLang( $ConLang );
$con->setConValue ( $ConValue ); $con->setConValue( $ConValue );
if ($con->validate ()) { if ($con->validate()) {
$res = $con->save (); $res = $con->save();
return $res; return $res;
} else { } else {
$e = new Exception ( "Error in addcontent, the row $ConCategory, $ConParent, $ConId, $ConLang is not Valid" ); $e = new Exception( "Error in addcontent, the row $ConCategory, $ConParent, $ConId, $ConLang is not Valid" );
throw ($e); throw ($e);
} }
} catch ( Exception $e ) { } catch (Exception $e) {
throw ($e); throw ($e);
} }
} }
@@ -226,21 +235,22 @@ class Content extends BaseContent {
* @param string $ConValue * @param string $ConValue
* @return variant * @return variant
*/ */
function removeContent($ConCategory, $ConParent, $ConId) { public function removeContent ($ConCategory, $ConParent, $ConId)
{
try { try {
$c = new Criteria ( ); $c = new Criteria();
$c->add ( ContentPeer::CON_CATEGORY, $ConCategory ); $c->add( ContentPeer::CON_CATEGORY, $ConCategory );
$c->add ( ContentPeer::CON_PARENT, $ConParent ); $c->add( ContentPeer::CON_PARENT, $ConParent );
$c->add ( ContentPeer::CON_ID, $ConId ); $c->add( ContentPeer::CON_ID, $ConId );
$result = ContentPeer::doSelectRS ( $c ); $result = ContentPeer::doSelectRS( $c );
$result->next (); $result->next();
$row = $result->getRow (); $row = $result->getRow();
while ( is_array ( $row ) ) { while (is_array( $row )) {
ContentPeer::doDelete ( array ($ConCategory, $ConParent, $ConId, $row [3] ) ); ContentPeer::doDelete( array ($ConCategory,$ConParent,$ConId,$row[3]) );
$result->next (); $result->next();
$row = $result->getRow (); $row = $result->getRow();
} }
} catch ( Exception $e ) { } catch (Exception $e) {
throw ($e); throw ($e);
} }
@@ -256,18 +266,17 @@ class Content extends BaseContent {
* @param string $ConValue * @param string $ConValue
* @return boolean true or false * @return boolean true or false
*/ */
function Exists ($ConCategory, $ConParent, $ConId, $ConLang) public function Exists ($ConCategory, $ConParent, $ConId, $ConLang)
{ {
try { try {
$oPro = ContentPeer::retrieveByPk($ConCategory, $ConParent, $ConId, $ConLang); $oPro = ContentPeer::retrieveByPk( $ConCategory, $ConParent, $ConId, $ConLang );
if (is_object($oPro) && get_class ($oPro) == 'Content' ) { if (is_object( $oPro ) && get_class( $oPro ) == 'Content') {
return true; return true;
} else { } else {
return false; return false;
} }
} } catch (Exception $oError) {
catch (Exception $oError) { throw ($oError);
throw($oError);
} }
} }
@@ -276,18 +285,18 @@ class Content extends BaseContent {
* *
* @param array $langs * @param array $langs
*/ */
function regenerateContent($langs, $workSpace=SYS_SYS) public function regenerateContent ($langs, $workSpace = SYS_SYS)
{ {
//Search the language //Search the language
$key = array_search('en',$langs); $key = array_search( 'en', $langs );
if ($key === false) { if ($key === false) {
$key = array_search(SYS_LANG,$langs); $key = array_search( SYS_LANG, $langs );
if ($key === false) { if ($key === false) {
$key = '0'; $key = '0';
} }
} }
$this->langsAsoc = array(); $this->langsAsoc = array ();
foreach ($langs as $key=>$value) { foreach ($langs as $key => $value) {
$this->langsAsoc[$value] = $value; $this->langsAsoc[$value] = $value;
} }
@@ -298,27 +307,27 @@ class Content extends BaseContent {
$this->rowsClustered = 0; $this->rowsClustered = 0;
//Creating table CONTENT_BACKUP //Creating table CONTENT_BACKUP
$oConnection = Propel::getConnection('workflow'); $oConnection = Propel::getConnection( 'workflow' );
$oStatement = $oConnection->prepareStatement("CREATE TABLE IF NOT EXISTS `CONTENT_BACKUP` ( $oStatement = $oConnection->prepareStatement( "CREATE TABLE IF NOT EXISTS `CONTENT_BACKUP` (
`CON_CATEGORY` VARCHAR(30) default '' NOT NULL, `CON_CATEGORY` VARCHAR(30) default '' NOT NULL,
`CON_PARENT` VARCHAR(32) default '' NOT NULL, `CON_PARENT` VARCHAR(32) default '' NOT NULL,
`CON_ID` VARCHAR(100) default '' NOT NULL, `CON_ID` VARCHAR(100) default '' NOT NULL,
`CON_LANG` VARCHAR(10) default '' NOT NULL, `CON_LANG` VARCHAR(10) default '' NOT NULL,
`CON_VALUE` MEDIUMTEXT NOT NULL, `CON_VALUE` MEDIUMTEXT NOT NULL,
CONSTRAINT CONTENT_BACKUP_PK PRIMARY KEY (CON_CATEGORY,CON_PARENT,CON_ID,CON_LANG) CONSTRAINT CONTENT_BACKUP_PK PRIMARY KEY (CON_CATEGORY,CON_PARENT,CON_ID,CON_LANG)
)Engine=MyISAM DEFAULT CHARSET='utf8' COMMENT='Table for add content';"); )Engine=MyISAM DEFAULT CHARSET='utf8' COMMENT='Table for add content';" );
$oStatement->executeQuery(); $oStatement->executeQuery();
$con = Propel::getConnection('workflow'); $con = Propel::getConnection( 'workflow' );
$sql = " SELECT DISTINCT CON_LANG $sql = " SELECT DISTINCT CON_LANG
FROM CONTENT "; FROM CONTENT ";
$stmt = $con->createStatement(); $stmt = $con->createStatement();
$rs = $stmt->executeQuery($sql, ResultSet::FETCHMODE_ASSOC); $rs = $stmt->executeQuery( $sql, ResultSet::FETCHMODE_ASSOC );
while ($rs->next()) { while ($rs->next()) {
$row = $rs->getRow(); $row = $rs->getRow();
$language = $row['CON_LANG']; $language = $row['CON_LANG'];
if (array_search($row['CON_LANG'],$langs) === false) { if (array_search( $row['CON_LANG'], $langs ) === false) {
Content::removeLanguageContent($row['CON_LANG']); Content::removeLanguageContent( $row['CON_LANG'] );
} }
} }
@@ -326,154 +335,151 @@ class Content extends BaseContent {
FROM CONTENT FROM CONTENT
ORDER BY CON_ID, CON_CATEGORY, CON_PARENT, CON_LANG"; ORDER BY CON_ID, CON_CATEGORY, CON_PARENT, CON_LANG";
G::LoadClass("wsTools"); G::LoadClass( "wsTools" );
$workSpace = new workspaceTools($workSpace); $workSpace = new workspaceTools( $workSpace );
$workSpace->getDBInfo(); $workSpace->getDBInfo();
$link = mysql_pconnect($workSpace->dbHost, $workSpace->dbUser, $workSpace->dbPass) $link = mysql_pconnect( $workSpace->dbHost, $workSpace->dbUser, $workSpace->dbPass ) or die( "Could not connect" );
or die ("Could not connect");
mysql_select_db($workSpace->dbName, $link); mysql_select_db( $workSpace->dbName, $link );
mysql_query("SET NAMES 'utf8';"); mysql_query( "SET NAMES 'utf8';" );
mysql_query('SET OPTION SQL_BIG_SELECTS=1'); mysql_query( 'SET OPTION SQL_BIG_SELECTS=1' );
$result = mysql_unbuffered_query($sql, $link); $result = mysql_unbuffered_query( $sql, $link );
$list = array(); $list = array ();
$default = array(); $default = array ();
$sw = array('CON_ID'=>'','CON_CATEGORY'=>'','CON_PARENT'=>''); $sw = array ('CON_ID' => '','CON_CATEGORY' => '','CON_PARENT' => ''
while ($row = mysql_fetch_assoc($result)) { );
if ($sw['CON_ID'] == $row['CON_ID'] && while ($row = mysql_fetch_assoc( $result )) {
$sw['CON_CATEGORY'] == $row['CON_CATEGORY'] && if ($sw['CON_ID'] == $row['CON_ID'] && $sw['CON_CATEGORY'] == $row['CON_CATEGORY'] && $sw['CON_PARENT'] == $row['CON_PARENT']) {
$sw['CON_PARENT'] == $row['CON_PARENT']) {
$list[] = $row; $list[] = $row;
} else { } else {
$this->rowsClustered++; $this->rowsClustered ++;
if (count($langs) != count($list)) { if (count( $langs ) != count( $list )) {
$this->checkLanguage($list, $default); $this->checkLanguage( $list, $default );
} else { } else {
$this->rowsUnchanged = $this->rowsUnchanged + count($langs); $this->rowsUnchanged = $this->rowsUnchanged + count( $langs );
} }
$sw = array(); $sw = array ();
$sw['CON_ID'] = $row['CON_ID']; $sw['CON_ID'] = $row['CON_ID'];
$sw['CON_CATEGORY'] = $row['CON_CATEGORY']; $sw['CON_CATEGORY'] = $row['CON_CATEGORY'];
$sw['CON_LANG'] = $row['CON_LANG']; $sw['CON_LANG'] = $row['CON_LANG'];
$sw['CON_PARENT'] = $row['CON_PARENT']; $sw['CON_PARENT'] = $row['CON_PARENT'];
unset($list); unset( $list );
unset($default); unset( $default );
$list = array(); $list = array ();
$default = array(); $default = array ();
$list[] = $row; $list[] = $row;
} }
if ($sw['CON_LANG'] == $langs[$key]) { if ($sw['CON_LANG'] == $langs[$key]) {
$default = $row; $default = $row;
} }
$this->rowsProcessed++; $this->rowsProcessed ++;
} }
if (count($langs) != count($list)) { if (count( $langs ) != count( $list )) {
$this->checkLanguage($list, $default); $this->checkLanguage( $list, $default );
} else { } else {
$this->rowsUnchanged = $this->rowsUnchanged + count($langs); $this->rowsUnchanged = $this->rowsUnchanged + count( $langs );
} }
mysql_free_result($result); mysql_free_result( $result );
$total = $this->rowsProcessed + $this->rowsInserted; $total = $this->rowsProcessed + $this->rowsInserted;
$connection = Propel::getConnection( 'workflow' );
$connection = Propel::getConnection('workflow'); $statement = $connection->prepareStatement( "INSERT INTO CONTENT
$statement = $connection->prepareStatement("INSERT INTO CONTENT
SELECT CON_CATEGORY, CON_PARENT, CON_ID , CON_LANG, CON_VALUE SELECT CON_CATEGORY, CON_PARENT, CON_ID , CON_LANG, CON_VALUE
FROM CONTENT_BACKUP"); FROM CONTENT_BACKUP" );
$statement->executeQuery(); $statement->executeQuery();
$statement = $connection->prepareStatement("DROP TABLE CONTENT_BACKUP"); $statement = $connection->prepareStatement( "DROP TABLE CONTENT_BACKUP" );
$statement->executeQuery(); $statement->executeQuery();
if (!isset($_SERVER['SERVER_NAME'])) { if (! isset( $_SERVER['SERVER_NAME'] )) {
CLI::logging("Rows Processed ---> $this->rowsProcessed ..... \n"); CLI::logging( "Rows Processed ---> $this->rowsProcessed ..... \n" );
CLI::logging("Rows Clustered ---> $this->rowsClustered ..... \n"); CLI::logging( "Rows Clustered ---> $this->rowsClustered ..... \n" );
CLI::logging("Rows Unchanged ---> $this->rowsUnchanged ..... \n"); CLI::logging( "Rows Unchanged ---> $this->rowsUnchanged ..... \n" );
CLI::logging("Rows Inserted ---> $this->rowsInserted ..... \n"); CLI::logging( "Rows Inserted ---> $this->rowsInserted ..... \n" );
CLI::logging("Rows Total ---> $total ..... \n"); CLI::logging( "Rows Total ---> $total ..... \n" );
} }
} }
function checkLanguage($content, $default) public function checkLanguage ($content, $default)
{ {
if (count($content)>0) { if (count( $content ) > 0) {
$langs = $this->langs; $langs = $this->langs;
$langsAsoc = $this->langsAsoc; $langsAsoc = $this->langsAsoc;
//Element default //Element default
$default = (count($default)>0) ? $default : $content[0]; $default = (count( $default ) > 0) ? $default : $content[0];
foreach ($content as $key => $value) { foreach ($content as $key => $value) {
unset($langsAsoc[$value['CON_LANG']]); unset( $langsAsoc[$value['CON_LANG']] );
} }
foreach ($langsAsoc as $key => $value) { foreach ($langsAsoc as $key => $value) {
$this->rowsInserted++; $this->rowsInserted ++;
$this->fastInsertContent( $this->fastInsertContent( $default['CON_CATEGORY'], $default['CON_PARENT'], $default['CON_ID'], $value, $default['CON_VALUE'] );
$default['CON_CATEGORY'],
$default['CON_PARENT'],
$default['CON_ID'],
$value,
$default['CON_VALUE']
);
} }
} }
} }
function fastInsertContent ($ConCategory, $ConParent, $ConId, $ConLang, $ConValue) { public function fastInsertContent ($ConCategory, $ConParent, $ConId, $ConLang, $ConValue)
$ConValue = mysql_real_escape_string($ConValue); {
$connection = Propel::getConnection('workflow'); $ConValue = mysql_real_escape_string( $ConValue );
$statement = $connection->prepareStatement("INSERT INTO CONTENT_BACKUP ( $connection = Propel::getConnection( 'workflow' );
$statement = $connection->prepareStatement( "INSERT INTO CONTENT_BACKUP (
CON_CATEGORY, CON_PARENT, CON_ID , CON_LANG, CON_VALUE) CON_CATEGORY, CON_PARENT, CON_ID , CON_LANG, CON_VALUE)
VALUES ('$ConCategory', '$ConParent', '$ConId', '$ConLang', '$ConValue');"); VALUES ('$ConCategory', '$ConParent', '$ConId', '$ConLang', '$ConValue');" );
$statement->executeQuery(); $statement->executeQuery();
} }
function removeLanguageContent($lanId) { public function removeLanguageContent ($lanId)
{
try { try {
$c = new Criteria ( ); $c = new Criteria();
$c->addSelectColumn(ContentPeer::CON_CATEGORY); $c->addSelectColumn( ContentPeer::CON_CATEGORY );
$c->addSelectColumn(ContentPeer::CON_PARENT); $c->addSelectColumn( ContentPeer::CON_PARENT );
$c->addSelectColumn(ContentPeer::CON_ID); $c->addSelectColumn( ContentPeer::CON_ID );
$c->addSelectColumn(ContentPeer::CON_LANG); $c->addSelectColumn( ContentPeer::CON_LANG );
$c->add ( ContentPeer::CON_LANG, $lanId ); $c->add( ContentPeer::CON_LANG, $lanId );
$result = ContentPeer::doSelectRS ( $c ); $result = ContentPeer::doSelectRS( $c );
$result->setFetchmode(ResultSet::FETCHMODE_ASSOC); $result->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$result->next (); $result->next();
$row = $result->getRow (); $row = $result->getRow();
while ( is_array ( $row ) ) { while (is_array( $row )) {
$content = ContentPeer::retrieveByPK( $row['CON_CATEGORY'], $row['CON_PARENT'], $row['CON_ID'], $lanId); $content = ContentPeer::retrieveByPK( $row['CON_CATEGORY'], $row['CON_PARENT'], $row['CON_ID'], $lanId );
if( $content !== null ) if ($content !== null) {
$content->delete(); $content->delete();
}
$result->next (); $result->next();
$row = $result->getRow (); $row = $result->getRow();
} }
} catch ( Exception $e ) { } catch (Exception $e) {
throw ($e); throw ($e);
} }
} }
//Added by Enrique at Feb 9th,2011 //Added by Enrique at Feb 9th,2011
//Gets all Role Names by Role //Gets all Role Names by Role
function getAllContentsByRole($sys_lang=SYS_LANG){ public function getAllContentsByRole ($sys_lang = SYS_LANG)
if (!isset($sys_lang)) $sys_lang = 'en'; {
$oCriteria = new Criteria('workflow'); if (! isset( $sys_lang )) {
$sys_lang = 'en';
}
$oCriteria = new Criteria( 'workflow' );
$oCriteria->clearSelectColumns(); $oCriteria->clearSelectColumns();
$oCriteria->addSelectColumn(ContentPeer::CON_ID); $oCriteria->addSelectColumn( ContentPeer::CON_ID );
$oCriteria->addAsColumn('ROL_NAME', ContentPeer::CON_VALUE); $oCriteria->addAsColumn( 'ROL_NAME', ContentPeer::CON_VALUE );
//$oCriteria->addAsColumn('ROL_UID', ContentPeer::CON_ID); //$oCriteria->addAsColumn('ROL_UID', ContentPeer::CON_ID);
$oCriteria->add(ContentPeer::CON_CATEGORY,'ROL_NAME'); $oCriteria->add( ContentPeer::CON_CATEGORY, 'ROL_NAME' );
$oCriteria->add(ContentPeer::CON_LANG, $sys_lang); $oCriteria->add( ContentPeer::CON_LANG, $sys_lang );
$oDataset = ContentPeer::doSelectRS($oCriteria); $oDataset = ContentPeer::doSelectRS( $oCriteria );
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$aRoles = Array(); $aRoles = Array ();
while ($oDataset->next()){ while ($oDataset->next()) {
$xRow = $oDataset->getRow(); $xRow = $oDataset->getRow();
$aRoles[$xRow['CON_ID']] = $xRow['ROL_NAME']; $aRoles[$xRow['CON_ID']] = $xRow['ROL_NAME'];
} }
return $aRoles; return $aRoles;
} }
}
// Content
} // Content

View File

@@ -1,6 +1,7 @@
<?php <?php
/** /**
* ReportTable.php * ReportTable.php
*
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
* *
* ProcessMaker Open Source Edition * ProcessMaker Open Source Edition
@@ -27,7 +28,6 @@
require_once 'classes/model/Content.php'; require_once 'classes/model/Content.php';
require_once 'classes/model/om/BaseReportTable.php'; require_once 'classes/model/om/BaseReportTable.php';
/** /**
* Skeleton subclass for representing a row from the 'REPORT_TABLE' table. * Skeleton subclass for representing a row from the 'REPORT_TABLE' table.
* *
@@ -39,23 +39,27 @@ require_once 'classes/model/om/BaseReportTable.php';
* *
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
class ReportTable extends BaseReportTable { class ReportTable extends BaseReportTable
{
/** /**
* This value goes in the content table * This value goes in the content table
*
* @var string * @var string
*/ */
protected $rep_tab_title = ''; protected $rep_tab_title = '';
/** /**
* Get the rep_tab_title column value. * Get the rep_tab_title column value.
*
* @return string * @return string
*/ */
public function getRepTabTitle() { public function getRepTabTitle ()
if ( $this->getRepTabUid() == "" ) { {
throw ( new Exception( "Error in getRepTabTitle, the getRepTabUid() can't be blank") ); if ($this->getRepTabUid() == "") {
throw (new Exception( "Error in getRepTabTitle, the getRepTabUid() can't be blank" ));
} }
$lang = defined ( 'SYS_LANG' ) ? SYS_LANG : 'en'; $lang = defined( 'SYS_LANG' ) ? SYS_LANG : 'en';
$this->rep_tab_title = Content::load ( 'REP_TAB_TITLE', '', $this->getRepTabUid(), $lang ); $this->rep_tab_title = Content::load( 'REP_TAB_TITLE', '', $this->getRepTabUid(), $lang );
return $this->rep_tab_title; return $this->rep_tab_title;
} }
@@ -65,14 +69,14 @@ class ReportTable extends BaseReportTable {
* @param string $v new value * @param string $v new value
* @return void * @return void
*/ */
public function setRepTabTitle($v) public function setRepTabTitle ($v)
{ {
if ( $this->getRepTabUid() == "" ) { if ($this->getRepTabUid() == "") {
throw ( new Exception( "Error in setRepTabTitle, the setRepTabUid() can't be blank") ); throw (new Exception( "Error in setRepTabTitle, the setRepTabUid() can't be blank" ));
} }
$v=isset($v)?((string)$v):''; $v = isset( $v ) ? ((string) $v) : '';
$lang = defined ( 'SYS_LANG') ? SYS_LANG : 'en'; $lang = defined( 'SYS_LANG' ) ? SYS_LANG : 'en';
if ($this->rep_tab_title !== $v || $v==="") { if ($this->rep_tab_title !== $v || $v === "") {
$this->rep_tab_title = $v; $this->rep_tab_title = $v;
$res = Content::addContent( 'REP_TAB_TITLE', '', $this->getRepTabUid(), $lang, $this->rep_tab_title ); $res = Content::addContent( 'REP_TAB_TITLE', '', $this->getRepTabUid(), $lang, $this->rep_tab_title );
return $res; return $res;
@@ -80,152 +84,144 @@ class ReportTable extends BaseReportTable {
return 0; return 0;
} }
public function load($RepTabUid) public function load ($RepTabUid)
{ {
try { try {
$oRow = ReportTablePeer::retrieveByPK( $RepTabUid ); $oRow = ReportTablePeer::retrieveByPK( $RepTabUid );
if (!is_null($oRow)) if (! is_null( $oRow )) {
{ $aFields = $oRow->toArray( BasePeer::TYPE_FIELDNAME );
$aFields = $oRow->toArray(BasePeer::TYPE_FIELDNAME); $this->fromArray( $aFields, BasePeer::TYPE_FIELDNAME );
$this->fromArray($aFields, BasePeer::TYPE_FIELDNAME); $this->setNew( false );
$this->setNew(false); $this->setRepTabTitle( $aFields['REP_TAB_TITLE'] = $this->getRepTabTitle() );
$this->setRepTabTitle($aFields['REP_TAB_TITLE']=$this->getRepTabTitle());
return $aFields; return $aFields;
} } else {
else {
//throw( new Exception( "The row '$RepTabUid' in table ReportTable doesn't exist!" )); //throw( new Exception( "The row '$RepTabUid' in table ReportTable doesn't exist!" ));
return array(); return array ();
}
} catch (Exception $oError) {
throw ($oError);
} }
} }
catch (Exception $oError) {
throw($oError); public function create ($aData)
}
}
public function create($aData)
{
$con = Propel::getConnection(ReportTablePeer::DATABASE_NAME);
try
{ {
$con = Propel::getConnection( ReportTablePeer::DATABASE_NAME );
try {
$con->begin(); $con->begin();
if ( isset ( $aData['REP_TAB_UID'] ) && $aData['REP_TAB_UID']== '' ) if (isset( $aData['REP_TAB_UID'] ) && $aData['REP_TAB_UID'] == '') {
unset ( $aData['REP_TAB_UID'] ); unset( $aData['REP_TAB_UID'] );
if ( !isset ( $aData['REP_TAB_UID'] ) ) }
$this->setRepTabUid(G::generateUniqueID()); if (! isset( $aData['REP_TAB_UID'] )) {
else $this->setRepTabUid( G::generateUniqueID() );
$this->setRepTabUid($aData['REP_TAB_UID'] ); } else {
$this->setRepTabUid( $aData['REP_TAB_UID'] );
}
$this->setProUid($aData['PRO_UID']); $this->setProUid( $aData['PRO_UID'] );
$this->setRepTabName($aData['REP_TAB_NAME']); $this->setRepTabName( $aData['REP_TAB_NAME'] );
$this->setRepTabType($aData['REP_TAB_TYPE']); $this->setRepTabType( $aData['REP_TAB_TYPE'] );
if ( !isset ( $aData['REP_TAB_GRID'] ) ) if (! isset( $aData['REP_TAB_GRID'] )) {
$this->setRepTabGrid(""); $this->setRepTabGrid( "" );
else } else {
$this->setRepTabGrid( $aData['REP_TAB_GRID'] ); $this->setRepTabGrid( $aData['REP_TAB_GRID'] );
if ( !isset ( $aData['REP_TAB_CONNECTION'] ) ) }
$this->setRepTabConnection("report"); if (! isset( $aData['REP_TAB_CONNECTION'] )) {
else $this->setRepTabConnection( "report" );
} else {
$this->setRepTabConnection( $aData['REP_TAB_CONNECTION'] ); $this->setRepTabConnection( $aData['REP_TAB_CONNECTION'] );
$this->setRepTabCreateDate(date('Y-m-d H:i:s')); }
$this->setRepTabStatus('ACTIVE'); $this->setRepTabCreateDate( date( 'Y-m-d H:i:s' ) );
$this->setRepTabStatus( 'ACTIVE' );
if($this->validate()) if ($this->validate()) {
{ if (! isset( $aData['REP_TAB_TITLE'] )) {
if ( !isset ( $aData['REP_TAB_TITLE'] ) ) $this->setRepTabTitle( "" );
$this->setRepTabTitle(""); } else {
else
$this->setRepTabTitle( $aData['REP_TAB_TITLE'] ); $this->setRepTabTitle( $aData['REP_TAB_TITLE'] );
}
$result=$this->save(); $result = $this->save();
$con->commit(); $con->commit();
return $result; return $result;
} } else {
else
{
$con->rollback(); $con->rollback();
throw(new Exception("Failed Validation in class ".get_class($this).".")); throw (new Exception( "Failed Validation in class " . get_class( $this ) . "." ));
} }
} } catch (Exception $e) {
catch(Exception $e)
{
$con->rollback(); $con->rollback();
throw($e); throw ($e);
} }
} }
public function update($fields)
{
$con = Propel::getConnection(ReportTablePeer::DATABASE_NAME);
try
{
$con->begin();
$this->load($fields['REP_TAB_UID']);
$this->fromArray($fields,BasePeer::TYPE_FIELDNAME);
$sDataBase = 'database_' . strtolower(DB_ADAPTER); public function update ($fields)
if(G::LoadSystemExist($sDataBase)){ {
G::LoadSystem($sDataBase); $con = Propel::getConnection( ReportTablePeer::DATABASE_NAME );
try {
$con->begin();
$this->load( $fields['REP_TAB_UID'] );
$this->fromArray( $fields, BasePeer::TYPE_FIELDNAME );
$sDataBase = 'database_' . strtolower( DB_ADAPTER );
if (G::LoadSystemExist( $sDataBase )) {
G::LoadSystem( $sDataBase );
$oDataBase = new database(); $oDataBase = new database();
$oValidate = $oDataBase->getValidate($this->validate()); $oValidate = $oDataBase->getValidate( $this->validate() );
} else { } else {
$oValidate = $this->validate(); $oValidate = $this->validate();
} }
// if($this->validate()) // if($this->validate())
if($oValidate) if ($oValidate) {
{ $contentResult = 0;
$contentResult=0; if (array_key_exists( "REP_TAB_TITLE", $fields )) {
if (array_key_exists("REP_TAB_TITLE", $fields)) $contentResult+=$this->setRepTabTitle($fields["REP_TAB_TITLE"]); $contentResult += $this->setRepTabTitle( $fields["REP_TAB_TITLE"] );
$result=$this->save(); }
$result=($result==0)?($contentResult>0?1:0):$result; $result = $this->save();
$result = ($result == 0) ? ($contentResult > 0 ? 1 : 0) : $result;
$con->commit(); $con->commit();
return $result; return $result;
} } else {
else
{
$con->rollback(); $con->rollback();
$validationE=new Exception("Failed Validation in class ".get_class($this)."."); $validationE = new Exception( "Failed Validation in class " . get_class( $this ) . "." );
$validationE->aValidationFailures = $this->getValidationFailures(); $validationE->aValidationFailures = $this->getValidationFailures();
throw($validationE); throw ($validationE);
} }
} } catch (Exception $e) {
catch(Exception $e)
{
$con->rollback(); $con->rollback();
throw($e); throw ($e);
} }
} }
public function remove($RepTabUid)
{ public function remove ($RepTabUid)
$con = Propel::getConnection(ReportTablePeer::DATABASE_NAME);
try
{ {
$con = Propel::getConnection( ReportTablePeer::DATABASE_NAME );
try {
$con->begin(); $con->begin();
$oRepTab = ReportTablePeer::retrieveByPK( $RepTabUid ); $oRepTab = ReportTablePeer::retrieveByPK( $RepTabUid );
if (!is_null($oRepTab)) { if (! is_null( $oRepTab )) {
Content::removeContent( 'REP_TAB_TITLE', '', $this->getRepTabUid()); Content::removeContent( 'REP_TAB_TITLE', '', $this->getRepTabUid() );
$result = $oRepTab->delete(); $result = $oRepTab->delete();
$con->commit(); $con->commit();
} }
return $result; return $result;
} } catch (Exception $e) {
catch(Exception $e)
{
$con->rollback(); $con->rollback();
throw($e); throw ($e);
} }
} }
function reportTableExists ( $RepTabUid ) { public function reportTableExists ($RepTabUid)
$con = Propel::getConnection(ReportTablePeer::DATABASE_NAME); {
$con = Propel::getConnection( ReportTablePeer::DATABASE_NAME );
try { try {
$oRepTabUid = ReportTablePeer::retrieveByPk( $RepTabUid ); $oRepTabUid = ReportTablePeer::retrieveByPk( $RepTabUid );
if (is_object($oRepTabUid) && get_class ($oRepTabUid) == 'ReportTable' ) { if (is_object( $oRepTabUid ) && get_class( $oRepTabUid ) == 'ReportTable') {
return true; return true;
} } else {
else {
return false; return false;
} }
} } catch (Exception $oError) {
catch (Exception $oError) { throw ($oError);
throw($oError);
} }
} }
} // ReportTable }
// ReportTable

View File

@@ -1,6 +1,7 @@
<?php <?php
/** /**
* Route.php * Route.php
*
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
* *
* ProcessMaker Open Source Edition * ProcessMaker Open Source Edition
@@ -38,162 +39,161 @@ require_once 'classes/model/Content.php';
* *
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
class Route extends BaseRoute { class Route extends BaseRoute
{
/* /*
* Load the application document registry * Load the application document registry
* @param string $sRouUid * @param string $sRouUid
* @return variant * @return variant
*/ */
public function load($sRouUid) public function load ($sRouUid)
{ {
try { try {
$oRoute = RoutePeer::retrieveByPK($sRouUid); $oRoute = RoutePeer::retrieveByPK( $sRouUid );
if (!is_null($oRoute)) if (! is_null( $oRoute )) {
{ $aFields = $oRoute->toArray( BasePeer::TYPE_FIELDNAME );
$aFields = $oRoute->toArray(BasePeer::TYPE_FIELDNAME); $this->fromArray( $aFields, BasePeer::TYPE_FIELDNAME );
$this->fromArray($aFields, BasePeer::TYPE_FIELDNAME);
return $aFields; return $aFields;
} else {
throw (new Exception( 'This row doesn\'t exist!' ));
} }
else { } catch (Exception $oError) {
throw(new Exception('This row doesn\'t exist!')); throw ($oError);
}
}
catch (Exception $oError) {
throw($oError);
} }
} }
/** /**
* Create the application document registry * Create the application document registry
*
* @param array $aData * @param array $aData
* @return string * @return string
**/ *
public function create($aData) */
public function create ($aData)
{ {
$oConnection = Propel::getConnection(RoutePeer::DATABASE_NAME); $oConnection = Propel::getConnection( RoutePeer::DATABASE_NAME );
try { try {
$sRouteUID = G::generateUniqueID(); $sRouteUID = G::generateUniqueID();
$aData['ROU_UID'] = $sRouteUID; $aData['ROU_UID'] = $sRouteUID;
$oRoute = new Route(); $oRoute = new Route();
// validating default values // validating default values
$aData['ROU_TO_LAST_USER'] = $this->validateValue(isset($aData['ROU_TO_LAST_USER']) ? $aData['ROU_TO_LAST_USER'] : '', array('TRUE', 'FALSE'), 'FALSE'); $aData['ROU_TO_LAST_USER'] = $this->validateValue( isset( $aData['ROU_TO_LAST_USER'] ) ? $aData['ROU_TO_LAST_USER'] : '', array ('TRUE','FALSE'
$aData['ROU_OPTIONAL'] = $this->validateValue(isset($aData['ROU_OPTIONAL']) ? $aData['ROU_OPTIONAL'] : '', array('TRUE', 'FALSE'), 'FALSE'); ), 'FALSE' );
$aData['ROU_SEND_EMAIL'] = $this->validateValue(isset($aData['ROU_SEND_EMAIL']) ? $aData['ROU_SEND_EMAIL']: '', array('TRUE', 'FALSE'), 'TRUE'); $aData['ROU_OPTIONAL'] = $this->validateValue( isset( $aData['ROU_OPTIONAL'] ) ? $aData['ROU_OPTIONAL'] : '', array ('TRUE','FALSE'
), 'FALSE' );
$aData['ROU_SEND_EMAIL'] = $this->validateValue( isset( $aData['ROU_SEND_EMAIL'] ) ? $aData['ROU_SEND_EMAIL'] : '', array ('TRUE','FALSE'
), 'TRUE' );
$oRoute->fromArray($aData, BasePeer::TYPE_FIELDNAME); $oRoute->fromArray( $aData, BasePeer::TYPE_FIELDNAME );
if ($oRoute->validate()) { if ($oRoute->validate()) {
$oConnection->begin(); $oConnection->begin();
$iResult = $oRoute->save(); $iResult = $oRoute->save();
$oConnection->commit(); $oConnection->commit();
return $sRouteUID; return $sRouteUID;
} } else {
else {
$sMessage = ''; $sMessage = '';
$aValidationFailures = $oRoute->getValidationFailures(); $aValidationFailures = $oRoute->getValidationFailures();
foreach($aValidationFailures as $oValidationFailure) { foreach ($aValidationFailures as $oValidationFailure) {
$sMessage .= $oValidationFailure->getMessage() . '<br />'; $sMessage .= $oValidationFailure->getMessage() . '<br />';
} }
throw(new Exception('The registry cannot be created!<br />'.$sMessage)); throw (new Exception( 'The registry cannot be created!<br />' . $sMessage ));
} }
} } catch (Exception $oError) {
catch (Exception $oError) {
$oConnection->rollback(); $oConnection->rollback();
throw($oError); throw ($oError);
} }
} }
/** /**
* Update the application document registry * Update the application document registry
*
* @param array $aData * @param array $aData
* @return string * @return string
**/ *
public function update($aData) */
public function update ($aData)
{ {
$oConnection = Propel::getConnection(RoutePeer::DATABASE_NAME); $oConnection = Propel::getConnection( RoutePeer::DATABASE_NAME );
try { try {
$oRoute = RoutePeer::retrieveByPK($aData['ROU_UID']); $oRoute = RoutePeer::retrieveByPK( $aData['ROU_UID'] );
if (!is_null($oRoute)) if (! is_null( $oRoute )) {
{
// validating default values // validating default values
if (isset($aData['ROU_TO_LAST_USER'])) { if (isset( $aData['ROU_TO_LAST_USER'] )) {
$aData['ROU_TO_LAST_USER'] = $this->validateValue($aData['ROU_TO_LAST_USER'], array('TRUE', 'FALSE'), 'FALSE'); $aData['ROU_TO_LAST_USER'] = $this->validateValue( $aData['ROU_TO_LAST_USER'], array ('TRUE','FALSE'
), 'FALSE' );
} }
if (isset($aData['ROU_OPTIONAL'])) { if (isset( $aData['ROU_OPTIONAL'] )) {
$aData['ROU_OPTIONAL'] = $this->validateValue($aData['ROU_OPTIONAL'], array('TRUE', 'FALSE'), 'FALSE'); $aData['ROU_OPTIONAL'] = $this->validateValue( $aData['ROU_OPTIONAL'], array ('TRUE','FALSE'
), 'FALSE' );
} }
if (isset($aData['ROU_SEND_EMAIL'])) { if (isset( $aData['ROU_SEND_EMAIL'] )) {
$aData['ROU_SEND_EMAIL'] = $this->validateValue($aData['ROU_SEND_EMAIL'], array('TRUE', 'FALSE'), 'TRUE'); $aData['ROU_SEND_EMAIL'] = $this->validateValue( $aData['ROU_SEND_EMAIL'], array ('TRUE','FALSE'
), 'TRUE' );
} }
$oRoute->fromArray($aData, BasePeer::TYPE_FIELDNAME); $oRoute->fromArray( $aData, BasePeer::TYPE_FIELDNAME );
if ($oRoute->validate()) { if ($oRoute->validate()) {
$oConnection->begin(); $oConnection->begin();
$iResult = $oRoute->save(); $iResult = $oRoute->save();
$oConnection->commit(); $oConnection->commit();
return $iResult; return $iResult;
} } else {
else {
$sMessage = ''; $sMessage = '';
$aValidationFailures = $oRoute->getValidationFailures(); $aValidationFailures = $oRoute->getValidationFailures();
foreach($aValidationFailures as $oValidationFailure) { foreach ($aValidationFailures as $oValidationFailure) {
$sMessage .= $oValidationFailure->getMessage() . '<br />'; $sMessage .= $oValidationFailure->getMessage() . '<br />';
} }
throw(new Exception('The ROUTE tables cannot be updated!<br />'.$sMessage)); throw (new Exception( 'The ROUTE tables cannot be updated!<br />' . $sMessage ));
} }
} else {
throw (new Exception( "The row " . $aData['ROU_UID'] . " doesn't exist!" ));
} }
else { } catch (Exception $oError) {
throw(new Exception( "The row " . $aData['ROU_UID'] . " doesn't exist!" ));
}
}
catch (Exception $oError) {
$oConnection->rollback(); $oConnection->rollback();
throw($oError); throw ($oError);
} }
} }
/** /**
* Remove the application document registry * Remove the application document registry
*
* @param array $aData * @param array $aData
* @return string * @return string
**/ *
public function remove($sRouUid) */
public function remove ($sRouUid)
{ {
$oConnection = Propel::getConnection(RoutePeer::DATABASE_NAME); $oConnection = Propel::getConnection( RoutePeer::DATABASE_NAME );
try { try {
$oRoute = RoutePeer::retrieveByPK($sRouUid); $oRoute = RoutePeer::retrieveByPK( $sRouUid );
if (!is_null($oRoute)) if (! is_null( $oRoute )) {
{
$oConnection->begin(); $oConnection->begin();
$iResult = $oRoute->delete(); $iResult = $oRoute->delete();
$oConnection->commit(); $oConnection->commit();
return $iResult; return $iResult;
} else {
throw (new Exception( 'This row doesn\'t exist!' ));
} }
else { } catch (Exception $oError) {
throw(new Exception('This row doesn\'t exist!'));
}
}
catch (Exception $oError) {
$oConnection->rollback(); $oConnection->rollback();
throw($oError); throw ($oError);
} }
} }
function routeExists ( $sRouUid ) { public function routeExists ($sRouUid)
$con = Propel::getConnection(RoutePeer::DATABASE_NAME); {
$con = Propel::getConnection( RoutePeer::DATABASE_NAME );
try { try {
$oRouUid = RoutePeer::retrieveByPk( $sRouUid ); $oRouUid = RoutePeer::retrieveByPk( $sRouUid );
if (is_object($oRouUid) && get_class ($oRouUid) == 'Route' ) { if (is_object( $oRouUid ) && get_class( $oRouUid ) == 'Route') {
return true; return true;
} } else {
else {
return false; return false;
} }
} } catch (Exception $oError) {
catch (Exception $oError) { throw ($oError);
throw($oError);
} }
} }
@@ -205,12 +205,13 @@ class Route extends BaseRoute {
* @param $default string default value, if the tested value is not valid the default value is returned * @param $default string default value, if the tested value is not valid the default value is returned
* @return the tested and accepted value * @return the tested and accepted value
*/ */
function validateValue($value, $validValues, $default) public function validateValue ($value, $validValues, $default)
{ {
if (!in_array($value, $validValues)) { if (! in_array( $value, $validValues )) {
$value = $default; $value = $default;
} }
return $value; return $value;
} }
} // Route }
// Route

View File

@@ -1,13 +1,13 @@
<?php <?php
/** /**
* Stage.php * Stage.php
*
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
require_once 'classes/model/Content.php'; require_once 'classes/model/Content.php';
require_once 'classes/model/om/BaseStage.php'; require_once 'classes/model/om/BaseStage.php';
/** /**
* Skeleton subclass for representing a row from the 'STAGE' table. * Skeleton subclass for representing a row from the 'STAGE' table.
* *
@@ -19,24 +19,27 @@ require_once 'classes/model/om/BaseStage.php';
* *
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
class Stage extends BaseStage { class Stage extends BaseStage
{
/** /**
* This value goes in the content table * This value goes in the content table
*
* @var string * @var string
*/ */
protected $stg_title = ''; protected $stg_title = '';
/** /**
* Get the stg_title column value. * Get the stg_title column value.
*
* @return string * @return string
*/ */
public function getStgTitle() { public function getStgTitle ()
if ( $this->getStgUid() == "" ) { {
throw ( new Exception( "Error in getStgTitle, the getStgUid() can't be blank") ); if ($this->getStgUid() == "") {
throw (new Exception( "Error in getStgTitle, the getStgUid() can't be blank" ));
} }
$lang = defined ( 'SYS_LANG' ) ? SYS_LANG : 'en'; $lang = defined( 'SYS_LANG' ) ? SYS_LANG : 'en';
$this->stg_title = Content::load ( 'STG_TITLE', '', $this->getStgUid(), $lang ); $this->stg_title = Content::load( 'STG_TITLE', '', $this->getStgUid(), $lang );
return $this->stg_title; return $this->stg_title;
} }
@@ -46,14 +49,14 @@ class Stage extends BaseStage {
* @param string $v new value * @param string $v new value
* @return void * @return void
*/ */
public function setStgTitle($v) public function setStgTitle ($v)
{ {
if ( $this->getStgUid() == "" ) { if ($this->getStgUid() == "") {
throw ( new Exception( "Error in setStgTitle, the setStgUid() can't be blank") ); throw (new Exception( "Error in setStgTitle, the setStgUid() can't be blank" ));
} }
$v=isset($v)?((string)$v):''; $v = isset( $v ) ? ((string) $v) : '';
$lang = defined ( 'SYS_LANG') ? SYS_LANG : 'en'; $lang = defined( 'SYS_LANG' ) ? SYS_LANG : 'en';
if ($this->stg_title !== $v || $v==="") { if ($this->stg_title !== $v || $v === "") {
$this->stg_title = $v; $this->stg_title = $v;
$res = Content::addContent( 'STG_TITLE', '', $this->getStgUid(), $lang, $this->stg_title ); $res = Content::addContent( 'STG_TITLE', '', $this->getStgUid(), $lang, $this->stg_title );
return $res; return $res;
@@ -61,140 +64,130 @@ class Stage extends BaseStage {
return 0; return 0;
} }
public function load($StgUid) public function load ($StgUid)
{ {
try { try {
$oRow = StagePeer::retrieveByPK( $StgUid ); $oRow = StagePeer::retrieveByPK( $StgUid );
if (!is_null($oRow)) if (! is_null( $oRow )) {
{ $aFields = $oRow->toArray( BasePeer::TYPE_FIELDNAME );
$aFields = $oRow->toArray(BasePeer::TYPE_FIELDNAME); $this->fromArray( $aFields, BasePeer::TYPE_FIELDNAME );
$this->fromArray($aFields, BasePeer::TYPE_FIELDNAME); $this->setNew( false );
$this->setNew(false); $this->setStgTitle( $aFields['STG_TITLE'] = $this->getStgTitle() );
$this->setStgTitle($aFields['STG_TITLE'] = $this->getStgTitle());
return $aFields; return $aFields;
} else {
throw (new Exception( "The row '$StgUid' in table Stage doesn't exist!" ));
} }
else { } catch (Exception $oError) {
throw( new Exception( "The row '$StgUid' in table Stage doesn't exist!" )); throw ($oError);
}
}
catch (Exception $oError) {
throw($oError);
} }
} }
public function create($aData) { public function create ($aData)
$oConnection = Propel::getConnection(StagePeer::DATABASE_NAME); {
$oConnection = Propel::getConnection( StagePeer::DATABASE_NAME );
try { try {
if ( isset ( $aData['STG_UID'] ) && $aData['STG_UID']== '' ) if (isset( $aData['STG_UID'] ) && $aData['STG_UID'] == '') {
unset ( $aData['STG_UID'] ); unset( $aData['STG_UID'] );
if ( !isset ( $aData['STG_UID'] ) ) }
if (! isset( $aData['STG_UID'] )) {
$aData['STG_UID'] = G::generateUniqueID(); $aData['STG_UID'] = G::generateUniqueID();
}
$oStage = new Stage(); $oStage = new Stage();
$oStage->fromArray($aData, BasePeer::TYPE_FIELDNAME); $oStage->fromArray( $aData, BasePeer::TYPE_FIELDNAME );
$oStage->setStgTitle($aData['STG_TITLE']); $oStage->setStgTitle( $aData['STG_TITLE'] );
if ($oStage->validate()) { if ($oStage->validate()) {
$oConnection->begin(); $oConnection->begin();
$iResult = $oStage->save(); $iResult = $oStage->save();
$oConnection->commit(); $oConnection->commit();
return $aData['STG_UID']; return $aData['STG_UID'];
} } else {
else {
$sMessage = ''; $sMessage = '';
$aValidationFailures = $oStage->getValidationFailures(); $aValidationFailures = $oStage->getValidationFailures();
foreach($aValidationFailures as $oValidationFailure) { foreach ($aValidationFailures as $oValidationFailure) {
$sMessage .= $oValidationFailure->getMessage() . '<br />'; $sMessage .= $oValidationFailure->getMessage() . '<br />';
} }
throw(new Exception('The registry cannot be created!<br />'.$sMessage)); throw (new Exception( 'The registry cannot be created!<br />' . $sMessage ));
} }
} } catch (Exception $oError) {
catch (Exception $oError) {
$oConnection->rollback(); $oConnection->rollback();
throw($oError); throw ($oError);
} }
} }
public function update($fields) public function update ($fields)
{
$con = Propel::getConnection(StagePeer::DATABASE_NAME);
try
{ {
$con = Propel::getConnection( StagePeer::DATABASE_NAME );
try {
$con->begin(); $con->begin();
$this->load($fields['STG_UID']); $this->load( $fields['STG_UID'] );
$this->fromArray($fields, BasePeer::TYPE_FIELDNAME); $this->fromArray( $fields, BasePeer::TYPE_FIELDNAME );
if($this->validate()) if ($this->validate()) {
{ $contentResult = 0;
$contentResult=0; if (array_key_exists( "STG_TITLE", $fields )) {
if (array_key_exists("STG_TITLE", $fields)) $contentResult+=$this->setStgTitle($fields["STG_TITLE"]); $contentResult += $this->setStgTitle( $fields["STG_TITLE"] );
$result=$this->save(); }
$result=($result==0)?($contentResult>0?1:0):$result; $result = $this->save();
$result = ($result == 0) ? ($contentResult > 0 ? 1 : 0) : $result;
$con->commit(); $con->commit();
return $result; return $result;
} } else {
else
{
$con->rollback(); $con->rollback();
$validationE=new Exception("Failed Validation in class ".get_class($this)."."); $validationE = new Exception( "Failed Validation in class " . get_class( $this ) . "." );
$validationE->aValidationFailures = $this->getValidationFailures(); $validationE->aValidationFailures = $this->getValidationFailures();
throw($validationE); throw ($validationE);
} }
} } catch (Exception $e) {
catch(Exception $e)
{
$con->rollback(); $con->rollback();
throw($e); throw ($e);
} }
} }
public function remove($StgUid) public function remove ($StgUid)
{
$con = Propel::getConnection(StagePeer::DATABASE_NAME);
try
{ {
$con = Propel::getConnection( StagePeer::DATABASE_NAME );
try {
$con->begin(); $con->begin();
$oStage = StagePeer::retrieveByPK( $StgUid ); $oStage = StagePeer::retrieveByPK( $StgUid );
if (!is_null($oStage)) { if (! is_null( $oStage )) {
Content::removeContent( 'STG_TITLE', '', $this->getStgUid()); Content::removeContent( 'STG_TITLE', '', $this->getStgUid() );
$result = $oStage->delete(); $result = $oStage->delete();
$con->commit(); $con->commit();
} }
return $result; return $result;
} } catch (Exception $e) {
catch(Exception $e)
{
$con->rollback(); $con->rollback();
throw($e); throw ($e);
} }
} }
function reorderPositions($sProcessUID, $iIndex) { public function reorderPositions ($sProcessUID, $iIndex)
{
try { try {
$oCriteria = new Criteria('workflow'); $oCriteria = new Criteria( 'workflow' );
$oCriteria->add(StagePeer::PRO_UID, $sProcessUID); $oCriteria->add( StagePeer::PRO_UID, $sProcessUID );
$oCriteria->add(StagePeer::STG_INDEX, $iIndex, '>'); $oCriteria->add( StagePeer::STG_INDEX, $iIndex, '>' );
$oDataset = StagePeer::doSelectRS($oCriteria); $oDataset = StagePeer::doSelectRS( $oCriteria );
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$oDataset->next(); $oDataset->next();
while ($aRow = $oDataset->getRow()) { while ($aRow = $oDataset->getRow()) {
$this->update(array('STG_UID' => $aRow['STG_UID'], $this->update( array ('STG_UID' => $aRow['STG_UID'],'PRO_UID' => $aRow['PRO_UID'],'STG_POSX' => $aRow['STG_POSX'],'STG_POSY' => $aRow['STG_POSY'],'STG_INDEX' => $aRow['STG_INDEX'] - 1
'PRO_UID' => $aRow['PRO_UID'], ) );
'STG_POSX' => $aRow['STG_POSX'],
'STG_POSY' => $aRow['STG_POSY'],
'STG_INDEX' => $aRow['STG_INDEX'] - 1));
$oDataset->next(); $oDataset->next();
} }
} } catch (Exception $oException) {
catch (Exception $oException) {
throw $Exception; throw $Exception;
} }
} }
function Exists ( $sUid ) { public function Exists ($sUid)
{
try { try {
$oObj = StagePeer::retrieveByPk($sUid); $oObj = StagePeer::retrieveByPk( $sUid );
return (is_object($oObj) && get_class($oObj) == 'Stage'); return (is_object( $oObj ) && get_class( $oObj ) == 'Stage');
} } catch (Exception $oError) {
catch (Exception $oError) { throw ($oError);
throw($oError);
} }
} }
} // Stage }
// Stage

View File

@@ -1,12 +1,12 @@
<?php <?php
/** /**
* StepSupervisor.php * StepSupervisor.php
*
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
require_once 'classes/model/om/BaseStepSupervisor.php'; require_once 'classes/model/om/BaseStepSupervisor.php';
/** /**
* Skeleton subclass for representing a row from the 'STEP_SUPERVISOR' table. * Skeleton subclass for representing a row from the 'STEP_SUPERVISOR' table.
* *
@@ -18,213 +18,212 @@ require_once 'classes/model/om/BaseStepSupervisor.php';
* *
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
class StepSupervisor extends BaseStepSupervisor { class StepSupervisor extends BaseStepSupervisor
{
public function load($Uid) public function load ($Uid)
{ {
try { try {
$oRow = StepSupervisorPeer::retrieveByPK( $Uid ); $oRow = StepSupervisorPeer::retrieveByPK( $Uid );
if (!is_null($oRow)) if (! is_null( $oRow )) {
{ $aFields = $oRow->toArray( BasePeer::TYPE_FIELDNAME );
$aFields = $oRow->toArray(BasePeer::TYPE_FIELDNAME); $this->fromArray( $aFields, BasePeer::TYPE_FIELDNAME );
$this->fromArray($aFields,BasePeer::TYPE_FIELDNAME); $this->setNew( false );
$this->setNew(false);
return $aFields; return $aFields;
} else {
throw (new Exception( "The row '$Uid' in table StepSupervisor doesn't exist!" ));
} }
else { } catch (Exception $oError) {
throw( new Exception( "The row '$Uid' in table StepSupervisor doesn't exist!" )); throw ($oError);
}
}
catch (Exception $oError) {
throw($oError);
} }
} }
function Exists ( $Uid ) { public function Exists ($Uid)
{
try { try {
$oPro = StepSupervisorPeer::retrieveByPk( $Uid ); $oPro = StepSupervisorPeer::retrieveByPk( $Uid );
if (is_object($oPro) && get_class ($oPro) == 'StepSupervisor' ) { if (is_object( $oPro ) && get_class( $oPro ) == 'StepSupervisor') {
return true; return true;
} } else {
else {
return false; return false;
} }
} } catch (Exception $oError) {
catch (Exception $oError) { throw ($oError);
throw($oError);
} }
} }
/** /**
* Create the step supervisor registry * Create the step supervisor registry
*
* @param array $aData * @param array $aData
* @return boolean * @return boolean
**/ *
public function create($aData) */
public function create ($aData)
{ {
$oConnection = Propel::getConnection(StepSupervisorPeer::DATABASE_NAME); $oConnection = Propel::getConnection( StepSupervisorPeer::DATABASE_NAME );
try { try {
if ( isset ( $aData['STEP_UID'] ) && $aData['STEP_UID']== '' ) if (isset( $aData['STEP_UID'] ) && $aData['STEP_UID'] == '') {
unset ( $aData['STEP_UID'] ); unset( $aData['STEP_UID'] );
if ( !isset ( $aData['STEP_UID'] ) ) }
if (! isset( $aData['STEP_UID'] )) {
$aData['STEP_UID'] = G::generateUniqueID(); $aData['STEP_UID'] = G::generateUniqueID();
}
$oStepSupervisor = new StepSupervisor(); $oStepSupervisor = new StepSupervisor();
$oStepSupervisor->fromArray($aData, BasePeer::TYPE_FIELDNAME); $oStepSupervisor->fromArray( $aData, BasePeer::TYPE_FIELDNAME );
if ($oStepSupervisor->validate()) { if ($oStepSupervisor->validate()) {
$oConnection->begin(); $oConnection->begin();
$iResult = $oStepSupervisor->save(); $iResult = $oStepSupervisor->save();
$oConnection->commit(); $oConnection->commit();
return true; return true;
} } else {
else {
$sMessage = ''; $sMessage = '';
$aValidationFailures = $oStepSupervisor->getValidationFailures(); $aValidationFailures = $oStepSupervisor->getValidationFailures();
foreach($aValidationFailures as $oValidationFailure) { foreach ($aValidationFailures as $oValidationFailure) {
$sMessage .= $oValidationFailure->getMessage() . '<br />'; $sMessage .= $oValidationFailure->getMessage() . '<br />';
} }
throw(new Exception('The registry cannot be created!<br />'.$sMessage)); throw (new Exception( 'The registry cannot be created!<br />' . $sMessage ));
} }
} } catch (Exception $oError) {
catch (Exception $oError) {
$oConnection->rollback(); $oConnection->rollback();
throw($oError); throw ($oError);
} }
} }
/** /**
* Update the step supervisor registry * Update the step supervisor registry
*
* @param array $aData * @param array $aData
* @return integer * @return integer
**/ *
public function update($aData) */
public function update ($aData)
{ {
$oConnection = Propel::getConnection(StepSupervisorPeer::DATABASE_NAME); $oConnection = Propel::getConnection( StepSupervisorPeer::DATABASE_NAME );
try { try {
$oStepSupervisor = StepSupervisorPeer::retrieveByPK($aData['STEP_UID']); $oStepSupervisor = StepSupervisorPeer::retrieveByPK( $aData['STEP_UID'] );
if (!is_null($oStepSupervisor)) if (! is_null( $oStepSupervisor )) {
{ $oStepSupervisor->fromArray( $aData, BasePeer::TYPE_FIELDNAME );
$oStepSupervisor->fromArray($aData, BasePeer::TYPE_FIELDNAME);
if ($oStepSupervisor->validate()) { if ($oStepSupervisor->validate()) {
$oConnection->begin(); $oConnection->begin();
$iResult = $oStepSupervisor->save(); $iResult = $oStepSupervisor->save();
$oConnection->commit(); $oConnection->commit();
return $iResult; return $iResult;
} } else {
else {
$sMessage = ''; $sMessage = '';
$aValidationFailures = $oStepSupervisor->getValidationFailures(); $aValidationFailures = $oStepSupervisor->getValidationFailures();
foreach($aValidationFailures as $oValidationFailure) { foreach ($aValidationFailures as $oValidationFailure) {
$sMessage .= $oValidationFailure->getMessage() . '<br />'; $sMessage .= $oValidationFailure->getMessage() . '<br />';
} }
throw(new Exception('The registry cannot be updated!<br />'.$sMessage)); throw (new Exception( 'The registry cannot be updated!<br />' . $sMessage ));
} }
} else {
throw (new Exception( 'This row doesn\'t exist!' ));
} }
else { } catch (Exception $oError) {
throw(new Exception('This row doesn\'t exist!'));
}
}
catch (Exception $oError) {
$oConnection->rollback(); $oConnection->rollback();
throw($oError); throw ($oError);
} }
} }
/** /**
* Remove the step supervisor registry * Remove the step supervisor registry
*
* @param string $sStepUID * @param string $sStepUID
* @return integer * @return integer
**/ *
public function remove($sStepUID) */
public function remove ($sStepUID)
{ {
$oConnection = Propel::getConnection(StepSupervisorPeer::DATABASE_NAME); $oConnection = Propel::getConnection( StepSupervisorPeer::DATABASE_NAME );
try { try {
$oConnection->begin(); $oConnection->begin();
$this->setStepUid($sStepUID); $this->setStepUid( $sStepUID );
$iResult = $this->delete(); $iResult = $this->delete();
$oConnection->commit(); $oConnection->commit();
return $iResult; return $iResult;
} } catch (Exception $oError) {
catch (Exception $oError) {
$oConnection->rollback(); $oConnection->rollback();
throw($oError); throw ($oError);
} }
} }
/** /**
* Get the next position for a atep * Get the next position for a atep
*
* @param string $sProcessUID * @param string $sProcessUID
* @return integer * @return integer
**/ *
function getNextPosition($sProcessUID, $sType) { */
public function getNextPosition ($sProcessUID, $sType)
{
try { try {
$oCriteria = new Criteria('workflow'); $oCriteria = new Criteria( 'workflow' );
$oCriteria->addSelectColumn('(COUNT(*) + 1) AS POSITION'); $oCriteria->addSelectColumn( '(COUNT(*) + 1) AS POSITION' );
$oCriteria->add(StepSupervisorPeer::PRO_UID, $sProcessUID); $oCriteria->add( StepSupervisorPeer::PRO_UID, $sProcessUID );
$oCriteria->add(StepSupervisorPeer::STEP_TYPE_OBJ, $sType); $oCriteria->add( StepSupervisorPeer::STEP_TYPE_OBJ, $sType );
$oDataset = StepSupervisorPeer::doSelectRS($oCriteria); $oDataset = StepSupervisorPeer::doSelectRS( $oCriteria );
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$oDataset->next(); $oDataset->next();
$aRow = $oDataset->getRow(); $aRow = $oDataset->getRow();
return (int)$aRow['POSITION']; return (int) $aRow['POSITION'];
} } catch (Exception $oException) {
catch (Exception $oException) {
throw $Exception; throw $Exception;
} }
} }
/** /**
* Reorder the steps positions * Reorder the steps positions
*
* @param string $sProcessUID * @param string $sProcessUID
* @param string $iPosition * @param string $iPosition
**/ *
function reorderPositions($sProcessUID, $iPosition, $sType) { */
public function reorderPositions ($sProcessUID, $iPosition, $sType)
{
try { try {
$oCriteria = new Criteria('workflow'); $oCriteria = new Criteria( 'workflow' );
$oCriteria->add(StepSupervisorPeer::PRO_UID, $sProcessUID); $oCriteria->add( StepSupervisorPeer::PRO_UID, $sProcessUID );
$oCriteria->add(StepSupervisorPeer::STEP_TYPE_OBJ, $sType); $oCriteria->add( StepSupervisorPeer::STEP_TYPE_OBJ, $sType );
$oCriteria->add(StepSupervisorPeer::STEP_POSITION, $iPosition, '>'); $oCriteria->add( StepSupervisorPeer::STEP_POSITION, $iPosition, '>' );
$oDataset = StepSupervisorPeer::doSelectRS($oCriteria); $oDataset = StepSupervisorPeer::doSelectRS( $oCriteria );
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$oDataset->next();var_dump(StepSupervisorPeer::doCount($oCriteria)); $oDataset->next();
while ($aRow = $oDataset->getRow()) {var_dump($aRow);echo "\n"; var_dump( StepSupervisorPeer::doCount( $oCriteria ) );
$this->update(array('STEP_UID' => $aRow['STEP_UID'], while ($aRow = $oDataset->getRow()) {
'PRO_UID' => $aRow['PRO_UID'], var_dump( $aRow );
'STEP_TYPE_OBJ' => $aRow['STEP_TYPE_OBJ'], echo "\n";
'STEP_UID_OBJ' => $aRow['STEP_UID_OBJ'], $this->update( array ('STEP_UID' => $aRow['STEP_UID'],'PRO_UID' => $aRow['PRO_UID'],'STEP_TYPE_OBJ' => $aRow['STEP_TYPE_OBJ'],'STEP_UID_OBJ' => $aRow['STEP_UID_OBJ'],'STEP_POSITION' => $aRow['STEP_POSITION'] - 1
'STEP_POSITION' => $aRow['STEP_POSITION'] - 1)); ) );
$oDataset->next(); $oDataset->next();
} }
} } catch (Exception $oException) {
catch (Exception $oException) {
throw $Exception; throw $Exception;
} }
} }
public function removeByObject ($sType, $sObjUid)
function removeByObject($sType, $sObjUid) { {
try { try {
$oCriteria = new Criteria('workflow'); $oCriteria = new Criteria( 'workflow' );
$oCriteria->add(StepSupervisorPeer::STEP_TYPE_OBJ, $sType); $oCriteria->add( StepSupervisorPeer::STEP_TYPE_OBJ, $sType );
$oCriteria->add(StepSupervisorPeer::STEP_UID_OBJ, $sObjUid); $oCriteria->add( StepSupervisorPeer::STEP_UID_OBJ, $sObjUid );
StepSupervisorPeer::doDelete($oCriteria); StepSupervisorPeer::doDelete( $oCriteria );
} } catch (Exception $e) {
catch(Exception $e) { throw ($e);
throw($e);
} }
} }
function loadInfo($sObjUID){ public function loadInfo ($sObjUID)
{
$oCriteria = new Criteria('workflow'); $oCriteria = new Criteria( 'workflow' );
$oCriteria->add(StepSupervisorPeer::STEP_UID_OBJ, $sObjUID); $oCriteria->add( StepSupervisorPeer::STEP_UID_OBJ, $sObjUID );
$oDataset = StepSupervisorPeer::doSelectRS($oCriteria); $oDataset = StepSupervisorPeer::doSelectRS( $oCriteria );
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$oDataset->next(); $oDataset->next();
$aRow = $oDataset->getRow(); $aRow = $oDataset->getRow();
return($aRow); return ($aRow);
} }
}
// StepSupervisor
} // StepSupervisor

View File

@@ -1,6 +1,7 @@
<?php <?php
/** /**
* Translation.php * Translation.php
*
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
* *
* ProcessMaker Open Source Edition * ProcessMaker Open Source Edition
@@ -26,7 +27,6 @@
require_once 'classes/model/om/BaseTranslation.php'; require_once 'classes/model/om/BaseTranslation.php';
/** /**
* Skeleton subclass for representing a row from the 'TRANSLATION' table. * Skeleton subclass for representing a row from the 'TRANSLATION' table.
* *
@@ -38,88 +38,80 @@ require_once 'classes/model/om/BaseTranslation.php';
* *
* @package workflow.engine.classes.model * @package workflow.engine.classes.model
*/ */
class Translation extends BaseTranslation { class Translation extends BaseTranslation
{
public static $meta; public static $meta;
public static $localeSeparator = '-'; public static $localeSeparator = '-';
private $envFilePath; private $envFilePath;
function __construct(){ public function __construct ()
{
$this->envFilePath = PATH_DATA . "META-INF" . PATH_SEP . "translations.env"; $this->envFilePath = PATH_DATA . "META-INF" . PATH_SEP . "translations.env";
} }
function getAllCriteria(){ public function getAllCriteria ()
{
//SELECT * from TRANSLATION WHERE TRN_LANG = 'en' order by TRN_CATEGORY, TRN_ID //SELECT * from TRANSLATION WHERE TRN_LANG = 'en' order by TRN_CATEGORY, TRN_ID
$oCriteria = new Criteria('workflow'); $oCriteria = new Criteria( 'workflow' );
$oCriteria->addSelectColumn(TranslationPeer::TRN_ID); $oCriteria->addSelectColumn( TranslationPeer::TRN_ID );
$oCriteria->addSelectColumn(TranslationPeer::TRN_CATEGORY); $oCriteria->addSelectColumn( TranslationPeer::TRN_CATEGORY );
$oCriteria->addSelectColumn(TranslationPeer::TRN_LANG); $oCriteria->addSelectColumn( TranslationPeer::TRN_LANG );
$oCriteria->addSelectColumn(TranslationPeer::TRN_VALUE); $oCriteria->addSelectColumn( TranslationPeer::TRN_VALUE );
//$c->add(TranslationPeer::TRN_LANG, 'en'); //$c->add(TranslationPeer::TRN_LANG, 'en');
return $oCriteria; return $oCriteria;
} }
function getAll($lang='en', $start=null, $limit=null, $search=null, $dateFrom=null, $dateTo=null){ public function getAll ($lang = 'en', $start = null, $limit = null, $search = null, $dateFrom = null, $dateTo = null)
{
$totalCount = 0; $totalCount = 0;
$oCriteria = new Criteria('workflow'); $oCriteria = new Criteria( 'workflow' );
$oCriteria->addSelectColumn(TranslationPeer::TRN_ID); $oCriteria->addSelectColumn( TranslationPeer::TRN_ID );
$oCriteria->addSelectColumn(TranslationPeer::TRN_CATEGORY); $oCriteria->addSelectColumn( TranslationPeer::TRN_CATEGORY );
$oCriteria->addSelectColumn(TranslationPeer::TRN_LANG); $oCriteria->addSelectColumn( TranslationPeer::TRN_LANG );
$oCriteria->addSelectColumn(TranslationPeer::TRN_VALUE); $oCriteria->addSelectColumn( TranslationPeer::TRN_VALUE );
$oCriteria->addSelectColumn(TranslationPeer::TRN_UPDATE_DATE); $oCriteria->addSelectColumn( TranslationPeer::TRN_UPDATE_DATE );
$oCriteria->add(TranslationPeer::TRN_LANG, $lang); $oCriteria->add( TranslationPeer::TRN_LANG, $lang );
$oCriteria->add(TranslationPeer::TRN_CATEGORY, 'LABEL'); $oCriteria->add( TranslationPeer::TRN_CATEGORY, 'LABEL' );
//$oCriteria->addAscendingOrderByColumn ( 'TRN_CATEGORY' ); //$oCriteria->addAscendingOrderByColumn ( 'TRN_CATEGORY' );
$oCriteria->addAscendingOrderByColumn ( 'TRN_ID' ); $oCriteria->addAscendingOrderByColumn( 'TRN_ID' );
if ($search) {
if( $search ) { $oCriteria->add( $oCriteria->getNewCriterion( TranslationPeer::TRN_ID, "%$search%", Criteria::LIKE )->addOr( $oCriteria->getNewCriterion( TranslationPeer::TRN_VALUE, "%$search%", Criteria::LIKE ) ) );
$oCriteria->add(
$oCriteria->getNewCriterion(
TranslationPeer::TRN_ID,
"%$search%", Criteria::LIKE
)->addOr($oCriteria->getNewCriterion(
TranslationPeer::TRN_VALUE,
"%$search%", Criteria::LIKE
))
);
} }
// for date filter // for date filter
if( ($dateFrom)&&($dateTo) ) { if (($dateFrom) && ($dateTo)) {
$oCriteria->add( $oCriteria->add( $oCriteria->getNewCriterion( TranslationPeer::TRN_UPDATE_DATE, "$dateFrom", Criteria::GREATER_EQUAL ) //LESS_EQUAL
$oCriteria->getNewCriterion( ->addAnd( $oCriteria->getNewCriterion( TranslationPeer::TRN_UPDATE_DATE, "$dateTo", Criteria::LESS_EQUAL ) //GREATER_EQUAL
TranslationPeer::TRN_UPDATE_DATE, ) );
"$dateFrom", Criteria::GREATER_EQUAL//LESS_EQUAL
)->addAnd($oCriteria->getNewCriterion(
TranslationPeer::TRN_UPDATE_DATE,
"$dateTo", Criteria::LESS_EQUAL//GREATER_EQUAL
))
);
} }
// end filter // end filter
$c = clone $oCriteria; $c = clone $oCriteria;
$c->clearSelectColumns(); $c->clearSelectColumns();
$c->addSelectColumn('COUNT(*)'); $c->addSelectColumn( 'COUNT(*)' );
$oDataset = TranslationPeer::doSelectRS($c); $oDataset = TranslationPeer::doSelectRS( $c );
$oDataset->next(); $oDataset->next();
$aRow = $oDataset->getRow(); $aRow = $oDataset->getRow();
if( is_array($aRow) ) if (is_array( $aRow )) {
$totalCount = $aRow[0]; $totalCount = $aRow[0];
}
if($start) if ($start) {
$oCriteria->setOffset($start); $oCriteria->setOffset( $start );
if($limit) //&& !isset($seach) && !isset($search)) }
$oCriteria->setLimit($limit); if ($limit) {
//&& !isset($seach) && !isset($search))
$rs = TranslationPeer::doSelectRS($oCriteria); $oCriteria->setLimit( $limit );
$rs->setFetchmode(ResultSet::FETCHMODE_ASSOC); }
$rows = Array(); $rs = TranslationPeer::doSelectRS( $oCriteria );
while( $rs->next() ) { $rs->setFetchmode( ResultSet::FETCHMODE_ASSOC );
$rows = Array ();
while ($rs->next()) {
$rows[] = $rs->getRow(); $rows[] = $rs->getRow();
} }
@@ -129,63 +121,63 @@ class Translation extends BaseTranslation {
return $result; return $result;
} }
/* Load strings from a Database . /* Load strings from a Database .
* @author Fernando Ontiveros <fernando@colosa.com> * @author Fernando Ontiveros <fernando@colosa.com>
* @parameter $languageId (es|en|...). * @parameter $languageId (es|en|...).
*/ */
function generateFileTranslation ($languageId = '') { public function generateFileTranslation ($languageId = '')
$translation = Array(); {
$translationJS = Array(); $translation = Array ();
$translationJS = Array ();
if ($languageId === '')
$languageId = defined('SYS_LANG') ? SYS_LANG : 'en';
if ($languageId === '') {
$languageId = defined( 'SYS_LANG' ) ? SYS_LANG : 'en';
}
$c = new Criteria(); $c = new Criteria();
$c->add(TranslationPeer::TRN_LANG, $languageId ); $c->add( TranslationPeer::TRN_LANG, $languageId );
$c->addAscendingOrderByColumn ( 'TRN_CATEGORY' ); $c->addAscendingOrderByColumn( 'TRN_CATEGORY' );
$c->addAscendingOrderByColumn ( 'TRN_ID' ); $c->addAscendingOrderByColumn( 'TRN_ID' );
$tranlations = TranslationPeer::doSelect($c); $tranlations = TranslationPeer::doSelect( $c );
$cacheFile = PATH_LANGUAGECONT . "translation." . $languageId; $cacheFile = PATH_LANGUAGECONT . "translation." . $languageId;
$cacheFileJS = PATH_CORE . 'js' . PATH_SEP . 'labels' . PATH_SEP . $languageId.".js"; $cacheFileJS = PATH_CORE . 'js' . PATH_SEP . 'labels' . PATH_SEP . $languageId . ".js";
foreach ( $tranlations as $key => $row ) { foreach ($tranlations as $key => $row) {
if ( $row->getTrnCategory() === 'LABEL' ) { if ($row->getTrnCategory() === 'LABEL') {
$translation[ $row->getTrnId() ] = $row->getTrnValue(); $translation[$row->getTrnId()] = $row->getTrnValue();
} }
if ( $row->getTrnCategory() === 'JAVASCRIPT') { if ($row->getTrnCategory() === 'JAVASCRIPT') {
$translationJS[ $row->getTrnId() ] = $row->getTrnValue(); $translationJS[$row->getTrnId()] = $row->getTrnValue();
} }
} }
try { try {
if( ! is_dir(dirname($cacheFile)) ) if (! is_dir( dirname( $cacheFile ) )) {
G::mk_dir(dirname($cacheFile)); G::mk_dir( dirname( $cacheFile ) );
}
if( ! is_dir(dirname($cacheFileJS)) ) if (! is_dir( dirname( $cacheFileJS ) )) {
G::mk_dir(dirname($cacheFileJS)); G::mk_dir( dirname( $cacheFileJS ) );
}
$f = fopen( $cacheFile , 'w+'); $f = fopen( $cacheFile, 'w+' );
fwrite( $f , "<?php\n" ); fwrite( $f, "<?php\n" );
fwrite( $f , '$translation =' . 'unserialize(\'' . addcslashes( serialize ( $translation ), '\\\'' ) . "');\n"); fwrite( $f, '$translation =' . 'unserialize(\'' . addcslashes( serialize( $translation ), '\\\'' ) . "');\n" );
fwrite( $f , "?>" ); fwrite( $f, "?>" );
fclose( $f ); fclose( $f );
$json=new Services_JSON(); $json = new Services_JSON();
$f = fopen( $cacheFileJS , 'w'); $f = fopen( $cacheFileJS, 'w' );
fwrite( $f , "var G_STRINGS =". $json->encode( $translationJS ) . ";\n"); fwrite( $f, "var G_STRINGS =" . $json->encode( $translationJS ) . ";\n" );
fclose( $f ); fclose( $f );
$res['cacheFile'] = $cacheFile; $res['cacheFile'] = $cacheFile;
$res['cacheFileJS'] = $cacheFileJS; $res['cacheFileJS'] = $cacheFileJS;
$res['rows'] = count ( $translation ); $res['rows'] = count( $translation );
$res['rowsJS'] = count ( $translationJS ); $res['rowsJS'] = count( $translationJS );
return $res; return $res;
} catch( Exception $e ) { } catch (Exception $e) {
echo $e->getMessage(); echo $e->getMessage();
} }
} }
@@ -196,144 +188,146 @@ class Translation extends BaseTranslation {
* rowsAffected 0,1 the number of rows affected * rowsAffected 0,1 the number of rows affected
* message message error. * message message error.
*/ */
function addTranslation ( $category, $id, $languageId, $value ) { public function addTranslation ($category, $id, $languageId, $value)
{
//if exists the row in the database propel will update it, otherwise will insert. //if exists the row in the database propel will update it, otherwise will insert.
$tr = TranslationPeer::retrieveByPK( $category, $id, $languageId ); $tr = TranslationPeer::retrieveByPK( $category, $id, $languageId );
if ( ! ( is_object ( $tr ) && get_class ($tr) == 'Translation' ) ) { if (! (is_object( $tr ) && get_class( $tr ) == 'Translation')) {
$tr = new Translation(); $tr = new Translation();
} }
$tr->setTrnCategory( $category ); $tr->setTrnCategory( $category );
$tr->setTrnId( $id ); $tr->setTrnId( $id );
$tr->setTrnLang( $languageId); $tr->setTrnLang( $languageId );
$tr->setTrnValue( $value ); $tr->setTrnValue( $value );
$tr->setTrnUpdateDate( date('Y-m-d') ); $tr->setTrnUpdateDate( date( 'Y-m-d' ) );
if ($tr->validate() ) { if ($tr->validate()) {
// we save it, since we get no validation errors, or do whatever else you like. // we save it, since we get no validation errors, or do whatever else you like.
$res = $tr->save(); $res = $tr->save();
} } else {
else {
// Something went wrong. We can now get the validationFailures and handle them. // Something went wrong. We can now get the validationFailures and handle them.
$msg = ''; $msg = '';
$validationFailuresArray = $tr->getValidationFailures(); $validationFailuresArray = $tr->getValidationFailures();
foreach($validationFailuresArray as $objValidationFailure) { foreach ($validationFailuresArray as $objValidationFailure) {
$msg .= $objValidationFailure->getMessage() . "\n"; $msg .= $objValidationFailure->getMessage() . "\n";
} }
return array ( 'codError' => -100, 'rowsAffected' => 0, 'message' => $msg ); return array ('codError' => - 100,'rowsAffected' => 0,'message' => $msg);
} }
return array ( 'codError' => 0, 'rowsAffected' => $res, 'message' => ''); return array ('codError' => 0,'rowsAffected' => $res,'message' => '');
//to do: uniform coderror structures for all classes //to do: uniform coderror structures for all classes
} }
function remove($sCategory, $sId, $sLang) { public function remove ($sCategory, $sId, $sLang)
$oTranslation = TranslationPeer::retrieveByPK($sCategory, $sId, $sLang); {
if ( ( is_object ( $oTranslation ) && get_class ($oTranslation) == 'Translation' ) ) { $oTranslation = TranslationPeer::retrieveByPK( $sCategory, $sId, $sLang );
if ((is_object( $oTranslation ) && get_class( $oTranslation ) == 'Translation')) {
$oTranslation->delete(); $oTranslation->delete();
} }
} }
function addTranslationEnvironment($locale, $headers, $numRecords) public function addTranslationEnvironment ($locale, $headers, $numRecords)
{ {
$filePath = $this->envFilePath; $filePath = $this->envFilePath;
$environments = Array(); $environments = Array ();
if( file_exists($filePath) ) { if (file_exists( $filePath )) {
$environments = unserialize(file_get_contents($filePath)); $environments = unserialize( file_get_contents( $filePath ) );
} }
$environment['LOCALE'] = $locale; $environment['LOCALE'] = $locale;
$environment['HEADERS'] = $headers; $environment['HEADERS'] = $headers;
$environment['DATE'] = date('Y-m-d H:i:s'); $environment['DATE'] = date( 'Y-m-d H:i:s' );
$environment['NUM_RECORDS'] = $numRecords; $environment['NUM_RECORDS'] = $numRecords;
$environment['LANGUAGE'] = $headers['X-Poedit-Language']; $environment['LANGUAGE'] = $headers['X-Poedit-Language'];
$environment['COUNTRY'] = $headers['X-Poedit-Country']; $environment['COUNTRY'] = $headers['X-Poedit-Country'];
if( strpos($locale, self::$localeSeparator) !== false ) { if (strpos( $locale, self::$localeSeparator ) !== false) {
list($environment['LAN_ID'], $environment['IC_UID']) = explode(self::$localeSeparator, strtoupper($locale)); list ($environment['LAN_ID'], $environment['IC_UID']) = explode( self::$localeSeparator, strtoupper( $locale ) );
$environments[$environment['LAN_ID']][$environment['IC_UID']] = $environment; $environments[$environment['LAN_ID']][$environment['IC_UID']] = $environment;
} else { } else {
$environment['LAN_ID'] = strtoupper($locale); $environment['LAN_ID'] = strtoupper( $locale );
$environment['IC_UID'] = ''; $environment['IC_UID'] = '';
$environments[$locale]['__INTERNATIONAL__'] = $environment; $environments[$locale]['__INTERNATIONAL__'] = $environment;
} }
file_put_contents( $filePath, serialize( $environments ) );
file_put_contents($filePath, serialize($environments));
} }
function removeTranslationEnvironment($locale) public function removeTranslationEnvironment ($locale)
{ {
$filePath = $this->envFilePath; $filePath = $this->envFilePath;
if (strpos($locale, self::$localeSeparator) !== false) { if (strpos( $locale, self::$localeSeparator ) !== false) {
list($LAN_ID, $IC_UID) = explode('-', strtoupper($locale)); list ($LAN_ID, $IC_UID) = explode( '-', strtoupper( $locale ) );
} else { } else {
$LAN_ID = $locale; $LAN_ID = $locale;
$IC_UID = '__INTERNATIONAL__'; $IC_UID = '__INTERNATIONAL__';
} }
if (file_exists($filePath)) { if (file_exists( $filePath )) {
$environments = unserialize(file_get_contents($filePath)); $environments = unserialize( file_get_contents( $filePath ) );
if (!isset($environments[$LAN_ID][$IC_UID])) { if (! isset( $environments[$LAN_ID][$IC_UID] )) {
return NULL; return null;
} }
unset($environments[$LAN_ID][$IC_UID]); unset( $environments[$LAN_ID][$IC_UID] );
file_put_contents($filePath, serialize($environments)); file_put_contents( $filePath, serialize( $environments ) );
if (file_exists(PATH_CORE . "META-INF" . PATH_SEP . "translation.".$locale)) { if (file_exists( PATH_CORE . "META-INF" . PATH_SEP . "translation." . $locale )) {
G::rm_dir(PATH_DATA . "META-INF" . PATH_SEP . "translation.".$locale); G::rm_dir( PATH_DATA . "META-INF" . PATH_SEP . "translation." . $locale );
} }
if (file_exists(PATH_CORE . PATH_SEP . 'content' . PATH_SEP . 'translations' . PATH_SEP . 'processmaker' . $locale . '.po')) { if (file_exists( PATH_CORE . PATH_SEP . 'content' . PATH_SEP . 'translations' . PATH_SEP . 'processmaker' . $locale . '.po' )) {
G::rm_dir(PATH_CORE . PATH_SEP . 'content' . PATH_SEP . 'translations' . PATH_SEP . 'processmaker' . $locale . '.po'); G::rm_dir( PATH_CORE . PATH_SEP . 'content' . PATH_SEP . 'translations' . PATH_SEP . 'processmaker' . $locale . '.po' );
} }
} }
} }
function getTranslationEnvironments(){ public function getTranslationEnvironments ()
{
$filePath = $this->envFilePath; $filePath = $this->envFilePath;
$envs = Array(); $envs = Array ();
if( ! file_exists($filePath) ) { if (! file_exists( $filePath )) {
//the transaltions table file doesn't exist, then build it //the transaltions table file doesn't exist, then build it
if( ! is_dir(dirname($this->envFilePath)) )
G::mk_dir(dirname($this->envFilePath));
if (! is_dir( dirname( $this->envFilePath ) )) {
G::mk_dir( dirname( $this->envFilePath ) );
}
$translationsPath = PATH_CORE . "content" . PATH_SEP . 'translations' . PATH_SEP; $translationsPath = PATH_CORE . "content" . PATH_SEP . 'translations' . PATH_SEP;
$basePOFile = $translationsPath . 'english' . PATH_SEP . 'processmaker.en.po'; $basePOFile = $translationsPath . 'english' . PATH_SEP . 'processmaker.en.po';
$params = self::getInfoFromPOFile($basePOFile); $params = self::getInfoFromPOFile( $basePOFile );
$this->addTranslationEnvironment($params['LOCALE'], $params['HEADERS'], $params['COUNT']); $this->addTranslationEnvironment( $params['LOCALE'], $params['HEADERS'], $params['COUNT'] );
//getting more lanuguage translations //getting more lanuguage translations
$files = glob($translationsPath . "*.po"); $files = glob( $translationsPath . "*.po" );
foreach( $files as $file ){ foreach ($files as $file) {
$params = self::getInfoFromPOFile($file); $params = self::getInfoFromPOFile( $file );
$this->addTranslationEnvironment($params['LOCALE'], $params['HEADERS'], $params['COUNT']); $this->addTranslationEnvironment( $params['LOCALE'], $params['HEADERS'], $params['COUNT'] );
} }
} }
$envs = unserialize(file_get_contents($filePath)); $envs = unserialize( file_get_contents( $filePath ) );
$environments = Array(); $environments = Array ();
foreach($envs as $LAN_ID => $rec1 ){ foreach ($envs as $LAN_ID => $rec1) {
foreach($rec1 as $IC_UID => $rec2 ){ foreach ($rec1 as $IC_UID => $rec2) {
$environments[] = $rec2; $environments[] = $rec2;
} }
} }
return $environments; return $environments;
/*G::LoadSystem('dbMaintenance'); /*
G::LoadSystem('dbMaintenance');
$o = new DataBaseMaintenance('localhost', 'root', 'atopml2005'); $o = new DataBaseMaintenance('localhost', 'root', 'atopml2005');
$o->connect('wf_os'); $o->connect('wf_os');
$r = $o->query('select * from ISO_COUNTRY'); $r = $o->query('select * from ISO_COUNTRY');
foreach($r as $i=>$v){ foreach ($r as $i=>$v) {
$r[$i]['IC_NAME'] = utf8_encode($r[$i]['IC_NAME']); $r[$i]['IC_NAME'] = utf8_encode($r[$i]['IC_NAME']);
unset($r[$i]['IC_SORT_ORDER']); unset($r[$i]['IC_SORT_ORDER']);
} }
$r1 = $o->query('select * from LANGUAGE'); $r1 = $o->query('select * from LANGUAGE');
$r2 = Array(); $r2 = Array();
foreach($r1 as $i=>$v){ foreach ($r1 as $i=>$v) {
$r2[$i]['LAN_NAME'] = utf8_encode($r1[$i]['LAN_NAME']); $r2[$i]['LAN_NAME'] = utf8_encode($r1[$i]['LAN_NAME']);
$r2[$i]['LAN_ID'] = utf8_encode($r1[$i]['LAN_ID']); $r2[$i]['LAN_ID'] = utf8_encode($r1[$i]['LAN_ID']);
} }
@@ -342,120 +336,120 @@ class Translation extends BaseTranslation {
*/ */
} }
function getInfoFromPOFile($file){ public function getInfoFromPOFile ($file)
G::loadClass('i18n_po'); {
$POFile = new i18n_PO($file); G::loadClass( 'i18n_po' );
$POFile = new i18n_PO( $file );
$POFile->readInit(); $POFile->readInit();
$POHeaders = $POFile->getHeaders(); $POHeaders = $POFile->getHeaders();
if( $POHeaders['X-Poedit-Country'] != '.' ) { if ($POHeaders['X-Poedit-Country'] != '.') {
$country = self::getTranslationMetaByCountryName($POHeaders['X-Poedit-Country']); $country = self::getTranslationMetaByCountryName( $POHeaders['X-Poedit-Country'] );
} else { } else {
$country = '.'; $country = '.';
} }
$language = self::getTranslationMetaByLanguageName($POHeaders['X-Poedit-Language']); $language = self::getTranslationMetaByLanguageName( $POHeaders['X-Poedit-Language'] );
if( $language !== false ) { if ($language !== false) {
if( $country !== false ) { if ($country !== false) {
if( $country != '.') { if ($country != '.') {
$LOCALE = $language['LAN_ID'] . '-' . $country['IC_UID']; $LOCALE = $language['LAN_ID'] . '-' . $country['IC_UID'];
} else if( $country == '.' ) { } else if ($country == '.') {
//this a trsnlation file with a language international, no country name was set //this a trsnlation file with a language international, no country name was set
$LOCALE = $language['LAN_ID']; $LOCALE = $language['LAN_ID'];
} else } else
throw new Exception('PO File Error: "'.$file.'" has a invalid country definition!'); throw new Exception( 'PO File Error: "' . $file . '" has a invalid country definition!' );
} else } else
throw new Exception('PO File Error: "'.$file.'" has a invalid country definition!'); throw new Exception( 'PO File Error: "' . $file . '" has a invalid country definition!' );
} else } else
throw new Exception('PO File Error: "'.$file.'" has a invalid language definition!'); throw new Exception( 'PO File Error: "' . $file . '" has a invalid language definition!' );
$countItems = 0; $countItems = 0;
try { try {
while( $rowTranslation = $POFile->getTranslation() ) { while ($rowTranslation = $POFile->getTranslation()) {
$countItems++; $countItems ++;
} }
} catch(Exception $e) { } catch (Exception $e) {
$countItems = '-'; $countItems = '-';
} }
return Array ('LOCALE' => $LOCALE,'HEADERS' => $POHeaders,'COUNT' => $countItems);
return Array('LOCALE'=>$LOCALE, 'HEADERS'=>$POHeaders , 'COUNT'=>$countItems);
} }
function getTranslationEnvironment($locale){ public function getTranslationEnvironment ($locale)
{
$filePath = $this->envFilePath; $filePath = $this->envFilePath;
$environments = Array(); $environments = Array ();
if( ! file_exists($filePath) ) { if (! file_exists( $filePath )) {
throw new Exception("The file $filePath doesn't exist"); throw new Exception( "The file $filePath doesn't exist" );
} }
$environments = unserialize(file_get_contents($filePath)); $environments = unserialize( file_get_contents( $filePath ) );
if( strpos($locale, self::$localeSeparator) !== false ) { if (strpos( $locale, self::$localeSeparator ) !== false) {
list($LAN_ID, $IC_UID) = explode(self::localeSeparator, strtoupper($locale)); list ($LAN_ID, $IC_UID) = explode( self::localeSeparator, strtoupper( $locale ) );
} else { } else {
$LAN_ID = $locale; $LAN_ID = $locale;
$IC_UID = '__INTERNATIONAL__'; $IC_UID = '__INTERNATIONAL__';
} }
if( isset($environments[$LAN_ID][$IC_UID]) ) if (isset( $environments[$LAN_ID][$IC_UID] )) {
return $environments[$LAN_ID][$IC_UID]; return $environments[$LAN_ID][$IC_UID];
else } else {
return false; return false;
} }
function saveTranslationEnvironment($locale, $data){
$filePath = $this->envFilePath;
$environments = Array();
if( ! file_exists($filePath) ) {
throw new Exception("The file $filePath doesn't exist");
} }
$environments = unserialize(file_get_contents($filePath)); public function saveTranslationEnvironment ($locale, $data)
if( strpos($locale, self::$localeSeparator) !== false ) { {
list($LAN_ID, $IC_UID) = explode(self::localeSeparator, strtoupper($locale)); $filePath = $this->envFilePath;
$environments = Array ();
if (! file_exists( $filePath )) {
throw new Exception( "The file $filePath doesn't exist" );
}
$environments = unserialize( file_get_contents( $filePath ) );
if (strpos( $locale, self::$localeSeparator ) !== false) {
list ($LAN_ID, $IC_UID) = explode( self::localeSeparator, strtoupper( $locale ) );
} else { } else {
$LAN_ID = $locale; $LAN_ID = $locale;
$IC_UID = '__INTERNATIONAL__'; $IC_UID = '__INTERNATIONAL__';
} }
$environments[$LAN_ID][$IC_UID] = $data; $environments[$LAN_ID][$IC_UID] = $data;
file_put_contents($filePath, serialize($environments)); file_put_contents( $filePath, serialize( $environments ) );
} }
function getTranslationMeta(){ public function getTranslationMeta ()
{
$translationsPath = PATH_CORE . "content" . PATH_SEP . 'translations' . PATH_SEP; $translationsPath = PATH_CORE . "content" . PATH_SEP . 'translations' . PATH_SEP;
$translationsTable = unserialize(file_get_contents($translationsPath . 'pmos-translations.meta')); $translationsTable = unserialize( file_get_contents( $translationsPath . 'pmos-translations.meta' ) );
return $translationsTable; return $translationsTable;
} }
function getTranslationMetaByCountryName($IC_NAME){ public function getTranslationMetaByCountryName ($IC_NAME)
{
$translationsTable = self::getTranslationMeta(); $translationsTable = self::getTranslationMeta();
foreach ($translationsTable['ISO_COUNTRY'] as $row) { foreach ($translationsTable['ISO_COUNTRY'] as $row) {
if( $row['IC_NAME'] == $IC_NAME ) if ($row['IC_NAME'] == $IC_NAME) {
return $row; return $row;
} }
}
return false; return false;
} }
function getTranslationMetaByLanguageName($LAN_NAME){ public function getTranslationMetaByLanguageName ($LAN_NAME)
{
$translationsTable = self::getTranslationMeta(); $translationsTable = self::getTranslationMeta();
foreach ($translationsTable['LANGUAGE'] as $row) { foreach ($translationsTable['LANGUAGE'] as $row) {
if( $row['LAN_NAME'] == $LAN_NAME ) if ($row['LAN_NAME'] == $LAN_NAME) {
return $row; return $row;
} }
}
return false; return false;
} }
} // Translation }
// Translation

View File

@@ -1,4 +1,5 @@
<?php <?php
/** /**
* class.pmSugar.pmFunctions.php * class.pmSugar.pmFunctions.php
* *
@@ -16,8 +17,9 @@
//////////////////////////////////////////////////// ////////////////////////////////////////////////////
function getSoapClientOptions() { function getSoapClientOptions ()
$options = array('trace' => 1); {
$options = array ('trace' => 1);
//Apply proxy settings //Apply proxy settings
$sysConf = System::getSystemConfiguration(); $sysConf = System::getSystemConfiguration();
@@ -40,35 +42,36 @@ function getSoapClientOptions() {
/** /**
* This collection of triggers allows to interact by getting and sending information to SugarCRM * This collection of triggers allows to interact by getting and sending information to SugarCRM
* @class pmSugar * @class pmSugar
*
* @name Sugar CRM Triggers * @name Sugar CRM Triggers
* @icon /images/triggers/icon_SugarCRM.gif * @icon /images/triggers/icon_SugarCRM.gif
* @className class.pmSugar.pmFunctions.php * @className class.pmSugar.pmFunctions.php
*/ */
function sugarLogin($sugarSoap, $user, $password) { function sugarLogin ($sugarSoap, $user, $password)
$client = new SoapClient ( $sugarSoap, getSoapClientOptions() ); {
$auth_array = array ('user_auth' => array ('user_name' => $user, 'password' => md5 ( $password ), 'version' => '1.0' ) ); $client = new SoapClient( $sugarSoap, getSoapClientOptions() );
$login_results = $client->__SoapCall ( 'login', $auth_array ); $auth_array = array ('user_auth' => array ('user_name' => $user,'password' => md5( $password ),'version' => '1.0') );
$login_results = $client->__SoapCall( 'login', $auth_array );
$session_id = $login_results->id; $session_id = $login_results->id;
$user_guid = $client->__SoapCall ( 'get_user_id', array ($session_id ) ); $user_guid = $client->__SoapCall( 'get_user_id', array ($session_id) );
return $session_id; return $session_id;
} }
function objectToArray($object) { function objectToArray ($object)
if (! is_object ( $object ) && ! is_array ( $object )) { {
if (! is_object( $object ) && ! is_array( $object )) {
return $object; return $object;
} }
if (is_object ( $object )) { if (is_object( $object )) {
$object = get_object_vars ( $object ); $object = get_object_vars( $object );
} }
return array_map ( "objectToArray", $object ); return array_map( "objectToArray", $object );
} }
/** /**
* @method
* *
* Gets SugarCRM entry using get_entry web service. * @method Gets SugarCRM entry using get_entry web service.
* *
* @name GetSugarEntry * @name GetSugarEntry
* @label Get SugarCRM Entry * @label Get SugarCRM Entry
@@ -86,24 +89,23 @@ function objectToArray($object) {
* *
*/ */
function GetSugarEntry($sugarSoap, $user, $password, $module, $id, $selectFields, $linkNameToFieldsArray, $resultType = 'array') { function GetSugarEntry ($sugarSoap, $user, $password, $module, $id, $selectFields, $linkNameToFieldsArray, $resultType = 'array')
$sessionId = sugarLogin ( $sugarSoap, $user, $password ); {
$client = new SoapClient ( $sugarSoap, getSoapClientOptions() ); $sessionId = sugarLogin( $sugarSoap, $user, $password );
$request_array = array ('session' => $sessionId, 'module_name' => $module, 'id' => $id, $client = new SoapClient( $sugarSoap, getSoapClientOptions() );
'select_fields' => $select_fields, 'link_name_to_fields_array' => $linkNameToFieldsArray); $request_array = array ('session' => $sessionId,'module_name' => $module,'id' => $id,'select_fields' => $select_fields,'link_name_to_fields_array' => $linkNameToFieldsArray);
$sugarEntry = $client->__SoapCall ( 'get_entry', $request_array ); $sugarEntry = $client->__SoapCall( 'get_entry', $request_array );
if($resultType == 'array'){ if ($resultType == 'array') {
$sugarEntry = objectToArray ( $sugarEntry ); $sugarEntry = objectToArray( $sugarEntry );
} }
return $sugarEntry; return $sugarEntry;
} }
/** /**
* @method
* *
* Gets SugarCRM entries from the indicated module. * @method Gets SugarCRM entries from the indicated module.
* *
* @name GetSugarEntries * @name GetSugarEntries
* @label Get SugarCRM Entries * @label Get SugarCRM Entries
@@ -122,25 +124,31 @@ function GetSugarEntry($sugarSoap, $user, $password, $module, $id, $selectFields
* *
*/ */
function GetSugarEntries($sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType="array") { function GetSugarEntries ($sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType = "array")
$sessionId = sugarLogin ( $sugarSoap, $user, $password ); {
$client = new SoapClient ( $sugarSoap, getSoapClientOptions() ); $sessionId = sugarLogin( $sugarSoap, $user, $password );
$request_array = array ('session' => $sessionId, 'module_name' => $module, 'query' => $query, 'order_by' => $orderBy, 'offset'=>"", 'select_fields'=>"", 'max_result'=>$maxResults ); $client = new SoapClient( $sugarSoap, getSoapClientOptions() );
$sugarEntriesO = $client->__SoapCall ( 'get_entry_list', $request_array ); $request_array = array ('session' => $sessionId,'module_name' => $module,'query' => $query,'order_by' => $orderBy,'offset' => "",'select_fields' => "",'max_result' => $maxResults);
$sugarEntriesO = $client->__SoapCall( 'get_entry_list', $request_array );
switch($resultType){ switch ($resultType) {
case 'array':$sugarEntries = objectToArray ( $sugarEntriesO ); break; case 'array':
case 'object':$sugarEntries = $sugarEntriesO; break; $sugarEntries = objectToArray( $sugarEntriesO );
default: $sugarEntries = objectToArray ( $sugarEntries ); break;
case 'object':
$sugarEntries = $sugarEntriesO;
break;
default:
$sugarEntries = objectToArray( $sugarEntries );
} }
return $sugarEntries; return $sugarEntries;
} }
/** /**
* @method
* *
* Gets SugarCRM entries from the Calls module * @method Gets SugarCRM entries from the Calls module
* *
* @name GetSugarCalls * @name GetSugarCalls
* @label Gets SugarCRM entries from the Calls module * @label Gets SugarCRM entries from the Calls module
@@ -158,14 +166,15 @@ function GetSugarEntries($sugarSoap, $user, $password, $module, $query, $orderBy
* *
*/ */
function GetSugarCalls($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType="array") { function GetSugarCalls ($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType = "array")
$module="Calls"; {
return GetSugarEntries($sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType); $module = "Calls";
return GetSugarEntries( $sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType );
} }
/** /**
* @method
* *
* Gets SugarCRM entries from the Leads module. * @method Gets SugarCRM entries from the Leads module.
* *
* @name GetSugarLeads * @name GetSugarLeads
* @label Gets SugarCRM entries from the Leads module. * @label Gets SugarCRM entries from the Leads module.
@@ -183,14 +192,15 @@ function GetSugarCalls($sugarSoap, $user, $password, $query, $orderBy, $selected
* *
*/ */
function GetSugarLeads($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType="array") { function GetSugarLeads ($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType = "array")
$module="Leads"; {
return GetSugarEntries($sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType); $module = "Leads";
return GetSugarEntries( $sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType );
} }
/** /**
* @method
* *
* Gets SugarCRM entries from the Contacts module. * @method Gets SugarCRM entries from the Contacts module.
* *
* @name GetSugarContacts * @name GetSugarContacts
* @label Gets SugarCRM entries from the Contacts module. * @label Gets SugarCRM entries from the Contacts module.
@@ -208,14 +218,15 @@ function GetSugarLeads($sugarSoap, $user, $password, $query, $orderBy, $selected
* *
*/ */
function GetSugarContacts($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType="array") { function GetSugarContacts ($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType = "array")
$module="Contacts"; {
return GetSugarEntries($sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType); $module = "Contacts";
return GetSugarEntries( $sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType );
} }
/** /**
* @method
* *
* Gets SugarCRM entries from the Opportunities module. * @method Gets SugarCRM entries from the Opportunities module.
* *
* @name GetSugarOpportunities * @name GetSugarOpportunities
* @label Gets SugarCRM entries from the Opportunities module. * @label Gets SugarCRM entries from the Opportunities module.
@@ -233,15 +244,15 @@ function GetSugarContacts($sugarSoap, $user, $password, $query, $orderBy, $selec
* *
*/ */
function GetSugarOpportunities($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType="array") { function GetSugarOpportunities ($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType = "array")
$module="Opportunities"; {
return GetSugarEntries($sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType); $module = "Opportunities";
return GetSugarEntries( $sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType );
} }
/** /**
* @method
* *
* Gets SugarCRM entries from the Account module. * @method Gets SugarCRM entries from the Account module.
* *
* @name GetSugarAccount * @name GetSugarAccount
* @label Gets SugarCRM entries from the Account module. * @label Gets SugarCRM entries from the Account module.
@@ -259,16 +270,15 @@ function GetSugarOpportunities($sugarSoap, $user, $password, $query, $orderBy, $
* *
*/ */
function GetSugarAccount($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType="array") { function GetSugarAccount ($sugarSoap, $user, $password, $query, $orderBy, $selectedFields, $maxResults, $resultType = "array")
$module="Accounts"; {
return GetSugarEntries($sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType); $module = "Accounts";
return GetSugarEntries( $sugarSoap, $user, $password, $module, $query, $orderBy, $selectedFields, $maxResults, $resultType );
} }
/** /**
* @method
* *
* Creates SugarCRM entries from the Account module. * @method Creates SugarCRM entries from the Account module.
* *
* @name CreateSugarAccount * @name CreateSugarAccount
* *
@@ -283,30 +293,33 @@ function GetSugarAccount($sugarSoap, $user, $password, $query, $orderBy, $select
* @return array/object | $sugarAccount | Sugar Opportunities (array or object) * @return array/object | $sugarAccount | Sugar Opportunities (array or object)
* *
*/ */
function CreateSugarAccount($sugarSoap, $user, $password, $name, $resultType="array") { function CreateSugarAccount ($sugarSoap, $user, $password, $name, $resultType = "array")
{
$module = "Accounts"; $module = "Accounts";
$sessionId = sugarLogin ( $sugarSoap, $user, $password ); $sessionId = sugarLogin( $sugarSoap, $user, $password );
$client = new SoapClient ( $sugarSoap, getSoapClientOptions() ); $client = new SoapClient( $sugarSoap, getSoapClientOptions() );
$request_array = array ('session' => $sessionId, 'module_name' => $module, 'name_value_list' => array( $request_array = array ('session' => $sessionId,'module_name' => $module,'name_value_list' => array (array ("name" => 'name',"value" => $name)));
array("name" => 'name', "value" => $name ) $sugarEntriesO = $client->__SoapCall( 'set_entry', $request_array );
) ); $account_id = $sugarEntriesO->id;
$sugarEntriesO = $client->__SoapCall ( 'set_entry', $request_array );
$account_id = $sugarEntriesO ->id;
switch($resultType){ switch ($resultType) {
case 'array':$sugarEntries = objectToArray ( $sugarEntriesO );break; case 'array':
case 'object':$sugarEntries = $sugarEntries ;break; $sugarEntries = objectToArray( $sugarEntriesO );
default: $sugarEntries = objectToArray ( $sugarEntries ); break;
case 'object':
$sugarEntries = $sugarEntries;
break;
default:
$sugarEntries = objectToArray( $sugarEntries );
} }
//return $sugarEntries; //return $sugarEntries;
return $account_id; return $account_id;
} }
/** /**
* @method
* *
* Creates SugarCRM entries from the Account module * @method Creates SugarCRM entries from the Account module
* *
* @name CreateSugarContact * @name CreateSugarContact
* *
@@ -326,46 +339,49 @@ function CreateSugarAccount($sugarSoap, $user, $password, $name, $resultType="a
* @return array/object | $sugarContact | Sugar Opportunities (array or object) * @return array/object | $sugarContact | Sugar Opportunities (array or object)
* *
*/ */
function CreateSugarContact($sugarSoap, $user, $password, $first_name, $last_name, $email, $title, $phone, $account_id, $resultType="array") { function CreateSugarContact ($sugarSoap, $user, $password, $first_name, $last_name, $email, $title, $phone, $account_id, $resultType = "array")
{
$module = "Contacts"; $module = "Contacts";
/* $aValue = array( /* $aValue = array(
array("name" => 'id', "value" => G::generateUniqueID()), array("name" => 'id', "value" => G::generateUniqueID()),
array("name" => 'first_name', "value" => $first_name), array("name" => 'first_name', "value" => $first_name),
array("name" => 'last_name', "value" => $last_name), array("name" => 'last_name', "value" => $last_name),
); );
*/ */
$sessionId = sugarLogin ( $sugarSoap, $user, $password ); $sessionId = sugarLogin( $sugarSoap, $user, $password );
$client = new SoapClient ( $sugarSoap, getSoapClientOptions() ); $client = new SoapClient( $sugarSoap, getSoapClientOptions() );
$request_array = array ('session' => $sessionId, 'module_name' => $module, array( $request_array = array ('session' => $sessionId,'module_name' => $module,array (array ("name" => 'first_name',"value" => $first_name
array("name" => 'first_name',"value" => $first_name), ),array ("name" => 'last_name',"value" => $last_name
array("name" => 'last_name',"value" => $last_name), ),array ("name" => 'email1',"value" => $email
array("name" => 'email1',"value" => $email), ),array ("name" => 'title',"value" => $title
array("name" => 'title',"value" => $title), ),array ("name" => 'phone_work',"value" => $phone
array("name" => 'phone_work',"value" => $phone), ),
// array("name" => 'account_id',"value" => '8cd10a60-101f-4363-1e0b-4cfd4106bd7e') // array("name" => 'account_id',"value" => '8cd10a60-101f-4363-1e0b-4cfd4106bd7e')
array("name" => 'account_id',"value" => $account_id) array ("name" => 'account_id',"value" => $account_id
)); )));
$sugarEntriesO = $client->__SoapCall ( 'set_entry', $request_array ); $sugarEntriesO = $client->__SoapCall( 'set_entry', $request_array );
switch($resultType){ switch ($resultType) {
case 'array':$sugarEntries = objectToArray ( $sugarEntriesO ); break; case 'array':
case 'object':$sugarEntries = $sugarEntries; break; $sugarEntries = objectToArray( $sugarEntriesO );
default: $sugarEntries = objectToArray ( $sugarEntries ); break;
case 'object':
$sugarEntries = $sugarEntries;
break;
default:
$sugarEntries = objectToArray( $sugarEntries );
} }
return $sugarEntries; return $sugarEntries;
} }
/** /**
* @method
* *
* Creates SugarCRM entries from the Opportunities module. * @method Creates SugarCRM entries from the Opportunities module.
* *
* @name CreateSugarOpportunity * @name CreateSugarOpportunity
*
* @label Creates SugarCRM entries from the Opportunities module. * @label Creates SugarCRM entries from the Opportunities module.
* *
* @param string | $sugarSoap | Sugar SOAP URL | http://www.example.com/sugar/soap.php?wsdl * @param string | $sugarSoap | Sugar SOAP URL | http://www.example.com/sugar/soap.php?wsdl
@@ -381,8 +397,9 @@ function CreateSugarContact($sugarSoap, $user, $password, $first_name, $last_nam
* @return array/object | $sugarOpportunity | Sugar Opportunities (array or object) * @return array/object | $sugarOpportunity | Sugar Opportunities (array or object)
* *
*/ */
function CreateSugarOpportunity($sugarSoap, $user, $password, $name,$account_id,$amount, $date_closed, $sales_stage,$resultType="array") { function CreateSugarOpportunity ($sugarSoap, $user, $password, $name, $account_id, $amount, $date_closed, $sales_stage, $resultType = "array")
// * @param string | $account_id | Account Id {
// * @param string | $account_id | Account Id
$module = "Opportunities"; $module = "Opportunities";
/* $aValue = array( /* $aValue = array(
@@ -394,33 +411,36 @@ function CreateSugarOpportunity($sugarSoap, $user, $password, $name,$account_id,
array("name" => 'sales_stage', "value" => $sales_stage) array("name" => 'sales_stage', "value" => $sales_stage)
);*/ );*/
$sessionId = sugarLogin ( $sugarSoap, $user, $password ); $sessionId = sugarLogin( $sugarSoap, $user, $password );
$client = new SoapClient ( $sugarSoap, getSoapClientOptions() ); $client = new SoapClient( $sugarSoap, getSoapClientOptions() );
$request_array = array ('session' => $sessionId, 'module_name' => $module, 'name_value_list' =>array( $request_array = array ('session' => $sessionId,'module_name' => $module,'name_value_list' => array (array ('name' => 'name','value' => $name
array('name' => 'name','value' => $name), ),array ("name" => 'account_id',"value" => $account_id
array("name" => 'account_id',"value" => $account_id), ),array ('name' => 'amount','value' => $amount
array('name' => 'amount','value' => $amount), ),array ('name' => 'date_closed','value' => $date_closed
array('name' => 'date_closed','value' => $date_closed), ),array ('name' => 'sales_stage','value' => $sales_stage
array('name' => 'sales_stage','value' => $sales_stage), )
)); )
);
$sugarEntriesO = $client->__SoapCall ( 'set_entry', $request_array ); $sugarEntriesO = $client->__SoapCall( 'set_entry', $request_array );
switch($resultType){ switch ($resultType) {
case 'array':$sugarEntries = objectToArray ( $sugarEntriesO ); break; case 'array':
case 'object':$sugarEntries = $sugarEntries; break; $sugarEntries = objectToArray( $sugarEntriesO );
default: $sugarEntries = objectToArray ( $sugarEntries ); break;
case 'object':
$sugarEntries = $sugarEntries;
break;
default:
$sugarEntries = objectToArray( $sugarEntries );
} }
return $sugarEntries; return $sugarEntries;
} }
/** /**
* @method
* *
* Creates SugarCRM entries from the Account module * @method Creates SugarCRM entries from the Account module
* *
* @name CreateSugarLeads * @name CreateSugarLeads
* *
@@ -440,28 +460,37 @@ function CreateSugarOpportunity($sugarSoap, $user, $password, $name,$account_id,
* @return array/object | $sugarContact | Sugar Opportunities (array or object) * @return array/object | $sugarContact | Sugar Opportunities (array or object)
* *
*/ */
function CreateSugarLeads($sugarSoap, $user, $password, $first_name, $last_name, $email, $title, $phone, $account_id, $resultType="array") { function CreateSugarLeads ($sugarSoap, $user, $password, $first_name, $last_name, $email, $title, $phone, $account_id, $resultType = "array")
{
$module = "Leads"; $module = "Leads";
$sessionId = sugarLogin ( $sugarSoap, $user, $password ); $sessionId = sugarLogin( $sugarSoap, $user, $password );
$client = new SoapClient ( $sugarSoap, getSoapClientOptions() ); $client = new SoapClient( $sugarSoap, getSoapClientOptions() );
$request_array = array ('session' => $sessionId, 'module_name' => $module, array( $request_array = array ('session' => $sessionId,'module_name' => $module,array (array ("name" => 'first_name',"value" => $first_name
array("name" => 'first_name',"value" => $first_name), ),array ("name" => 'last_name',"value" => $last_name
array("name" => 'last_name',"value" => $last_name), ),array ("name" => 'email1',"value" => $email
array("name" => 'email1',"value" => $email), ),array ("name" => 'title',"value" => $title
array("name" => 'title',"value" => $title), ),array ("name" => 'phone_work',"value" => $phone
array("name" => 'phone_work',"value" => $phone), ),
// array("name" => 'account_id',"value" => '8cd10a60-101f-4363-1e0b-4cfd4106bd7e') // array("name" => 'account_id',"value" => '8cd10a60-101f-4363-1e0b-4cfd4106bd7e')
array("name" => 'account_id',"value" => $account_id) array ("name" => 'account_id',"value" => $account_id
)); )
)
);
$sugarEntriesO = $client->__SoapCall ( 'set_entry', $request_array ); $sugarEntriesO = $client->__SoapCall( 'set_entry', $request_array );
switch($resultType){ switch ($resultType) {
case 'array':$sugarEntries = objectToArray ( $sugarEntriesO ); break; case 'array':
case 'object':$sugarEntries = $sugarEntries; break; $sugarEntries = objectToArray( $sugarEntriesO );
default: $sugarEntries = objectToArray ( $sugarEntries ); break;
case 'object':
$sugarEntries = $sugarEntries;
break;
default:
$sugarEntries = objectToArray( $sugarEntries );
} }
return $sugarEntries; return $sugarEntries;
} }

View File

@@ -43,14 +43,16 @@ try {
$oCase = new Cases(); $oCase = new Cases();
if (isset( $_POST['APP_UIDS'] )) { if (isset( $_POST['APP_UIDS'] )) {
$ids = explode( ',', $_POST['APP_UIDS'] ); $ids = explode( ',', $_POST['APP_UIDS'] );
foreach ($ids as $id) foreach ($ids as $id) {
$oCase->removeCase( $id ); $oCase->removeCase( $id );
}
if (count( $_POST['APP_UIDS'] ) > 1) if (count( $_POST['APP_UIDS'] ) > 1) {
echo 'The Case was deleted successfully'; echo 'The Case was deleted successfully';
else } else {
echo 'All Cases were deleted successfully'; echo 'All Cases were deleted successfully';
} }
}
} catch (Exception $e) { } catch (Exception $e) {
echo $e->getMessage(); echo $e->getMessage();
} }

View File

@@ -29,8 +29,9 @@
*/ */
/* Permissions */ /* Permissions */
if (($RBAC_Response = $RBAC->userCanAccess( "PM_CASES" )) != 1) if (($RBAC_Response = $RBAC->userCanAccess( "PM_CASES" )) != 1) {
return $RBAC_Response; return $RBAC_Response;
}
/* Includes */ /* Includes */
G::LoadClass( 'case' ); G::LoadClass( 'case' );
@@ -99,8 +100,9 @@ switch ($sTypeList) {
if (defined( 'ENABLE_CASE_LIST_OPTIMIZATION' )) { if (defined( 'ENABLE_CASE_LIST_OPTIMIZATION' )) {
$aCriteria = $oCases->prepareCriteriaForToDo( $sUIDUserLogged ); $aCriteria = $oCases->prepareCriteriaForToDo( $sUIDUserLogged );
$xmlfile = 'cases/cases_ListTodoNew'; $xmlfile = 'cases/cases_ListTodoNew';
} else } else {
list ($aCriteria, $xmlfile) = $oCases->getConditionCasesList( $sTypeList, $sUIDUserLogged, true, $aAdditionalFilter ); list ($aCriteria, $xmlfile) = $oCases->getConditionCasesList( $sTypeList, $sUIDUserLogged, true, $aAdditionalFilter );
}
break; break;
default: default:
list ($aCriteria, $xmlfile) = $oCases->getConditionCasesList( $sTypeList, $sUIDUserLogged, true, $aAdditionalFilter ); list ($aCriteria, $xmlfile) = $oCases->getConditionCasesList( $sTypeList, $sUIDUserLogged, true, $aAdditionalFilter );
@@ -156,14 +158,14 @@ G::RenderPage( 'publish', 'blank' );
function InAssocArray ($a, $k, $v) function InAssocArray ($a, $k, $v)
{ {
foreach ($a as $item) { foreach ($a as $item) {
if (isset( $item[$k] ) && $v == $item[$k]) if (isset( $item[$k] ) && $v == $item[$k]) {
return true; return true;
} }
}
return false; return false;
} }
?> ?>
<script> <script>
try{ try{
oPropelTable = document.getElementById('publisherContent[0]'); oPropelTable = document.getElementById('publisherContent[0]');
@@ -176,4 +178,5 @@ function InAssocArray ($a, $k, $v)
if(parent.refreshCountFolders) parent.refreshCountFolders(); if(parent.refreshCountFolders) parent.refreshCountFolders();
}catch(e){} }catch(e){}
</script> </script>
<?php

View File

@@ -48,7 +48,6 @@ switch ($RBAC->userCanAccess( 'PM_CASES' )) {
G::header( 'location: ../login/login' ); G::header( 'location: ../login/login' );
die(); die();
break; break;
case - 1: case - 1:
G::SendTemporalMessage( 'ID_USER_HAVENT_RIGHTS_PAGE', 'error', 'labels' ); G::SendTemporalMessage( 'ID_USER_HAVENT_RIGHTS_PAGE', 'error', 'labels' );
G::header( 'location: ../login/login' ); G::header( 'location: ../login/login' );
@@ -137,18 +136,21 @@ $aFields['CHANGE_LINK'] = G::LoadTranslation( 'ID_CHANGE_VIEW' );
if (isset( $aMessage )) { if (isset( $aMessage )) {
$G_PUBLISH->AddContent( 'xmlform', 'xmlform', 'login/showMessage', '', $aMessage ); $G_PUBLISH->AddContent( 'xmlform', 'xmlform', 'login/showMessage', '', $aMessage );
} }
if ($listType == 'dropdown') if ($listType == 'dropdown') {
$G_PUBLISH->AddContent( 'xmlform', 'xmlform', $sXmlForm, '', $aFields, 'cases_Save' ); $G_PUBLISH->AddContent( 'xmlform', 'xmlform', $sXmlForm, '', $aFields, 'cases_Save' );
}
if ($listType == 'link') { if ($listType == 'link') {
if ($bCanStart) if ($bCanStart) {
$sXmlForm = 'cases/cases_NewRadioGroup.xml'; $sXmlForm = 'cases/cases_NewRadioGroup.xml';
}
$G_PUBLISH->AddContent( 'xmlform', 'xmlform', $sXmlForm, '', $aFields, 'cases_Save' ); $G_PUBLISH->AddContent( 'xmlform', 'xmlform', $sXmlForm, '', $aFields, 'cases_Save' );
} }
if ($listType == 'category') { if ($listType == 'category') {
if ($bCanStart) if ($bCanStart) {
$sXmlForm = 'cases/cases_NewCategory.xml'; $sXmlForm = 'cases/cases_NewCategory.xml';
}
$G_PUBLISH->AddContent( 'view', 'cases/cases_NewCategory' ); $G_PUBLISH->AddContent( 'view', 'cases/cases_NewCategory' );
} }
@@ -160,3 +162,5 @@ G::RenderPage( 'publish', 'blank' );
parent.PANEL_EAST_OPEN = false; parent.PANEL_EAST_OPEN = false;
</script> </script>
<?php

View File

@@ -21,8 +21,9 @@
* For more information, contact Colosa Inc, 2566 Le Jeune Rd., * For more information, contact Colosa Inc, 2566 Le Jeune Rd.,
* Coral Gables, FL, 33134, USA, or email info@colosa.com. * Coral Gables, FL, 33134, USA, or email info@colosa.com.
*/ */
if (($RBAC_Response = $RBAC->userCanAccess( "PM_CASES" )) != 1) if (($RBAC_Response = $RBAC->userCanAccess( "PM_CASES" )) != 1) {
return $RBAC_Response; return $RBAC_Response;
}
//go to the next step //go to the next step
G::LoadClass( 'case' ); G::LoadClass( 'case' );
$oCase = new Cases(); $oCase = new Cases();

View File

@@ -108,8 +108,8 @@ try {
$oDataset->next(); $oDataset->next();
$aData = $oDataset->getRow(); $aData = $oDataset->getRow();
if ($aData['USR_UID'] != $_SESSION['USER_LOGGED'] && $aData['USR_UID'] != "") //distinct "" for selfservice if ($aData['USR_UID'] != $_SESSION['USER_LOGGED'] && $aData['USR_UID'] != "") {
{ //distinct "" for selfservice
//so we show just the resume //so we show just the resume
$_SESSION['alreadyDerivated'] = true; $_SESSION['alreadyDerivated'] = true;
//the case is paused show only the resume //the case is paused show only the resume
@@ -183,7 +183,6 @@ try {
require_once (PATH_METHODS . 'cases' . PATH_SEP . 'cases_Resume.php'); require_once (PATH_METHODS . 'cases' . PATH_SEP . 'cases_Resume.php');
} }
break; break;
default: //APP_STATUS <> DRAFT and TO_DO default: //APP_STATUS <> DRAFT and TO_DO
$_SESSION['APPLICATION'] = $sAppUid; $_SESSION['APPLICATION'] = $sAppUid;
$_SESSION['INDEX'] = $iDelIndex != "" ? $iDelIndex : $oCase->getCurrentDelegationCase( $_GET['APP_UID'] ); $_SESSION['INDEX'] = $iDelIndex != "" ? $iDelIndex : $oCase->getCurrentDelegationCase( $_GET['APP_UID'] );

View File

@@ -23,7 +23,7 @@
*/ */
/* Permissions */ /* Permissions */
if ($RBAC->userCanAccess( 'PM_SUPERVISOR' ) != 1) if ($RBAC->userCanAccess( 'PM_SUPERVISOR' ) != 1) {
switch ($RBAC->userCanAccess( 'PM_SUPERVISOR' )) { switch ($RBAC->userCanAccess( 'PM_SUPERVISOR' )) {
case - 2: case - 2:
G::SendTemporalMessage( 'ID_USER_HAVENT_RIGHTS_SYSTEM', 'error', 'labels' ); G::SendTemporalMessage( 'ID_USER_HAVENT_RIGHTS_SYSTEM', 'error', 'labels' );
@@ -36,6 +36,7 @@ if ($RBAC->userCanAccess( 'PM_SUPERVISOR' ) != 1)
die(); die();
break; break;
} }
}
/* Includes */ /* Includes */
G::LoadClass( 'case' ); G::LoadClass( 'case' );

View File

@@ -123,3 +123,5 @@ try {
} catch(e){} } catch(e){}
</script> </script>
<?php

View File

@@ -42,11 +42,9 @@ foreach ($pmTableFields as $iRow => $aRow) {
foreach ($pmTableFields as $iRow => $aRow) { foreach ($pmTableFields as $iRow => $aRow) {
$oFields->create( array ('FLD_INDEX' => $iRow + 1,'ADD_TAB_UID' => $sAddTabUid,'FLD_NAME' => $aRow['FLD_NAME'],'FLD_DESCRIPTION' => isset( $aRow['FLD_DESCRIPTION'] ) ? $aRow['FLD_DESCRIPTION'] : '','FLD_TYPE' => isset( $aRow['FLD_TYPE'] ) ? $aRow['FLD_TYPE'] : 'VARCHAR','FLD_SIZE' => isset( $aRow['FLD_SIZE'] ) ? $aRow['FLD_SIZE'] : '32','FLD_NULL' => ($aRow['FLD_NULL'] == 'on' ? 1 : 0),'FLD_AUTO_INCREMENT' => ($aRow['FLD_AUTO_INCREMENT'] == 'on' ? 1 : 0),'FLD_KEY' => ($aRow['FLD_KEY'] == 'on' ? 1 : 0),'FLD_FOREIGN_KEY' => ($aRow['FLD_FOREIGN_KEY'] == 'on' ? 1 : 0),'FLD_FOREIGN_KEY_TABLE' => isset( $aRow['FLD_FOREIGN_KEY_TABLE'] ) ? $aRow['FLD_FOREIGN_KEY_TABLE'] : '' $oFields->create( array ('FLD_INDEX' => $iRow + 1,'ADD_TAB_UID' => $sAddTabUid,'FLD_NAME' => $aRow['FLD_NAME'],'FLD_DESCRIPTION' => isset( $aRow['FLD_DESCRIPTION'] ) ? $aRow['FLD_DESCRIPTION'] : '','FLD_TYPE' => isset( $aRow['FLD_TYPE'] ) ? $aRow['FLD_TYPE'] : 'VARCHAR','FLD_SIZE' => isset( $aRow['FLD_SIZE'] ) ? $aRow['FLD_SIZE'] : '32','FLD_NULL' => ($aRow['FLD_NULL'] == 'on' ? 1 : 0),'FLD_AUTO_INCREMENT' => ($aRow['FLD_AUTO_INCREMENT'] == 'on' ? 1 : 0),'FLD_KEY' => ($aRow['FLD_KEY'] == 'on' ? 1 : 0),'FLD_FOREIGN_KEY' => ($aRow['FLD_FOREIGN_KEY'] == 'on' ? 1 : 0),'FLD_FOREIGN_KEY_TABLE' => isset( $aRow['FLD_FOREIGN_KEY_TABLE'] ) ? $aRow['FLD_FOREIGN_KEY_TABLE'] : '') );
) );
$aFields[] = array ('sType' => isset( $aRow['FLD_TYPE'] ) ? $aRow['FLD_TYPE'] : 'VARCHAR','iSize' => isset( $aRow['FLD_SIZE'] ) ? $aRow['FLD_SIZE'] : '32','sFieldName' => $aRow['FLD_NAME'],'bNull' => ($aRow['FLD_NULL'] == 'on' ? 1 : 0),'bAI' => ($aRow['FLD_AUTO_INCREMENT'] == 'on' ? 1 : 0),'bPrimaryKey' => ($aRow['FLD_KEY'] == 'on' ? 1 : 0) $aFields[] = array ('sType' => isset( $aRow['FLD_TYPE'] ) ? $aRow['FLD_TYPE'] : 'VARCHAR','iSize' => isset( $aRow['FLD_SIZE'] ) ? $aRow['FLD_SIZE'] : '32','sFieldName' => $aRow['FLD_NAME'],'bNull' => ($aRow['FLD_NULL'] == 'on' ? 1 : 0),'bAI' => ($aRow['FLD_AUTO_INCREMENT'] == 'on' ? 1 : 0),'bPrimaryKey' => ($aRow['FLD_KEY'] == 'on' ? 1 : 0));
);
} }
$oAdditionalTables->createTable( strtoupper( $pmTableName ), 'wf', $aFields ); $oAdditionalTables->createTable( strtoupper( $pmTableName ), 'wf', $aFields );
@@ -93,7 +91,7 @@ while ($aRow = $oDataset->getRow()) {
$i++; $i++;
if ( $i == 10 ) die; if ( $i == 10 ) die;
} }
*/ */
$oDataset->next(); $oDataset->next();
} }
print "--$i--"; print "--$i--";

View File

@@ -1,675 +0,0 @@
var installer=function()
{
this.make=function(options)
{
this.options={
target:inst.elements.content,
vdef:{
wf:'wf_workflow',
rb:'rb_workflow',
rp:'rp_workflow'
}
}.concat(options || {});
this.html();
this.check();
};
this.html=function()
{
this.titleBar = document.createElement("div");
this.titleBar.className="app_grid_headerBar___gray";
leimnud.dom.setStyle(this.titleBar,{
height:"auto",
textAlign:"right"
});
this.options.target.appendChild(this.titleBar);
this.options.button0 = document.createElement("input");
this.options.button0.type="button";
this.options.button0.value="Test";
this.titleBar.appendChild(this.options.button0);
this.options.button1 = document.createElement("input");
this.options.button1.type="button";
this.options.button1.value="Install";
this.titleBar.appendChild(this.options.button1);
this.options.button2 = document.createElement("input");
this.options.button2.type="button";
this.options.button2.value="Reset";
this.titleBar.appendChild(this.options.button2);
this.options.phpinfo = document.createElement("input");
this.options.phpinfo.type="button";
this.options.phpinfo.style.fontWeight="bold";
this.options.phpinfo.value="phpinfo()";
this.titleBar.appendChild(this.options.phpinfo);
this.options.phpinfo.onmouseup=this.showPhpinfo;
this.options.button1.disabled=true;
this.options.button0.onmouseup=this.check;
this.options.button1.onmouseup=function(){inst.selectTab(1);}.extend(this);
this.options.button2.onmouseup=this.reset;
this.buttonFun(this.options.button0);
this.buttonFun(this.options.button1);
this.buttonFun(this.options.button2);
this.buttonFun(this.options.phpinfo);
//this.phpVersion =
this.table = $(document.createElement("table"));
/* this.table.setStyle({
cellpadding:23
});*/
this.table.className="inst_table";
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"<b>Requirements</b>",className:"app_grid_title___gray title",colSpan:4})
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"PHP Version > 5.1.0",className:"inst_td0",colSpan:2}),
this.phpVersion = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"MySQL",className:"inst_td0",colSpan:2}),
this.mysqlVersion = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"Maximum amount of memory a script may consume (memory_limit) >= 40M",className:"inst_td0",colSpan:2}),
this.checkMemory = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"Directory "+this.options.path_trunk+"config/<br> permissions: <b>writable</b>",className:"inst_td0",colSpan:2}),
this.checkPI = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"Directory "+this.options.path_trunk+"content/languages/<br> permissions: <b>writable</b>",className:"inst_td0",colSpan:2}),
this.checkDL = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"File "+this.options.path_trunk+"js/labels/<br> permissions: <b>writable</b>",className:"inst_td0",colSpan:2}),
this.checkDLJ = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"File "+this.options.path_trunk+"plugins/<br> permissions: <b>writable</b>",className:"inst_td0",colSpan:2}),
this.checkPL = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"File "+this.options.path_trunk+"xmlform/<br> permissions: <b>writable</b>",className:"inst_td0",colSpan:2}),
this.checkXF = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
/* Database */
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"<b>Database</b>",className:"app_grid_title___gray title",colSpan:2}),
new DOM('td',{className:"app_grid_title___gray title",colSpan:2}).append(
this.select_ao_db = new select({data:[
{value:1,text:"Advanced options by default"},
{value:2,text:"Change Advanced options"}
],
style:{width:"100%",border:"1px solid #919B9C"},
properties:{onchange:function(){
if(this.select_ao_db.selected().value==1)
{
this.ed_advanced_options({
sta:"disabled",
act:'usr',
def:true
});
this.ao_db_wf.passed().value=this.options.vdef.wf;
this.ao_db_rb.passed().value=this.options.vdef.rb;
this.ao_db_rp.passed().value=this.options.vdef.rp;
this.ao_db_drop.checked=false;
}
else
{
this.ed_advanced_options({
act:'usr',
sta:"enabled"
});
this.ao_db_wf.focus();
}
}.extend(this)}
})
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"Database server Hostname",className:"inst_td0"},{width:"30%"}),
new DOM('td',{className:"inst_td1"},{width:"30%"}).append(
// this.databaseHostname =new DOM("input",{value:'localhost',type:"text",onkeyup:this.submit,className:"inputNormal"})
this.databaseHostname = new input({label:'localhost',properties:{onkeyup:this.submit},style:{width:"100%"}})
),
new DOM('td',{innerHTML:"Workflow Database:",className:"inst_td0"},{width:"20%"}),
new DOM('td',{className:"inst_td1"},{width:"20%"}).append(
this.ao_db_wf = new input({label:this.options.vdef.wf,properties:{onkeyup:this.submit},style:{width:"100%"},maxlength:16}).passed().disable()
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"Username",className:"inst_td0"},{width:"30%"}),
new DOM('td',{className:"inst_td1"},{width:"30%"}).append(
// this.databaseUsername =new DOM("input",{value:'root',type:"text",onkeyup:this.submit,className:"inputNormal"})
this.databaseUsername = new input({label:'root',properties:{onkeyup:this.submit},style:{width:"100%"}})
),
new DOM('td',{innerHTML:"Rbac Database:",className:"inst_td0"},{width:"20%"}),
new DOM('td',{className:"inst_td1"},{width:"20%"}).append(
this.ao_db_rb = new input({label:this.options.vdef.rb,properties:{onkeyup:this.submit},style:{width:"100%"},maxlength:16}).passed().disable()
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"Password",className:"inst_td0"},{width:"30%"}),
new DOM('td',{className:"inst_td1"},{width:"30%"}).append(
// this.databasePassword =new DOM("input",{type:"text",onkeyup:this.submit,className:"inputNormal"})
this.databasePassword = new input({properties:{type:'password',onkeyup:this.submit},style:{width:"100%"}})
),
new DOM('td',{innerHTML:"Report Database:",className:"inst_td0"},{width:"20%"}),
new DOM('td',{className:"inst_td1"},{width:"20%"}).append(
this.ao_db_rp = new input({label:this.options.vdef.rp,properties:{onkeyup:this.submit},style:{width:"100%"},maxlength:16}).passed().disable()
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"Database Access",className:"inst_td0"},{width:"30%"}),
this.databaseGrant = new DOM('td',{className:"inst_td1"},{width:"30%"}),
new DOM('td',{innerHTML:"DROP DATABASE IF EXISTS",className:"inst_td0"},{width:"20%"}),
new DOM('td',{className:"inst_td0"},{width:"20%",textAlign:'left'}).append(
this.ao_db_drop = new input({
properties:{type:'checkbox',disabled:true,className:''},style:{border:"1px solid #666"}
})
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
this.databaseStatus = new DOM('td',{innerHTML:"<br>",className:"tdNormal",colSpan:4},{height:50})
);
/* Database End */
/* Directories Begin */
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"<b>Processmaker Configuration</b>",className:"app_grid_title___gray title",colSpan:2}),
new DOM('td',{className:"app_grid_title___gray title",colSpan:2}).append(
this.select_ao_pm = new select({data:[
{value:1,text:"Advanced options by default"},
{value:2,text:"Change Advanced options"}
],
style:{width:"100%",border:"1px solid #919B9C"},
properties:{onchange:function(){
if(this.select_ao_pm.selected().value==1)
{
this.ed_advanced_options({
act:'pm',
sta:"disabled",
def:true
});
this.ao_admin.passed().value="admin";
this.ao_admin_pass1.passed().value="admin";
this.ao_admin_pass2.passed().value="admin";
}
else
{
this.ed_advanced_options({
act:'pm',
sta:"enabled"
});
this.ao_admin.focus();
}
}.extend(this)}
})
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"Workflow Data Directory (permissions: <b>writable</b>): ",className:"inst_td0"},{width:"30%"}),
new DOM('td',{className:"inst_td1"},{width:"30%"}).append(
this.workflowData = new input({label:this.options.path_data,properties:{onkeyup:this.submit},style:{width:"100%"},maxlength:200})
),
new DOM('td',{innerHTML:"Username (Default: admin):",className:"inst_td0"},{width:"20%"}),
new DOM('td',{className:"inst_td1"},{width:"20%"}).append(
this.ao_admin = new input({label:'admin',properties:{onkeyup:this.submit},style:{width:"100%"}}).passed().disable()
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"",className:"inst_td0"},{width:"30%"}),
new DOM('td',{className:"inst_td1"},{width:"30%"}).append(
this.compiled = new input({label:this.options.path_compiled,properties:{onkeyup:this.submit},style:{width:"100%", display:'none'},maxlength:200})
),
new DOM('td',{innerHTML:"Username (Default: admin):",className:"inst_td0"},{width:"20%"}),
new DOM('td',{className:"inst_td1"},{width:"20%"}).append(
this.ao_admin_pass1 = new input({label:'admin',properties:{onkeyup:this.submit,type:'password'},style:{width:"100%"}}).passed().disable()
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{className:"inst_td0",colSpan:2}),
new DOM('td',{innerHTML:"Re-type Password:",className:"inst_td0"},{width:"20%"}),
new DOM('td',{className:"inst_td1"},{width:"20%"}).append(
this.ao_admin_pass2 = new input({label:'admin',properties:{onkeyup:this.submit,type:'password'},style:{width:"100%"}}).passed().disable()
)
);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"<b>HeartBeat Configuration</b><br><i>Heartbeat is an anonymous statistics collector for ProcessMaker. It runs in the background and if you have internet enabled, it will periodically send anonymous information to ProcessMaker servers.<br />No sensitive or private information is collected.<br /><br /> The information collected will allow us to keep improving our software to offer everyone a better user experience</i>",className:"app_grid_title___gray title",colSpan:4})
);
this.heartBeatTitle=tr;
var tr = this.table.insertRow(-1);
$(tr).append(
this.heartBeat =
new DOM('td',{innerHTML:"Enable HeartBeat",className:"inst_td0"},{width:"20%"}),
new DOM('td',{className:"inst_td0",colSpan:2},{textAlign:'left'}).append(
this.ao_hb_status = new input({
properties:{type:'checkbox',disabled:false,checked:true,className:''},style:{border:"1px solid #666"}
})
)
);
this.heartBeatRow=tr;
//alert(this.options.availableProcess);
//alert(this.options.availableProcess.length);
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"<b>Available Processes (auto install)</b>",className:"app_grid_title___gray title",colSpan:4})
);
this.availableProcessTitle=tr;
var tr = this.table.insertRow(-1);
$(tr).append(
this.availableProcess = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
this.availableProcessRow=tr;
var tr = this.table.insertRow(-1);
$(tr).append(
new DOM('td',{innerHTML:"<b>Available Plugins (auto install)</b>",className:"app_grid_title___gray title",colSpan:4})
);
this.availablePluginsTitle=tr;
var tr = this.table.insertRow(-1);
$(tr).append(
this.availablePlugins = new DOM('td',{innerHTML:'Loading...',className:"inst_td1",colSpan:2})
);
this.availablePluginsRow=tr;
leimnud.dom.setStyle([this.workflowData,this.compiled],{
textAlign:"left"
});
this.options.target.appendChild(this.table);
};
this.formData=function()
{
//alert(this.databaseExe.value.eplace("\\","/"))
return {
mysqlH :escape(this.databaseHostname.value),
mysqlU :escape(this.databaseUsername.value),
mysqlP :escape(this.databasePassword.value),
// port :this.port.value,
path_data:this.workflowData.value,
path_compiled:this.compiled.value,
ao_admin :escape(this.ao_admin.value),
ao_admin_pass1 :escape(this.ao_admin_pass1.value),
ao_admin_pass2 :escape(this.ao_admin_pass2.value),
ao_db_wf :this.ao_db_wf.value,
ao_db_rb :this.ao_db_rb.value,
ao_db_rp :this.ao_db_rp.value,
ao_db :parseInt(this.select_ao_db.selected().value),
ao_pm :parseInt(this.select_ao_pm.selected().value),
ao_db_drop :this.ao_db_drop.checked,
heartbeatEnabled :this.ao_hb_status.checked
};
};
this.check=function()
{
inst.loader.show();
this.disabled(true);
this.ed_advanced_options({sta:'disabled',act:'all'});
var r = new leimnud.module.rpc.xmlhttp({
url :this.options.server,
method :"POST",
args :"action=check&data="+this.formData().toJSONString()
});
r.callback=function(rpc)
{
try
{
this.cstatus = rpc.xmlhttp.responseText.parseJSON();
}
catch(e)
{
this.cstatus={
ao_db_wf:false,
ao_db_rb:false,
ao_db_rp:false
};
}
this.phpVersion.className = (!this.cstatus.phpVersion)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.phpVersion.innerHTML = (!this.cstatus.phpVersion)?"FAILED":"PASSED";
this.mysqlVersion.className = (!this.cstatus.mysqlVersion)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.mysqlVersion.innerHTML = (!this.cstatus.mysqlVersion)?"FAILED":"PASSED";
this.checkMemory.className = (!this.cstatus.checkMemory)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.checkMemory.innerHTML = (!this.cstatus.checkMemory)?"FAILED":"PASSED";
// this.checkmqgpc.className = (!this.cstatus.checkmqgpc)?"inst_td1 tdFailed":"inst_td1 tdOk";
// this.checkmqgpc.innerHTML = (!this.cstatus.checkmqgpc)?"FAILED":"PASSED";
this.checkPI.className = (!this.cstatus.checkPI)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.checkPI.innerHTML = (!this.cstatus.checkPI)?"FAILED":"PASSED";
this.checkDL.className = (!this.cstatus.checkDL)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.checkDL.innerHTML = (!this.cstatus.checkDL)?"FAILED":"PASSED";
this.checkDLJ.className = (!this.cstatus.checkDLJ)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.checkDLJ.innerHTML = (!this.cstatus.checkDLJ)?"FAILED":"PASSED";
this.checkPL.className = (!this.cstatus.checkPL)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.checkPL.innerHTML = (!this.cstatus.checkPL)?"FAILED":"PASSED";
this.checkXF.className = (!this.cstatus.checkXF)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.checkXF.innerHTML = (!this.cstatus.checkXF)?"FAILED":"PASSED";
this.databaseHostname[(!this.cstatus.mysqlConnection)?"failed":"passed"]();
this.databaseUsername[(!this.cstatus.mysqlConnection)?"failed":"passed"]();
this.databasePassword[(!this.cstatus.mysqlConnection)?"failed":"passed"]();
this.databaseGrant.className = (!this.cstatus.grantPriv && this.select_ao_db.selected().value==1)?"inst_td1 tdFailed":"inst_td1 tdOk";
this.databaseGrant.innerHTML = (!this.cstatus.grantPriv)?"FAILED":((this.cstatus.grantPriv==1)?'ALL PRIVILEGES':'USAGE');
this.databaseStatus.className = (!this.cstatus.grantPriv || !this.cstatus.mysqlConnection)?"tdFailed":"tdOk";
this.databaseStatus.innerHTML = this.cstatus.databaseMessage;
this.workflowData[(!this.cstatus.path_data)?"failed":"passed"]();
this.compiled[(!this.cstatus.path_compiled)?"failed":"passed"]();
this.ao_db_wf[((!this.cstatus.ao_db_wf['status'])?"failed":"passed")]();
this.ao_db_rb[((!this.cstatus.ao_db_rb['status'])?"failed":"passed")]();
this.ao_db_rp[((!this.cstatus.ao_db_rp['status'])?"failed":"passed")]();
this.ao_admin[(!this.cstatus.ao_admin && this.select_ao_pm.selected().value==2)?"failed":"passed"]();
this.ao_admin_pass1[(!this.cstatus.ao_admin_pass && this.select_ao_pm.selected().value==2)?"failed":"passed"]();
this.ao_admin_pass2[(!this.cstatus.ao_admin_pass && this.select_ao_pm.selected().value==2)?"failed":"passed"]();
if(this.cstatus.ao_db_wf['status'] && this.cstatus.ao_db_rb['status'] && this.cstatus.ao_db_rp['status'] && this.cstatus.ao_admin && this.cstatus.ao_admin_pass && this.cstatus.checkMemory && this.cstatus.checkPI && this.cstatus.checkDL && this.cstatus.checkDLJ && this.cstatus.checkPL && this.cstatus.checkXF && this.cstatus.phpVersion && this.cstatus.mysqlVersion && this.cstatus.mysqlConnection && this.cstatus.grantPriv && this.cstatus.path_data && this.cstatus.path_compiled)
{
this.options.button0.disabled=true;
this.options.button1.disabled=false;
this.disabled(true);
}
else
{
this.options.button0.disabled=false;
this.options.button1.disabled=true;
this.disabled(false);
try {
this.compiled.focus();
} catch(err) {}
this.ed_advanced_options({sta:((this.select_ao_db.selected().value==2)?'enabled':'disabled'),act:'usr'});
this.ed_advanced_options({sta:((this.select_ao_pm.selected().value==2)?'enabled':'disabled'),act:'pm'});
}
this.buttonFun(this.options.button0);
this.buttonFun(this.options.button1);
this.ao_db_wf.title=this.cstatus.ao_db_wf.message;
this.ao_db_rb.title=this.cstatus.ao_db_rb.message;
this.ao_db_rp.title=this.cstatus.ao_db_rp.message;
this.ao_admin.title=(this.cstatus.ao_admin)?'Username invalid':'PASSED';
//*Autoinstall Process and Plugins. By JHL
// March 11th. 2009
// To enable the way of aoutoinstall process and/or plugins
// at same time of initial PM setup
if(this.cstatus.availableProcess.length>0){
this.availableProcess.className = "inst_td1 tdOk";
this.availableProcess.innerHTML="";
for(i_process=0;i_process<this.cstatus.availableProcess.length;i_process++){
this.availableProcess.innerHTML+=this.cstatus.availableProcess[i_process]+"<br />";
}
}else{
//Hide entire Group
this.availableProcessTitle.style.display="none";
this.availableProcessRow.style.display="none";
}
if(this.cstatus.availablePlugins.length>0){
this.availablePlugins.className = "inst_td1 tdOk";
this.availablePlugins.innerHTML="";
for(i_plugin=0;i_plugin<this.cstatus.availablePlugins.length;i_plugin++){
this.availablePlugins.innerHTML+=this.cstatus.availablePlugins[i_plugin]+"<br />";
}
}else{
//Hide entire Group
this.availablePluginsTitle.style.display="none";
this.availablePluginsRow.style.display="none";
}
//End Autoinstall
inst.loader.hide();
}.extend(this);
r.make();
};
this.reset=function()
{
this.options.button1.disabled=true;
this.buttonFun(this.options.button1);
this.disabled(false);
};
this.disabled=function(dis)
{
this.databaseHostname[(dis===true)?'disable':'enable']();
this.databaseUsername[(dis===true)?'disable':'enable']();
this.databasePassword[(dis===true)?'disable':'enable']();
this.workflowData[(dis===true)?'disable':'enable']();
this.compiled[(dis===true)?'disable':'enable']();
if(this.compiled.disabled===false)
{
try {
this.compiled.focus();
} catch(err) {}
}
this.options.button0.disabled=dis;
this.buttonFun(this.options.button0);
};
this.ed_advanced_options=function(options)
{
options = {
sta:"disabled",
act:"all",
def:false
}.concat(options || {});
if(options.act=='pm' || options.act=="all")
{
this.ao_admin[(options.sta=="disabled")?'disable':'enable']();
this.ao_admin_pass1[(options.sta=="disabled")?'disable':'enable']();
this.ao_admin_pass2[(options.sta=="disabled")?'disable':'enable']();
}
if(options.act=='usr' || options.act=="all")
{
this.ao_db_wf[(options.sta=="disabled")?'disable':'enable']();
this.ao_db_rb[(options.sta=="disabled")?'disable':'enable']();
this.ao_db_rp[(options.sta=="disabled")?'disable':'enable']();
this.ao_db_drop.disabled=(options.sta=="disabled")?true:false;
}
};
this.submit=function(evt)
{
var evt = (window.event)?window.event:evt;
var key = (evt.which)?evt.which:evt.keyCode;
if(key==13)
{
this.check();
}
return false;
};
this.install=function()
{
this.values = this.formData();
inst.clearContent();
inst.loader.show();
this.options.button2.disabled=true;
this.options.button1.disabled=true;
var r = new leimnud.module.rpc.xmlhttp({
url :this.options.server,
method :"POST",
args :"action=install&data="+this.values.toJSONString()
});
r.callback=this.installation;
r.make();
};
this.installation=function(rpc)
{
/* var r = new leimnud.module.rpc.xmlhttp({
url :"/sysworkflow/en/classic/tools/updateTranslation",
method :"GET"
});
r.callback=function(rpc)
{*/
inst.loader.hide();
this.table = document.createElement("table");
this.table.className="inst_table";
var success = (rpc.xmlhttp.status == 200);
var tr = this.table.insertRow(-1);
var tdtitle = tr.insertCell(0);
tdtitle.innerHTML="Status";
tdtitle.className="app_grid_title___gray title";
var tr = this.table.insertRow(-1);
var td0 = tr.insertCell(0);
td0.innerHTML=(success) ? "Success" : "Failed (Check log below)";
td0.className=(success) ? "tdOk" : "tdFailed";
this.options.target.appendChild(this.table);
if (success) {
var tr = this.table.insertRow(-1);
var tdS = tr.insertCell(0);
tdS.colSpan = 2;
tdS.innerHTML="<br><br>";
tdS.className="tdNormal";
this.options.buttong = document.createElement("input");
this.options.buttong.type="button";
this.options.buttong.value="Finish Installation";
this.options.buttong.onmouseup=function()
{
window.location = "/sysworkflow/en/classic/login/login";
}.extend(this);
tdS.appendChild(this.options.buttong);
this.buttonFun(this.options.buttong);
tdS.appendChild(document.createElement("br"));
tdS.appendChild(document.createElement("br"));
}
var tr = this.table.insertRow(-1);
var tdtitle = tr.insertCell(0);
tdtitle.innerHTML="Installation Log";
tdtitle.className="app_grid_title___gray title";
var tr = this.table.insertRow(-1);
var td0 = tr.insertCell(0);
var pre = document.createElement('pre');
pre.style.overflow='scroll';
pre.style.width=(this.options.target.clientWidth-10)+"px";
pre.style.height=((this.options.target.clientHeight-this.table.clientHeight)-15)+'px';
pre.innerHTML=rpc.xmlhttp.responseText;
td0.appendChild(pre);
// }.extend(this);
// r.make();
};
this.buttonFun=function(but)
{
if(but.disabled==true)
{
but.className="app_grid_title___gray button buttonDisabled";
but.onmouseover=function(){ this.className="app_grid_title___gray button buttonDisabled"};
but.onmouseout=function(){ this.className="app_grid_title___gray button buttonDisabled"};
but.onblur=function(){ this.className="app_grid_title___gray button buttonDisabled"};
}
else
{
but.className="app_grid_title___gray button";
but.onmouseover=function(){ this.className="app_grid_title___gray button buttonHover"};
but.onmouseout=function(){ this.className="app_grid_title___gray button"};
but.onblur=function(){ this.className="app_grid_title___gray button"};
}
};
this.showPhpinfo=function()
{
var panel = new leimnud.module.panel();
panel.options={
title:"PHP info",
position:{center:true},
size:{w:700,h:document.body.clientHeight-50},
fx:{modal:true}
};
panel.make();
var r = new leimnud.module.rpc.xmlhttp({
url :"install.php",
method :"POST",
args :"phpinfo=true"
});
r.callback=function(rpc)
{
panel.addContent(rpc.xmlhttp.responseText);
};
r.make();
};
this.expand(this);
}

View File

@@ -1,209 +0,0 @@
<?php
/**
* install.php
*
* ProcessMaker Open Source Edition
* Copyright (C) 2004 - 2008 Colosa Inc.23
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* For more information, contact Colosa Inc, 2566 Le Jeune Rd.,
* Coral Gables, FL, 33134, USA, or email info@colosa.com.
*/
/**
* Default home page view
*
* @author MaBoRaK
* @version 0.1
*/
if ($_POST && isset( $_POST['phpinfo'] )) {
phpinfo();
die();
}
echo '<?xml version="1.0" encoding="UTF-8" ?>';
?>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Processmaker Installer</title>
<script type='text/javascript' src='/js/maborak/core/maborak.js'></script>
<link rel="stylesheet" type="text/css"
href="/js/maborak/samples/style.css" />
<script type='text/javascript' src='/sys/en/classic/install/install.js'></script>
<script type='text/javascript'>
var ifr;
var forceCssLoad = true;
var grid,winGrill, leimnud = new maborak(forceCssLoad);
var inWIN = false;
leimnud.make();
leimnud.Package.Load("dom,validator,app,rpc,fx,drag,drop,panel,grid,abbr",{Instance:leimnud,Type:"module"});
leimnud.Package.Load("json",{Type:"file"});
leimnud.exec(leimnud.fix.memoryLeak);
var inst;
leimnud.event.add(window,'load',function(){myload();});
var myload = function() {
if (typeof(DOM) === 'undefined') {
setTimeout("myload();", 1000);
return;
}
inst = new leimnud.module.panel();
inst.options={
size:{w:document.body.offsetWidth-50,h:825},
title :"",
position:{x:2,y:2,center:true},
statusBar:false,
control:{
roll :false,
close :false
},
fx:{
shadow:false,
fadeIn:false
}
};
inst.setStyle={
content:{padding:2}
};
var classInstaller = new installer();
inst.tab={
optWidth:190,
manualDisabled:true,
step :(leimnud.browser.isIE?-1:5),
options:[{
title :"Configuration",
content :function()
{
classInstaller.make({
server :"installServer.php",
path_data:"<?php echo defined('PATH_DATA')?PATH_DATA:PATH_TRUNK.'shared';?>",
path_compiled:"<?php echo defined('PATH_C')?PATH_C:PATH_TRUNK.'compiled';?>",
path_trunk:"<?php echo PATH_CORE;?>"
});
},
selected:true
},
{
title :"Installation",
noClear : true,
content :classInstaller.install
}
]
};
inst.make();
};
</script>
<style>
input {
font: normal 8pt sans-serif, Tahoma, MiscFixed;
}
body {
background-color: white;
font: normal 8pt sans-serif, Tahoma;
}
.inst_table {
width: 100%;
border-collapse: collapse;
font: normal 8pt Tahoma, sans-serif;
}
.inst_td0 {
width: 60%;
text-align: right;
border: 1px solid #CCC;
padding: 5px;
}
.inst_td1 {
font-weight: bold;
width: 40%;
padding: 5px;
border: 1px solid #CCC;
text-align: center;
}
.tdNormal,.tdOk,.tdFailed {
font-weight: bold;
border: 1px solid #CCC;
text-align: center;
}
.tdOk {
font-weight: bold;
color: green;
padding: 6px;
}
.tdFailed {
font-weight: bold;
color: red;
}
.title {
text-align: left;
padding-left: 10px;
}
.inputNormal,.inputOk,.inputFailed {
width: 100%;
border: 1px solid #666;
border-left: 3px solid #666;
font: normal 8pt Tahoma, sans-serif;
text-align: center;
}
.inputOk {
border: 1px solid green;
border-left: 3px solid green;
}
.inputFailed {
border: 1px solid red;
border-left: 3px solid red;
}
.button {
font: normal 8pt Tahoma, MiscFixed, sans-serif;
border: 1px solid #afafaf;
margin-left: 2px;
color: black;
cursor: pointer;
}
.buttonHover {
border: 1px solid #666;
background-position: 0 -8;
}
.buttonDisabled {
border: 1px solid #9f9f9f;
background-position: 0 -10;
color: #9f9f9f;
cursor: default;
}
</style>
</head>
<body>
<?php
//exec("mkdir /var/www/html/asas",$console);
?>
</body>
</html>

View File

@@ -1,380 +0,0 @@
<?php
/**
* installServer.php
*
* ProcessMaker Open Source Edition
* Copyright (C) 2004 - 2008 Colosa Inc.23
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* For more information, contact Colosa Inc, 2566 Le Jeune Rd.,
* Coral Gables, FL, 33134, USA, or email info@colosa.com.
*/
$isWindows = PHP_OS == 'WINNT' ? true : false;
$oJSON = new Services_JSON();
$action = $_POST['action'];
$dataClient = $oJSON->decode( stripslashes( $_POST['data'] ) );
function find_SQL_Version ($my = 'mysql', $infExe = null)
{
if (PHP_OS == "WINNT" && ! $infExe) {
return false;
}
$output = shell_exec( $my . ' -V' );
preg_match( '@[0-9]+\.[0-9]+\.[0-9]+@', $output, $version );
return $version[0];
}
if ($action === "check") {
/* TODO: Check if this space is required */
print " ";
G::LoadClass( 'Installer' );
$inst = new Installer();
$siteName = "workflow";
$p1 = (isset( $dataClient->ao_admin_pass1 )) ? $dataClient->ao_admin_pass1 : 'admin';
$p2 = (isset( $dataClient->ao_admin_pass2 )) ? $dataClient->ao_admin_pass2 : 'admin';
$s = $inst->create_site( Array ('name' => 'workflow','path_data' => $dataClient->path_data,'path_compiled' => $dataClient->path_compiled,'admin' => Array ('username' => (isset( $dataClient->ao_admin )) ? $dataClient->ao_admin : 'admin','password' => $p1
),'advanced' => Array ('ao_db' => (isset( $dataClient->ao_db ) && $dataClient->ao_db === 2) ? false : true,'ao_db_drop' => (isset( $dataClient->ao_db_drop ) && $dataClient->ao_db_drop === true) ? true : false,'ao_db_wf' => (isset( $dataClient->ao_db_wf )) ? $dataClient->ao_db_wf : 'wf_' . $siteName,'ao_db_rb' => (isset( $dataClient->ao_db_rb )) ? $dataClient->ao_db_rb : 'rb_' . $siteName,'ao_db_rp' => (isset( $dataClient->ao_db_rp )) ? $dataClient->ao_db_rp : 'rp_' . $siteName
),'database' => Array ('hostname' => $dataClient->mysqlH,'username' => $dataClient->mysqlU,'password' => $dataClient->mysqlP
)
) );
$data = null;
$data->phpVersion = (version_compare( PHP_VERSION, "5.1.0", ">" )) ? true : false;
if (trim( $dataClient->mysqlH ) == '' || trim( $dataClient->mysqlU ) == '') {
$con = array ('connection' => false,'grant' => false,'message' => 'Please complete the input fields (Hostname/Username)'
);
}
$data->mysqlConnection = $s['result']['database']['connection'];
$data->grantPriv = $s['result']['database']['grant'];
$data->databaseMessage = $s['result']['database']['message'];
$data->mysqlVersion = $s['result']['database']['version'];
$data->path_data = $s['result']['path_data'];
$data->path_compiled = true;
$data->checkMemory = (((int) ini_get( "memory_limit" )) >= 40) ? true : false;
#$data->checkmqgpc =(get_magic_quotes_gpc())?false:true;
$data->checkPI = $inst->is_dir_writable( PATH_CORE . "config/" );
$data->checkDL = $inst->is_dir_writable( PATH_CORE . "content/languages/" );
$data->checkDLJ = $inst->is_dir_writable( PATH_CORE . "js/labels/" );
$data->checkPL = $inst->is_dir_writable( PATH_CORE . "plugins/" );
$data->checkXF = $inst->is_dir_writable( PATH_CORE . "xmlform/" );
$data->ao_db_wf = $s['result']['database']['ao']['ao_db_wf'];
$data->ao_db_rb = $s['result']['database']['ao']['ao_db_rb'];
$data->ao_db_rp = $s['result']['database']['ao']['ao_db_rp'];
$data->ao_admin = $s['result']['admin']['username'];
$data->ao_admin_pass = ($p1 !== $p2) ? false : true;
//*Autoinstall Process and Plugins. By JHL
// March 11th. 2009
// To enable the way of aoutoinstall process and/or plugins
// at same time of initial PM setup
//Get Available autoinstall process
$data->availableProcess = $inst->getDirectoryFiles( PATH_OUTTRUNK . "autoinstall", "pm" );
//Get Available autoinstall plugins
$data->availablePlugins = $inst->getDirectoryFiles( PATH_OUTTRUNK . "autoinstall", "tar" );
//End autoinstall
$data->microtime = microtime( true );
echo $oJSON->encode( $data );
} elseif ($action === "install") {
/*
* Installation with SIMPLE POST
*
* Data necessary for the POST:
*
*
* action=install
* data= {"mysqlE":"Path/to/mysql.exe",
* "mysqlH":"Mysqlhostname",
* "mysqlU":"mysqlUsername",
* "mysqlP":"mysqlPassword",
* "path_data":"/path/to/workflow_data/",
* "path_compiled":"/path/to/compiled/",
* "heartbeatEnabled":"1"}
*
*--------------------------------------------------------------------------------------------------------------
*
* Steps to install.
* 1) This data is required:
* $HOSTNAME
* $USERNAME
* $PASSWORD
* $PATH_TO_WORKFLOW_DATA
* $PATH_TO_COMPILED DATA
* 2) create $PATH_TO_WORKFLOW_DATA
* 3) create $PATH_TO_COMPILED_DATA
* 4) Create the site workflow
*
* 4.1 Create user (mysql) wf_workflow , password: sample
* 4.1.1 Create database wf_workflow with user wf_workflow
* 4.1.2 Give all priviledges to database wf_workflow for user wf_workflow
* 4.1.3 Dump file processmaker/workflow/engine/data/mysql/schema.sql
* 4.1.4 Dump file processmaker/workflow/engine/data/mysql/insert.sql
*
* 4.2 Create user (mysql) wf_rbac, password: sample
* 4.2.1 Create database wf_rbac with user wf_rbac
* 4.2.2 Give all priviledges to databse wf_rbac for user wf_rbac
* 4.2.3 Dump file processmaker/rbac/engine/data/mysql/schema.sql
* 4.2.4 Dump file processmaker/rbac/engine/data/mysql/insert.sql
*
* 4.3 Create configuratoin file and directories to site workflow
*
* 4.3.1 Create directories:
*
* $PATH_TO_WORKFLOW_DATA./sites/workflow/
* $PATH_TO_WORKFLOW_DATA./sites/workflow/cutomFunctions/
* $PATH_TO_WORKFLOW_DATA./sites/workflow/rtfs/
* $PATH_TO_WORKFLOW_DATA./sites/workflow/xmlforms/
* $PATH_TO_WORKFLOW_DATA./sites/workflow/processesImages/
* $PATH_TO_WORKFLOW_DATA./sites/workflow/files/
* 4.3.2 Create file.
*
* $PATH_TO_WORKFLOW_DATA./sites/workflow/db.php
*
* with these contents replacing $HOSTNAME.
*
<?php
// Processmaker configuration
define ('DB_ADAPTER', 'mysql' );
define ('DB_HOST', $HOSTNAME );
define ('DB_NAME', 'wf_workflow' );
define ('DB_USER', 'wf_workflow' );
define ('DB_PASS', 'sample' );
define ('DB_RBAC_HOST', $HOSTNAME );
define ('DB_RBAC_NAME', 'rbac_workflow' );
define ('DB_RBAC_USER', 'rbac_workflow' );
define ('DB_RBAC_PASS', 'sample' );
?>
* 4.4 Create file workflow/engine/config/paths_installed.php with these contents.
*
* <?php
define( 'PATH_DATA', '$PATH_TO_WORKFLOW_DATA' );
define( 'PATH_C', '$PATH_TO_COMPILED_DATA' );
?>
* Restarting:
* $PATH_TO_WORKFLOW_DATA
* $PATH_TO_COMPILED DATA
*
* 4.2 Update translation from this url (background)
*
* http://ProcessmakerHostname/sysworkflow/en/classic/tools/updateTranslation
*
*
*
*
*5) Auto install processes and plugins
*5.1 Install processes
*5.2 Install plugins
* */
$report = null;
try {
require_once 'Log.php';
$sp = "/";
$dir_data = $dataClient->path_data;
$dir_data = (substr( $dir_data, - 1 ) == $sp) ? $dir_data : $dir_data . "/";
$dir_compiled = $dir_data . "compiled/";
$dir_log = "{$dir_data}log/";
global $isWindows;
@mkdir( $dir_data . "sites", 0777, true );
@mkdir( $dir_compiled, 0777, true );
@mkdir( $dir_log, 0777, true );
$logFilename = "{$dir_log}install.log";
$displayLog = Log::singleton( 'display', '', 'INSTALLER', array ('lineFormat' => "%{message}"
) );
$fileLog = Log::singleton( 'file', $logFilename, 'INSTALLER' );
global $logger;
$logger = Log::singleton( 'composite' );
$logger->addChild( $displayLog );
$create_db = "create-db.sql";
$schema = "schema.sql";
G::LoadClass( 'Installer' );
/* Create default workspace called workflow */
$inst = new Installer();
$siteName = "workflow";
$p1 = (isset( $dataClient->ao_admin_pass1 )) ? $dataClient->ao_admin_pass1 : 'admin';
$p2 = (isset( $dataClient->ao_admin_pass2 )) ? $dataClient->ao_admin_pass2 : 'admin';
$s = $inst->create_site( Array ('name' => 'workflow','path_data' => $dataClient->path_data,'path_compiled' => $dataClient->path_compiled,'admin' => Array ('username' => (isset( $dataClient->ao_admin )) ? $dataClient->ao_admin : 'admin','password' => $p1
),'advanced' => Array ('ao_db' => (isset( $dataClient->ao_db ) && $dataClient->ao_db === 2) ? false : true,'ao_db_drop' => (isset( $dataClient->ao_db_drop ) && $dataClient->ao_db_drop === true) ? true : false,'ao_db_wf' => (isset( $dataClient->ao_db_wf )) ? $dataClient->ao_db_wf : 'wf_' . $siteName,'ao_db_rb' => (isset( $dataClient->ao_db_rb )) ? $dataClient->ao_db_rb : 'rb_' . $siteName,'ao_db_rp' => (isset( $dataClient->ao_db_rp )) ? $dataClient->ao_db_rp : 'rp_' . $siteName
),'database' => Array ('hostname' => $dataClient->mysqlH,'username' => $dataClient->mysqlU,'password' => $dataClient->mysqlP
)
), true );
if ($s['created']) {
$report = $inst->report;
} else {
/* On a failed install, $inst->report is blank because the
* installation didnt occured at all. So we use the test report
* instead.
*/
$report = $s['result'];
}
$installError = (! $s['created']);
} catch (Exception $e) {
$installError = ($e->getMessage() ? $e->getMessage() : true);
}
if ($installError) {
header( 'HTTP', true, 500 );
}
/* Status is used in the Windows installer, do not change this */
print_r( "Status: " . (($installError) ? 'FAILED' : 'SUCCESS') . "\n\n" );
/* Try to open the file log, if it fails, set it to NULL, so we don't try to
* write to it again afterwards. If it succeeds, add to the logger.
* Only open the log after writing status, otherwise a warning can be issued
* which will affect the Windows installer.
*/
if (! $fileLog->open()) {
$fileLog = null;
$displayLog->log( "Failed to create file log in $logFilename" );
} else {
$logger->addChild( $fileLog );
$fileLog->log( " ** Starting installation ** " );
$fileLog->log( "Status: " . (($installError) ? 'FAILED' : 'SUCCESS') );
$displayLog->log( "This log is also available in $logFilename" );
}
$installArgs = (array) $dataClient;
$hiddenFields = array ('mysqlP','ao_admin_pass1','ao_admin_pass2');
foreach ($installArgs as $arg => $param) {
if (in_array( $arg, $hiddenFields )) {
$installArgs[$arg] = "********";
}
}
$logger->log( "Installation arguments\n" . neat_r( array ($installArgs) ) );
if (isset( $report )) {
$logger->log( "Installation report\n" . neat_r( array ($report ) ) );
} else {
$logger->log( "** Installation crashed **" );
}
if (is_string( $installError )) {
$logger->log( "Error message: $installError" );
}
if ($installError) {
$logger->log( "Installation ending with errors" );
die();
}
$sh = md5( filemtime( PATH_GULLIVER . "/class.g.php" ) );
$h = G::encrypt( $dataClient->mysqlH . $sh . $dataClient->mysqlU . $sh . $dataClient->mysqlP . $sh . $inst->cc_status, $sh );
$db_text = "<?php\n" . "define( 'PATH_DATA', '" . $dir_data . "' );\n" . "define( 'PATH_C', '" . $dir_compiled . "' );\n" . "define( 'HASH_INSTALLATION','" . $h . "' );\n" . "define( 'SYSTEM_HASH','" . $sh . "' );\n" . "?>";
$fp = fopen( FILE_PATHS_INSTALLED, "w" );
fputs( $fp, $db_text, strlen( $db_text ) );
fclose( $fp );
/* Update languages */
$update = file_get_contents( "http://" . $_SERVER['SERVER_NAME'] . ":" . $_SERVER['SERVER_PORT'] . "/sysworkflow/en/classic/tools/updateTranslation" );
$logger->log( "Update language => " . ((! $update) ? $update : "OK") );
/* Heartbeat Enable/Disable */
if (! isset( $dataClient->heartbeatEnabled )) {
$dataClient->heartbeatEnabled = true;
}
$update = file_get_contents( "http://" . $_SERVER['SERVER_NAME'] . ":" . $_SERVER['SERVER_PORT'] . "/sysworkflow/en/classic/install/heartbeatStatus?status=" . $dataClient->heartbeatEnabled );
$logger->log( "Heartbeat Status => " . str_replace( "<br>", "\n", $update ) );
/* Autoinstall Process */
$update = file_get_contents( "http://" . $_SERVER['SERVER_NAME'] . ":" . $_SERVER['SERVER_PORT'] . "/sysworkflow/en/classic/install/autoinstallProcesses" );
if (trim( str_replace( "<br>", "", $update ) ) == "") {
$update = "Nothing to do.";
}
$logger->log( "Process AutoInstall => " . str_replace( "<br>", "\n", $update ) );
/* Autoinstall Plugins */
$update = file_get_contents( "http://" . $_SERVER['SERVER_NAME'] . ":" . $_SERVER['SERVER_PORT'] . "/sysworkflow/en/classic/install/autoinstallPlugins" );
if (trim( str_replace( "<br>", "", $update ) ) == "") {
$update = "Nothing to do.";
}
$logger->log( "Plugin AutoInstall => " . str_replace( "<br>", "\n", $update ) );
$logger->log( "Installation finished successfuly" );
}
/*
neat_r works like print_r but with much less visual clutter.
By Jake Lodwick. Copy freely.
*/
function neat_r ($arr, $return = false)
{
$out = array ();
$oldtab = " ";
$newtab = " ";
$lines = explode( "\n", print_r( $arr, true ) );
foreach ($lines as $line) {
//remove numeric indexes like "[0] =>" unless the value is an array
//if (substr($line, -5) != "Array") {
$line = preg_replace( "/^(\s*)\[[0-9]+\] => /", "$1", $line, 1 );
//}
//garbage symbols
foreach (array ("Array" => "","[" => "","]" => ""
) as
//" =>" => ":",
$old => $new) {
$out = str_replace( $old, $new, $out );
}
//garbage lines
if (in_array( trim( $line ), array ("Array","(",")",""
) )) {
continue;
}
//indents
$indent = "";
$indents = floor( (substr_count( $line, $oldtab ) - 1) / 2 );
if ($indents > 0) {
for ($i = 0; $i < $indents; $i ++) {
$indent .= $newtab;
}
}
$out[] = $indent . trim( $line );
}
$out = implode( "\n", $out );
if ($return == true) {
return $out;
}
return $out;
}