186 lines
5.3 KiB
PHP
186 lines
5.3 KiB
PHP
|
|
<?php
|
||
|
|
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4 foldmethod=marker: */
|
||
|
|
// +---------------------------------------------------------------------------
|
||
|
|
// | SWAN [ $_SWANBR_SLOGAN_$ ]
|
||
|
|
// +---------------------------------------------------------------------------
|
||
|
|
// | Copyright $_SWANBR_COPYRIGHT_$
|
||
|
|
// +---------------------------------------------------------------------------
|
||
|
|
// | Version $_SWANBR_VERSION_$
|
||
|
|
// +---------------------------------------------------------------------------
|
||
|
|
// | Licensed ( $_SWANBR_LICENSED_URL_$ )
|
||
|
|
// +---------------------------------------------------------------------------
|
||
|
|
// | $_SWANBR_WEB_DOMAIN_$
|
||
|
|
// +---------------------------------------------------------------------------
|
||
|
|
|
||
|
|
namespace Kafka\Protocol;
|
||
|
|
|
||
|
|
/**
|
||
|
|
+------------------------------------------------------------------------------
|
||
|
|
* Kafka protocol for fetch offset api
|
||
|
|
+------------------------------------------------------------------------------
|
||
|
|
*
|
||
|
|
* @package
|
||
|
|
* @version $_SWANBR_VERSION_$
|
||
|
|
* @copyright Copyleft
|
||
|
|
* @author $_SWANBR_AUTHOR_$
|
||
|
|
+------------------------------------------------------------------------------
|
||
|
|
*/
|
||
|
|
|
||
|
|
class FetchOffset extends Protocol
|
||
|
|
{
|
||
|
|
// {{{ functions
|
||
|
|
// {{{ public function encode()
|
||
|
|
|
||
|
|
/**
|
||
|
|
* fetch offset request encode
|
||
|
|
*
|
||
|
|
* @param array $payloads
|
||
|
|
* @access public
|
||
|
|
* @return string
|
||
|
|
*/
|
||
|
|
public function encode($payloads)
|
||
|
|
{
|
||
|
|
if (!isset($payloads['data'])) {
|
||
|
|
throw new \Kafka\Exception\Protocol('given fetch offset data invalid. `data` is undefined.');
|
||
|
|
}
|
||
|
|
|
||
|
|
if (!isset($payloads['group_id'])) {
|
||
|
|
throw new \Kafka\Exception\Protocol('given fetch offset data invalid. `group_id` is undefined.');
|
||
|
|
}
|
||
|
|
|
||
|
|
$header = $this->requestHeader('kafka-php', self::OFFSET_FETCH_REQUEST, self::OFFSET_FETCH_REQUEST);
|
||
|
|
$data = self::encodeString($payloads['group_id'], self::PACK_INT16);
|
||
|
|
$data .= self::encodeArray($payloads['data'], array($this, 'encodeOffsetTopic'));
|
||
|
|
$data = self::encodeString($header . $data, self::PACK_INT32);
|
||
|
|
|
||
|
|
return $data;
|
||
|
|
}
|
||
|
|
|
||
|
|
// }}}
|
||
|
|
// {{{ public function decode()
|
||
|
|
|
||
|
|
/**
|
||
|
|
* decode group response
|
||
|
|
*
|
||
|
|
* @param byte[] $data
|
||
|
|
* @access public
|
||
|
|
* @return array
|
||
|
|
*/
|
||
|
|
public function decode($data)
|
||
|
|
{
|
||
|
|
$offset = 0;
|
||
|
|
$version = $this->getApiVersion(self::OFFSET_REQUEST);
|
||
|
|
$topics = $this->decodeArray(substr($data, $offset), array($this, 'offsetTopic'), $version);
|
||
|
|
$offset += $topics['length'];
|
||
|
|
|
||
|
|
return $topics['data'];
|
||
|
|
}
|
||
|
|
|
||
|
|
// }}}
|
||
|
|
// {{{ protected function encodeOffsetPartion()
|
||
|
|
|
||
|
|
/**
|
||
|
|
* encode signal part
|
||
|
|
*
|
||
|
|
* @param byte[] values partions data
|
||
|
|
* @access protected
|
||
|
|
* @return string
|
||
|
|
*/
|
||
|
|
protected function encodeOffsetPartion($values)
|
||
|
|
{
|
||
|
|
return self::pack(self::BIT_B32, $values);
|
||
|
|
}
|
||
|
|
|
||
|
|
// }}}
|
||
|
|
// {{{ protected function encodeOffsetTopic()
|
||
|
|
|
||
|
|
/**
|
||
|
|
* encode signal topic
|
||
|
|
*
|
||
|
|
* @param partions
|
||
|
|
* @access protected
|
||
|
|
* @return string
|
||
|
|
*/
|
||
|
|
protected function encodeOffsetTopic($values)
|
||
|
|
{
|
||
|
|
if (!isset($values['topic_name'])) {
|
||
|
|
throw new \Kafka\Exception\Protocol('given fetch offset data invalid. `topic_name` is undefined.');
|
||
|
|
}
|
||
|
|
|
||
|
|
if (!isset($values['partitions']) || empty($values['partitions'])) {
|
||
|
|
throw new \Kafka\Exception\Protocol('given fetch offset data invalid. `partitions` is undefined.');
|
||
|
|
}
|
||
|
|
|
||
|
|
$topic = self::encodeString($values['topic_name'], self::PACK_INT16);
|
||
|
|
$partitions = self::encodeArray($values['partitions'], array($this, 'encodeOffsetPartion'));
|
||
|
|
|
||
|
|
return $topic . $partitions;
|
||
|
|
}
|
||
|
|
|
||
|
|
// }}}
|
||
|
|
// {{{ protected function offsetTopic()
|
||
|
|
|
||
|
|
/**
|
||
|
|
* decode offset topic response
|
||
|
|
*
|
||
|
|
* @access protected
|
||
|
|
* @return array
|
||
|
|
*/
|
||
|
|
protected function offsetTopic($data, $version)
|
||
|
|
{
|
||
|
|
$offset = 0;
|
||
|
|
$topicInfo = $this->decodeString(substr($data, $offset), self::BIT_B16);
|
||
|
|
$offset += $topicInfo['length'];
|
||
|
|
|
||
|
|
$partitions = $this->decodeArray(substr($data, $offset), array($this, 'offsetPartition'), $version);
|
||
|
|
$offset += $partitions['length'];
|
||
|
|
|
||
|
|
return array(
|
||
|
|
'length' => $offset,
|
||
|
|
'data' => array(
|
||
|
|
'topicName' => $topicInfo['data'],
|
||
|
|
'partitions' => $partitions['data'],
|
||
|
|
)
|
||
|
|
);
|
||
|
|
}
|
||
|
|
|
||
|
|
// }}}
|
||
|
|
// {{{ protected function offsetPartition()
|
||
|
|
|
||
|
|
/**
|
||
|
|
* decode offset partition response
|
||
|
|
*
|
||
|
|
* @access protected
|
||
|
|
* @return array
|
||
|
|
*/
|
||
|
|
protected function offsetPartition($data, $version)
|
||
|
|
{
|
||
|
|
$offset = 0;
|
||
|
|
|
||
|
|
$partitionId = self::unpack(self::BIT_B32, substr($data, $offset, 4));
|
||
|
|
$offset += 4;
|
||
|
|
|
||
|
|
$roffset = self::unpack(self::BIT_B64, substr($data, $offset, 8));
|
||
|
|
$offset += 8;
|
||
|
|
|
||
|
|
$metadata = $this->decodeString(substr($data, $offset), self::BIT_B16);
|
||
|
|
$offset += $metadata['length'];
|
||
|
|
$errorCode = self::unpack(self::BIT_B16_SIGNED, substr($data, $offset, 2));
|
||
|
|
$offset += 2;
|
||
|
|
|
||
|
|
|
||
|
|
return array(
|
||
|
|
'length' => $offset,
|
||
|
|
'data' => array(
|
||
|
|
'partition' => $partitionId,
|
||
|
|
'errorCode' => $errorCode,
|
||
|
|
'metadata' => $metadata['data'],
|
||
|
|
'offset' => $roffset,
|
||
|
|
)
|
||
|
|
);
|
||
|
|
}
|
||
|
|
|
||
|
|
// }}}
|
||
|
|
// }}}
|
||
|
|
}
|