-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathfiber-local-manual.php
81 lines (58 loc) · 1.91 KB
/
fiber-local-manual.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
81
<?php
declare(strict_types=1);
use Revolt\EventLoop;
use Revolt\EventLoop\FiberLocal;
require __DIR__ . '/../vendor/autoload.php';
/**
* This logger uses {@see FiberLocal} to automatically log a transaction identifier bound to the current fiber.
*
* This might be used to log the current URL, authenticated user, or request identifier in an HTTP server.
*/
final class Logger
{
private FiberLocal $transactionId;
public function __construct()
{
$this->transactionId = new FiberLocal(fn () => throw new \Exception('Unknown transaction ID'));
}
public function setTransactionId(int $transactionId): void
{
$this->transactionId->set($transactionId);
}
public function unsetTransactionId(): void
{
$this->transactionId->unset();
}
public function log(string $message): void
{
echo $this->transactionId->get() . ': ' . $message . PHP_EOL;
}
}
$logger = new Logger();
$logger->setTransactionId(1);
EventLoop::delay(1, static function () use ($logger) {
$logger->setTransactionId(2);
$logger->log('Initializing...');
$suspension = EventLoop::getSuspension();
EventLoop::delay(1, static fn () => $suspension->resume());
$suspension->suspend();
$logger->log('Done.');
$logger->unsetTransactionId();
try {
$logger->log('Outside transaction');
} catch (\Exception) {
echo 'Caught exception, because we\'re outside a transaction' . PHP_EOL;
}
$logger->setTransactionId(3);
$logger->log('Initializing...');
$suspension = EventLoop::getSuspension();
EventLoop::delay(1, static fn () => $suspension->resume());
$suspension->suspend();
$logger->log('Done.');
$logger->unsetTransactionId();
});
$logger->log('Initializing...');
$suspension = EventLoop::getSuspension();
EventLoop::delay(3, static fn () => $suspension->resume());
$suspension->suspend();
$logger->log('Done.');