blob: 8f216b251e7650f4fb89ce0a8b0b1ad74e049866 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
|
<?php
namespace App\Message;
use Exception;
/**
* Handles messages and context
*
* @author Phil Burton <phil@pgburton.com>
*/
class Handler
{
/**
* The important set of injects for this handler
*
* @var string[]
*/
protected $important = [];
/**
* Construct our handler
*
* @author Phil Burton <phil@pgburton.com>
* @param string[] $important
*/
public function __construct($important)
{
$this->important = $important;
$this->initImportantValues();
}
/**
* Set important values
*
* @author Phil Burton <phil@pgburton.com>
* @param mixed[] $array
*/
protected function initImportantValues()
{
foreach ($this->important as $name) {
$this->addImportantValue($name, false);
}
}
/**
* Add an important value to our array
*
* @author Phil Burton <phil@pgburton.com>
* @param string $name
* @param mixed[] $value
*/
protected function addImportantValue($name, $value)
{
if (in_array($name, $this->important)) {
$this->$name = $value;
}
return $name;
}
/**
* Get a single important value
*
* @author Phil Burton <phil@pgburton.com>
* @param string $name
* @return mixed
*/
public function returnImportant($name)
{
if (!isset($this->$name)) {
throw new Exception('The var ' . $name . ' is not set in this context');
}
return $this->$name;
}
protected function addImportantFromArray($array)
{
foreach ($array as $key => $value) {
if (!isset($this->$key)) {
throw new Exception('The var ' . $value . ' is not set in this context');
}
$this->$key = $value;
}
}
/**
* Return all importnat vars and values in array
*
* @author Phil Burton <phil@pgburton.com>
* @return string[]
*/
public function returnImportants()
{
return $this->important;
}
/**
* Magic __get override to be able to get important values using ->myValue
* which then runs $this->returnImportant('myValue')
*
* @author Phil Burton <phil@pgburton.com>
* @param string $name
* @param mixed[] $arguments
* @return string
*/
public function __get($name)
{
return $this->returnImporant(substr($name, 3));
}
/**
* Allow for magic rendering
* Call renderFooBar to render the FooBar message class
*
* @author Phil Burton <phil@pgburton.com>
* @param string $name
* @param mixed[] $arguments
* @return string
*/
public function __call($name, $arguments)
{
if (strpos($name, 'render') === 0) {
return $this->doRender(substr($name, 6));
}
}
/**
* Render the opening message
*
* @author Phil Burton <phil@pgburton.com>
* @return string
*/
public function doRender($name)
{
$name = "App\\Message\\" . $name;
if (!class_exists($name)) {
throw new Exception('Could not find message class `' . $name . '`');
}
$messageObj = new $name($this);
$message = $messageObj->renderMessage();
$this->addImportantFromArray($messageObj->getImportantValues());
return $message;
}
}
|