noccylabs/react-serial (0.1.0)

Published 2025-03-21 12:51:37 +00:00 by noccy in noccy/php-react-serial

Installation

{
	"repositories": [{
			"type": "composer",
			"url": ""
		}
	]
}
composer require noccylabs/react-serial:0.1.0

About this package

Serial port I/O for ReactPHP

Serial port support for ReactPHP

Note

Only Linux is supported for now. Feel free to contribute support for additional platforms.

Installing

$ composer require noccylabs/react-serial:@dev

Using

The SerialFactory is really a SerialStreamFactory. Its open() method returns a promise that will resolve with a duplex stream for the port.

$serial = new SerialFactory();
$serial->open("/dev/ttyUSB0", 115200)
    ->then(function (DuplexStreamInterface $stream) { ... });

You may find that you need line buffering, in which case you should wrap the stream in a LineBufferedDuplexStream. The wrapped stream will emit the same data and close events as the original stream, but it will also emit a line event once a full line has been received. If you give it a $promptPattern in the constructor it will also emit a prompt event whenever a matching prompt is detected, and with $bufferOutput you will also get an output event with all the lines emitted since the last prompt.

// Wrap our stream and use '#> ' as the prompt pattern.
$shell = new LineBufferedDuplexStream($stream, promptPattern: '/\#\> /', bufferOutput:true);

// Prepare the commands to execute, in order. These are the commands you would use
// on an OpenWRT router to configure the WiFi password for the "main" WiFi interface.
$commands = [
    'uci set wireless.main.key="pennyisafreeloader"',
    'uci commit wireless',
    'wifi restart',
];

// Execute the next command once we get a prompt
$shell->on("prompt", function () use ($shell, &$commands) {
    $command = array_shift($commands);
    if (!$command) {
        // Closing the wrapper closes the stream
        $shell->close();
        return;
    }
    echo $command."\n";
    $shell->write($command."\n");
});

// Receives all the output lines from the last command.
$shell->on("output", function(array $lines) {
    echo "  ".join("\n  ",$lines)."\n";
});

// write "echo" to the shell on our fictive device to get a fresh prompt
$shell->write("echo\n");

Dependencies

Dependencies

ID Version
react/async ^4.3
react/event-loop ^1.5
react/partial ^3.0
react/promise ^3.2
react/stream ^1.4
Details
Composer
2025-03-21 12:51:37 +00:00
2
Christopher Vagnetoft
GPL-2.0-or-later
10 KiB
Assets (1)
Versions (1) View all
0.1.0 2025-03-21