Entity/DocumentRepository.php
author ymh <ymh.work@gmail.com>
Thu, 17 Nov 2011 11:29:26 +0100
changeset 34 21fab44f46fe
parent 30 d2fba1e3b94b
child 37 9ba15af20acc
permissions -rwxr-xr-x
add event on tag changed
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;
2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
/**
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
 * DocumentRepository
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
 *
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
 * This class was generated by the Doctrine ORM. Add your own custom
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
 * repository methods below.
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
 */
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
class DocumentRepository extends EntityRepository
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
{
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    19
    /**
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
     * TODO : Enter description here ...
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    22
     * @var ReflectionClass
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    23
     */
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    24
    private $reflection_class;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    25
    private $reflection_doc_class;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    26
    private $set_methods = array();
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    27
    private $get_methods = array();
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    28
    
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
    29
    function findOneByExternalId($external_id)
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
    30
    {
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    31
        return $this->findOneBy(array("externalId" => $external_id));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    32
    }
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
    private function reflectionSetField($object, $method_name, $value)
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    35
    {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    36
        if(isset($this->set_methods[$method_name]))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    37
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    38
            $set_method = $this->set_methods[$method_name];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    39
        }
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
        if(!isset($set_method) || is_null($set_method))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    42
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    43
            if(is_null($this->reflection_doc_class))
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
                $this->reflection_doc_class = new ReflectionClass(get_class($object));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    46
            }
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
            $set_method = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    49
            if($this->reflection_doc_class->hasMethod($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->reflection_doc_class->getMethod($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
            if(!is_null($set_method))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    54
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    55
                $this->set_methods[$method_name]=$set_method;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    56
            }
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
        if(!isset($set_method) || is_null($set_method) || !$set_method->isPublic())
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
            throw new \Exception("setter method unknown $method_name");
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    62
        }
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 value
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    65
        $set_method->invoke($object, $value);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    66
        
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
    67
    }
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
    68
    
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    69
    private function reflectionGetField($document, $accessor)
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($this->get_methods[$accessor]) ||  is_null($this->get_methods[$accessor]))
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
            if(is_null($this->reflection_class))
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
                $this->reflection_class = new \ReflectionClass(get_class($document));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    77
            }
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
            //look at properties
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    80
            if($this->reflection_class->hasProperty($accessor))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    81
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    82
                $get_object = $this->reflection_class->getProperty($accessor);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    83
                if(!$get_object->isPublic())
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
                    $get_object = NULL;
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
            }
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
            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
    90
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    91
                $get_object = $this->reflection_class->getMethod($accessor);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    92
                if(!$get_object->isPublic())
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    93
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    94
                    $get_object = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
    95
                }
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
            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
    99
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   100
                $get_object = $this->reflection_class->getMethod("get".ucfirst($accessor));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   101
                if(!$get_object->isPublic())
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   102
                {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   103
                    $get_object = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   104
                }
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
            if(isset($get_object) && !is_null($get_object))
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
                $this->get_methods[$accessor] = $get_object;
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
        }
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
        if(isset($this->get_methods[$accessor]))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   114
        {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   115
            $get_object = $this->get_methods[$accessor];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   116
            if(!is_null($get_object))
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
                if(is_a($get_object,"\ReflectionMethod"))
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
                    return $get_object->invoke($document);
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
                elseif(is_a($get_object,"\ReflectionProperty"))
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
                    return $get_object->getValue($document);
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
                else
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
                    //TODO : custom exception
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   129
                    throw new \Exception("Bad reflection object type");
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
            }
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
        //TODO: replace by custom exception
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   135
        throw new \Exception("Unknown accessor $accessor");
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
    
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   138
    function writeDocument($document,  $document_id_column, $fields)
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   139
    {
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   140
        // get document from id
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   141
         
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   142
        $docid = $this->reflectionGetField($document, $document_id_column);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   143
        $baseDocument = $this->findOneByExternalId($docid);
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   144
    
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   145
        if(is_null($baseDocument))
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   146
        {
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   147
            $baseDocument = new Document();
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   148
            $baseDocument->setExternalId($document);
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   149
        }
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   150
        
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   151
        foreach ($fields as $name => $field_def) {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   152
            if(isset($field_def['accessor']))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   153
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   154
                $accessor = $field_def['accessor'];
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   155
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   156
            else
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   157
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   158
                $accessor = NULL;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   159
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   160
            if(is_null($accessor))
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   161
            {
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   162
                $accessor = $name;
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   163
            }
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   164
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   165
            $value = strval($this->reflectionGetField($document,$accessor));
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   166
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   167
            $method_name = "set".ucfirst($name);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   168
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   169
            $this->reflectionSetField($baseDocument, $method_name, $value);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   170
            
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   171
        }
3
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
        $this->getEntityManager()->persist($baseDocument);
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   174
        $this->getEntityManager()->flush();
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   175
        return $baseDocument;
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   176
    
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   177
    }
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   178
    
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   179
    function removeDocument($document, $document_id_column)
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   180
    {
18
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   181
        $docid = $this->reflectionGetField($document, $document_id_column);
6f16b9fd6a17 finish dynamic save
ymh <ymh.work@gmail.com>
parents: 5
diff changeset
   182
        $baseDocument = $this->findOneByExternalId($docid);
5
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   183
        if(!is_null($baseDocument))
45378793512a Correct tag insert + external id on doc
ymh <ymh.work@gmail.com>
parents: 3
diff changeset
   184
        {
3
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   185
            $this->getEntityManager()->remove($baseDocument);
976d922e52f0 link document lifecycle
ymh <ymh.work@gmail.com>
parents: 2
diff changeset
   186
        }
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
    
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   189
    function getTagsStr($document)
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   190
    {
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   191
        $em = $this->getEntityManager();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   192
        $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
   193
        $query = $query->setParameter("docid", $document);
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   194
        $result = $query->getScalarResult();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   195
        $tagstr = array();
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   196
        foreach ($result as $res) {
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   197
            $tagstr[] = $res['label'];
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   198
        }
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   199
        return $tagstr;
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   200
    }
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   201
    
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   202
    function updateTagsStr($document)
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   203
    {
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   204
        
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   205
        $tagstr = $this->getTagsStr($document);
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   206
        
27
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   207
        $document->setTagsStr(implode(",",$tagstr));
8551d844b4f3 Correct memory problem
ymh <ymh.work@gmail.com>
parents: 23
diff changeset
   208
        $this->getEntityManager()->persist($document);
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   209
    }
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   210
    
34
21fab44f46fe add event on tag changed
ymh <ymh.work@gmail.com>
parents: 30
diff changeset
   211
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   212
    /**
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   213
     *
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   214
     * Enter description here ...
34
21fab44f46fe add event on tag changed
ymh <ymh.work@gmail.com>
parents: 30
diff changeset
   215
     * @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
   216
     * @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
   217
     * @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
   218
     */
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   219
    function search(array $values, array $conditions=NULL)
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   220
    {
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   221
        $em = $this->getEntityManager();
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   222
        
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   223
        $rsm = new ResultSetMapping();
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   224
        $rsm->addEntityResult("IRI\Bundle\WikiTagBundle\Entity\Document", "d");
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   225
        $rsm->addFieldResult("d", "id", "id");
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   226
        $rsm->addScalarResult("score", "score");
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   227
        $rsm->addMetaResult("d", "external_id", "externalId");
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   228
        
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   229
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   230
        $score = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   231
        $i = 0;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   232
        foreach ($values as $fielddef) {
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   233
            $i++;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   234
            $columns = $fielddef["columns"];
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   235
            $value = $fielddef["value"];
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   236
            $weight = isset($fielddef["weight"])?$fielddef["weight"]:1.0;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   237
            
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   238
            $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
   239
            $parameters["value_$i"] = $value;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   240
            $parameters["weight_$i"] = $weight;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   241
        }
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   242
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   243
        $score_def = "(".implode("+", $score).")";
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   244
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   245
        $conditions_str = "";
29
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
        if(!is_null($conditions))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   248
        {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   249
            $conditions_array = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   250
            $i = 0;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   251
            foreach ($conditions as $field => $conddef)
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   252
            {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   253
                $i++;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   254
                if(is_array($conddef) && isset($conddef['operator']))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   255
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   256
                    $operator = $conddef["operator"];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   257
                    $values = $conddef["value"];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   258
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   259
                elseif(is_array($conddef))
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   260
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   261
                    $operator = "IN";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   262
                    $values = $conddef;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   263
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   264
                else
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   265
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   266
                    $operator = "=";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   267
                    $values = $conddef;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   268
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   269
                   
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   270
                if($operator === "IN")
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   271
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   272
                    $in_parameters = array();
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   273
                    for ($j = 0; $j < count($values); $j++) {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   274
                        $parameters["cond_val_$i_$j"] = $values[$j];
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   275
                        $in_parameters[] = ":cond_val_$i_$j";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   276
                    }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   277
                    $cond = "($field IN (".implode(",",$in_parameters)."))";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   278
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   279
                else
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   280
                {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   281
                    $cond = "($field $operator :cond_val_$i)";
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   282
                    $parameters["cond_val_$i"] = $values;
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   283
                }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   284
                $conditions_array[] = $cond;
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
            
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   287
            if(count($conditions_array) > 0)
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   288
            {
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   289
                $conditions_str = " AND ".implode(" AND ", $conditions_array);
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   290
            }
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   291
                
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   292
        }
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   293
        
30
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   294
        $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
   295
        
d2fba1e3b94b correction of reorder tag (including the javascript)
ymh <ymh.work@gmail.com>
parents: 29
diff changeset
   296
        $query->setParameters($parameters);
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
        $res = $query->getResult();
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
        return $res;
29
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   301
        
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   302
        
7496254cfead correct add tag
ymh <ymh.work@gmail.com>
parents: 27
diff changeset
   303
    }
23
b435f8055cb4 improve dynamic docs. create and lad class dynamically
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   304
        
2
13f43f53d0ba first implementation
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
}