Fixes for doctrine resource.
This commit is contained in:
parent
5aa73029cf
commit
b98130db1e
@ -589,12 +589,15 @@ class Doctrine_Collection extends Doctrine_Access implements Countable, Iterator
|
||||
*
|
||||
* @param boolean $deep
|
||||
*/
|
||||
public function toArray($deep = false)
|
||||
public function toArray($deep = false, $prefixKey = false)
|
||||
{
|
||||
if ($deep) {
|
||||
$data = array();
|
||||
foreach ($this->data as $key => $record) {
|
||||
$data[$key] = $record->toArray($deep);
|
||||
|
||||
$key = $prefixKey ? get_class($record) . '_' .$key:$key;
|
||||
|
||||
$data[$key] = $record->toArray($deep, $prefixKey);
|
||||
}
|
||||
return $data;
|
||||
} else {
|
||||
|
@ -108,7 +108,7 @@ class Doctrine_Parser_Xml extends Doctrine_Parser
|
||||
if (is_array($return)) {
|
||||
return $return;
|
||||
} else {
|
||||
return $false;
|
||||
return array();
|
||||
}
|
||||
}
|
||||
}
|
@ -1118,7 +1118,7 @@ abstract class Doctrine_Record extends Doctrine_Record_Abstract implements Count
|
||||
* @param boolean $deep - Return also the relations
|
||||
* @return array
|
||||
*/
|
||||
public function toArray($deep = false)
|
||||
public function toArray($deep = false, $prefixKey = false)
|
||||
{
|
||||
$a = array();
|
||||
|
||||
@ -1134,18 +1134,20 @@ abstract class Doctrine_Record extends Doctrine_Record_Abstract implements Count
|
||||
}
|
||||
if ($deep) {
|
||||
foreach ($this->_references as $key => $relation) {
|
||||
$a[$key] = $relation->toArray($deep);
|
||||
$a[$key] = $relation->toArray($deep, $prefixKey);
|
||||
}
|
||||
}
|
||||
return array_merge($a, $this->_values);
|
||||
}
|
||||
public function fromArray($array)
|
||||
{
|
||||
if (is_array($array)) {
|
||||
foreach ($array as $key => $value) {
|
||||
if (!$this->getTable()->hasRelation($key) && $this->getTable()->hasColumn($key)) {
|
||||
$this->$key = $value;
|
||||
} else {
|
||||
if (is_array($value)) {
|
||||
$this->$key->fromArray($value);
|
||||
} else {
|
||||
$this->$key = $value;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -6,6 +6,29 @@ class Doctrine_Resource
|
||||
$url .= strstr($url, '?') ? '&':'?';
|
||||
$url .= http_build_query($request);
|
||||
|
||||
return file_get_contents($url);
|
||||
$response = file_get_contents($url);
|
||||
|
||||
return $response;
|
||||
}
|
||||
|
||||
public function hydrate(array $array, $model, $config, $passedKey = null)
|
||||
{
|
||||
$collection = new Doctrine_Resource_Collection($model, $config);
|
||||
|
||||
foreach ($array as $record) {
|
||||
$r = new Doctrine_Resource_Record($model, $config);
|
||||
|
||||
foreach ($record as $key => $value) {
|
||||
if (is_array($value)) {
|
||||
$r->data[$key] = $this->hydrate($value, $model, $config, $key);
|
||||
} else {
|
||||
$r->data[$key] = $value;
|
||||
}
|
||||
}
|
||||
|
||||
$collection->data[] = $r;
|
||||
}
|
||||
|
||||
return $collection;
|
||||
}
|
||||
}
|
@ -17,4 +17,9 @@ class Doctrine_Resource_Client extends Doctrine_Resource
|
||||
{
|
||||
return new Doctrine_Resource_Record($model, $this->config);
|
||||
}
|
||||
|
||||
public function newCollection($model)
|
||||
{
|
||||
return new Doctrine_Resource_Collection($model, $this->config);
|
||||
}
|
||||
}
|
@ -5,9 +5,10 @@ class Doctrine_Resource_Collection extends Doctrine_Access implements Countable,
|
||||
public $config = array();
|
||||
public $model = null;
|
||||
|
||||
public function __construct($model)
|
||||
public function __construct($model, $config)
|
||||
{
|
||||
$this->model = $model;
|
||||
$this->config = $config;
|
||||
}
|
||||
|
||||
public function count()
|
||||
@ -15,6 +16,18 @@ class Doctrine_Resource_Collection extends Doctrine_Access implements Countable,
|
||||
return count($data);
|
||||
}
|
||||
|
||||
public function get($get)
|
||||
{
|
||||
if (isset($this->data[$get])) {
|
||||
return $this->data[$get];
|
||||
}
|
||||
}
|
||||
|
||||
public function set($set, $value)
|
||||
{
|
||||
$this->data[$set] = $value;
|
||||
}
|
||||
|
||||
public function getIterator()
|
||||
{
|
||||
$data = $this->data;
|
||||
@ -30,6 +43,7 @@ class Doctrine_Resource_Collection extends Doctrine_Access implements Countable,
|
||||
public function toArray()
|
||||
{
|
||||
$array = array();
|
||||
|
||||
foreach ($this->data as $key => $record) {
|
||||
$array[$key] = $record->toArray();
|
||||
}
|
||||
|
@ -54,7 +54,7 @@ class Doctrine_Resource_Query extends Doctrine_Resource
|
||||
{
|
||||
$array = Doctrine_Parser::load($response, $this->getFormat());
|
||||
|
||||
$hydrated = $this->hydrate($array);
|
||||
$hydrated = $this->hydrate($array, $this->getModel(), $this->config);
|
||||
|
||||
return $hydrated;
|
||||
}
|
||||
@ -74,29 +74,6 @@ class Doctrine_Resource_Query extends Doctrine_Resource
|
||||
return $url;
|
||||
}
|
||||
|
||||
public function hydrate(array $array, $passedKey = null)
|
||||
{
|
||||
$model = $passedKey ? $passedKey:$this->getModel();
|
||||
|
||||
$collection = new Doctrine_Resource_Collection($model, $this->config);
|
||||
|
||||
foreach ($array as $record) {
|
||||
$r = new Doctrine_Resource_Record($model, $this->config);
|
||||
|
||||
foreach ($record as $key => $value) {
|
||||
if (is_array($value)) {
|
||||
$r->data[$key] = $this->hydrate($value, $key);
|
||||
} else {
|
||||
$r->data[$key] = $value;
|
||||
}
|
||||
}
|
||||
|
||||
$collection->data[] = $r;
|
||||
}
|
||||
|
||||
return $collection;
|
||||
}
|
||||
|
||||
public function getModel()
|
||||
{
|
||||
$dql = $this->getDql();
|
||||
|
@ -4,7 +4,6 @@ class Doctrine_Resource_Record extends Doctrine_Record_Abstract implements Count
|
||||
public $data = array();
|
||||
public $config = array();
|
||||
public $model = null;
|
||||
public $changes = array();
|
||||
|
||||
public function __construct($model, $config)
|
||||
{
|
||||
@ -24,8 +23,6 @@ class Doctrine_Resource_Record extends Doctrine_Record_Abstract implements Count
|
||||
public function set($set, $value)
|
||||
{
|
||||
$this->data[$set] = $value;
|
||||
|
||||
$this->changes[$set] = $value;
|
||||
}
|
||||
|
||||
public function count()
|
||||
@ -40,22 +37,27 @@ class Doctrine_Resource_Record extends Doctrine_Record_Abstract implements Count
|
||||
return new ArrayIterator($data);
|
||||
}
|
||||
|
||||
public function save()
|
||||
public function newRequest($type)
|
||||
{
|
||||
$request = array();
|
||||
$request['format'] = $this->config['format'];
|
||||
$request['type'] = 'save';
|
||||
$request['format'] = isset($this->config['format']) ? $this->config['format']:'xml';
|
||||
$request['type'] = $type;
|
||||
$request['model'] = $this->model;
|
||||
$request['data'] = $this->data;
|
||||
$request['changes'] = $this->changes;
|
||||
|
||||
return $request;
|
||||
}
|
||||
|
||||
public function save()
|
||||
{
|
||||
$request = $this->newRequest('save');
|
||||
$request['data'] = $this->toArray();
|
||||
|
||||
$response = Doctrine_Resource::request($this->config['url'], $request);
|
||||
|
||||
$array = Doctrine_Parser::load($response, $request['format']);
|
||||
|
||||
$this->data = array_merge($this->data, $array);
|
||||
|
||||
return $array;
|
||||
$resource = new Doctrine_Resource();
|
||||
$this->data = $resource->hydrate(array($array), $this->model, $this->config)->getFirst()->data;
|
||||
}
|
||||
|
||||
public function toArray()
|
||||
@ -63,7 +65,7 @@ class Doctrine_Resource_Record extends Doctrine_Record_Abstract implements Count
|
||||
$array = array();
|
||||
|
||||
foreach ($this->data as $key => $value) {
|
||||
if ($value instanceof Doctrine_Resource_Collection) {
|
||||
if ($value instanceof Doctrine_Resource_Collection OR $value instanceof Doctrine_Resource_Record) {
|
||||
$array[$key] = $value->toArray();
|
||||
} else {
|
||||
$array[$key] = $value;
|
||||
|
@ -2,12 +2,35 @@
|
||||
class Doctrine_Resource_Server extends Doctrine_Resource
|
||||
{
|
||||
public $config = array();
|
||||
public $format = 'xml';
|
||||
|
||||
public function __construct($config)
|
||||
{
|
||||
$this->config = array_merge($config, $this->config);
|
||||
}
|
||||
|
||||
public function executeSave($request)
|
||||
{
|
||||
$model = $request['model'];
|
||||
$data = $request['data'];
|
||||
|
||||
$record = new $model();
|
||||
$record->fromArray($data);
|
||||
$record->save();
|
||||
|
||||
return $record->toArray(true, true);
|
||||
}
|
||||
|
||||
public function executeQuery($request)
|
||||
{
|
||||
$dql = $request['dql'];
|
||||
$params = isset($request['params']) ? $request['params']:array();
|
||||
|
||||
$conn = Doctrine_Manager::connection();
|
||||
|
||||
return $conn->query($dql, $params)->toArray(true, true);
|
||||
}
|
||||
|
||||
public function execute($request)
|
||||
{
|
||||
if (!isset($request['type'])) {
|
||||
@ -15,50 +38,10 @@ class Doctrine_Resource_Server extends Doctrine_Resource
|
||||
}
|
||||
|
||||
$format = isset($request['format']) ? $request['format']:'xml';
|
||||
$type = $request['type'];
|
||||
$funcName = 'execute' . Doctrine::classify($type);
|
||||
|
||||
if ($request['type'] == 'query') {
|
||||
if (isset($request['dql']) && $request['dql']) {
|
||||
$dql = $request['dql'];
|
||||
$params = isset($request['params']) ? $request['params']:array();
|
||||
|
||||
$conn = Doctrine_Manager::connection();
|
||||
$result = $conn->query($dql, $params, Doctrine::FETCH_ARRAY);
|
||||
} else {
|
||||
throw new Doctrine_Resource_Exception('You must specify a dql query');
|
||||
}
|
||||
} else if ($request['type'] == 'save') {
|
||||
$model = $request['model'];
|
||||
$table = Doctrine_Manager::getInstance()->getTable($model);
|
||||
$pks = (array) $table->getIdentifier();
|
||||
$pks = array_flip($pks);
|
||||
|
||||
$hasPk = false;
|
||||
foreach (array_keys($pks) as $key) {
|
||||
if (isset($request['data'][$key]) && $request['data'][$key]) {
|
||||
$pks[$key] = $request['data'][$key];
|
||||
|
||||
$hasPk = true;
|
||||
}
|
||||
}
|
||||
|
||||
if ($hasPk) {
|
||||
$record = $table->find($pks);
|
||||
} else {
|
||||
$record = new $model();
|
||||
}
|
||||
|
||||
if (isset($request['changes']) && !empty($request['changes'])) {
|
||||
$changes = $request['changes'];
|
||||
|
||||
foreach ($changes as $key => $value) {
|
||||
$record->$key = $value;
|
||||
}
|
||||
}
|
||||
|
||||
$record->save();
|
||||
|
||||
$result = $record->toArray();
|
||||
}
|
||||
$result = $this->$funcName($request);
|
||||
|
||||
return Doctrine_Parser::dump($result, $format);
|
||||
}
|
||||
|
@ -3,3 +3,22 @@ require_once('playground.php');
|
||||
require_once('connection.php');
|
||||
require_once('models.php');
|
||||
require_once('data.php');
|
||||
|
||||
$action = isset($_REQUEST['action']) ? $_REQUEST['action']:'client';
|
||||
|
||||
if ($action == 'server') {
|
||||
$config = array();
|
||||
|
||||
$server = new Doctrine_Resource_Server($config);
|
||||
$server->run($_REQUEST);
|
||||
} else {
|
||||
$config = array('url' => 'http://localhost/~jwage/doctrine_trunk/playground/index.php?action=server');
|
||||
|
||||
$client = new Doctrine_Resource_Client($config);
|
||||
$record = $client->newRecord('User');
|
||||
$record->name = 'jon wage';
|
||||
$record->loginname = 'test';
|
||||
$record->save();
|
||||
|
||||
print_r($record->toArray());
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user