Context Contexto de Corrotina

Contexto é usado para armazenar e transmitir informações de contexto em corrotinas, como conexões de banco de dados, informações do usuário, etc. Cada corrotina possui seu próprio contexto, e o contexto entre diferentes corrotinas é isolado.

Nota
O tipo de driver é automaticamente identificado pelo sistema subjacente, suportando apenas os drivers Swoole/Swow/Fiber.

Dica
Esse recurso requer workerman>=5.1.0

<?php

use Workerman\Connection\TcpConnection;
use Workerman\Coroutine;
use Workerman\Coroutine\Context;
use Workerman\Events\Swoole;
use Workerman\Protocols\Http\Request;
use Workerman\Worker;
require_once __DIR__ . '/vendor/autoload.php';

$worker = new Worker('http://0.0.0.0:8001');

$worker->eventLoop = Swoole::class; // Ou Swow::class ou Fiber::class

$worker->onMessage = function (TcpConnection $connection, Request $request) {
    // Configure o dados do contexto na corrotina atual
    Context::set('user_info', ['id' => 1, 'name' => 'name']);
    // Crie uma nova corrotina
    Coroutine::create(function () use ($connection) {
        // Os dados do contexto entre corrotinas são isolados, então na nova corrotina obtemos null
        $userInfo = Context::get('user_info');
        var_dump($userInfo); // Saída null
    });
    // Obtenha os dados do contexto da corrotina atual
    $userInfo = Context::get('user_info'); // Obtemos ['id' => 1, 'name' => 'name']
    $connection->send(json_encode($userInfo));
};

Worker::runAll();

Interface de Descrição

interface ContextInterface
{
    /**
     * Obtém o valor dentro do contexto
     */
    public static function get(string $name, mixed $default = null): mixed;

    /**
     * Define o valor dentro do contexto
     */
    public static function set(string $name, mixed $value): void;

    /**
     * Verifica se existe um valor com o nome especificado no contexto
     */
    public static function has(string $name): bool;

    /**
     * Redefine o contexto da corrotina atual
     */
    public static function reset(?ArrayObject $data = null): void;

    /**
     * Destroi o contexto
     */
    public static function destroy(): void;

}