-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLogger.php
More file actions
80 lines (66 loc) · 1.98 KB
/
Logger.php
File metadata and controls
80 lines (66 loc) · 1.98 KB
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
declare(strict_types = 1);
namespace Innmind\OperatingSystem\CurrentProcess;
use Innmind\OperatingSystem\CurrentProcess;
use Innmind\Server\Control\Server\Process\Pid;
use Innmind\Server\Status\Server\Memory\Bytes;
use Innmind\TimeContinuum\Period;
use Innmind\Immutable\Attempt;
use Psr\Log\LoggerInterface;
final class Logger implements CurrentProcess
{
private CurrentProcess $process;
private LoggerInterface $logger;
private ?Signals $signals = null;
private function __construct(CurrentProcess $process, LoggerInterface $logger)
{
$this->process = $process;
$this->logger = $logger;
}
public static function psr(CurrentProcess $process, LoggerInterface $logger): self
{
return new self($process, $logger);
}
#[\Override]
public function id(): Pid
{
$pid = $this->process->id();
$this->logger->debug(
'Current process id is {pid}',
['pid' => $pid->toInt()],
);
return $pid;
}
#[\Override]
public function signals(): Signals
{
return $this->signals ??= Signals\Logger::psr(
$this->process->signals(),
$this->logger,
);
}
#[\Override]
public function halt(Period $period): Attempt
{
$this->logger->debug('Halting current process...', ['period' => [
'years' => $period->years(),
'months' => $period->months(),
'days' => $period->days(),
'hours' => $period->hours(),
'minutes' => $period->minutes(),
'seconds' => $period->seconds(),
'milliseconds' => $period->milliseconds(),
]]);
return $this->process->halt($period);
}
#[\Override]
public function memory(): Bytes
{
$memory = $this->process->memory();
$this->logger->debug(
'Current process memory at {memory}',
['memory' => $memory->toString()],
);
return $memory;
}
}