PHPackages                             phpdot/container-swoole - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. phpdot/container-swoole

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

phpdot/container-swoole
=======================

Swoole context provider for phpdot/container

v1.2.0(1mo ago)014MITPHPPHP &gt;=8.3

Since Mar 31Pushed 1mo agoCompare

[ Source](https://github.com/phpdot/container-swoole)[ Packagist](https://packagist.org/packages/phpdot/container-swoole)[ RSS](/packages/phpdot-container-swoole/feed)WikiDiscussions main Synced 4w ago

READMEChangelogDependencies (13)Versions (4)Used By (0)

phpdot/container-swoole
=======================

[](#phpdotcontainer-swoole)

Swoole adapter for [phpdot/container](https://github.com/phpdot/container).

Each Swoole coroutine gets its own isolated service scope via `Coroutine::getContext()`. When the coroutine exits, Swoole destroys the context automatically — no manual cleanup required.

Installation
------------

[](#installation)

```
composer require phpdot/container-swoole
```

Usage
-----

[](#usage)

```
use PHPdot\Container\ContainerBuilder;
use PHPdot\Container\Swoole\SwooleContextProvider;
use function PHPdot\Container\singleton;
use function PHPdot\Container\scoped;

$container = (new ContainerBuilder())
    ->withContextProvider(new SwooleContextProvider())
    ->addDefinitions([
        // Shared across all coroutines
        Router::class  => singleton(),
        Redis::class   => singleton(),

        // Isolated per coroutine — fresh for each request
        Session::class       => scoped(),
        SignalManager::class => scoped(),
    ])
    ->build();
```

How It Works
------------

[](#how-it-works)

```
┌──────────────────────────────────────────────────────────┐
│ Swoole Worker                                            │
│                                                          │
│  Singletons (shared)                                     │
│  ┌────────────────────────────────────────────────────┐  │
│  │  Router       Redis       Config      LogBridge    │  │
│  └────────────────────────────────────────────────────┘  │
│                                                          │
│  Coroutine 1              Coroutine 2                    │
│  ┌──────────────────┐    ┌──────────────────┐           │
│  │ Session (User A)  │    │ Session (User B)  │           │
│  │ Signal (trace-1)  │    │ Signal (trace-2)  │           │
│  └──────────────────┘    └──────────────────┘           │
│    auto-destroyed           auto-destroyed               │
│    on coroutine exit        on coroutine exit             │
└──────────────────────────────────────────────────────────┘

```

**Singleton** services resolve once and are shared across all coroutines in the worker.

**Scoped** services resolve once per coroutine and are stored in `Swoole\Coroutine::getContext()`. When the coroutine finishes, Swoole's runtime destroys the context and all scoped instances are garbage collected.

**Outside a coroutine** (CLI bootstrap, `onStart` callback), the provider falls back to an in-memory `ArrayContext`.

Server Example
--------------

[](#server-example)

```
use Swoole\Http\Server;
use PHPdot\Container\ContainerBuilder;
use PHPdot\Container\Swoole\SwooleContextProvider;
use function PHPdot\Container\singleton;
use function PHPdot\Container\scoped;

$container = (new ContainerBuilder())
    ->withContextProvider(new SwooleContextProvider())
    ->addDefinitions([
        Config::class  => singleton(),
        Session::class => scoped(fn($c) => Session::fromRequest($c->get(Request::class))),
    ])
    ->build();

$server = new Server('0.0.0.0', 8080);

$server->on('request', function ($req, $res) use ($container) {
    // Each request runs in its own coroutine.
    // Scoped services are fresh. Singletons are shared.
    $session = $container->get(Session::class);

    $res->end('Hello ' . $session->user());
    // Coroutine ends here — scoped instances destroyed automatically.
});

$server->start();
```

Requirements
------------

[](#requirements)

- PHP &gt;= 8.3
- ext-swoole &gt;= 5.0
- [phpdot/container](https://github.com/phpdot/container) ^1.0

License
-------

[](#license)

MIT

###  Health Score

40

—

FairBetter than 86% of packages

Maintenance89

Actively maintained with recent releases

Popularity6

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity51

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~16 days

Total

3

Last Release

58d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/62e82421bda4b5d6ba9a47ba6d88caca060dcd0d1a2862f351f3a97657385db0?d=identicon)[phpdot](/maintainers/phpdot)

---

Top Contributors

[![phpdot](https://avatars.githubusercontent.com/u/252500?v=4)](https://github.com/phpdot "phpdot (4 commits)")

###  Code Quality

TestsPHPUnit

Static AnalysisPHPStan

Code StylePHP CS Fixer

Type Coverage Yes

### Embed Badge

![Health badge](/badges/phpdot-container-swoole/health.svg)

```
[![Health](https://phpackages.com/badges/phpdot-container-swoole/health.svg)](https://phpackages.com/packages/phpdot-container-swoole)
```

###  Alternatives

[selvinortiz/flux

Fluent regular expressions in PHP.

3372.1k3](/packages/selvinortiz-flux)[internezzo/childreload

Neos CMS package that helps to reload the page on change of any of the child nodes of the specific nodetype

1176.8k1](/packages/internezzo-childreload)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
