Bases: BaseConfluentTelemetrySettingsProvider['Message']
Source code in faststream/confluent/opentelemetry/provider.py
| def __init__(self) -> None:
self.messaging_system = "kafka"
|
messaging_system
instance-attribute
messaging_system = 'kafka'
get_consume_attrs_from_message
get_consume_attrs_from_message(msg)
Source code in faststream/confluent/opentelemetry/provider.py
| def get_consume_attrs_from_message(
self,
msg: "StreamMessage[Message]",
) -> dict[str, Any]:
attrs = {
SpanAttributes.MESSAGING_SYSTEM: self.messaging_system,
SpanAttributes.MESSAGING_MESSAGE_ID: msg.message_id,
SpanAttributes.MESSAGING_MESSAGE_CONVERSATION_ID: msg.correlation_id,
SpanAttributes.MESSAGING_MESSAGE_PAYLOAD_SIZE_BYTES: len(msg.body),
SpanAttributes.MESSAGING_KAFKA_DESTINATION_PARTITION: msg.raw_message.partition(),
SpanAttributes.MESSAGING_KAFKA_MESSAGE_OFFSET: msg.raw_message.offset(),
MESSAGING_DESTINATION_PUBLISH_NAME: msg.raw_message.topic(),
}
if (key := msg.raw_message.key()) is not None:
attrs[SpanAttributes.MESSAGING_KAFKA_MESSAGE_KEY] = key
return attrs
|
get_consume_destination_name
get_consume_destination_name(msg)
Source code in faststream/confluent/opentelemetry/provider.py
| def get_consume_destination_name(
self,
msg: "StreamMessage[Message]",
) -> str:
return cast("str", msg.raw_message.topic())
|
get_publish_attrs_from_cmd
get_publish_attrs_from_cmd(cmd)
Source code in faststream/confluent/opentelemetry/provider.py
| def get_publish_attrs_from_cmd(self, cmd: "KafkaPublishCommand") -> dict[str, Any]:
attrs: dict[str, Any] = {
SpanAttributes.MESSAGING_SYSTEM: self.messaging_system,
SpanAttributes.MESSAGING_DESTINATION_NAME: cmd.destination,
SpanAttributes.MESSAGING_MESSAGE_CONVERSATION_ID: cmd.correlation_id,
}
if cmd.partition is not None:
attrs[SpanAttributes.MESSAGING_KAFKA_DESTINATION_PARTITION] = cmd.partition
if cmd.key is not None:
attrs[SpanAttributes.MESSAGING_KAFKA_MESSAGE_KEY] = cmd.key
return attrs
|
get_publish_destination_name
get_publish_destination_name(cmd)
Source code in faststream/confluent/opentelemetry/provider.py
| def get_publish_destination_name(self, cmd: "PublishCommand") -> str:
return cmd.destination
|