keinos / mastodon-streaming-api-parser
Parses the Mastodon Streaming API server-sent events to JSON.
1.0.1
2020-07-24 17:10 UTC
Requires
- php: ^8.0 || ^7.1
- ext-json: *
- ext-mbstring: *
Requires (Dev)
- bamarni/composer-bin-plugin: ^1.3
- phan/phan: ^2.5
- php-coveralls/php-coveralls: ^2.2
- phpbench/phpbench: @dev
- phpmd/phpmd: @stable
- phpstan/extension-installer: ^1.0
- phpstan/phpstan: ^0.12.10
- phpunit/phpunit: ^9.0 || ^8.0 || ^7.0 || ^6.5
- psalm/phar: ^3.9
- squizlabs/php_codesniffer: ^3.5
This package is auto-updated.
Last update: 2024-10-25 03:17:25 UTC
README
Server-Sent Events parser of Mastodon Streaming API in PHP
This class simply parses the received lines from server-sent events of the Mastodon Streaming API to JSON object string.
The below lines (server-sent event messages) will be parsed in JSON as below.
5b1
event: update
data: {"id":"10000 ... visible\">0FS8QET2TT</span></a><br><a hr
350
ef=\"https://www ... ts":[],"mentions":[],"tags":[],"emojis":[]}
↓
use \KEINOS\MSTDN_TOOLS\Parser\Parser; $parser = new Parser(); while (! feof($stream)) { $line = fgets($stream); $json = $parser->parse($line); if (false === $json) { continue; } echo $json . PHP_EOL; }
↓
{"event":"update","payload":{"id":"10000 ... visible\">0FS8QET2TT<\/span><\/a><br><a href=\"https:\/\/www .... ts":[],"mentions":[],"tags":[],"emojis":[]}}
Use this class if you are receiving the streaming signal directly from Mastodon Streaming API via socket connection, rather than WebSocket which requires an access token when upgrading the protocol.
Install
composer require keinos/mastodon-streaming-api-parser
Usage
-
Instantiation
$parser = new \KEINOS\MSTDN_TOOLS\Parser\Parser();
-
Method
/** * @param string $line Received streaming line. * @return bool|string Returns the data unit in JSON string. Or false if the * status is "buffering in progress". */ $json = $parser->parse($line);
-
Returned JSON string structure
{ "event":"[Event name]", "payload":"[Data of the event]" }
-
Interface: ParserInterface.php
Sample
// Instantiate the parser $parser = new \KEINOS\MSTDN_TOOLS\Parser\Parser(); // Open socket $fp = fsockopen($hostname, $port, $errno, $errstr, $timeout); // Send GET request fwrite($fp, $req); // Looper while (! feof($fp)) { // Read the stream $read = fgets($fp); // Buffer each line until it returns the data $json = $parser->parse($read); if (false === $json) { continue; } // Do something with the data echo $json . PHP_EOL; } // Close connection fclose($fp);
- Complete sample see: ./samples/Main.php
Specifications/Info
- PHP: ^7.1 || ^8.0
- Available event types to detect:
update
anddelete
- Source Code: Mastodon_StreamingAPI_Parser @ GitHub
- Package release: keinos/mastodon-streaming-api-parser @ Packagist
Contribution
- Issues
- Throw an issue at: https://github.com/KEINOS/Mastodon_StreamingAPI_Parser/issues
- If the issue is a bug, then please provide a simple example that are reproducible.
- If the issue is a feature request, then also provide a simple example with the results you wish, so we can create a test before implementing your feature.
- PR (Pull Request)
- Please PR to the
padawan
branch. After the CI tests/reviews, then merged tomaster
branch it will ;-) - For more see: CONTRIBUTE.md
- Please PR to the
- Rules
- Be nice, be happy and stay safe.