123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\VarDumper\Caster;
- use RdKafka\Conf;
- use RdKafka\Exception as RdKafkaException;
- use RdKafka\KafkaConsumer;
- use RdKafka\Message;
- use RdKafka\Metadata\Broker as BrokerMetadata;
- use RdKafka\Metadata\Collection as CollectionMetadata;
- use RdKafka\Metadata\Partition as PartitionMetadata;
- use RdKafka\Metadata\Topic as TopicMetadata;
- use RdKafka\Topic;
- use RdKafka\TopicConf;
- use RdKafka\TopicPartition;
- use Symfony\Component\VarDumper\Cloner\Stub;
- /**
- * Casts RdKafka related classes to array representation.
- *
- * @author Romain Neutron <imprec@gmail.com>
- */
- class RdKafkaCaster
- {
- public static function castKafkaConsumer(KafkaConsumer $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- try {
- $assignment = $c->getAssignment();
- } catch (RdKafkaException $e) {
- $assignment = [];
- }
- $a += [
- $prefix.'subscription' => $c->getSubscription(),
- $prefix.'assignment' => $assignment,
- ];
- $a += self::extractMetadata($c);
- return $a;
- }
- public static function castTopic(Topic $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- $a += [
- $prefix.'name' => $c->getName(),
- ];
- return $a;
- }
- public static function castTopicPartition(TopicPartition $c, array $a)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- $a += [
- $prefix.'offset' => $c->getOffset(),
- $prefix.'partition' => $c->getPartition(),
- $prefix.'topic' => $c->getTopic(),
- ];
- return $a;
- }
- public static function castMessage(Message $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- $a += [
- $prefix.'errstr' => $c->errstr(),
- ];
- return $a;
- }
- public static function castConf(Conf $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- foreach ($c->dump() as $key => $value) {
- $a[$prefix.$key] = $value;
- }
- return $a;
- }
- public static function castTopicConf(TopicConf $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- foreach ($c->dump() as $key => $value) {
- $a[$prefix.$key] = $value;
- }
- return $a;
- }
- public static function castRdKafka(\RdKafka $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- $a += [
- $prefix.'out_q_len' => $c->getOutQLen(),
- ];
- $a += self::extractMetadata($c);
- return $a;
- }
- public static function castCollectionMetadata(CollectionMetadata $c, array $a, Stub $stub, $isNested)
- {
- $a += iterator_to_array($c);
- return $a;
- }
- public static function castTopicMetadata(TopicMetadata $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- $a += [
- $prefix.'name' => $c->getTopic(),
- $prefix.'partitions' => $c->getPartitions(),
- ];
- return $a;
- }
- public static function castPartitionMetadata(PartitionMetadata $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- $a += [
- $prefix.'id' => $c->getId(),
- $prefix.'err' => $c->getErr(),
- $prefix.'leader' => $c->getLeader(),
- ];
- return $a;
- }
- public static function castBrokerMetadata(BrokerMetadata $c, array $a, Stub $stub, $isNested)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- $a += [
- $prefix.'id' => $c->getId(),
- $prefix.'host' => $c->getHost(),
- $prefix.'port' => $c->getPort(),
- ];
- return $a;
- }
- private static function extractMetadata($c)
- {
- $prefix = Caster::PREFIX_VIRTUAL;
- try {
- $m = $c->getMetadata(true, null, 500);
- } catch (RdKafkaException $e) {
- return [];
- }
- return [
- $prefix.'orig_broker_id' => $m->getOrigBrokerId(),
- $prefix.'orig_broker_name' => $m->getOrigBrokerName(),
- $prefix.'brokers' => $m->getBrokers(),
- $prefix.'topics' => $m->getTopics(),
- ];
- }
- }
|