Weave Code
Code Weaver
Helps Laravel developers discover, compare, and choose open-source packages. See popularity, security, maintainers, and scores at a glance to make better decisions.
Feedback
Share your thoughts, report bugs, or suggest improvements.
Subject
Message

Stream Decorators Laravel Package

zbateson/stream-decorators

Lightweight PHP stream decorators for composing and filtering streams. Wrap any resource to add behaviors like buffering, limiting, logging, or on-the-fly transforms while keeping a standard stream interface. Useful for email parsing, I/O pipelines, and testing.

View on GitHub
Deep Wiki
Context7

zbateson/stream-decorators

PSR-7 stream decorators for character set conversion and common mail format content encodings.

Build Status Total Downloads Latest Stable Version

composer require zbateson/stream-decorators

Sponsors

SecuMailer

A huge thank you to all my sponsors. <3

If this project's helped you, please consider sponsoring me.

Requirements

PHP 8.1 or newer. Tested on PHP 8.1, 8.2, 8.3, 8.4, and 8.5.

Description

The library provides the following Psr\Http\Message\StreamInterface implementations:

  • Base64Stream - decodes on read and encodes on write to base64
  • CharsetStream - encodes from $streamCharset to $stringCharset on read, and vice-versa on write
  • ChunkSplitStream - splits written characters into lines of $lineLength long (stream implementation of PHP's chunk_split)
  • DecoratedCachingStream - a caching stream that writes to a decorated stream, and reads from the cached undecorated stream
  • NonClosingStream - overrides close() and detach(), and simply unsets the attached stream without closing it
  • PregReplaceFilterStream - calls preg_replace with passed arguments on every read() call
  • QuotedPrintableStream - decodes on read and encodes on write to quoted-printable
  • SeekingLimitStream - similar to GuzzleHttp's LimitStream, but maintains an internal current read position
  • TellZeroStream - tell() always returns 0 -- used by DecoratedCachingStream to wrap a BufferStream in a CachingStream
  • UUStream - decodes on read, encodes on write to uu-encoded

Usage

$stream = GuzzleHttp\Psr7\Utils::streamFor($handle);
$b64Stream = new ZBateson\StreamDecorators\Base64Stream($stream);
$charsetStream = new ZBateson\StreamDecorators\CharsetStream($b64Stream, 'UTF-32', 'UTF-8');

while (($line = GuzzleHttp\Psr7\Utils::readLine()) !== false) {
    echo $line, "\r\n";
}

Note that CharsetStream, depending on the target encoding, may return multiple bytes when a single 'char' is read. If using PHP's fread, this will result in a warning. It is recommended to not convert to a stream handle (with StreamWrapper) when using CharsetStream.

License

BSD licensed - please see license agreement.

Weaver

How can I help you explore Laravel packages today?

Conversation history is not saved when not logged in.
Prompt
Add packages to context
No packages found.
davejamesmiller/laravel-breadcrumbs
artisanry/parsedown
christhompsontldr/phpsdk
enqueue/dsn
bunny/bunny
enqueue/test
enqueue/null
enqueue/amqp-tools
milesj/emojibase
bower-asset/punycode
bower-asset/inputmask
bower-asset/jquery
bower-asset/yii2-pjax
laravel/nova
spatie/laravel-mailcoach
spatie/laravel-superseeder
laravel/liferaft
nst/json-test-suite
danielmiessler/sec-lists
jackalope/jackalope-transport