123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 |
- <?php
-
- namespace Illuminate\Queue;
-
- use Closure;
- use InvalidArgumentException;
- use Illuminate\Contracts\Queue\Factory as FactoryContract;
- use Illuminate\Contracts\Queue\Monitor as MonitorContract;
-
- /**
- * @mixin \Illuminate\Contracts\Queue\Queue
- */
- class QueueManager implements FactoryContract, MonitorContract
- {
- /**
- * The application instance.
- *
- * @var \Illuminate\Foundation\Application
- */
- protected $app;
-
- /**
- * The array of resolved queue connections.
- *
- * @var array
- */
- protected $connections = [];
-
- /**
- * The array of resolved queue connectors.
- *
- * @var array
- */
- protected $connectors = [];
-
- /**
- * Create a new queue manager instance.
- *
- * @param \Illuminate\Foundation\Application $app
- * @return void
- */
- public function __construct($app)
- {
- $this->app = $app;
- }
-
- /**
- * Register an event listener for the before job event.
- *
- * @param mixed $callback
- * @return void
- */
- public function before($callback)
- {
- $this->app['events']->listen(Events\JobProcessing::class, $callback);
- }
-
- /**
- * Register an event listener for the after job event.
- *
- * @param mixed $callback
- * @return void
- */
- public function after($callback)
- {
- $this->app['events']->listen(Events\JobProcessed::class, $callback);
- }
-
- /**
- * Register an event listener for the exception occurred job event.
- *
- * @param mixed $callback
- * @return void
- */
- public function exceptionOccurred($callback)
- {
- $this->app['events']->listen(Events\JobExceptionOccurred::class, $callback);
- }
-
- /**
- * Register an event listener for the daemon queue loop.
- *
- * @param mixed $callback
- * @return void
- */
- public function looping($callback)
- {
- $this->app['events']->listen(Events\Looping::class, $callback);
- }
-
- /**
- * Register an event listener for the failed job event.
- *
- * @param mixed $callback
- * @return void
- */
- public function failing($callback)
- {
- $this->app['events']->listen(Events\JobFailed::class, $callback);
- }
-
- /**
- * Register an event listener for the daemon queue stopping.
- *
- * @param mixed $callback
- * @return void
- */
- public function stopping($callback)
- {
- $this->app['events']->listen(Events\WorkerStopping::class, $callback);
- }
-
- /**
- * Determine if the driver is connected.
- *
- * @param string $name
- * @return bool
- */
- public function connected($name = null)
- {
- return isset($this->connections[$name ?: $this->getDefaultDriver()]);
- }
-
- /**
- * Resolve a queue connection instance.
- *
- * @param string $name
- * @return \Illuminate\Contracts\Queue\Queue
- */
- public function connection($name = null)
- {
- $name = $name ?: $this->getDefaultDriver();
-
- // If the connection has not been resolved yet we will resolve it now as all
- // of the connections are resolved when they are actually needed so we do
- // not make any unnecessary connection to the various queue end-points.
- if (! isset($this->connections[$name])) {
- $this->connections[$name] = $this->resolve($name);
-
- $this->connections[$name]->setContainer($this->app);
- }
-
- return $this->connections[$name];
- }
-
- /**
- * Resolve a queue connection.
- *
- * @param string $name
- * @return \Illuminate\Contracts\Queue\Queue
- */
- protected function resolve($name)
- {
- $config = $this->getConfig($name);
-
- return $this->getConnector($config['driver'])
- ->connect($config)
- ->setConnectionName($name);
- }
-
- /**
- * Get the connector for a given driver.
- *
- * @param string $driver
- * @return \Illuminate\Queue\Connectors\ConnectorInterface
- *
- * @throws \InvalidArgumentException
- */
- protected function getConnector($driver)
- {
- if (! isset($this->connectors[$driver])) {
- throw new InvalidArgumentException("No connector for [$driver]");
- }
-
- return call_user_func($this->connectors[$driver]);
- }
-
- /**
- * Add a queue connection resolver.
- *
- * @param string $driver
- * @param \Closure $resolver
- * @return void
- */
- public function extend($driver, Closure $resolver)
- {
- return $this->addConnector($driver, $resolver);
- }
-
- /**
- * Add a queue connection resolver.
- *
- * @param string $driver
- * @param \Closure $resolver
- * @return void
- */
- public function addConnector($driver, Closure $resolver)
- {
- $this->connectors[$driver] = $resolver;
- }
-
- /**
- * Get the queue connection configuration.
- *
- * @param string $name
- * @return array
- */
- protected function getConfig($name)
- {
- if (! is_null($name) && $name !== 'null') {
- return $this->app['config']["queue.connections.{$name}"];
- }
-
- return ['driver' => 'null'];
- }
-
- /**
- * Get the name of the default queue connection.
- *
- * @return string
- */
- public function getDefaultDriver()
- {
- return $this->app['config']['queue.default'];
- }
-
- /**
- * Set the name of the default queue connection.
- *
- * @param string $name
- * @return void
- */
- public function setDefaultDriver($name)
- {
- $this->app['config']['queue.default'] = $name;
- }
-
- /**
- * Get the full name for the given connection.
- *
- * @param string $connection
- * @return string
- */
- public function getName($connection = null)
- {
- return $connection ?: $this->getDefaultDriver();
- }
-
- /**
- * Determine if the application is in maintenance mode.
- *
- * @return bool
- */
- public function isDownForMaintenance()
- {
- return $this->app->isDownForMaintenance();
- }
-
- /**
- * Dynamically pass calls to the default connection.
- *
- * @param string $method
- * @param array $parameters
- * @return mixed
- */
- public function __call($method, $parameters)
- {
- return $this->connection()->$method(...$parameters);
- }
- }
|