1
0
mirror of synced 2025-01-06 00:57:10 +03:00

Fixes for Doctrine Resource

This commit is contained in:
Jonathan.Wage 2007-09-24 18:22:52 +00:00
parent d6c0bcb4fc
commit e9ba4504bf
7 changed files with 139 additions and 53 deletions

View File

@ -1143,9 +1143,9 @@ abstract class Doctrine_Record extends Doctrine_Record_Abstract implements Count
{ {
if (is_array($array)) { if (is_array($array)) {
foreach ($array as $key => $value) { foreach ($array as $key => $value) {
if (is_array($value)) { if ($this->getTable()->hasRelation($key) && $value) {
$this->$key->fromArray($value); $this->$key->fromArray($value);
} else { } else if($this->getTable()->hasColumn($key) && $value) {
$this->$key = $value; $this->$key = $value;
} }
} }

View File

@ -59,7 +59,7 @@ class Doctrine_Resource_Client extends Doctrine_Resource
} else { } else {
$request = new Doctrine_Resource_Request(); $request = new Doctrine_Resource_Request();
$request->set('type', 'load'); $request->set('type', 'load');
$request->set('format', 'xml'); $request->set('format', $this->getConfig()->get('format'));
$schema = $request->execute(); $schema = $request->execute();
@ -67,7 +67,7 @@ class Doctrine_Resource_Client extends Doctrine_Resource
} }
$import = new Doctrine_Import_Schema(); $import = new Doctrine_Import_Schema();
$schema = $import->buildSchema($path, 'xml'); $schema = $import->buildSchema($path, $this->getConfig()->get('format'));
$this->getConfig()->set('schema', $schema); $this->getConfig()->set('schema', $schema);
} }

View File

@ -31,7 +31,7 @@
* @link www.phpdoctrine.com * @link www.phpdoctrine.com
* @since 1.0 * @since 1.0
*/ */
class Doctrine_Resource_Collection extends Doctrine_Access implements Countable, IteratorAggregate class Doctrine_Resource_Collection extends Doctrine_Resource_Access implements Countable, IteratorAggregate
{ {
protected $_data = array(); protected $_data = array();
protected $_config = array(); protected $_config = array();
@ -84,7 +84,9 @@ class Doctrine_Resource_Collection extends Doctrine_Access implements Countable,
$array = array(); $array = array();
foreach ($this->_data as $key => $record) { foreach ($this->_data as $key => $record) {
$array[$key] = $record->toArray(); if ($record->exists()) {
$array[$this->_model . '_' .$key] = $record->toArray();
}
} }
return $array; return $array;

View File

@ -31,7 +31,7 @@
* @link www.phpdoctrine.com * @link www.phpdoctrine.com
* @since 1.0 * @since 1.0
*/ */
class Doctrine_Resource_Record extends Doctrine_Record_Abstract implements Countable, IteratorAggregate class Doctrine_Resource_Record extends Doctrine_Resource_Access implements Countable, IteratorAggregate
{ {
protected $_data = array(); protected $_data = array();
protected $_model = null; protected $_model = null;
@ -119,7 +119,7 @@ class Doctrine_Resource_Record extends Doctrine_Record_Abstract implements Count
public function save() public function save()
{ {
$format = $this->getConfig('format') ? $this->getConfig('format'):'xml'; $format = $this->getConfig('format');
$request = new Doctrine_Resource_Request(); $request = new Doctrine_Resource_Request();
$request->set('format', $format); $request->set('format', $format);
@ -139,14 +139,73 @@ class Doctrine_Resource_Record extends Doctrine_Record_Abstract implements Count
return $this->_model; return $this->_model;
} }
public function identifier()
{
$identifier = array();
if (isset($this->_schema['columns']) && is_array($this->_schema['columns'])) {
foreach ($this->_schema['columns'] as $name => $column) {
if ($column['primary'] == true) {
$identifier[$name] = $this->_data[$name];
}
}
}
return $identifier;
}
public function exists()
{
$identifier = $this->identifier();
foreach ($identifier as $key => $value) {
if (!$value) {
return false;
}
}
return true;
}
public function hasColumn($name)
{
return isset($this->_schema['columns'][$name]) ? true:false;
}
public function getColumn($name)
{
if ($this->hasColumn($name)) {
return $this->_columns[$name];
}
}
public function hasRelation($name)
{
return isset($this->_schema['relations'][$name]) ? true:false;
}
public function getRelation($name)
{
if ($this->hasRelation($name)) {
return $this->_schema['relations'][$name];
}
}
public function toArray() public function toArray()
{ {
$array = array(); $array = array();
foreach ($this->_data as $key => $value) { foreach ($this->_data as $key => $value) {
if ($value instanceof Doctrine_Resource_Collection OR $value instanceof Doctrine_Resource_Record) {
if ($this->hasRelation($key) && $value instanceof Doctrine_Resource_Collection) {
if ($value->count() > 0) {
$array[$key] = $value->toArray(); $array[$key] = $value->toArray();
} else { }
} else if ($this->hasRelation($key) && $value instanceof Doctrine_Resource_Record) {
if ($value->exists()) {
$array[$key] = $value->toArray();
}
} else if (!$this->hasRelation($key) && $this->hasColumn($key)) {
$array[$key] = $value; $array[$key] = $value;
} }
} }

View File

@ -40,49 +40,49 @@ class Doctrine_Resource_Request extends Doctrine_Resource_Params
return Doctrine_Resource_Client::getInstance()->getConfig($key); return Doctrine_Resource_Client::getInstance()->getConfig($key);
} }
public function getParams()
{
if ($this->_params === null) {
$this->_params = new Doctrine_Resource_Params();
}
return $this->_params;
}
public function get($key)
{
return $this->getParams()->get($key);
}
public function set($key, $value)
{
return $this->getParams()->set($key, $value);
}
public function execute() public function execute()
{ {
$url = $this->getConfig()->get('url'); $url = $this->getConfig()->get('url');
$url .= strstr($this->getConfig()->get('url'), '?') ? '&':'?'; $data = array('type' => $this->get('type'), 'format' => $this->getConfig()->get('format'), 'data' => Doctrine_Parser::dump($this->getAll(), $this->getConfig()->get('format')));
$url .= http_build_query($this->getParams()->getAll());
$response = file_get_contents($url); $ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
$response = curl_exec($ch);
if (curl_errno($ch)) {
throw new Doctrine_Resource_Exception('Request failed');
}
curl_close($ch);
return $response; return $response;
} }
public function hydrate(array $array, $model, $passedKey = null) public function hydrate(array $array, $model, $passedKey = null)
{ {
$config = $this->getConfig(); if (empty($array)) {
return false;
}
$collection = new Doctrine_Resource_Collection($model, $config); $collection = new Doctrine_Resource_Collection($model);
foreach ($array as $record) { foreach ($array as $record) {
$r = new Doctrine_Resource_Record($model, $config); $r = new Doctrine_Resource_Record($model);
foreach ($record as $key => $value) { foreach ($record as $key => $value) {
if (is_array($value)) { if ($r->hasRelation($key) && !empty($value)) {
$r->set($key, $this->hydrate($value, $model, $config, $key)); $relation = $r->getRelation($key);
if ($relation['type'] === Doctrine_Relation::MANY) {
$r->set($key, $this->hydrate($value, $relation['class'], $key));
} else { } else {
$r->set($key, $this->hydrate(array($value), $relation['class'], $key)->getFirst());
}
} else if($r->hasColumn($key)) {
$r->set($key, $value); $r->set($key, $value);
} }
} }

View File

@ -31,7 +31,7 @@
* @link www.phpdoctrine.com * @link www.phpdoctrine.com
* @since 1.0 * @since 1.0
*/ */
class Doctrine_Resource_Server extends Doctrine_resource class Doctrine_Resource_Server extends Doctrine_Resource
{ {
static public function getInstance($config = null) static public function getInstance($config = null)
{ {
@ -49,7 +49,29 @@ class Doctrine_Resource_Server extends Doctrine_resource
$model = $request->get('model'); $model = $request->get('model');
$data = $request->get('data'); $data = $request->get('data');
$table = Doctrine_Manager::getInstance()->getTable($model);
$identifier = $table->getIdentifier();
if (!is_array($identifier)) {
$identifier = array($identifier);
}
$existing = true;
$pks = array();
foreach ($identifier as $name) {
if (isset($data[$name])) {
$pks[$name] = $data[$name];
} else {
$existing = false;
}
}
if ($existing) {
$record = $table->find($pks);
} else {
$record = new $model(); $record = new $model();
}
$record->fromArray($data); $record->fromArray($data);
$record->save(); $record->save();
@ -82,20 +104,22 @@ class Doctrine_Resource_Server extends Doctrine_resource
return $schema; return $schema;
} }
public function execute($request) public function execute(array $r)
{ {
if (!isset($request['type'])) { if (!isset($r['data'])) {
throw new Doctrine_Resource_Exception('You must specify a request type'); throw new Doctrine_Resource_Exception('You must specify a data xml string in your request');
} }
$format = isset($request['format']) ? $request['format']:'xml'; $type = $r['type'];
$type = $request['type']; $format = isset($r['format']) ? $r['format']:'xml';
$data = Doctrine_Parser::load($r['data'], $format);
$funcName = 'execute' . Doctrine::classify($type); $funcName = 'execute' . Doctrine::classify($type);
$request = new Doctrine_Resource_Request($request); $requestObj = new Doctrine_Resource_Request($data);
if (method_exists($this, $funcName)) { if (method_exists($this, $funcName)) {
$result = $this->$funcName($request); $result = $this->$funcName($requestObj);
} else { } else {
throw new Doctrine_Resource_Exception('Unknown Doctrine Resource Server function'); throw new Doctrine_Resource_Exception('Unknown Doctrine Resource Server function');
} }

View File

@ -18,9 +18,10 @@ if ($action == 'server') {
$client = Doctrine_Resource_Client::getInstance($config); $client = Doctrine_Resource_Client::getInstance($config);
$user = $client->newRecord('User'); $query = new Doctrine_Resource_Query();
$user->name = 'jonathan h. wage'; $query->from('User u, u.Email e, u.Phonenumber p');
$user->save();
print_r($user->toArray()); $users = $query->execute();
print_r($users->toArray());
} }