mirror of
https://github.com/atlanticbiomedical/portal-legacy.git
synced 2025-07-02 01:47:28 -04:00
580 lines
12 KiB
PHP
580 lines
12 KiB
PHP
![]() |
<?php
|
||
|
|
||
|
|
||
|
abstract class BaseLocation extends BaseObject implements Persistent {
|
||
|
|
||
|
|
||
|
|
||
|
protected static $peer;
|
||
|
|
||
|
|
||
|
|
||
|
protected $id;
|
||
|
|
||
|
|
||
|
|
||
|
protected $latitude = '<null>';
|
||
|
|
||
|
|
||
|
|
||
|
protected $longitude = '<null>';
|
||
|
|
||
|
|
||
|
|
||
|
protected $created_at;
|
||
|
|
||
|
|
||
|
|
||
|
protected $updated_at;
|
||
|
|
||
|
|
||
|
protected $collClients;
|
||
|
|
||
|
|
||
|
protected $lastClientCriteria = null;
|
||
|
|
||
|
|
||
|
protected $alreadyInSave = false;
|
||
|
|
||
|
|
||
|
protected $alreadyInValidation = false;
|
||
|
|
||
|
|
||
|
public function getId()
|
||
|
{
|
||
|
|
||
|
return $this->id;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getLatitude()
|
||
|
{
|
||
|
|
||
|
return $this->latitude;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getLongitude()
|
||
|
{
|
||
|
|
||
|
return $this->longitude;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getCreatedAt($format = 'Y-m-d H:i:s')
|
||
|
{
|
||
|
|
||
|
if ($this->created_at === null || $this->created_at === '') {
|
||
|
return null;
|
||
|
} elseif (!is_int($this->created_at)) {
|
||
|
$ts = strtotime($this->created_at);
|
||
|
if ($ts === -1 || $ts === false) { throw new PropelException("Unable to parse value of [created_at] as date/time value: " . var_export($this->created_at, true));
|
||
|
}
|
||
|
} else {
|
||
|
$ts = $this->created_at;
|
||
|
}
|
||
|
if ($format === null) {
|
||
|
return $ts;
|
||
|
} elseif (strpos($format, '%') !== false) {
|
||
|
return strftime($format, $ts);
|
||
|
} else {
|
||
|
return date($format, $ts);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getUpdatedAt($format = 'Y-m-d H:i:s')
|
||
|
{
|
||
|
|
||
|
if ($this->updated_at === null || $this->updated_at === '') {
|
||
|
return null;
|
||
|
} elseif (!is_int($this->updated_at)) {
|
||
|
$ts = strtotime($this->updated_at);
|
||
|
if ($ts === -1 || $ts === false) { throw new PropelException("Unable to parse value of [updated_at] as date/time value: " . var_export($this->updated_at, true));
|
||
|
}
|
||
|
} else {
|
||
|
$ts = $this->updated_at;
|
||
|
}
|
||
|
if ($format === null) {
|
||
|
return $ts;
|
||
|
} elseif (strpos($format, '%') !== false) {
|
||
|
return strftime($format, $ts);
|
||
|
} else {
|
||
|
return date($format, $ts);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
public function setId($v)
|
||
|
{
|
||
|
|
||
|
if ($v !== null && !is_int($v) && is_numeric($v)) {
|
||
|
$v = (int) $v;
|
||
|
}
|
||
|
|
||
|
if ($this->id !== $v) {
|
||
|
$this->id = $v;
|
||
|
$this->modifiedColumns[] = LocationPeer::ID;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
public function setLatitude($v)
|
||
|
{
|
||
|
|
||
|
if ($v !== null && !is_string($v)) {
|
||
|
$v = (string) $v;
|
||
|
}
|
||
|
|
||
|
if ($this->latitude !== $v || $v === '<null>') {
|
||
|
$this->latitude = $v;
|
||
|
$this->modifiedColumns[] = LocationPeer::LATITUDE;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
public function setLongitude($v)
|
||
|
{
|
||
|
|
||
|
if ($v !== null && !is_string($v)) {
|
||
|
$v = (string) $v;
|
||
|
}
|
||
|
|
||
|
if ($this->longitude !== $v || $v === '<null>') {
|
||
|
$this->longitude = $v;
|
||
|
$this->modifiedColumns[] = LocationPeer::LONGITUDE;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
public function setCreatedAt($v)
|
||
|
{
|
||
|
|
||
|
if ($v !== null && !is_int($v)) {
|
||
|
$ts = strtotime($v);
|
||
|
if ($ts === -1 || $ts === false) { throw new PropelException("Unable to parse date/time value for [created_at] from input: " . var_export($v, true));
|
||
|
}
|
||
|
} else {
|
||
|
$ts = $v;
|
||
|
}
|
||
|
if ($this->created_at !== $ts) {
|
||
|
$this->created_at = $ts;
|
||
|
$this->modifiedColumns[] = LocationPeer::CREATED_AT;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
public function setUpdatedAt($v)
|
||
|
{
|
||
|
|
||
|
if ($v !== null && !is_int($v)) {
|
||
|
$ts = strtotime($v);
|
||
|
if ($ts === -1 || $ts === false) { throw new PropelException("Unable to parse date/time value for [updated_at] from input: " . var_export($v, true));
|
||
|
}
|
||
|
} else {
|
||
|
$ts = $v;
|
||
|
}
|
||
|
if ($this->updated_at !== $ts) {
|
||
|
$this->updated_at = $ts;
|
||
|
$this->modifiedColumns[] = LocationPeer::UPDATED_AT;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
public function hydrate(ResultSet $rs, $startcol = 1)
|
||
|
{
|
||
|
try {
|
||
|
|
||
|
$this->id = $rs->getInt($startcol + 0);
|
||
|
|
||
|
$this->latitude = $rs->getString($startcol + 1);
|
||
|
|
||
|
$this->longitude = $rs->getString($startcol + 2);
|
||
|
|
||
|
$this->created_at = $rs->getTimestamp($startcol + 3, null);
|
||
|
|
||
|
$this->updated_at = $rs->getTimestamp($startcol + 4, null);
|
||
|
|
||
|
$this->resetModified();
|
||
|
|
||
|
$this->setNew(false);
|
||
|
|
||
|
return $startcol + 5;
|
||
|
} catch (Exception $e) {
|
||
|
throw new PropelException("Error populating Location object", $e);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
public function delete($con = null)
|
||
|
{
|
||
|
if ($this->isDeleted()) {
|
||
|
throw new PropelException("This object has already been deleted.");
|
||
|
}
|
||
|
|
||
|
if ($con === null) {
|
||
|
$con = Propel::getConnection(LocationPeer::DATABASE_NAME);
|
||
|
}
|
||
|
|
||
|
try {
|
||
|
$con->begin();
|
||
|
LocationPeer::doDelete($this, $con);
|
||
|
$this->setDeleted(true);
|
||
|
$con->commit();
|
||
|
} catch (PropelException $e) {
|
||
|
$con->rollback();
|
||
|
throw $e;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
public function save($con = null)
|
||
|
{
|
||
|
if ($this->isNew() && !$this->isColumnModified(LocationPeer::CREATED_AT))
|
||
|
{
|
||
|
$this->setCreatedAt(time());
|
||
|
}
|
||
|
|
||
|
if ($this->isModified() && !$this->isColumnModified(LocationPeer::UPDATED_AT))
|
||
|
{
|
||
|
$this->setUpdatedAt(time());
|
||
|
}
|
||
|
|
||
|
if ($this->isDeleted()) {
|
||
|
throw new PropelException("You cannot save an object that has been deleted.");
|
||
|
}
|
||
|
|
||
|
if ($con === null) {
|
||
|
$con = Propel::getConnection(LocationPeer::DATABASE_NAME);
|
||
|
}
|
||
|
|
||
|
try {
|
||
|
$con->begin();
|
||
|
$affectedRows = $this->doSave($con);
|
||
|
$con->commit();
|
||
|
return $affectedRows;
|
||
|
} catch (PropelException $e) {
|
||
|
$con->rollback();
|
||
|
throw $e;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
protected function doSave($con)
|
||
|
{
|
||
|
$affectedRows = 0; if (!$this->alreadyInSave) {
|
||
|
$this->alreadyInSave = true;
|
||
|
|
||
|
|
||
|
if ($this->isModified()) {
|
||
|
if ($this->isNew()) {
|
||
|
$pk = LocationPeer::doInsert($this, $con);
|
||
|
$affectedRows += 1;
|
||
|
$this->setId($pk);
|
||
|
$this->setNew(false);
|
||
|
} else {
|
||
|
$affectedRows += LocationPeer::doUpdate($this, $con);
|
||
|
}
|
||
|
$this->resetModified(); }
|
||
|
|
||
|
if ($this->collClients !== null) {
|
||
|
foreach($this->collClients as $referrerFK) {
|
||
|
if (!$referrerFK->isDeleted()) {
|
||
|
$affectedRows += $referrerFK->save($con);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$this->alreadyInSave = false;
|
||
|
}
|
||
|
return $affectedRows;
|
||
|
}
|
||
|
|
||
|
protected $validationFailures = array();
|
||
|
|
||
|
|
||
|
public function getValidationFailures()
|
||
|
{
|
||
|
return $this->validationFailures;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function validate($columns = null)
|
||
|
{
|
||
|
$res = $this->doValidate($columns);
|
||
|
if ($res === true) {
|
||
|
$this->validationFailures = array();
|
||
|
return true;
|
||
|
} else {
|
||
|
$this->validationFailures = $res;
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
protected function doValidate($columns = null)
|
||
|
{
|
||
|
if (!$this->alreadyInValidation) {
|
||
|
$this->alreadyInValidation = true;
|
||
|
$retval = null;
|
||
|
|
||
|
$failureMap = array();
|
||
|
|
||
|
|
||
|
if (($retval = LocationPeer::doValidate($this, $columns)) !== true) {
|
||
|
$failureMap = array_merge($failureMap, $retval);
|
||
|
}
|
||
|
|
||
|
|
||
|
if ($this->collClients !== null) {
|
||
|
foreach($this->collClients as $referrerFK) {
|
||
|
if (!$referrerFK->validate($columns)) {
|
||
|
$failureMap = array_merge($failureMap, $referrerFK->getValidationFailures());
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
$this->alreadyInValidation = false;
|
||
|
}
|
||
|
|
||
|
return (!empty($failureMap) ? $failureMap : true);
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getByName($name, $type = BasePeer::TYPE_PHPNAME)
|
||
|
{
|
||
|
$pos = LocationPeer::translateFieldName($name, $type, BasePeer::TYPE_NUM);
|
||
|
return $this->getByPosition($pos);
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getByPosition($pos)
|
||
|
{
|
||
|
switch($pos) {
|
||
|
case 0:
|
||
|
return $this->getId();
|
||
|
break;
|
||
|
case 1:
|
||
|
return $this->getLatitude();
|
||
|
break;
|
||
|
case 2:
|
||
|
return $this->getLongitude();
|
||
|
break;
|
||
|
case 3:
|
||
|
return $this->getCreatedAt();
|
||
|
break;
|
||
|
case 4:
|
||
|
return $this->getUpdatedAt();
|
||
|
break;
|
||
|
default:
|
||
|
return null;
|
||
|
break;
|
||
|
} }
|
||
|
|
||
|
|
||
|
public function toArray($keyType = BasePeer::TYPE_PHPNAME)
|
||
|
{
|
||
|
$keys = LocationPeer::getFieldNames($keyType);
|
||
|
$result = array(
|
||
|
$keys[0] => $this->getId(),
|
||
|
$keys[1] => $this->getLatitude(),
|
||
|
$keys[2] => $this->getLongitude(),
|
||
|
$keys[3] => $this->getCreatedAt(),
|
||
|
$keys[4] => $this->getUpdatedAt(),
|
||
|
);
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function setByName($name, $value, $type = BasePeer::TYPE_PHPNAME)
|
||
|
{
|
||
|
$pos = LocationPeer::translateFieldName($name, $type, BasePeer::TYPE_NUM);
|
||
|
return $this->setByPosition($pos, $value);
|
||
|
}
|
||
|
|
||
|
|
||
|
public function setByPosition($pos, $value)
|
||
|
{
|
||
|
switch($pos) {
|
||
|
case 0:
|
||
|
$this->setId($value);
|
||
|
break;
|
||
|
case 1:
|
||
|
$this->setLatitude($value);
|
||
|
break;
|
||
|
case 2:
|
||
|
$this->setLongitude($value);
|
||
|
break;
|
||
|
case 3:
|
||
|
$this->setCreatedAt($value);
|
||
|
break;
|
||
|
case 4:
|
||
|
$this->setUpdatedAt($value);
|
||
|
break;
|
||
|
} }
|
||
|
|
||
|
|
||
|
public function fromArray($arr, $keyType = BasePeer::TYPE_PHPNAME)
|
||
|
{
|
||
|
$keys = LocationPeer::getFieldNames($keyType);
|
||
|
|
||
|
if (array_key_exists($keys[0], $arr)) $this->setId($arr[$keys[0]]);
|
||
|
if (array_key_exists($keys[1], $arr)) $this->setLatitude($arr[$keys[1]]);
|
||
|
if (array_key_exists($keys[2], $arr)) $this->setLongitude($arr[$keys[2]]);
|
||
|
if (array_key_exists($keys[3], $arr)) $this->setCreatedAt($arr[$keys[3]]);
|
||
|
if (array_key_exists($keys[4], $arr)) $this->setUpdatedAt($arr[$keys[4]]);
|
||
|
}
|
||
|
|
||
|
|
||
|
public function buildCriteria()
|
||
|
{
|
||
|
$criteria = new Criteria(LocationPeer::DATABASE_NAME);
|
||
|
|
||
|
if ($this->isColumnModified(LocationPeer::ID)) $criteria->add(LocationPeer::ID, $this->id);
|
||
|
if ($this->isColumnModified(LocationPeer::LATITUDE)) $criteria->add(LocationPeer::LATITUDE, $this->latitude);
|
||
|
if ($this->isColumnModified(LocationPeer::LONGITUDE)) $criteria->add(LocationPeer::LONGITUDE, $this->longitude);
|
||
|
if ($this->isColumnModified(LocationPeer::CREATED_AT)) $criteria->add(LocationPeer::CREATED_AT, $this->created_at);
|
||
|
if ($this->isColumnModified(LocationPeer::UPDATED_AT)) $criteria->add(LocationPeer::UPDATED_AT, $this->updated_at);
|
||
|
|
||
|
return $criteria;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function buildPkeyCriteria()
|
||
|
{
|
||
|
$criteria = new Criteria(LocationPeer::DATABASE_NAME);
|
||
|
|
||
|
$criteria->add(LocationPeer::ID, $this->id);
|
||
|
|
||
|
return $criteria;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getPrimaryKey()
|
||
|
{
|
||
|
return $this->getId();
|
||
|
}
|
||
|
|
||
|
|
||
|
public function setPrimaryKey($key)
|
||
|
{
|
||
|
$this->setId($key);
|
||
|
}
|
||
|
|
||
|
|
||
|
public function copyInto($copyObj, $deepCopy = false)
|
||
|
{
|
||
|
|
||
|
$copyObj->setLatitude($this->latitude);
|
||
|
|
||
|
$copyObj->setLongitude($this->longitude);
|
||
|
|
||
|
$copyObj->setCreatedAt($this->created_at);
|
||
|
|
||
|
$copyObj->setUpdatedAt($this->updated_at);
|
||
|
|
||
|
|
||
|
if ($deepCopy) {
|
||
|
$copyObj->setNew(false);
|
||
|
|
||
|
foreach($this->getClients() as $relObj) {
|
||
|
$copyObj->addClient($relObj->copy($deepCopy));
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
$copyObj->setNew(true);
|
||
|
|
||
|
$copyObj->setId(NULL);
|
||
|
}
|
||
|
|
||
|
|
||
|
public function copy($deepCopy = false)
|
||
|
{
|
||
|
$clazz = get_class($this);
|
||
|
$copyObj = new $clazz();
|
||
|
$this->copyInto($copyObj, $deepCopy);
|
||
|
return $copyObj;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getPeer()
|
||
|
{
|
||
|
if (self::$peer === null) {
|
||
|
self::$peer = new LocationPeer();
|
||
|
}
|
||
|
return self::$peer;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function initClients()
|
||
|
{
|
||
|
if ($this->collClients === null) {
|
||
|
$this->collClients = array();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getClients($criteria = null, $con = null)
|
||
|
{
|
||
|
include_once 'lib/model/om/BaseClientPeer.php';
|
||
|
if ($criteria === null) {
|
||
|
$criteria = new Criteria();
|
||
|
}
|
||
|
elseif ($criteria instanceof Criteria)
|
||
|
{
|
||
|
$criteria = clone $criteria;
|
||
|
}
|
||
|
|
||
|
if ($this->collClients === null) {
|
||
|
if ($this->isNew()) {
|
||
|
$this->collClients = array();
|
||
|
} else {
|
||
|
|
||
|
$criteria->add(ClientPeer::LOCATION_ID, $this->getId());
|
||
|
|
||
|
ClientPeer::addSelectColumns($criteria);
|
||
|
$this->collClients = ClientPeer::doSelect($criteria, $con);
|
||
|
}
|
||
|
} else {
|
||
|
if (!$this->isNew()) {
|
||
|
|
||
|
|
||
|
$criteria->add(ClientPeer::LOCATION_ID, $this->getId());
|
||
|
|
||
|
ClientPeer::addSelectColumns($criteria);
|
||
|
if (!isset($this->lastClientCriteria) || !$this->lastClientCriteria->equals($criteria)) {
|
||
|
$this->collClients = ClientPeer::doSelect($criteria, $con);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$this->lastClientCriteria = $criteria;
|
||
|
return $this->collClients;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function countClients($criteria = null, $distinct = false, $con = null)
|
||
|
{
|
||
|
include_once 'lib/model/om/BaseClientPeer.php';
|
||
|
if ($criteria === null) {
|
||
|
$criteria = new Criteria();
|
||
|
}
|
||
|
elseif ($criteria instanceof Criteria)
|
||
|
{
|
||
|
$criteria = clone $criteria;
|
||
|
}
|
||
|
|
||
|
$criteria->add(ClientPeer::LOCATION_ID, $this->getId());
|
||
|
|
||
|
return ClientPeer::doCount($criteria, $distinct, $con);
|
||
|
}
|
||
|
|
||
|
|
||
|
public function addClient(Client $l)
|
||
|
{
|
||
|
$this->collClients[] = $l;
|
||
|
$l->setLocation($this);
|
||
|
}
|
||
|
|
||
|
}
|