This is an example of implementing a WorkerListener class for the new CakePHP/Queue plugin as mentioned here => https://book.cakephp.org/queue/1/en/index.html#worker-events
Config array
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | // ... 'Queue' => [ 'default' => [ // A DSN for your configured backend. default: null 'url' => 'redis:' , // The queue that will be used for sending messages. default: default // This can be overriden when queuing or processing messages 'queue' => 'default' , // The name of a configured logger, default: null 'logger' => 'stdout' , // The name of an event listener class to associate with the worker 'listener' => \App\Listener\WorkerListener:: class , ] ], // ... |
Put it in src/Listener
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | // src/Listener/WorkerListener.php <?php namespace App\Listener; use Cake\Event\EventListenerInterface; use Cake\Log\LogTrait; class WorkerListener implements EventListenerInterface { use LogTrait; public function implementedEvents(): array { return [ 'Processor.message.exception' => 'processorMessageException' , 'Processor.message.invalid' => 'processorMessageInvalid' , 'Processor.message.reject' => 'processorMessageReject' , 'Processor.message.success' => 'processorMessageSuccess' , 'Processor.maxIterations' => 'processorMaxIterations' , 'Processor.maxRuntime' => "processorMaxRuntime" , 'Processor.message.failure' => "processorMessageFailure" , 'Processor.message.seen' => 'processorMessageSeen' , 'Processor.message.start' => 'processorMessageStart' , ]; } public function processorMessageException( $message , $exception ) { $this ->log( __METHOD__ ); $this ->log(print_r( $message , true)); $this ->log( $exception ); } public function processorMessageInvalid( $message ) { $this ->log( __METHOD__ ); } public function processorMessageReject( $message ) { $this ->log( __METHOD__ ); } public function processorMessageSuccess( $message ) { $this ->log( __METHOD__ ); } public function processorMaxIterations() { $this ->log( __METHOD__ ); } public function processorMaxRuntime() { $this ->log( __METHOD__ ); } public function processorMessageFailure( $message ) { $this ->log( __METHOD__ ); } public function processorMessageSeen( $message ) { $this ->log( __METHOD__ ); } public function processorMessageStart( $message ) { $this ->log( __METHOD__ ); } } |
0 Comments