-
Notifications
You must be signed in to change notification settings - Fork 110
/
RedisCanBeAccessed.php
80 lines (71 loc) · 2.1 KB
/
RedisCanBeAccessed.php
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
<?php
namespace BeyondCode\SelfDiagnosis\Checks;
use Illuminate\Support\Arr;
use Illuminate\Support\Facades\Redis;
class RedisCanBeAccessed implements Check
{
private $message;
/**
* The name of the check.
*
* @param array $config
* @return string
*/
public function name(array $config): string
{
return trans('self-diagnosis::checks.redis_can_be_accessed.name');
}
/**
* Perform the actual verification of this check.
*
* @param array $config
* @return bool
*/
public function check(array $config): bool
{
try {
if (Arr::get($config, 'default_connection', true)) {
if (!$this->testConnection()) {
$this->message = trans('self-diagnosis::checks.redis_can_be_accessed.message.default_cache');
return false;
}
}
foreach (Arr::get($config, 'connections', []) as $connection) {
if (!$this->testConnection($connection)) {
$this->message = trans('self-diagnosis::checks.redis_can_be_accessed.message.named_cache', [
'name' => $connection,
]);
return false;
}
}
} catch (\Exception $e) {
$this->message = $e->getMessage();
return false;
}
return true;
}
/**
* The error message to display in case the check does not pass.
*
* @param array $config
* @return string
*/
public function message(array $config): string
{
return trans('self-diagnosis::checks.redis_can_be_accessed.message.not_accessible', [
'error' => $this->message,
]);
}
/**
* Tests a redis connection and returns whether the connection is opened or not.
*
* @param string|null $name
* @return bool
*/
private function testConnection(string $name = null): bool
{
$connection = Redis::connection($name);
$connection->connect();
return $connection->isConnected();
}
}