Entity/DocumentRepository.php
author ymh <ymh.work@gmail.com>
Fri, 25 Nov 2011 18:55:42 +0100
changeset 42 0e57c730bb18
parent 37 9ba15af20acc
child 57 186c4121c7b3
permissions -rwxr-xr-x
Documentation and add alternative wp url and label + migrations
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
namespace IRI\Bundle\WikiTagBundle\Entity;
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
     5
use IRI\Bundle\WikiTagBundle\Model\DocumentInterface;
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
     6
2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
use Doctrine\ORM\EntityRepository;
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
     8
use IRI\Bundle\WikiTagBundle\Entity\Document;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
     9
use Doctrine\ORM\Query\ResultSetMapping;
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    10
use \ReflectionClass;
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
    11
use Doctrine\ORM\AbstractQuery;
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
    12
use Doctrine\ORM\Mapping\ClassMetadataInfo;
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    13
use IRI\Bundle\WikiTagBundle\Model\ModelException;
2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
/**
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
 * DocumentRepository
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
 *
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
 * This class was generated by the Doctrine ORM. Add your own custom
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
 * repository methods below.
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
 */
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
class DocumentRepository extends EntityRepository
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
{
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    23
    /**
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    24
     * The cache for the host document class
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    25
     * @var ReflectionClass
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    26
     */
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    27
    private $reflection_class;
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    28
    
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    29
    /**
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    30
     * The cache for the wikitag document class
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    31
     * @var ReflectionClass
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    32
     */
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    33
    private $reflection_doc_class;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    34
    private $set_methods = array();
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    35
    private $get_methods = array();
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    36
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    37
    /**
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    38
     * Find one wikitagRepository by its externalId i.e. the host document id.
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    39
     * @param $external_id
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    40
     */
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    41
    public function findOneByExternalId($external_id)
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
    42
    {
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    43
        return $this->findOneBy(array("externalId" => $external_id));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    44
    }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    45
    
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
    46
    
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    47
    private function reflectionSetField($object, $method_name, $value)
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    48
    {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    49
        if(isset($this->set_methods[$method_name]))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    50
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    51
            $set_method = $this->set_methods[$method_name];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    52
        }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    53
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    54
        if(!isset($set_method) || is_null($set_method))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    55
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    56
            if(is_null($this->reflection_doc_class))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    57
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    58
                $this->reflection_doc_class = new ReflectionClass(get_class($object));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    59
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    60
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    61
            $set_method = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    62
            if($this->reflection_doc_class->hasMethod($method_name))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    63
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    64
                $set_method = $this->reflection_doc_class->getMethod($method_name);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    65
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    66
            if(!is_null($set_method))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    67
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    68
                $this->set_methods[$method_name]=$set_method;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    69
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    70
        }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    71
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    72
        if(!isset($set_method) || is_null($set_method) || !$set_method->isPublic())
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    73
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    74
            throw new \Exception("setter method unknown $method_name");
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    75
        }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    76
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    77
        //set value
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    78
        $set_method->invoke($object, $value);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    79
        
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
    80
    }
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    81
    
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    82
    private function reflectionGetField($document, $accessor)
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    83
    {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    84
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    85
        if(!isset($this->get_methods[$accessor]) ||  is_null($this->get_methods[$accessor]))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    86
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    87
            if(is_null($this->reflection_class))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    88
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    89
                $this->reflection_class = new \ReflectionClass(get_class($document));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    90
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    91
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    92
            //look at properties
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    93
            if($this->reflection_class->hasProperty($accessor))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    94
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    95
                $get_object = $this->reflection_class->getProperty($accessor);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    96
                if(!$get_object->isPublic())
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    97
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    98
                    $get_object = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    99
                }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   100
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   101
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   102
            if((!isset($get_object) || is_null($get_object)) && $this->reflection_class->hasMethod($accessor))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   103
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   104
                $get_object = $this->reflection_class->getMethod($accessor);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   105
                if(!$get_object->isPublic())
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   106
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   107
                    $get_object = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   108
                }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   109
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   110
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   111
            if((!isset($get_object) || is_null($get_object)) && $this->reflection_class->hasMethod("get".ucfirst($accessor)))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   112
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   113
                $get_object = $this->reflection_class->getMethod("get".ucfirst($accessor));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   114
                if(!$get_object->isPublic())
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   115
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   116
                    $get_object = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   117
                }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   118
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   119
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   120
            if(isset($get_object) && !is_null($get_object))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   121
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   122
                $this->get_methods[$accessor] = $get_object;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   123
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   124
        }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   125
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   126
        if(isset($this->get_methods[$accessor]))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   127
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   128
            $get_object = $this->get_methods[$accessor];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   129
            if(!is_null($get_object))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   130
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   131
                if(is_a($get_object,"\ReflectionMethod"))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   132
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   133
                    return $get_object->invoke($document);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   134
                }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   135
                elseif(is_a($get_object,"\ReflectionProperty"))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   136
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   137
                    return $get_object->getValue($document);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   138
                }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   139
                else
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   140
                {
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   141
                    throw new ModelException("Bad reflection object type");
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   142
                }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   143
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   144
        }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   145
        
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   146
        throw new ModelException("Unknown accessor $accessor");
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   147
    }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   148
    
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   149
    
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   150
    private function getColumnName($field_name)
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   151
    {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   152
        if(isset($this->getClassMetadata()->columnNames[$field_name]))
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   153
        {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   154
            return $this->getClassMetadata()->columnNames[$field_name];
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   155
        }
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   156
        
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   157
        $res = $field_name;
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   158
        if(isset($this->getClassMetadata()->associationMappings[$field_name]))
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   159
        {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   160
            $association_mapping = $this->getClassMetadata()->associationMappings[$field_name];
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   161
            if(
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   162
                isset($association_mapping['type'])
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   163
                && ( $association_mapping['type'] === ClassMetadataInfo::ONE_TO_ONE || $association_mapping['type'] === ClassMetadataInfo::MANY_TO_ONE)
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   164
                && count($association_mapping['joinColumns']) > 0
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   165
            )
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   166
            {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   167
                $res = $association_mapping['joinColumns'][0]['name'];
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   168
            }
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   169
        }
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   170
        
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   171
        return $res;
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   172
    }
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   173
    
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   174
    /**
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   175
     * Write a wikitag document given the host document and the field list.
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   176
     * @param $document The source document
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   177
     * @param $document_id_column the name of the source document id column
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   178
     * @param $fields The list of field definition. This is an associative array [<field name>=><field definition>].
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   179
     *     See the @IRI\Bundle\WikiTagBundle\DependencyInjection\Configuration documentation
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   180
     */
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   181
    public function writeDocument($document,  $document_id_column, $fields)
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   182
    {
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   183
        // get document from id
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   184
         
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   185
        $docid = $this->reflectionGetField($document, $document_id_column);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   186
        $baseDocument = $this->findOneByExternalId($docid);
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   187
    
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   188
        if(is_null($baseDocument))
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   189
        {
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   190
            $baseDocument = new Document();
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   191
            $baseDocument->setExternalId($document);
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   192
        }
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   193
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   194
        foreach ($fields as $name => $field_def) {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   195
            if(isset($field_def['accessor']))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   196
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   197
                $accessor = $field_def['accessor'];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   198
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   199
            else
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   200
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   201
                $accessor = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   202
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   203
            if(is_null($accessor))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   204
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   205
                $accessor = $name;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   206
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   207
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   208
            $value = strval($this->reflectionGetField($document,$accessor));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   209
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   210
            $method_name = "set".ucfirst($name);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   211
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   212
            $this->reflectionSetField($baseDocument, $method_name, $value);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   213
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   214
        }
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   215
        
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   216
        $this->getEntityManager()->persist($baseDocument);
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   217
        $this->getEntityManager()->flush();
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   218
        return $baseDocument;
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   219
    
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   220
    }
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   221
    
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   222
    /**
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   223
     * Remove a Wikitag doument given the host docuument.
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   224
     * @param $document The host document
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   225
     * @param string $document_id_column The host document id column name
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   226
     */
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   227
    public function removeDocument($document, $document_id_column)
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   228
    {
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   229
        $docid = $this->reflectionGetField($document, $document_id_column);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   230
        $baseDocument = $this->findOneByExternalId($docid);
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   231
        if(!is_null($baseDocument))
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   232
        {
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   233
            $this->getEntityManager()->remove($baseDocument);
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   234
        }
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   235
    }
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   236
    
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   237
    
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   238
    /**
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   239
     * return the list of a wikitag documents the tags label.
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   240
     * @param DocumentInterface $document the wikitag document
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   241
     * @return array
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   242
     */
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   243
    public function getTagsStr($document)
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   244
    {
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   245
        $em = $this->getEntityManager();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   246
        $query = $em->createQuery("SELECT t.label FROM WikiTagBundle:DocumentTag dt JOIN dt.tag t WHERE dt.document = :docid");
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   247
        $query = $query->setParameter("docid", $document);
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   248
        $result = $query->getScalarResult();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   249
        $tagstr = array();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   250
        foreach ($result as $res) {
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   251
            $tagstr[] = $res['label'];
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   252
        }
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   253
        return $tagstr;
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   254
    }
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   255
    
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   256
    /**
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   257
     * Update a wikitag document tags string.
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   258
     * @param DocumentInterface $document the wikitag document
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   259
     */
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   260
    function updateTagsStr(DocumentInterface $document)
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   261
    {
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   262
        
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   263
        $tagstr = $this->getTagsStr($document);
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   264
        
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   265
        $document->setTagsStr(implode(",",$tagstr));
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   266
        $this->getEntityManager()->persist($document);
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   267
    }
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   268
    
34
21fab44f46fe add event on tag changed
ymh <ymh.work@gmail.com>
parents: 30
diff changeset
   269
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   270
    /**
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   271
     * Search wikitag documents using the index.
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   272
     *
34
21fab44f46fe add event on tag changed
ymh <ymh.work@gmail.com>
parents: 30
diff changeset
   273
     * @param array $values : key: the fields to search into, value : array('value'=>value, 'weight'=>weight)
21fab44f46fe add event on tag changed
ymh <ymh.work@gmail.com>
parents: 30
diff changeset
   274
     * @param array $conditions : array : key : field name, value : simple value (operator is "=") or array(valuea, value2,...) (operatr is IN) or array("operator"=>"", "value"=>value)
42
0e57c730bb18 Documentation and add alternative wp url and label + migrations
ymh <ymh.work@gmail.com>
parents: 37
diff changeset
   275
     * @return array [["id" => <the wikitag document id>, "externalId" => <the host document ids>, "score" => <the score for this document>]]
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   276
     */
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   277
    function search(array $values, array $conditions=NULL)
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   278
    {
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   279
        $em = $this->getEntityManager();
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   280
        
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   281
        $rsm = new ResultSetMapping();
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   282
        $rsm->addEntityResult("IRI\Bundle\WikiTagBundle\Entity\Document", "d");
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   283
        $rsm->addFieldResult("d", "id", "id");
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   284
        $rsm->addScalarResult("score", "score");
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   285
        $rsm->addMetaResult("d", "external_id", "externalId");
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   286
        
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   287
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   288
        $score = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   289
        $i = 0;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   290
        foreach ($values as $fielddef) {
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   291
            $i++;
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   292
            $field_list = explode(",", $fielddef["columns"]);
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   293
            $column_list = array();
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   294
            foreach($field_list as $field_name)
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   295
            {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   296
                $column_list[] = $this->getColumnName(trim($field_name));
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   297
            }
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   298
            $columns = join(",", $column_list);
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   299
            
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   300
            $value = $fielddef["value"];
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   301
            $weight = isset($fielddef["weight"])?$fielddef["weight"]:1.0;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   302
            
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   303
            $score[] = "(MATCH($columns) AGAINST (:value_$i))*:weight_$i";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   304
            $parameters["value_$i"] = $value;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   305
            $parameters["weight_$i"] = $weight;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   306
        }
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   307
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   308
        $score_def = "(".implode("+", $score).")";
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   309
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   310
        $conditions_str = "";
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   311
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   312
        if(!is_null($conditions))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   313
        {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   314
            $conditions_array = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   315
            $i = 0;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   316
            foreach ($conditions as $field => $conddef)
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   317
            {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   318
                $i++;
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   319
                $col = $this->getColumnName($field);
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   320
                if(is_array($conddef) && isset($conddef['operator']))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   321
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   322
                    $operator = $conddef["operator"];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   323
                    $values = $conddef["value"];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   324
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   325
                elseif(is_array($conddef))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   326
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   327
                    $operator = "IN";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   328
                    $values = $conddef;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   329
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   330
                else
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   331
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   332
                    $operator = "=";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   333
                    $values = $conddef;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   334
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   335
                   
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   336
                if($operator === "IN")
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   337
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   338
                    $in_parameters = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   339
                    for ($j = 0; $j < count($values); $j++) {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   340
                        $parameters["cond_val_$i_$j"] = $values[$j];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   341
                        $in_parameters[] = ":cond_val_$i_$j";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   342
                    }
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   343
                    $cond = "($col IN (".implode(",",$in_parameters)."))";
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   344
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   345
                else
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   346
                {
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   347
                    $cond = "($col $operator :cond_val_$i)";
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   348
                    $parameters["cond_val_$i"] = $values;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   349
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   350
                $conditions_array[] = $cond;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   351
            }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   352
            
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   353
            if(count($conditions_array) > 0)
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   354
            {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   355
                $conditions_str = " AND ".implode(" AND ", $conditions_array);
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   356
            }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   357
                
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   358
        }
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   359
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   360
        $query = $em->createNativeQuery("SELECT d.id, d.external_id, $score_def AS score FROM wikitag_document d WHERE $score_def > 0  $conditions_str ORDER BY score DESC", $rsm);
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   361
        
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   362
        $query->setParameters($parameters);
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   363
        
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   364
        $res = $query->getResult();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   365
        
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   366
        return $res;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   367
    }
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   368
        
2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
}