ikarusbot/vendor/trafficcophp/bytebuffer
2025-01-10 19:52:34 +02:00
..
src/TrafficCophp/ByteBuffer first commit 2025-01-10 19:52:34 +02:00
tests/TrafficCophp/ByteBuffer first commit 2025-01-10 19:52:34 +02:00
.gitignore first commit 2025-01-10 19:52:34 +02:00
.travis.yml first commit 2025-01-10 19:52:34 +02:00
composer.json first commit 2025-01-10 19:52:34 +02:00
composer.lock first commit 2025-01-10 19:52:34 +02:00
phpunit.xml.dist first commit 2025-01-10 19:52:34 +02:00
README.md first commit 2025-01-10 19:52:34 +02:00

PHP Library for reading and writing binary data

Build Status No Maintenance Intended

I intentionally needed that for writing a PHP Client for TrafficCop. But the source grows so I decided to move it into an own package. You can also call this a pack() wrapper.

Install

Installation should be done via composer.

{
    "require": {
        "TrafficCophp/ByteBuffer": "dev-master"
    }
}

Example

A simple usage example could look like this

<?php

require __DIR__ . '/vendor/.composer/autoload.php';

use TrafficCophp\ByteBuffer\ByteBuffer;

$channel = 'channel_one';
$message = 'php';

$buffer = new ByteBuffer(4 + 1 + 4 + strlen($channel) + strlen($message));
$buffer->writeInt32BE($buffer->length(), 0);
$buffer->writeInt8(0x1, 4);
$buffer->writeInt32BE(strlen($channel), 5);
$buffer->write($channel, 9);
$buffer->write($message, 9 + strlen($channel));

$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
$result = socket_connect($socket, '127.0.0.1', 3542);

socket_write($socket, (string) $buffer, $buffer->length());

ToDo's

  • Write Documentation
  • Improve examples
  • Allow Buffer as constructor
  • Write test for concatinating buffers

License

Licensed under the MIT license.