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

EntityContainer   A

Complexity

Total Complexity 14

Size/Duplication

Total Lines 86
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 1

Test Coverage

Coverage 0%

Importance

Changes 8
Bugs 0 Features 0
Metric Value
c 8
b 0
f 0
dl 0
loc 86
ccs 0
cts 34
cp 0
rs 10
wmc 14
lcom 1
cbo 1

5 Methods

Rating   Name   Duplication   Size   Complexity  
A setProperties() 0 3 1
B processRow() 0 20 7
A importRow() 0 9 3
A exportRow() 0 6 1
A clearProperties() 0 5 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