mirror of
https://github.com/atlanticbiomedical/portal-legacy.git
synced 2025-07-02 01:47:28 -04:00
620 lines
16 KiB
PHP
Executable File
620 lines
16 KiB
PHP
Executable File
<?php
|
|
|
|
|
|
abstract class BaseUserPeer {
|
|
|
|
|
|
const DATABASE_NAME = 'propel';
|
|
|
|
|
|
const TABLE_NAME = 'user';
|
|
|
|
|
|
const CLASS_DEFAULT = 'lib.model.User';
|
|
|
|
|
|
const NUM_COLUMNS = 20;
|
|
|
|
|
|
const NUM_LAZY_LOAD_COLUMNS = 0;
|
|
|
|
|
|
|
|
const ID = 'user.ID';
|
|
|
|
|
|
const USER_NAME = 'user.USER_NAME';
|
|
|
|
|
|
const FIRST_NAME = 'user.FIRST_NAME';
|
|
|
|
|
|
const LAST_NAME = 'user.LAST_NAME';
|
|
|
|
|
|
const EMAIL = 'user.EMAIL';
|
|
|
|
|
|
const PHONE = 'user.PHONE';
|
|
|
|
|
|
const ADDRESS = 'user.ADDRESS';
|
|
|
|
|
|
const ADDRESS_2 = 'user.ADDRESS_2';
|
|
|
|
|
|
const CITY = 'user.CITY';
|
|
|
|
|
|
const STATE = 'user.STATE';
|
|
|
|
|
|
const ZIP = 'user.ZIP';
|
|
|
|
|
|
const PASSWORD = 'user.PASSWORD';
|
|
|
|
|
|
const START_TIME = 'user.START_TIME';
|
|
|
|
|
|
const END_TIME = 'user.END_TIME';
|
|
|
|
|
|
const LOCATION_ID = 'user.LOCATION_ID';
|
|
|
|
|
|
const CREATED_AT = 'user.CREATED_AT';
|
|
|
|
|
|
const UPDATED_AT = 'user.UPDATED_AT';
|
|
|
|
|
|
const USER_TYPE_ID = 'user.USER_TYPE_ID';
|
|
|
|
|
|
const WEIGHT = 'user.WEIGHT';
|
|
|
|
|
|
const ADMIN = 'user.ADMIN';
|
|
|
|
|
|
private static $phpNameMap = null;
|
|
|
|
|
|
|
|
private static $fieldNames = array (
|
|
BasePeer::TYPE_PHPNAME => array ('Id', 'UserName', 'FirstName', 'LastName', 'Email', 'Phone', 'Address', 'Address2', 'City', 'State', 'Zip', 'Password', 'StartTime', 'EndTime', 'LocationId', 'CreatedAt', 'UpdatedAt', 'UserTypeId', 'Weight', 'Admin', ),
|
|
BasePeer::TYPE_COLNAME => array (UserPeer::ID, UserPeer::USER_NAME, UserPeer::FIRST_NAME, UserPeer::LAST_NAME, UserPeer::EMAIL, UserPeer::PHONE, UserPeer::ADDRESS, UserPeer::ADDRESS_2, UserPeer::CITY, UserPeer::STATE, UserPeer::ZIP, UserPeer::PASSWORD, UserPeer::START_TIME, UserPeer::END_TIME, UserPeer::LOCATION_ID, UserPeer::CREATED_AT, UserPeer::UPDATED_AT, UserPeer::USER_TYPE_ID, UserPeer::WEIGHT, UserPeer::ADMIN, ),
|
|
BasePeer::TYPE_FIELDNAME => array ('id', 'user_name', 'first_name', 'last_name', 'email', 'phone', 'address', 'address_2', 'city', 'state', 'zip', 'password', 'start_time', 'end_time', 'location_id', 'created_at', 'updated_at', 'user_type_id', 'weight', 'admin', ),
|
|
BasePeer::TYPE_NUM => array (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, )
|
|
);
|
|
|
|
|
|
private static $fieldKeys = array (
|
|
BasePeer::TYPE_PHPNAME => array ('Id' => 0, 'UserName' => 1, 'FirstName' => 2, 'LastName' => 3, 'Email' => 4, 'Phone' => 5, 'Address' => 6, 'Address2' => 7, 'City' => 8, 'State' => 9, 'Zip' => 10, 'Password' => 11, 'StartTime' => 12, 'EndTime' => 13, 'LocationId' => 14, 'CreatedAt' => 15, 'UpdatedAt' => 16, 'UserTypeId' => 17, 'Weight' => 18, 'Admin' => 19, ),
|
|
BasePeer::TYPE_COLNAME => array (UserPeer::ID => 0, UserPeer::USER_NAME => 1, UserPeer::FIRST_NAME => 2, UserPeer::LAST_NAME => 3, UserPeer::EMAIL => 4, UserPeer::PHONE => 5, UserPeer::ADDRESS => 6, UserPeer::ADDRESS_2 => 7, UserPeer::CITY => 8, UserPeer::STATE => 9, UserPeer::ZIP => 10, UserPeer::PASSWORD => 11, UserPeer::START_TIME => 12, UserPeer::END_TIME => 13, UserPeer::LOCATION_ID => 14, UserPeer::CREATED_AT => 15, UserPeer::UPDATED_AT => 16, UserPeer::USER_TYPE_ID => 17, UserPeer::WEIGHT => 18, UserPeer::ADMIN => 19, ),
|
|
BasePeer::TYPE_FIELDNAME => array ('id' => 0, 'user_name' => 1, 'first_name' => 2, 'last_name' => 3, 'email' => 4, 'phone' => 5, 'address' => 6, 'address_2' => 7, 'city' => 8, 'state' => 9, 'zip' => 10, 'password' => 11, 'start_time' => 12, 'end_time' => 13, 'location_id' => 14, 'created_at' => 15, 'updated_at' => 16, 'user_type_id' => 17, 'weight' => 18, 'admin' => 19, ),
|
|
BasePeer::TYPE_NUM => array (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, )
|
|
);
|
|
|
|
|
|
public static function getMapBuilder()
|
|
{
|
|
include_once 'lib/model/map/UserMapBuilder.php';
|
|
return BasePeer::getMapBuilder('lib.model.map.UserMapBuilder');
|
|
}
|
|
|
|
public static function getPhpNameMap()
|
|
{
|
|
if (self::$phpNameMap === null) {
|
|
$map = UserPeer::getTableMap();
|
|
$columns = $map->getColumns();
|
|
$nameMap = array();
|
|
foreach ($columns as $column) {
|
|
$nameMap[$column->getPhpName()] = $column->getColumnName();
|
|
}
|
|
self::$phpNameMap = $nameMap;
|
|
}
|
|
return self::$phpNameMap;
|
|
}
|
|
|
|
static public function translateFieldName($name, $fromType, $toType)
|
|
{
|
|
$toNames = self::getFieldNames($toType);
|
|
$key = isset(self::$fieldKeys[$fromType][$name]) ? self::$fieldKeys[$fromType][$name] : null;
|
|
if ($key === null) {
|
|
throw new PropelException("'$name' could not be found in the field names of type '$fromType'. These are: " . print_r(self::$fieldKeys[$fromType], true));
|
|
}
|
|
return $toNames[$key];
|
|
}
|
|
|
|
|
|
|
|
static public function getFieldNames($type = BasePeer::TYPE_PHPNAME)
|
|
{
|
|
if (!array_key_exists($type, self::$fieldNames)) {
|
|
throw new PropelException('Method getFieldNames() expects the parameter $type to be one of the class constants TYPE_PHPNAME, TYPE_COLNAME, TYPE_FIELDNAME, TYPE_NUM. ' . $type . ' was given.');
|
|
}
|
|
return self::$fieldNames[$type];
|
|
}
|
|
|
|
|
|
public static function alias($alias, $column)
|
|
{
|
|
return str_replace(UserPeer::TABLE_NAME.'.', $alias.'.', $column);
|
|
}
|
|
|
|
|
|
public static function addSelectColumns(Criteria $criteria)
|
|
{
|
|
|
|
$criteria->addSelectColumn(UserPeer::ID);
|
|
|
|
$criteria->addSelectColumn(UserPeer::USER_NAME);
|
|
|
|
$criteria->addSelectColumn(UserPeer::FIRST_NAME);
|
|
|
|
$criteria->addSelectColumn(UserPeer::LAST_NAME);
|
|
|
|
$criteria->addSelectColumn(UserPeer::EMAIL);
|
|
|
|
$criteria->addSelectColumn(UserPeer::PHONE);
|
|
|
|
$criteria->addSelectColumn(UserPeer::ADDRESS);
|
|
|
|
$criteria->addSelectColumn(UserPeer::ADDRESS_2);
|
|
|
|
$criteria->addSelectColumn(UserPeer::CITY);
|
|
|
|
$criteria->addSelectColumn(UserPeer::STATE);
|
|
|
|
$criteria->addSelectColumn(UserPeer::ZIP);
|
|
|
|
$criteria->addSelectColumn(UserPeer::PASSWORD);
|
|
|
|
$criteria->addSelectColumn(UserPeer::START_TIME);
|
|
|
|
$criteria->addSelectColumn(UserPeer::END_TIME);
|
|
|
|
$criteria->addSelectColumn(UserPeer::LOCATION_ID);
|
|
|
|
$criteria->addSelectColumn(UserPeer::CREATED_AT);
|
|
|
|
$criteria->addSelectColumn(UserPeer::UPDATED_AT);
|
|
|
|
$criteria->addSelectColumn(UserPeer::USER_TYPE_ID);
|
|
|
|
$criteria->addSelectColumn(UserPeer::WEIGHT);
|
|
|
|
$criteria->addSelectColumn(UserPeer::ADMIN);
|
|
|
|
}
|
|
|
|
const COUNT = 'COUNT(user.ID)';
|
|
const COUNT_DISTINCT = 'COUNT(DISTINCT user.ID)';
|
|
|
|
|
|
public static function doCount(Criteria $criteria, $distinct = false, $con = null)
|
|
{
|
|
$criteria = clone $criteria;
|
|
|
|
$criteria->clearSelectColumns()->clearOrderByColumns();
|
|
if ($distinct || in_array(Criteria::DISTINCT, $criteria->getSelectModifiers())) {
|
|
$criteria->addSelectColumn(UserPeer::COUNT_DISTINCT);
|
|
} else {
|
|
$criteria->addSelectColumn(UserPeer::COUNT);
|
|
}
|
|
|
|
foreach($criteria->getGroupByColumns() as $column)
|
|
{
|
|
$criteria->addSelectColumn($column);
|
|
}
|
|
|
|
$rs = UserPeer::doSelectRS($criteria, $con);
|
|
if ($rs->next()) {
|
|
return $rs->getInt(1);
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
public static function doSelectOne(Criteria $criteria, $con = null)
|
|
{
|
|
$critcopy = clone $criteria;
|
|
$critcopy->setLimit(1);
|
|
$objects = UserPeer::doSelect($critcopy, $con);
|
|
if ($objects) {
|
|
return $objects[0];
|
|
}
|
|
return null;
|
|
}
|
|
|
|
public static function doSelect(Criteria $criteria, $con = null)
|
|
{
|
|
return UserPeer::populateObjects(UserPeer::doSelectRS($criteria, $con));
|
|
}
|
|
|
|
public static function doSelectRS(Criteria $criteria, $con = null)
|
|
{
|
|
if ($con === null) {
|
|
$con = Propel::getConnection(self::DATABASE_NAME);
|
|
}
|
|
|
|
if (!$criteria->getSelectColumns()) {
|
|
$criteria = clone $criteria;
|
|
UserPeer::addSelectColumns($criteria);
|
|
}
|
|
|
|
$criteria->setDbName(self::DATABASE_NAME);
|
|
|
|
return BasePeer::doSelect($criteria, $con);
|
|
}
|
|
|
|
public static function populateObjects(ResultSet $rs)
|
|
{
|
|
$results = array();
|
|
|
|
$cls = UserPeer::getOMClass();
|
|
$cls = Propel::import($cls);
|
|
while($rs->next()) {
|
|
|
|
$obj = new $cls();
|
|
$obj->hydrate($rs);
|
|
$results[] = $obj;
|
|
|
|
}
|
|
return $results;
|
|
}
|
|
|
|
|
|
public static function doCountJoinUserType(Criteria $criteria, $distinct = false, $con = null)
|
|
{
|
|
$criteria = clone $criteria;
|
|
|
|
$criteria->clearSelectColumns()->clearOrderByColumns();
|
|
if ($distinct || in_array(Criteria::DISTINCT, $criteria->getSelectModifiers())) {
|
|
$criteria->addSelectColumn(UserPeer::COUNT_DISTINCT);
|
|
} else {
|
|
$criteria->addSelectColumn(UserPeer::COUNT);
|
|
}
|
|
|
|
foreach($criteria->getGroupByColumns() as $column)
|
|
{
|
|
$criteria->addSelectColumn($column);
|
|
}
|
|
|
|
$criteria->addJoin(UserPeer::USER_TYPE_ID, UserTypePeer::ID);
|
|
|
|
$rs = UserPeer::doSelectRS($criteria, $con);
|
|
if ($rs->next()) {
|
|
return $rs->getInt(1);
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
public static function doSelectJoinUserType(Criteria $c, $con = null)
|
|
{
|
|
$c = clone $c;
|
|
|
|
if ($c->getDbName() == Propel::getDefaultDB()) {
|
|
$c->setDbName(self::DATABASE_NAME);
|
|
}
|
|
|
|
UserPeer::addSelectColumns($c);
|
|
$startcol = (UserPeer::NUM_COLUMNS - UserPeer::NUM_LAZY_LOAD_COLUMNS) + 1;
|
|
UserTypePeer::addSelectColumns($c);
|
|
|
|
$c->addJoin(UserPeer::USER_TYPE_ID, UserTypePeer::ID);
|
|
$rs = BasePeer::doSelect($c, $con);
|
|
$results = array();
|
|
|
|
while($rs->next()) {
|
|
|
|
$omClass = UserPeer::getOMClass();
|
|
|
|
$cls = Propel::import($omClass);
|
|
$obj1 = new $cls();
|
|
$obj1->hydrate($rs);
|
|
|
|
$omClass = UserTypePeer::getOMClass();
|
|
|
|
$cls = Propel::import($omClass);
|
|
$obj2 = new $cls();
|
|
$obj2->hydrate($rs, $startcol);
|
|
|
|
$newObject = true;
|
|
foreach($results as $temp_obj1) {
|
|
$temp_obj2 = $temp_obj1->getUserType(); if ($temp_obj2->getPrimaryKey() === $obj2->getPrimaryKey()) {
|
|
$newObject = false;
|
|
$temp_obj2->addUser($obj1); break;
|
|
}
|
|
}
|
|
if ($newObject) {
|
|
$obj2->initUsers();
|
|
$obj2->addUser($obj1); }
|
|
$results[] = $obj1;
|
|
}
|
|
return $results;
|
|
}
|
|
|
|
|
|
|
|
public static function doCountJoinAll(Criteria $criteria, $distinct = false, $con = null)
|
|
{
|
|
$criteria = clone $criteria;
|
|
|
|
$criteria->clearSelectColumns()->clearOrderByColumns();
|
|
if ($distinct || in_array(Criteria::DISTINCT, $criteria->getSelectModifiers())) {
|
|
$criteria->addSelectColumn(UserPeer::COUNT_DISTINCT);
|
|
} else {
|
|
$criteria->addSelectColumn(UserPeer::COUNT);
|
|
}
|
|
|
|
foreach($criteria->getGroupByColumns() as $column)
|
|
{
|
|
$criteria->addSelectColumn($column);
|
|
}
|
|
|
|
$criteria->addJoin(UserPeer::USER_TYPE_ID, UserTypePeer::ID);
|
|
|
|
$rs = UserPeer::doSelectRS($criteria, $con);
|
|
if ($rs->next()) {
|
|
return $rs->getInt(1);
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
public static function doSelectJoinAll(Criteria $c, $con = null)
|
|
{
|
|
$c = clone $c;
|
|
|
|
if ($c->getDbName() == Propel::getDefaultDB()) {
|
|
$c->setDbName(self::DATABASE_NAME);
|
|
}
|
|
|
|
UserPeer::addSelectColumns($c);
|
|
$startcol2 = (UserPeer::NUM_COLUMNS - UserPeer::NUM_LAZY_LOAD_COLUMNS) + 1;
|
|
|
|
UserTypePeer::addSelectColumns($c);
|
|
$startcol3 = $startcol2 + UserTypePeer::NUM_COLUMNS;
|
|
|
|
$c->addJoin(UserPeer::USER_TYPE_ID, UserTypePeer::ID);
|
|
|
|
$rs = BasePeer::doSelect($c, $con);
|
|
$results = array();
|
|
|
|
while($rs->next()) {
|
|
|
|
$omClass = UserPeer::getOMClass();
|
|
|
|
|
|
$cls = Propel::import($omClass);
|
|
$obj1 = new $cls();
|
|
$obj1->hydrate($rs);
|
|
|
|
|
|
|
|
$omClass = UserTypePeer::getOMClass();
|
|
|
|
|
|
$cls = Propel::import($omClass);
|
|
$obj2 = new $cls();
|
|
$obj2->hydrate($rs, $startcol2);
|
|
|
|
$newObject = true;
|
|
for ($j=0, $resCount=count($results); $j < $resCount; $j++) {
|
|
$temp_obj1 = $results[$j];
|
|
$temp_obj2 = $temp_obj1->getUserType(); if ($temp_obj2->getPrimaryKey() === $obj2->getPrimaryKey()) {
|
|
$newObject = false;
|
|
$temp_obj2->addUser($obj1); break;
|
|
}
|
|
}
|
|
|
|
if ($newObject) {
|
|
$obj2->initUsers();
|
|
$obj2->addUser($obj1);
|
|
}
|
|
|
|
$results[] = $obj1;
|
|
}
|
|
return $results;
|
|
}
|
|
|
|
|
|
public static function getTableMap()
|
|
{
|
|
return Propel::getDatabaseMap(self::DATABASE_NAME)->getTable(self::TABLE_NAME);
|
|
}
|
|
|
|
|
|
public static function getOMClass()
|
|
{
|
|
return UserPeer::CLASS_DEFAULT;
|
|
}
|
|
|
|
|
|
public static function doInsert($values, $con = null)
|
|
{
|
|
if ($con === null) {
|
|
$con = Propel::getConnection(self::DATABASE_NAME);
|
|
}
|
|
|
|
if ($values instanceof Criteria) {
|
|
$criteria = clone $values; } else {
|
|
$criteria = $values->buildCriteria(); }
|
|
|
|
$criteria->remove(UserPeer::ID);
|
|
|
|
$criteria->setDbName(self::DATABASE_NAME);
|
|
|
|
try {
|
|
$con->begin();
|
|
$pk = BasePeer::doInsert($criteria, $con);
|
|
$con->commit();
|
|
} catch(PropelException $e) {
|
|
$con->rollback();
|
|
throw $e;
|
|
}
|
|
|
|
return $pk;
|
|
}
|
|
|
|
|
|
public static function doUpdate($values, $con = null)
|
|
{
|
|
if ($con === null) {
|
|
$con = Propel::getConnection(self::DATABASE_NAME);
|
|
}
|
|
|
|
$selectCriteria = new Criteria(self::DATABASE_NAME);
|
|
|
|
if ($values instanceof Criteria) {
|
|
$criteria = clone $values;
|
|
$comparison = $criteria->getComparison(UserPeer::ID);
|
|
$selectCriteria->add(UserPeer::ID, $criteria->remove(UserPeer::ID), $comparison);
|
|
|
|
} else { $criteria = $values->buildCriteria(); $selectCriteria = $values->buildPkeyCriteria(); }
|
|
|
|
$criteria->setDbName(self::DATABASE_NAME);
|
|
|
|
return BasePeer::doUpdate($selectCriteria, $criteria, $con);
|
|
}
|
|
|
|
|
|
public static function doDeleteAll($con = null)
|
|
{
|
|
if ($con === null) {
|
|
$con = Propel::getConnection(self::DATABASE_NAME);
|
|
}
|
|
$affectedRows = 0; try {
|
|
$con->begin();
|
|
$affectedRows += BasePeer::doDeleteAll(UserPeer::TABLE_NAME, $con);
|
|
$con->commit();
|
|
return $affectedRows;
|
|
} catch (PropelException $e) {
|
|
$con->rollback();
|
|
throw $e;
|
|
}
|
|
}
|
|
|
|
|
|
public static function doDelete($values, $con = null)
|
|
{
|
|
if ($con === null) {
|
|
$con = Propel::getConnection(UserPeer::DATABASE_NAME);
|
|
}
|
|
|
|
if ($values instanceof Criteria) {
|
|
$criteria = clone $values; } elseif ($values instanceof User) {
|
|
|
|
$criteria = $values->buildPkeyCriteria();
|
|
} else {
|
|
$criteria = new Criteria(self::DATABASE_NAME);
|
|
$criteria->add(UserPeer::ID, (array) $values, Criteria::IN);
|
|
}
|
|
|
|
$criteria->setDbName(self::DATABASE_NAME);
|
|
|
|
$affectedRows = 0;
|
|
try {
|
|
$con->begin();
|
|
|
|
$affectedRows += BasePeer::doDelete($criteria, $con);
|
|
$con->commit();
|
|
return $affectedRows;
|
|
} catch (PropelException $e) {
|
|
$con->rollback();
|
|
throw $e;
|
|
}
|
|
}
|
|
|
|
|
|
public static function doValidate(User $obj, $cols = null)
|
|
{
|
|
$columns = array();
|
|
|
|
if ($cols) {
|
|
$dbMap = Propel::getDatabaseMap(UserPeer::DATABASE_NAME);
|
|
$tableMap = $dbMap->getTable(UserPeer::TABLE_NAME);
|
|
|
|
if (! is_array($cols)) {
|
|
$cols = array($cols);
|
|
}
|
|
|
|
foreach($cols as $colName) {
|
|
if ($tableMap->containsColumn($colName)) {
|
|
$get = 'get' . $tableMap->getColumn($colName)->getPhpName();
|
|
$columns[$colName] = $obj->$get();
|
|
}
|
|
}
|
|
} else {
|
|
|
|
}
|
|
|
|
$res = BasePeer::doValidate(UserPeer::DATABASE_NAME, UserPeer::TABLE_NAME, $columns);
|
|
if ($res !== true) {
|
|
$request = sfContext::getInstance()->getRequest();
|
|
foreach ($res as $failed) {
|
|
$col = UserPeer::translateFieldname($failed->getColumn(), BasePeer::TYPE_COLNAME, BasePeer::TYPE_PHPNAME);
|
|
$request->setError($col, $failed->getMessage());
|
|
}
|
|
}
|
|
|
|
return $res;
|
|
}
|
|
|
|
|
|
public static function retrieveByPK($pk, $con = null)
|
|
{
|
|
if ($con === null) {
|
|
$con = Propel::getConnection(self::DATABASE_NAME);
|
|
}
|
|
|
|
$criteria = new Criteria(UserPeer::DATABASE_NAME);
|
|
|
|
$criteria->add(UserPeer::ID, $pk);
|
|
|
|
|
|
$v = UserPeer::doSelect($criteria, $con);
|
|
|
|
return !empty($v) > 0 ? $v[0] : null;
|
|
}
|
|
|
|
|
|
public static function retrieveByPKs($pks, $con = null)
|
|
{
|
|
if ($con === null) {
|
|
$con = Propel::getConnection(self::DATABASE_NAME);
|
|
}
|
|
|
|
$objs = null;
|
|
if (empty($pks)) {
|
|
$objs = array();
|
|
} else {
|
|
$criteria = new Criteria();
|
|
$criteria->add(UserPeer::ID, $pks, Criteria::IN);
|
|
$objs = UserPeer::doSelect($criteria, $con);
|
|
}
|
|
return $objs;
|
|
}
|
|
|
|
}
|
|
if (Propel::isInit()) {
|
|
try {
|
|
BaseUserPeer::getMapBuilder();
|
|
} catch (Exception $e) {
|
|
Propel::log('Could not initialize Peer: ' . $e->getMessage(), Propel::LOG_ERR);
|
|
}
|
|
} else {
|
|
require_once 'lib/model/map/UserMapBuilder.php';
|
|
Propel::registerMapBuilder('lib.model.map.UserMapBuilder');
|
|
}
|