/inspect-protobuf

inspect protobuf messages or convert to json, best served with kafkacat

Primary LanguageJavaScript

inspect-protobuf

Inspect the content of messages encoded with google protobuf.

Requirements

  • nodejs ^8

Installation

sudo npm install -g @royaltm/inspect-protobuf

Usage

Display help

inspect-protobuf -h
Usage: inspect-protobuf [options] <proto-file> <ProtoMessageName>


Options:

  -V, --version           output the version number
  -j, --json              json output
  -C, --no-color          monochrome inspect output
  -3, --proto-3           use protobufjs parser (proto-3 support)
  -I, --no-ip             do not decode 4 or 16 bytes as ip addresses
  -e, --bytes <encoding>  decode bytes as strings with encoding
  -m, --msgpack           decode bytes with MessagePack
  -b, --json-bytes        decode bytes as JSON strings
  -h, --help              output usage information

Arguments

Pass proto file and message name arguments. If message name is not provided the first message found in proto file will be used.

cat message.bin | inspect-protobuf path/to/file.proto MyMessage

Alternatively set the environment variable INSPECT_PROTOBUF="path/to/file.proto/MyMessage". In this instance you must append the message name as the last path component.

Format options

no colors

cat message.bin | inspect-protobuf -C

use external json inspector

cat message.bin | inspect-protobuf -j | jq .
Protobuf options

Switch to protobufjs module for proto3 and other protobuf features that are not handled by the protocol-buffers module.

cat message.bin | inspect-protobuf -3

Kafkacat

This tool is best served with kafkacat.

export INSPECT_PROTOBUF="path/to/file.proto/MessageName"
kafkacat -C -b BROKER.BOOTSTRAP.NAME -c 20 -t SOME_TOPIC_NAME -o -1 -f '%S %s' | inspect-protobuf

The important part is kafkacat ... -f '%S %s'. It prepends each message with its byte length, so inspect-protobuf can distinguish each message in a message stream.