mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 02:56:15 +00:00
Implementing automatic join models for HABTM associations, adding table prefix fix for Ticket #1965
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@5522 3807eeeb-6ff5-0310-8944-8be069107fe0
This commit is contained in:
parent
214ad6346f
commit
c3dc8cb827
2 changed files with 376 additions and 372 deletions
|
@ -601,10 +601,6 @@ class Model extends Overloadable {
|
||||||
$className = $value['className'];
|
$className = $value['className'];
|
||||||
}
|
}
|
||||||
$this->__constructLinkedModel($assoc, $className);
|
$this->__constructLinkedModel($assoc, $className);
|
||||||
|
|
||||||
if (isset($value['with']) && !empty($value['with'])) {
|
|
||||||
$this->__constructLinkedModel($value['with'], $value['with']);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
$this->__generateAssociation($type);
|
$this->__generateAssociation($type);
|
||||||
}
|
}
|
||||||
|
@ -618,8 +614,11 @@ class Model extends Overloadable {
|
||||||
* @param string $ds Name of DataSource the model should be bound to
|
* @param string $ds Name of DataSource the model should be bound to
|
||||||
* @access private
|
* @access private
|
||||||
*/
|
*/
|
||||||
function __constructLinkedModel($assoc, $className, $id = false, $table = null, $ds = null) {
|
function __constructLinkedModel($assoc, $className = null, $id = false, $table = null, $ds = null) {
|
||||||
$colKey = Inflector::underscore($className);
|
$colKey = Inflector::underscore($className);
|
||||||
|
if (empty($className)) {
|
||||||
|
$className = $assoc;
|
||||||
|
}
|
||||||
|
|
||||||
if (!class_exists($className)) {
|
if (!class_exists($className)) {
|
||||||
if (!loadModel($className)) {
|
if (!loadModel($className)) {
|
||||||
|
@ -694,14 +693,25 @@ class Model extends Overloadable {
|
||||||
if ($key == 'foreignKey' && !isset($this->keyToTable[$this->{$type}[$assocKey][$key]])) {
|
if ($key == 'foreignKey' && !isset($this->keyToTable[$this->{$type}[$assocKey][$key]])) {
|
||||||
$this->keyToTable[$this->{$type}[$assocKey][$key]][0] = $this->{$class}->table;
|
$this->keyToTable[$this->{$type}[$assocKey][$key]][0] = $this->{$class}->table;
|
||||||
$this->keyToTable[$this->{$type}[$assocKey][$key]][1] = $this->{$class}->name;
|
$this->keyToTable[$this->{$type}[$assocKey][$key]][1] = $this->{$class}->name;
|
||||||
|
|
||||||
if ($this->{$class}->name != $class) {
|
if ($this->{$class}->name != $class) {
|
||||||
$this->keyToTable[$this->{$type}[$assocKey][$key]][2] = $class;
|
$this->keyToTable[$this->{$type}[$assocKey][$key]][2] = $class;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($this->{$type}[$assocKey]['with'])) {
|
if (isset($this->{$type}[$assocKey]['with'])) {
|
||||||
$with = $this->{$type}[$assocKey]['with'];
|
$with = $this->{$type}[$assocKey]['with'];
|
||||||
|
$this->__constructLinkedModel($with);
|
||||||
$this->{$type}[$assocKey]['joinTable'] = $this->{$with}->table;
|
$this->{$type}[$assocKey]['joinTable'] = $this->{$with}->table;
|
||||||
|
} elseif ($type == 'hasAndBelongsToMany') {
|
||||||
|
$joinClass = Inflector::camelize($this->name . $assocKey);
|
||||||
|
$this->{$type}[$assocKey]['_with'] = $joinClass;
|
||||||
|
$this->{$joinClass} = new AppModel(array(
|
||||||
|
'name' => $joinClass,
|
||||||
|
'table' => $this->{$type}[$assocKey]['joinTable'],
|
||||||
|
'ds' => $this->useDbConfig
|
||||||
|
));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -967,8 +977,7 @@ class Model extends Overloadable {
|
||||||
$db =& ConnectionManager::getDataSource($this->useDbConfig);
|
$db =& ConnectionManager::getDataSource($this->useDbConfig);
|
||||||
|
|
||||||
$this->set($data);
|
$this->set($data);
|
||||||
|
$whitelist = !empty($fieldList);
|
||||||
$whitelist = !(empty($fieldList) || count($fieldList) == 0);
|
|
||||||
|
|
||||||
if ($validate && !$this->validates()) {
|
if ($validate && !$this->validates()) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -1883,10 +1892,9 @@ class Model extends Overloadable {
|
||||||
if ($dataSource != null) {
|
if ($dataSource != null) {
|
||||||
$this->useDbConfig = $dataSource;
|
$this->useDbConfig = $dataSource;
|
||||||
}
|
}
|
||||||
|
|
||||||
$db =& ConnectionManager::getDataSource($this->useDbConfig);
|
$db =& ConnectionManager::getDataSource($this->useDbConfig);
|
||||||
|
|
||||||
if (!empty($db->config['prefix']) && $this->tablePrefix == null) {
|
if (!empty($db->config['prefix']) && $this->tablePrefix !== false) {
|
||||||
$this->tablePrefix = $db->config['prefix'];
|
$this->tablePrefix = $db->config['prefix'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -308,7 +308,7 @@ class Author extends CakeTestModel {
|
||||||
class ModelTest extends CakeTestCase {
|
class ModelTest extends CakeTestCase {
|
||||||
|
|
||||||
var $fixtures = array(
|
var $fixtures = array(
|
||||||
'core.category', 'core.category_thread', 'core.user', 'core.article', 'core.featured',
|
'core.category', 'core.category_thread', 'core.user', 'core.article', 'core.featured', 'core.article_featureds_tags',
|
||||||
'core.article_featured', 'core.tag', 'core.articles_tag', 'core.comment', 'core.attachment',
|
'core.article_featured', 'core.tag', 'core.articles_tag', 'core.comment', 'core.attachment',
|
||||||
'core.apple', 'core.sample', 'core.another_article', 'core.advertisement', 'core.home', 'core.post', 'core.author'
|
'core.apple', 'core.sample', 'core.another_article', 'core.advertisement', 'core.home', 'core.post', 'core.author'
|
||||||
);
|
);
|
||||||
|
@ -1744,9 +1744,7 @@ function testRecursiveFindAllWithLimit() {
|
||||||
|
|
||||||
$data = array(
|
$data = array(
|
||||||
'Article' => array('id' => '2', 'title' => 'New Second Article'),
|
'Article' => array('id' => '2', 'title' => 'New Second Article'),
|
||||||
'Tag' => array(
|
'Tag' => array('Tag' => array(1, 2))
|
||||||
'Tag' => array( 1, 2 )
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
$result = $this->model->set($data);
|
$result = $this->model->set($data);
|
||||||
|
@ -2221,9 +2219,7 @@ function testRecursiveFindAllWithLimit() {
|
||||||
|
|
||||||
$result = $this->model->findNeighbours(null, 'Article.id', '3');
|
$result = $this->model->findNeighbours(null, 'Article.id', '3');
|
||||||
$expected = array(
|
$expected = array(
|
||||||
'prev' => array(
|
'prev' => array('Article' => array('id' => 2)),
|
||||||
'Article' => array('id' => 2)
|
|
||||||
),
|
|
||||||
'next' => array()
|
'next' => array()
|
||||||
);
|
);
|
||||||
$this->assertEqual($result, $expected);
|
$this->assertEqual($result, $expected);
|
||||||
|
|
Loading…
Add table
Reference in a new issue