Entity/DocumentRepository.php
author ymh <ymh.work@gmail.com>
Thu, 17 Nov 2011 16:48:19 +0100
changeset 37 9ba15af20acc
parent 34 21fab44f46fe
child 42 0e57c730bb18
permissions -rwxr-xr-x
make sure that we use external ids in the controller
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
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
use Doctrine\ORM\EntityRepository;
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
     6
use IRI\Bundle\WikiTagBundle\Entity\Document;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
     7
use Doctrine\ORM\Query\ResultSetMapping;
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
     8
use \ReflectionClass;
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
     9
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
    10
use Doctrine\ORM\Mapping\ClassMetadataInfo;
2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
/**
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
 * DocumentRepository
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
 *
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
 * This class was generated by the Doctrine ORM. Add your own custom
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
 * repository methods below.
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
 */
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
class DocumentRepository extends EntityRepository
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
{
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    20
    /**
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    21
     *
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    22
     * TODO : Enter description here ...
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    23
     * @var ReflectionClass
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    24
     */
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    25
    private $reflection_class;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    26
    private $reflection_doc_class;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    27
    private $set_methods = array();
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    28
    private $get_methods = array();
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    29
    
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
    30
    function findOneByExternalId($external_id)
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
    31
    {
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    32
        return $this->findOneBy(array("externalId" => $external_id));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    33
    }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    34
    
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    35
    private function reflectionSetField($object, $method_name, $value)
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    36
    {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    37
        if(isset($this->set_methods[$method_name]))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    38
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    39
            $set_method = $this->set_methods[$method_name];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    40
        }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    41
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    42
        if(!isset($set_method) || is_null($set_method))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    43
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    44
            if(is_null($this->reflection_doc_class))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    45
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    46
                $this->reflection_doc_class = new ReflectionClass(get_class($object));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    47
            }
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
            $set_method = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    50
            if($this->reflection_doc_class->hasMethod($method_name))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    51
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    52
                $set_method = $this->reflection_doc_class->getMethod($method_name);
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(!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
                $this->set_methods[$method_name]=$set_method;
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
        }
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
        if(!isset($set_method) || is_null($set_method) || !$set_method->isPublic())
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    61
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    62
            throw new \Exception("setter method unknown $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
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    65
        //set value
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    66
        $set_method->invoke($object, $value);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    67
        
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
    68
    }
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    69
    
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    70
    private function reflectionGetField($document, $accessor)
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
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    73
        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
    74
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    75
            if(is_null($this->reflection_class))
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
                $this->reflection_class = new \ReflectionClass(get_class($document));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    78
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    79
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    80
            //look at properties
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    81
            if($this->reflection_class->hasProperty($accessor))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    82
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    83
                $get_object = $this->reflection_class->getProperty($accessor);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    84
                if(!$get_object->isPublic())
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    85
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    86
                    $get_object = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    87
                }
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
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    90
            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
    91
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    92
                $get_object = $this->reflection_class->getMethod($accessor);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    93
                if(!$get_object->isPublic())
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 = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    96
                }
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
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    99
            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
   100
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   101
                $get_object = $this->reflection_class->getMethod("get".ucfirst($accessor));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   102
                if(!$get_object->isPublic())
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 = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   105
                }
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
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   108
            if(isset($get_object) && !is_null($get_object))
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
                $this->get_methods[$accessor] = $get_object;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   111
            }
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
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   114
        if(isset($this->get_methods[$accessor]))
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 = $this->get_methods[$accessor];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   117
            if(!is_null($get_object))
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
                if(is_a($get_object,"\ReflectionMethod"))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   120
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   121
                    return $get_object->invoke($document);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   122
                }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   123
                elseif(is_a($get_object,"\ReflectionProperty"))
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
                    return $get_object->getValue($document);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   126
                }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   127
                else
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   128
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   129
                    //TODO : custom exception
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   130
                    throw new \Exception("Bad reflection object type");
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   131
                }
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
        }
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
        //TODO: replace by custom exception
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   136
        throw new \Exception("Unknown accessor $accessor");
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   137
    }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   138
    
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   139
    
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   140
    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
   141
    {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   142
        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
   143
        {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   144
            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
   145
        }
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   146
        
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   147
        $res = $field_name;
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   148
        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
   149
        {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   150
            $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
   151
            if(
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   152
                isset($association_mapping['type'])
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   153
                && ( $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
   154
                && 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
   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 = $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
   158
            }
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
        
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   161
        return $res;
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   162
    }
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   163
    
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   164
    public function writeDocument($document,  $document_id_column, $fields)
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   165
    {
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   166
        // get document from id
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   167
         
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   168
        $docid = $this->reflectionGetField($document, $document_id_column);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   169
        $baseDocument = $this->findOneByExternalId($docid);
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   170
    
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   171
        if(is_null($baseDocument))
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   172
        {
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   173
            $baseDocument = new Document();
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   174
            $baseDocument->setExternalId($document);
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   175
        }
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   176
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   177
        foreach ($fields as $name => $field_def) {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   178
            if(isset($field_def['accessor']))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   179
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   180
                $accessor = $field_def['accessor'];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   181
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   182
            else
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   183
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   184
                $accessor = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   185
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   186
            if(is_null($accessor))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   187
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   188
                $accessor = $name;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   189
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   190
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   191
            $value = strval($this->reflectionGetField($document,$accessor));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   192
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   193
            $method_name = "set".ucfirst($name);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   194
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   195
            $this->reflectionSetField($baseDocument, $method_name, $value);
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
        }
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   198
        
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   199
        $this->getEntityManager()->persist($baseDocument);
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   200
        $this->getEntityManager()->flush();
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   201
        return $baseDocument;
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   202
    
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   203
    }
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   204
    
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   205
    function removeDocument($document, $document_id_column)
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   206
    {
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   207
        $docid = $this->reflectionGetField($document, $document_id_column);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   208
        $baseDocument = $this->findOneByExternalId($docid);
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   209
        if(!is_null($baseDocument))
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   210
        {
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   211
            $this->getEntityManager()->remove($baseDocument);
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   212
        }
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   213
    }
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   214
    
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   215
    function getTagsStr($document)
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   216
    {
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   217
        $em = $this->getEntityManager();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   218
        $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
   219
        $query = $query->setParameter("docid", $document);
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   220
        $result = $query->getScalarResult();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   221
        $tagstr = array();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   222
        foreach ($result as $res) {
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   223
            $tagstr[] = $res['label'];
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   224
        }
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   225
        return $tagstr;
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   226
    }
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   227
    
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   228
    function updateTagsStr($document)
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   229
    {
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   230
        
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   231
        $tagstr = $this->getTagsStr($document);
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   232
        
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   233
        $document->setTagsStr(implode(",",$tagstr));
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   234
        $this->getEntityManager()->persist($document);
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   235
    }
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   236
    
34
21fab44f46fe add event on tag changed
ymh <ymh.work@gmail.com>
parents: 30
diff changeset
   237
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   238
    /**
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   239
     *
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   240
     * Enter description here ...
34
21fab44f46fe add event on tag changed
ymh <ymh.work@gmail.com>
parents: 30
diff changeset
   241
     * @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
   242
     * @param array $conditions : array : key : field name, value : simple value (operator is "=") or array(valuea, value2,...) (operatr is IN) or array("operator"=>"", "value"=>value)
21fab44f46fe add event on tag changed
ymh <ymh.work@gmail.com>
parents: 30
diff changeset
   243
     * @return Ambigous <multitype:, \Doctrine\ORM\mixed, \Doctrine\DBAL\Driver\Statement, \Doctrine\ORM\Internal\Hydration\mixed>
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   244
     */
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   245
    function search(array $values, array $conditions=NULL)
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   246
    {
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   247
        $em = $this->getEntityManager();
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   248
        
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   249
        $rsm = new ResultSetMapping();
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   250
        $rsm->addEntityResult("IRI\Bundle\WikiTagBundle\Entity\Document", "d");
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   251
        $rsm->addFieldResult("d", "id", "id");
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   252
        $rsm->addScalarResult("score", "score");
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   253
        $rsm->addMetaResult("d", "external_id", "externalId");
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   254
        
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   255
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   256
        $score = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   257
        $i = 0;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   258
        foreach ($values as $fielddef) {
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   259
            $i++;
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   260
            $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
   261
            $column_list = array();
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   262
            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
   263
            {
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   264
                $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
   265
            }
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   266
            $columns = join(",", $column_list);
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   267
            
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   268
            $value = $fielddef["value"];
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   269
            $weight = isset($fielddef["weight"])?$fielddef["weight"]:1.0;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   270
            
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   271
            $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
   272
            $parameters["value_$i"] = $value;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   273
            $parameters["weight_$i"] = $weight;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   274
        }
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   275
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   276
        $score_def = "(".implode("+", $score).")";
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   277
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   278
        $conditions_str = "";
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   279
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   280
        if(!is_null($conditions))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   281
        {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   282
            $conditions_array = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   283
            $i = 0;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   284
            foreach ($conditions as $field => $conddef)
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   285
            {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   286
                $i++;
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   287
                $col = $this->getColumnName($field);
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   288
                if(is_array($conddef) && isset($conddef['operator']))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   289
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   290
                    $operator = $conddef["operator"];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   291
                    $values = $conddef["value"];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   292
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   293
                elseif(is_array($conddef))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   294
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   295
                    $operator = "IN";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   296
                    $values = $conddef;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   297
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   298
                else
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   299
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   300
                    $operator = "=";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   301
                    $values = $conddef;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   302
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   303
                   
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   304
                if($operator === "IN")
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   305
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   306
                    $in_parameters = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   307
                    for ($j = 0; $j < count($values); $j++) {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   308
                        $parameters["cond_val_$i_$j"] = $values[$j];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   309
                        $in_parameters[] = ":cond_val_$i_$j";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   310
                    }
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   311
                    $cond = "($col IN (".implode(",",$in_parameters)."))";
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   312
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   313
                else
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   314
                {
37
9ba15af20acc make sure that we use external ids in the controller
ymh <ymh.work@gmail.com>
parents: 34
diff changeset
   315
                    $cond = "($col $operator :cond_val_$i)";
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   316
                    $parameters["cond_val_$i"] = $values;
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
                $conditions_array[] = $cond;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   319
            }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   320
            
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   321
            if(count($conditions_array) > 0)
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   322
            {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   323
                $conditions_str = " AND ".implode(" AND ", $conditions_array);
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
                
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   326
        }
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   327
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   328
        $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
   329
        
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   330
        $query->setParameters($parameters);
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
        $res = $query->getResult();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   333
        
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   334
        return $res;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   335
        
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   336
        
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   337
    }
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   338
        
2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
}