Files
luos/workflow/engine/classes/model/om/BaseAppDocument.php
Erik Amaru Ortiz d0e20c4b2e Session handling to prevent session lose in other places like, home, admin, etc
when user is using the new designer that have not session because it is using only the API
2014-06-16 18:56:08 -04:00

1391 lines
40 KiB
PHP
Executable File

<?php
require_once 'propel/om/BaseObject.php';
require_once 'propel/om/Persistent.php';
include_once 'propel/util/Criteria.php';
include_once 'classes/model/AppDocumentPeer.php';
/**
* Base class that represents a row from the 'APP_DOCUMENT' table.
*
*
*
* @package workflow.classes.model.om
*/
abstract class BaseAppDocument extends BaseObject implements Persistent
{
/**
* The Peer class.
* Instance provides a convenient way of calling static methods on a class
* that calling code may not be able to identify.
* @var AppDocumentPeer
*/
protected static $peer;
/**
* The value for the app_doc_uid field.
* @var string
*/
protected $app_doc_uid = '';
/**
* The value for the doc_version field.
* @var int
*/
protected $doc_version = 1;
/**
* The value for the app_uid field.
* @var string
*/
protected $app_uid = '';
/**
* The value for the del_index field.
* @var int
*/
protected $del_index = 0;
/**
* The value for the doc_uid field.
* @var string
*/
protected $doc_uid = '';
/**
* The value for the usr_uid field.
* @var string
*/
protected $usr_uid = '';
/**
* The value for the app_doc_type field.
* @var string
*/
protected $app_doc_type = '';
/**
* The value for the app_doc_create_date field.
* @var int
*/
protected $app_doc_create_date;
/**
* The value for the app_doc_index field.
* @var int
*/
protected $app_doc_index;
/**
* The value for the folder_uid field.
* @var string
*/
protected $folder_uid = '';
/**
* The value for the app_doc_plugin field.
* @var string
*/
protected $app_doc_plugin = '';
/**
* The value for the app_doc_tags field.
* @var string
*/
protected $app_doc_tags;
/**
* The value for the app_doc_status field.
* @var string
*/
protected $app_doc_status = 'ACTIVE';
/**
* The value for the app_doc_status_date field.
* @var int
*/
protected $app_doc_status_date;
/**
* The value for the app_doc_fieldname field.
* @var string
*/
protected $app_doc_fieldname;
/**
* Flag to prevent endless save loop, if this object is referenced
* by another object which falls in this transaction.
* @var boolean
*/
protected $alreadyInSave = false;
/**
* Flag to prevent endless validation loop, if this object is referenced
* by another object which falls in this transaction.
* @var boolean
*/
protected $alreadyInValidation = false;
/**
* Get the [app_doc_uid] column value.
*
* @return string
*/
public function getAppDocUid()
{
return $this->app_doc_uid;
}
/**
* Get the [doc_version] column value.
*
* @return int
*/
public function getDocVersion()
{
return $this->doc_version;
}
/**
* Get the [app_uid] column value.
*
* @return string
*/
public function getAppUid()
{
return $this->app_uid;
}
/**
* Get the [del_index] column value.
*
* @return int
*/
public function getDelIndex()
{
return $this->del_index;
}
/**
* Get the [doc_uid] column value.
*
* @return string
*/
public function getDocUid()
{
return $this->doc_uid;
}
/**
* Get the [usr_uid] column value.
*
* @return string
*/
public function getUsrUid()
{
return $this->usr_uid;
}
/**
* Get the [app_doc_type] column value.
*
* @return string
*/
public function getAppDocType()
{
return $this->app_doc_type;
}
/**
* Get the [optionally formatted] [app_doc_create_date] column value.
*
* @param string $format The date/time format string (either date()-style or strftime()-style).
* If format is NULL, then the integer unix timestamp will be returned.
* @return mixed Formatted date/time value as string or integer unix timestamp (if format is NULL).
* @throws PropelException - if unable to convert the date/time to timestamp.
*/
public function getAppDocCreateDate($format = 'Y-m-d H:i:s')
{
if ($this->app_doc_create_date === null || $this->app_doc_create_date === '') {
return null;
} elseif (!is_int($this->app_doc_create_date)) {
// a non-timestamp value was set externally, so we convert it
$ts = strtotime($this->app_doc_create_date);
if ($ts === -1 || $ts === false) {
throw new PropelException("Unable to parse value of [app_doc_create_date] as date/time value: " .
var_export($this->app_doc_create_date, true));
}
} else {
$ts = $this->app_doc_create_date;
}
if ($format === null) {
return $ts;
} elseif (strpos($format, '%') !== false) {
return strftime($format, $ts);
} else {
return date($format, $ts);
}
}
/**
* Get the [app_doc_index] column value.
*
* @return int
*/
public function getAppDocIndex()
{
return $this->app_doc_index;
}
/**
* Get the [folder_uid] column value.
*
* @return string
*/
public function getFolderUid()
{
return $this->folder_uid;
}
/**
* Get the [app_doc_plugin] column value.
*
* @return string
*/
public function getAppDocPlugin()
{
return $this->app_doc_plugin;
}
/**
* Get the [app_doc_tags] column value.
*
* @return string
*/
public function getAppDocTags()
{
return $this->app_doc_tags;
}
/**
* Get the [app_doc_status] column value.
*
* @return string
*/
public function getAppDocStatus()
{
return $this->app_doc_status;
}
/**
* Get the [optionally formatted] [app_doc_status_date] column value.
*
* @param string $format The date/time format string (either date()-style or strftime()-style).
* If format is NULL, then the integer unix timestamp will be returned.
* @return mixed Formatted date/time value as string or integer unix timestamp (if format is NULL).
* @throws PropelException - if unable to convert the date/time to timestamp.
*/
public function getAppDocStatusDate($format = 'Y-m-d H:i:s')
{
if ($this->app_doc_status_date === null || $this->app_doc_status_date === '') {
return null;
} elseif (!is_int($this->app_doc_status_date)) {
// a non-timestamp value was set externally, so we convert it
$ts = strtotime($this->app_doc_status_date);
if ($ts === -1 || $ts === false) {
throw new PropelException("Unable to parse value of [app_doc_status_date] as date/time value: " .
var_export($this->app_doc_status_date, true));
}
} else {
$ts = $this->app_doc_status_date;
}
if ($format === null) {
return $ts;
} elseif (strpos($format, '%') !== false) {
return strftime($format, $ts);
} else {
return date($format, $ts);
}
}
/**
* Get the [app_doc_fieldname] column value.
*
* @return string
*/
public function getAppDocFieldname()
{
return $this->app_doc_fieldname;
}
/**
* Set the value of [app_doc_uid] column.
*
* @param string $v new value
* @return void
*/
public function setAppDocUid($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->app_doc_uid !== $v || $v === '') {
$this->app_doc_uid = $v;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_UID;
}
} // setAppDocUid()
/**
* Set the value of [doc_version] column.
*
* @param int $v new value
* @return void
*/
public function setDocVersion($v)
{
// Since the native PHP type for this column is integer,
// we will cast the input value to an int (if it is not).
if ($v !== null && !is_int($v) && is_numeric($v)) {
$v = (int) $v;
}
if ($this->doc_version !== $v || $v === 1) {
$this->doc_version = $v;
$this->modifiedColumns[] = AppDocumentPeer::DOC_VERSION;
}
} // setDocVersion()
/**
* Set the value of [app_uid] column.
*
* @param string $v new value
* @return void
*/
public function setAppUid($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->app_uid !== $v || $v === '') {
$this->app_uid = $v;
$this->modifiedColumns[] = AppDocumentPeer::APP_UID;
}
} // setAppUid()
/**
* Set the value of [del_index] column.
*
* @param int $v new value
* @return void
*/
public function setDelIndex($v)
{
// Since the native PHP type for this column is integer,
// we will cast the input value to an int (if it is not).
if ($v !== null && !is_int($v) && is_numeric($v)) {
$v = (int) $v;
}
if ($this->del_index !== $v || $v === 0) {
$this->del_index = $v;
$this->modifiedColumns[] = AppDocumentPeer::DEL_INDEX;
}
} // setDelIndex()
/**
* Set the value of [doc_uid] column.
*
* @param string $v new value
* @return void
*/
public function setDocUid($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->doc_uid !== $v || $v === '') {
$this->doc_uid = $v;
$this->modifiedColumns[] = AppDocumentPeer::DOC_UID;
}
} // setDocUid()
/**
* Set the value of [usr_uid] column.
*
* @param string $v new value
* @return void
*/
public function setUsrUid($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->usr_uid !== $v || $v === '') {
$this->usr_uid = $v;
$this->modifiedColumns[] = AppDocumentPeer::USR_UID;
}
} // setUsrUid()
/**
* Set the value of [app_doc_type] column.
*
* @param string $v new value
* @return void
*/
public function setAppDocType($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->app_doc_type !== $v || $v === '') {
$this->app_doc_type = $v;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_TYPE;
}
} // setAppDocType()
/**
* Set the value of [app_doc_create_date] column.
*
* @param int $v new value
* @return void
*/
public function setAppDocCreateDate($v)
{
if ($v !== null && !is_int($v)) {
$ts = strtotime($v);
//Date/time accepts null values
if ($v == '') {
$ts = null;
}
if ($ts === -1 || $ts === false) {
throw new PropelException("Unable to parse date/time value for [app_doc_create_date] from input: " .
var_export($v, true));
}
} else {
$ts = $v;
}
if ($this->app_doc_create_date !== $ts) {
$this->app_doc_create_date = $ts;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_CREATE_DATE;
}
} // setAppDocCreateDate()
/**
* Set the value of [app_doc_index] column.
*
* @param int $v new value
* @return void
*/
public function setAppDocIndex($v)
{
// Since the native PHP type for this column is integer,
// we will cast the input value to an int (if it is not).
if ($v !== null && !is_int($v) && is_numeric($v)) {
$v = (int) $v;
}
if ($this->app_doc_index !== $v) {
$this->app_doc_index = $v;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_INDEX;
}
} // setAppDocIndex()
/**
* Set the value of [folder_uid] column.
*
* @param string $v new value
* @return void
*/
public function setFolderUid($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->folder_uid !== $v || $v === '') {
$this->folder_uid = $v;
$this->modifiedColumns[] = AppDocumentPeer::FOLDER_UID;
}
} // setFolderUid()
/**
* Set the value of [app_doc_plugin] column.
*
* @param string $v new value
* @return void
*/
public function setAppDocPlugin($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->app_doc_plugin !== $v || $v === '') {
$this->app_doc_plugin = $v;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_PLUGIN;
}
} // setAppDocPlugin()
/**
* Set the value of [app_doc_tags] column.
*
* @param string $v new value
* @return void
*/
public function setAppDocTags($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->app_doc_tags !== $v) {
$this->app_doc_tags = $v;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_TAGS;
}
} // setAppDocTags()
/**
* Set the value of [app_doc_status] column.
*
* @param string $v new value
* @return void
*/
public function setAppDocStatus($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->app_doc_status !== $v || $v === 'ACTIVE') {
$this->app_doc_status = $v;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_STATUS;
}
} // setAppDocStatus()
/**
* Set the value of [app_doc_status_date] column.
*
* @param int $v new value
* @return void
*/
public function setAppDocStatusDate($v)
{
if ($v !== null && !is_int($v)) {
$ts = strtotime($v);
//Date/time accepts null values
if ($v == '') {
$ts = null;
}
if ($ts === -1 || $ts === false) {
throw new PropelException("Unable to parse date/time value for [app_doc_status_date] from input: " .
var_export($v, true));
}
} else {
$ts = $v;
}
if ($this->app_doc_status_date !== $ts) {
$this->app_doc_status_date = $ts;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_STATUS_DATE;
}
} // setAppDocStatusDate()
/**
* Set the value of [app_doc_fieldname] column.
*
* @param string $v new value
* @return void
*/
public function setAppDocFieldname($v)
{
// Since the native PHP type for this column is string,
// we will cast the input to a string (if it is not).
if ($v !== null && !is_string($v)) {
$v = (string) $v;
}
if ($this->app_doc_fieldname !== $v) {
$this->app_doc_fieldname = $v;
$this->modifiedColumns[] = AppDocumentPeer::APP_DOC_FIELDNAME;
}
} // setAppDocFieldname()
/**
* Hydrates (populates) the object variables with values from the database resultset.
*
* An offset (1-based "start column") is specified so that objects can be hydrated
* with a subset of the columns in the resultset rows. This is needed, for example,
* for results of JOIN queries where the resultset row includes columns from two or
* more tables.
*
* @param ResultSet $rs The ResultSet class with cursor advanced to desired record pos.
* @param int $startcol 1-based offset column which indicates which restultset column to start with.
* @return int next starting column
* @throws PropelException - Any caught Exception will be rewrapped as a PropelException.
*/
public function hydrate(ResultSet $rs, $startcol = 1)
{
try {
$this->app_doc_uid = $rs->getString($startcol + 0);
$this->doc_version = $rs->getInt($startcol + 1);
$this->app_uid = $rs->getString($startcol + 2);
$this->del_index = $rs->getInt($startcol + 3);
$this->doc_uid = $rs->getString($startcol + 4);
$this->usr_uid = $rs->getString($startcol + 5);
$this->app_doc_type = $rs->getString($startcol + 6);
$this->app_doc_create_date = $rs->getTimestamp($startcol + 7, null);
$this->app_doc_index = $rs->getInt($startcol + 8);
$this->folder_uid = $rs->getString($startcol + 9);
$this->app_doc_plugin = $rs->getString($startcol + 10);
$this->app_doc_tags = $rs->getString($startcol + 11);
$this->app_doc_status = $rs->getString($startcol + 12);
$this->app_doc_status_date = $rs->getTimestamp($startcol + 13, null);
$this->app_doc_fieldname = $rs->getString($startcol + 14);
$this->resetModified();
$this->setNew(false);
// FIXME - using NUM_COLUMNS may be clearer.
return $startcol + 15; // 15 = AppDocumentPeer::NUM_COLUMNS - AppDocumentPeer::NUM_LAZY_LOAD_COLUMNS).
} catch (Exception $e) {
throw new PropelException("Error populating AppDocument object", $e);
}
}
/**
* Removes this object from datastore and sets delete attribute.
*
* @param Connection $con
* @return void
* @throws PropelException
* @see BaseObject::setDeleted()
* @see BaseObject::isDeleted()
*/
public function delete($con = null)
{
if ($this->isDeleted()) {
throw new PropelException("This object has already been deleted.");
}
if ($con === null) {
$con = Propel::getConnection(AppDocumentPeer::DATABASE_NAME);
}
try {
$con->begin();
AppDocumentPeer::doDelete($this, $con);
$this->setDeleted(true);
$con->commit();
} catch (PropelException $e) {
$con->rollback();
throw $e;
}
}
/**
* Stores the object in the database. If the object is new,
* it inserts it; otherwise an update is performed. This method
* wraps the doSave() worker method in a transaction.
*
* @param Connection $con
* @return int The number of rows affected by this insert/update
* @throws PropelException
* @see doSave()
*/
public function save($con = null)
{
if ($this->isDeleted()) {
throw new PropelException("You cannot save an object that has been deleted.");
}
if ($con === null) {
$con = Propel::getConnection(AppDocumentPeer::DATABASE_NAME);
}
try {
$con->begin();
$affectedRows = $this->doSave($con);
$con->commit();
return $affectedRows;
} catch (PropelException $e) {
$con->rollback();
throw $e;
}
}
/**
* Stores the object in the database.
*
* If the object is new, it inserts it; otherwise an update is performed.
* All related objects are also updated in this method.
*
* @param Connection $con
* @return int The number of rows affected by this insert/update and any referring
* @throws PropelException
* @see save()
*/
protected function doSave($con)
{
$affectedRows = 0; // initialize var to track total num of affected rows
if (!$this->alreadyInSave) {
$this->alreadyInSave = true;
// If this object has been modified, then save it to the database.
if ($this->isModified()) {
if ($this->isNew()) {
$pk = AppDocumentPeer::doInsert($this, $con);
$affectedRows += 1; // we are assuming that there is only 1 row per doInsert() which
// should always be true here (even though technically
// BasePeer::doInsert() can insert multiple rows).
$this->setNew(false);
} else {
$affectedRows += AppDocumentPeer::doUpdate($this, $con);
}
$this->resetModified(); // [HL] After being saved an object is no longer 'modified'
}
$this->alreadyInSave = false;
}
return $affectedRows;
} // doSave()
/**
* Array of ValidationFailed objects.
* @var array ValidationFailed[]
*/
protected $validationFailures = array();
/**
* Gets any ValidationFailed objects that resulted from last call to validate().
*
*
* @return array ValidationFailed[]
* @see validate()
*/
public function getValidationFailures()
{
return $this->validationFailures;
}
/**
* Validates the objects modified field values and all objects related to this table.
*
* If $columns is either a column name or an array of column names
* only those columns are validated.
*
* @param mixed $columns Column name or an array of column names.
* @return boolean Whether all columns pass validation.
* @see doValidate()
* @see getValidationFailures()
*/
public function validate($columns = null)
{
$res = $this->doValidate($columns);
if ($res === true) {
$this->validationFailures = array();
return true;
} else {
$this->validationFailures = $res;
return false;
}
}
/**
* This function performs the validation work for complex object models.
*
* In addition to checking the current object, all related objects will
* also be validated. If all pass then <code>true</code> is returned; otherwise
* an aggreagated array of ValidationFailed objects will be returned.
*
* @param array $columns Array of column names to validate.
* @return mixed <code>true</code> if all validations pass;
array of <code>ValidationFailed</code> objects otherwise.
*/
protected function doValidate($columns = null)
{
if (!$this->alreadyInValidation) {
$this->alreadyInValidation = true;
$retval = null;
$failureMap = array();
if (($retval = AppDocumentPeer::doValidate($this, $columns)) !== true) {
$failureMap = array_merge($failureMap, $retval);
}
$this->alreadyInValidation = false;
}
return (!empty($failureMap) ? $failureMap : true);
}
/**
* Retrieves a field from the object by name passed in as a string.
*
* @param string $name name
* @param string $type The type of fieldname the $name is of:
* one of the class type constants TYPE_PHPNAME,
* TYPE_COLNAME, TYPE_FIELDNAME, TYPE_NUM
* @return mixed Value of field.
*/
public function getByName($name, $type = BasePeer::TYPE_PHPNAME)
{
$pos = AppDocumentPeer::translateFieldName($name, $type, BasePeer::TYPE_NUM);
return $this->getByPosition($pos);
}
/**
* Retrieves a field from the object by Position as specified in the xml schema.
* Zero-based.
*
* @param int $pos position in xml schema
* @return mixed Value of field at $pos
*/
public function getByPosition($pos)
{
switch($pos) {
case 0:
return $this->getAppDocUid();
break;
case 1:
return $this->getDocVersion();
break;
case 2:
return $this->getAppUid();
break;
case 3:
return $this->getDelIndex();
break;
case 4:
return $this->getDocUid();
break;
case 5:
return $this->getUsrUid();
break;
case 6:
return $this->getAppDocType();
break;
case 7:
return $this->getAppDocCreateDate();
break;
case 8:
return $this->getAppDocIndex();
break;
case 9:
return $this->getFolderUid();
break;
case 10:
return $this->getAppDocPlugin();
break;
case 11:
return $this->getAppDocTags();
break;
case 12:
return $this->getAppDocStatus();
break;
case 13:
return $this->getAppDocStatusDate();
break;
case 14:
return $this->getAppDocFieldname();
break;
default:
return null;
break;
} // switch()
}
/**
* Exports the object as an array.
*
* You can specify the key type of the array by passing one of the class
* type constants.
*
* @param string $keyType One of the class type constants TYPE_PHPNAME,
* TYPE_COLNAME, TYPE_FIELDNAME, TYPE_NUM
* @return an associative array containing the field names (as keys) and field values
*/
public function toArray($keyType = BasePeer::TYPE_PHPNAME)
{
$keys = AppDocumentPeer::getFieldNames($keyType);
$result = array(
$keys[0] => $this->getAppDocUid(),
$keys[1] => $this->getDocVersion(),
$keys[2] => $this->getAppUid(),
$keys[3] => $this->getDelIndex(),
$keys[4] => $this->getDocUid(),
$keys[5] => $this->getUsrUid(),
$keys[6] => $this->getAppDocType(),
$keys[7] => $this->getAppDocCreateDate(),
$keys[8] => $this->getAppDocIndex(),
$keys[9] => $this->getFolderUid(),
$keys[10] => $this->getAppDocPlugin(),
$keys[11] => $this->getAppDocTags(),
$keys[12] => $this->getAppDocStatus(),
$keys[13] => $this->getAppDocStatusDate(),
$keys[14] => $this->getAppDocFieldname(),
);
return $result;
}
/**
* Sets a field from the object by name passed in as a string.
*
* @param string $name peer name
* @param mixed $value field value
* @param string $type The type of fieldname the $name is of:
* one of the class type constants TYPE_PHPNAME,
* TYPE_COLNAME, TYPE_FIELDNAME, TYPE_NUM
* @return void
*/
public function setByName($name, $value, $type = BasePeer::TYPE_PHPNAME)
{
$pos = AppDocumentPeer::translateFieldName($name, $type, BasePeer::TYPE_NUM);
return $this->setByPosition($pos, $value);
}
/**
* Sets a field from the object by Position as specified in the xml schema.
* Zero-based.
*
* @param int $pos position in xml schema
* @param mixed $value field value
* @return void
*/
public function setByPosition($pos, $value)
{
switch($pos) {
case 0:
$this->setAppDocUid($value);
break;
case 1:
$this->setDocVersion($value);
break;
case 2:
$this->setAppUid($value);
break;
case 3:
$this->setDelIndex($value);
break;
case 4:
$this->setDocUid($value);
break;
case 5:
$this->setUsrUid($value);
break;
case 6:
$this->setAppDocType($value);
break;
case 7:
$this->setAppDocCreateDate($value);
break;
case 8:
$this->setAppDocIndex($value);
break;
case 9:
$this->setFolderUid($value);
break;
case 10:
$this->setAppDocPlugin($value);
break;
case 11:
$this->setAppDocTags($value);
break;
case 12:
$this->setAppDocStatus($value);
break;
case 13:
$this->setAppDocStatusDate($value);
break;
case 14:
$this->setAppDocFieldname($value);
break;
} // switch()
}
/**
* Populates the object using an array.
*
* This is particularly useful when populating an object from one of the
* request arrays (e.g. $_POST). This method goes through the column
* names, checking to see whether a matching key exists in populated
* array. If so the setByName() method is called for that column.
*
* You can specify the key type of the array by additionally passing one
* of the class type constants TYPE_PHPNAME, TYPE_COLNAME, TYPE_FIELDNAME,
* TYPE_NUM. The default key type is the column's phpname (e.g. 'authorId')
*
* @param array $arr An array to populate the object from.
* @param string $keyType The type of keys the array uses.
* @return void
*/
public function fromArray($arr, $keyType = BasePeer::TYPE_PHPNAME)
{
$keys = AppDocumentPeer::getFieldNames($keyType);
if (array_key_exists($keys[0], $arr)) {
$this->setAppDocUid($arr[$keys[0]]);
}
if (array_key_exists($keys[1], $arr)) {
$this->setDocVersion($arr[$keys[1]]);
}
if (array_key_exists($keys[2], $arr)) {
$this->setAppUid($arr[$keys[2]]);
}
if (array_key_exists($keys[3], $arr)) {
$this->setDelIndex($arr[$keys[3]]);
}
if (array_key_exists($keys[4], $arr)) {
$this->setDocUid($arr[$keys[4]]);
}
if (array_key_exists($keys[5], $arr)) {
$this->setUsrUid($arr[$keys[5]]);
}
if (array_key_exists($keys[6], $arr)) {
$this->setAppDocType($arr[$keys[6]]);
}
if (array_key_exists($keys[7], $arr)) {
$this->setAppDocCreateDate($arr[$keys[7]]);
}
if (array_key_exists($keys[8], $arr)) {
$this->setAppDocIndex($arr[$keys[8]]);
}
if (array_key_exists($keys[9], $arr)) {
$this->setFolderUid($arr[$keys[9]]);
}
if (array_key_exists($keys[10], $arr)) {
$this->setAppDocPlugin($arr[$keys[10]]);
}
if (array_key_exists($keys[11], $arr)) {
$this->setAppDocTags($arr[$keys[11]]);
}
if (array_key_exists($keys[12], $arr)) {
$this->setAppDocStatus($arr[$keys[12]]);
}
if (array_key_exists($keys[13], $arr)) {
$this->setAppDocStatusDate($arr[$keys[13]]);
}
if (array_key_exists($keys[14], $arr)) {
$this->setAppDocFieldname($arr[$keys[14]]);
}
}
/**
* Build a Criteria object containing the values of all modified columns in this object.
*
* @return Criteria The Criteria object containing all modified values.
*/
public function buildCriteria()
{
$criteria = new Criteria(AppDocumentPeer::DATABASE_NAME);
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_UID)) {
$criteria->add(AppDocumentPeer::APP_DOC_UID, $this->app_doc_uid);
}
if ($this->isColumnModified(AppDocumentPeer::DOC_VERSION)) {
$criteria->add(AppDocumentPeer::DOC_VERSION, $this->doc_version);
}
if ($this->isColumnModified(AppDocumentPeer::APP_UID)) {
$criteria->add(AppDocumentPeer::APP_UID, $this->app_uid);
}
if ($this->isColumnModified(AppDocumentPeer::DEL_INDEX)) {
$criteria->add(AppDocumentPeer::DEL_INDEX, $this->del_index);
}
if ($this->isColumnModified(AppDocumentPeer::DOC_UID)) {
$criteria->add(AppDocumentPeer::DOC_UID, $this->doc_uid);
}
if ($this->isColumnModified(AppDocumentPeer::USR_UID)) {
$criteria->add(AppDocumentPeer::USR_UID, $this->usr_uid);
}
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_TYPE)) {
$criteria->add(AppDocumentPeer::APP_DOC_TYPE, $this->app_doc_type);
}
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_CREATE_DATE)) {
$criteria->add(AppDocumentPeer::APP_DOC_CREATE_DATE, $this->app_doc_create_date);
}
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_INDEX)) {
$criteria->add(AppDocumentPeer::APP_DOC_INDEX, $this->app_doc_index);
}
if ($this->isColumnModified(AppDocumentPeer::FOLDER_UID)) {
$criteria->add(AppDocumentPeer::FOLDER_UID, $this->folder_uid);
}
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_PLUGIN)) {
$criteria->add(AppDocumentPeer::APP_DOC_PLUGIN, $this->app_doc_plugin);
}
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_TAGS)) {
$criteria->add(AppDocumentPeer::APP_DOC_TAGS, $this->app_doc_tags);
}
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_STATUS)) {
$criteria->add(AppDocumentPeer::APP_DOC_STATUS, $this->app_doc_status);
}
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_STATUS_DATE)) {
$criteria->add(AppDocumentPeer::APP_DOC_STATUS_DATE, $this->app_doc_status_date);
}
if ($this->isColumnModified(AppDocumentPeer::APP_DOC_FIELDNAME)) {
$criteria->add(AppDocumentPeer::APP_DOC_FIELDNAME, $this->app_doc_fieldname);
}
return $criteria;
}
/**
* Builds a Criteria object containing the primary key for this object.
*
* Unlike buildCriteria() this method includes the primary key values regardless
* of whether or not they have been modified.
*
* @return Criteria The Criteria object containing value(s) for primary key(s).
*/
public function buildPkeyCriteria()
{
$criteria = new Criteria(AppDocumentPeer::DATABASE_NAME);
$criteria->add(AppDocumentPeer::APP_DOC_UID, $this->app_doc_uid);
$criteria->add(AppDocumentPeer::DOC_VERSION, $this->doc_version);
return $criteria;
}
/**
* Returns the composite primary key for this object.
* The array elements will be in same order as specified in XML.
* @return array
*/
public function getPrimaryKey()
{
$pks = array();
$pks[0] = $this->getAppDocUid();
$pks[1] = $this->getDocVersion();
return $pks;
}
/**
* Set the [composite] primary key.
*
* @param array $keys The elements of the composite key (order must match the order in XML file).
* @return void
*/
public function setPrimaryKey($keys)
{
$this->setAppDocUid($keys[0]);
$this->setDocVersion($keys[1]);
}
/**
* Sets contents of passed object to values from current object.
*
* If desired, this method can also make copies of all associated (fkey referrers)
* objects.
*
* @param object $copyObj An object of AppDocument (or compatible) type.
* @param boolean $deepCopy Whether to also copy all rows that refer (by fkey) to the current row.
* @throws PropelException
*/
public function copyInto($copyObj, $deepCopy = false)
{
$copyObj->setAppUid($this->app_uid);
$copyObj->setDelIndex($this->del_index);
$copyObj->setDocUid($this->doc_uid);
$copyObj->setUsrUid($this->usr_uid);
$copyObj->setAppDocType($this->app_doc_type);
$copyObj->setAppDocCreateDate($this->app_doc_create_date);
$copyObj->setAppDocIndex($this->app_doc_index);
$copyObj->setFolderUid($this->folder_uid);
$copyObj->setAppDocPlugin($this->app_doc_plugin);
$copyObj->setAppDocTags($this->app_doc_tags);
$copyObj->setAppDocStatus($this->app_doc_status);
$copyObj->setAppDocStatusDate($this->app_doc_status_date);
$copyObj->setAppDocFieldname($this->app_doc_fieldname);
$copyObj->setNew(true);
$copyObj->setAppDocUid(''); // this is a pkey column, so set to default value
$copyObj->setDocVersion('1'); // this is a pkey column, so set to default value
}
/**
* Makes a copy of this object that will be inserted as a new row in table when saved.
* It creates a new object filling in the simple attributes, but skipping any primary
* keys that are defined for the table.
*
* If desired, this method can also make copies of all associated (fkey referrers)
* objects.
*
* @param boolean $deepCopy Whether to also copy all rows that refer (by fkey) to the current row.
* @return AppDocument Clone of current object.
* @throws PropelException
*/
public function copy($deepCopy = false)
{
// we use get_class(), because this might be a subclass
$clazz = get_class($this);
$copyObj = new $clazz();
$this->copyInto($copyObj, $deepCopy);
return $copyObj;
}
/**
* Returns a peer instance associated with this om.
*
* Since Peer classes are not to have any instance attributes, this method returns the
* same instance for all member of this class. The method could therefore
* be static, but this would prevent one from overriding the behavior.
*
* @return AppDocumentPeer
*/
public function getPeer()
{
if (self::$peer === null) {
self::$peer = new AppDocumentPeer();
}
return self::$peer;
}
}