Completed
Push — work-fleets ( 9e987d...ec9dc8 )
by SuperNova.WS
06:04
created

EntityContainer::isNew()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 2
Bugs 0 Features 0
Metric Value
cc 1
eloc 2
nc 1
nop 0
dl 0
loc 3
rs 10
c 2
b 0
f 0
ccs 0
cts 2
cp 0
crap 2
1
<?php
2
3
/**
4
 * Class EntityContainer
5
 *
6
 * Introduces linked models and export/import operations
7
 *
8
 * Importer is a callable like
9
 *    function ($that, &$row[, $propertyName[, $fieldName]]) {}
10
 *
11
 * Exporter is a callable like
12
 *    function ($that, &$row[, $propertyName[, $fieldName]]) {}
13
 */
14
class EntityContainer extends ContainerAccessors {
15
  /**
16
   * Property list and description
17
   *
18
   * propertyName => array(
19
   *    P_DB_FIELD => 'dbFieldName', - directly converts property to field and vice versa
20
   * )
21
   *
22
   * @var array[] $properties
23
   */
24
  protected $properties = array();
25
26
27
  /**
28
   * Set properties data from external source
29
   *
30
   * @param array $properties
31
   */
32
  public function setProperties($properties) {
33
    $this->properties = $properties;
34
  }
35
36
  /**
37
   * @param array  $row
38
   * @param string $processor
39
   */
40
  protected function processRow(&$row, $processor) {
41
    foreach ($this->properties as $propertyName => $propertyData) {
42
      $fieldName = !empty($propertyData[P_DB_FIELD]) ? $propertyData[P_DB_FIELD] : '';
43
      if (
44
        !empty($this->accessors[$propertyName][$processor])
45
        &&
46
        is_callable($this->accessors[$propertyName][$processor])
47
      ) {
48
        call_user_func_array($this->accessors[$propertyName][$processor], array($this, &$row, $propertyName, $fieldName));
49
      } elseif ($fieldName) {
50
        if ($processor == P_CONTAINER_IMPORT) {
51
          $this->$propertyName = $row[$fieldName];
52
        } else {
53
          $row[$fieldName] = $this->$propertyName;
54
        }
55
      }
56
      // Otherwise it's internal field - filled and used internally
57
    }
58
59
  }
60
61
  /**
62
   * Import DB row state into object properties
63
   *
64
   * @param array $row
65
   */
66
  public function importRow($row) {
67
    $this->clearProperties();
68
69
    if (is_array($row) && !empty($row)) {
70
      $this->processRow($row, P_CONTAINER_IMPORT);
71
    }
72
73
    return true;
74
  }
75
76
  /**
77
   * Exports object properties to DB row state WITHOUT ID
78
   *
79
   * Useful for INSERT operations
80
   *
81
   * @return array
82
   */
83
  public function exportRow() {
84
    $row = array();
85
    $this->processRow($row, P_CONTAINER_EXPORT);
86
87
    return $row;
88
  }
89
90
  /**
91
   * Clears only properties which declared in $properties array
92
   */
93
  public function clearProperties() {
94
    foreach ($this->properties as $propertyName => $propertyData) {
95
      unset($this->$propertyName);
96
    }
97
  }
98
99
}
100