Documentation

AmqpHandler extends AbstractProcessingHandler
in package

Base Handler class providing the Handler structure, including processors and formatters

Classes extending it should (in most cases) only implement write($record)

Table of Contents

Properties

$bubble  : bool
$exchange  : AMQPExchange|AMQPChannel
$exchangeName  : string
$formatter  : FormatterInterface|null
$level  : Level
$processors  : array<string|int, callable>
$extraAttributes  : array<string, mixed>

Methods

__construct()  : mixed
__destruct()  : mixed
__sleep()  : mixed
close()  : void
Closes the handler.
getBubble()  : bool
Gets the bubbling behavior.
getExtraAttributes()  : array<string, mixed>
getFormatter()  : FormatterInterface
getLevel()  : Level
Gets minimum logging level at which this handler will be triggered.
handle()  : bool
Handles a record.
handleBatch()  : void
Handles a set of records at once.
isHandling()  : bool
Checks whether the given record will be handled by this handler.
popProcessor()  : callable
pushProcessor()  : HandlerInterface
reset()  : void
setBubble()  : $this
Sets the bubbling behavior.
setExtraAttributes()  : $this
Configure extra attributes to pass to the AMQPExchange (if you are using the amqp extension)
setFormatter()  : HandlerInterface
setLevel()  : $this
Sets minimum logging level at which this handler will be triggered.
getDefaultFormatter()  : FormatterInterface
getRoutingKey()  : string
Gets the routing key for the AMQP exchange
processRecord()  : LogRecord
resetProcessors()  : void
write()  : void
Writes the (already formatted) record down to the log of the implementing handler
createAmqpMessage()  : AMQPMessage

Properties

$exchange

protected AMQPExchange|AMQPChannel $exchange

$processors

protected array<string|int, callable> $processors = []
Tags
phpstan-var

array<(callable(LogRecord): LogRecord)|ProcessorInterface>

$extraAttributes

private array<string, mixed> $extraAttributes = []

Methods

__construct()

public __construct(AMQPExchange|AMQPChannel $exchange[, string|null $exchangeName = null ][, int|string|Level $level = Level::Debug ][, bool $bubble = true ]) : mixed
Parameters
$exchange : AMQPExchange|AMQPChannel

AMQPExchange (php AMQP ext) or PHP AMQP lib channel, ready for use

$exchangeName : string|null = null

Optional exchange name, for AMQPChannel (PhpAmqpLib) only

$level : int|string|Level = Level::Debug

The minimum logging level at which this handler will be triggered

$bubble : bool = true

Whether the messages that are handled can bubble up the stack or not

__destruct()

public __destruct() : mixed

close()

Closes the handler.

public close() : void
Tags
inheritDoc

getBubble()

Gets the bubbling behavior.

public getBubble() : bool
Return values
bool

true means that this handler allows bubbling. false means that bubbling is not permitted.

getExtraAttributes()

public getExtraAttributes() : array<string, mixed>
Return values
array<string, mixed>

getLevel()

Gets minimum logging level at which this handler will be triggered.

public getLevel() : Level
Return values
Level

handle()

Handles a record.

public handle(LogRecord $record) : bool
Parameters
$record : LogRecord

The record to handle

Tags
inheritDoc
Return values
bool

true means that this handler handled the record, and that bubbling is not permitted. false means the record was either not processed or that this handler allows bubbling.

handleBatch()

Handles a set of records at once.

public handleBatch(array<string|int, mixed> $records) : void
Parameters
$records : array<string|int, mixed>

The records to handle

Tags
inheritDoc

isHandling()

Checks whether the given record will be handled by this handler.

public isHandling(LogRecord $record) : bool
Parameters
$record : LogRecord

Partial log record having only a level initialized

Tags
inheritDoc
Return values
bool

setBubble()

Sets the bubbling behavior.

public setBubble(bool $bubble) : $this
Parameters
$bubble : bool

true means that this handler allows bubbling. false means that bubbling is not permitted.

Return values
$this

setExtraAttributes()

Configure extra attributes to pass to the AMQPExchange (if you are using the amqp extension)

public setExtraAttributes(array<string, mixed> $extraAttributes) : $this
Parameters
$extraAttributes : array<string, mixed>

One of content_type, content_encoding, message_id, user_id, app_id, delivery_mode, priority, timestamp, expiration, type or reply_to, headers.

Return values
$this

setLevel()

Sets minimum logging level at which this handler will be triggered.

public setLevel(Level|LogLevel::* $level) : $this
Parameters
$level : Level|LogLevel::*

Level or level name

Tags
phpstan-param

value-ofLevel::VALUES|value-ofLevel::NAMES|Level|LogLevel::* $level

Return values
$this

getRoutingKey()

Gets the routing key for the AMQP exchange

protected getRoutingKey(LogRecord $record) : string
Parameters
$record : LogRecord
Return values
string

write()

Writes the (already formatted) record down to the log of the implementing handler

protected write(LogRecord $record) : void
Parameters
$record : LogRecord
Tags
inheritDoc

createAmqpMessage()

private createAmqpMessage(string $data) : AMQPMessage
Parameters
$data : string
Return values
AMQPMessage

        
On this page

Search results