Upgrade framework
This commit is contained in:
@@ -71,4 +71,27 @@ class Hub implements HubContract
|
||||
$this->pipelines[$pipeline], new Pipeline($this->container), $object
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the container instance used by the hub.
|
||||
*
|
||||
* @return \Illuminate\Contracts\Container\Container
|
||||
*/
|
||||
public function getContainer()
|
||||
{
|
||||
return $this->container;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the container instance used by the hub.
|
||||
*
|
||||
* @param \Illuminate\Contracts\Container\Container $container
|
||||
* @return $this
|
||||
*/
|
||||
public function setContainer(Container $container)
|
||||
{
|
||||
$this->container = $container;
|
||||
|
||||
return $this;
|
||||
}
|
||||
}
|
||||
|
||||
21
vendor/laravel/framework/src/Illuminate/Pipeline/LICENSE.md
vendored
Normal file
21
vendor/laravel/framework/src/Illuminate/Pipeline/LICENSE.md
vendored
Normal file
@@ -0,0 +1,21 @@
|
||||
The MIT License (MIT)
|
||||
|
||||
Copyright (c) Taylor Otwell
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
@@ -3,16 +3,17 @@
|
||||
namespace Illuminate\Pipeline;
|
||||
|
||||
use Closure;
|
||||
use RuntimeException;
|
||||
use Illuminate\Contracts\Container\Container;
|
||||
use Illuminate\Contracts\Pipeline\Pipeline as PipelineContract;
|
||||
use RuntimeException;
|
||||
use Throwable;
|
||||
|
||||
class Pipeline implements PipelineContract
|
||||
{
|
||||
/**
|
||||
* The container implementation.
|
||||
*
|
||||
* @var \Illuminate\Contracts\Container\Container
|
||||
* @var \Illuminate\Contracts\Container\Container|null
|
||||
*/
|
||||
protected $container;
|
||||
|
||||
@@ -74,6 +75,19 @@ class Pipeline implements PipelineContract
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Push additional pipes onto the pipeline.
|
||||
*
|
||||
* @param array|mixed $pipes
|
||||
* @return $this
|
||||
*/
|
||||
public function pipe($pipes)
|
||||
{
|
||||
array_push($this->pipes, ...(is_array($pipes) ? $pipes : func_get_args()));
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the method to call on the pipes.
|
||||
*
|
||||
@@ -96,12 +110,24 @@ class Pipeline implements PipelineContract
|
||||
public function then(Closure $destination)
|
||||
{
|
||||
$pipeline = array_reduce(
|
||||
array_reverse($this->pipes), $this->carry(), $this->prepareDestination($destination)
|
||||
array_reverse($this->pipes()), $this->carry(), $this->prepareDestination($destination)
|
||||
);
|
||||
|
||||
return $pipeline($this->passable);
|
||||
}
|
||||
|
||||
/**
|
||||
* Run the pipeline and return the result.
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function thenReturn()
|
||||
{
|
||||
return $this->then(function ($passable) {
|
||||
return $passable;
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the final piece of the Closure onion.
|
||||
*
|
||||
@@ -111,7 +137,11 @@ class Pipeline implements PipelineContract
|
||||
protected function prepareDestination(Closure $destination)
|
||||
{
|
||||
return function ($passable) use ($destination) {
|
||||
return $destination($passable);
|
||||
try {
|
||||
return $destination($passable);
|
||||
} catch (Throwable $e) {
|
||||
return $this->handleException($passable, $e);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
@@ -124,28 +154,36 @@ class Pipeline implements PipelineContract
|
||||
{
|
||||
return function ($stack, $pipe) {
|
||||
return function ($passable) use ($stack, $pipe) {
|
||||
if ($pipe instanceof Closure) {
|
||||
// If the pipe is an instance of a Closure, we will just call it directly but
|
||||
// otherwise we'll resolve the pipes out of the container and call it with
|
||||
// the appropriate method and arguments, returning the results back out.
|
||||
return $pipe($passable, $stack);
|
||||
} elseif (! is_object($pipe)) {
|
||||
list($name, $parameters) = $this->parsePipeString($pipe);
|
||||
try {
|
||||
if (is_callable($pipe)) {
|
||||
// If the pipe is a callable, then we will call it directly, but otherwise we
|
||||
// will resolve the pipes out of the dependency container and call it with
|
||||
// the appropriate method and arguments, returning the results back out.
|
||||
return $pipe($passable, $stack);
|
||||
} elseif (! is_object($pipe)) {
|
||||
[$name, $parameters] = $this->parsePipeString($pipe);
|
||||
|
||||
// If the pipe is a string we will parse the string and resolve the class out
|
||||
// of the dependency injection container. We can then build a callable and
|
||||
// execute the pipe function giving in the parameters that are required.
|
||||
$pipe = $this->getContainer()->make($name);
|
||||
// If the pipe is a string we will parse the string and resolve the class out
|
||||
// of the dependency injection container. We can then build a callable and
|
||||
// execute the pipe function giving in the parameters that are required.
|
||||
$pipe = $this->getContainer()->make($name);
|
||||
|
||||
$parameters = array_merge([$passable, $stack], $parameters);
|
||||
} else {
|
||||
// If the pipe is already an object we'll just make a callable and pass it to
|
||||
// the pipe as-is. There is no need to do any extra parsing and formatting
|
||||
// since the object we're given was already a fully instantiated object.
|
||||
$parameters = [$passable, $stack];
|
||||
$parameters = array_merge([$passable, $stack], $parameters);
|
||||
} else {
|
||||
// If the pipe is already an object we'll just make a callable and pass it to
|
||||
// the pipe as-is. There is no need to do any extra parsing and formatting
|
||||
// since the object we're given was already a fully instantiated object.
|
||||
$parameters = [$passable, $stack];
|
||||
}
|
||||
|
||||
$carry = method_exists($pipe, $this->method)
|
||||
? $pipe->{$this->method}(...$parameters)
|
||||
: $pipe(...$parameters);
|
||||
|
||||
return $this->handleCarry($carry);
|
||||
} catch (Throwable $e) {
|
||||
return $this->handleException($passable, $e);
|
||||
}
|
||||
|
||||
return $pipe->{$this->method}(...$parameters);
|
||||
};
|
||||
};
|
||||
}
|
||||
@@ -153,12 +191,12 @@ class Pipeline implements PipelineContract
|
||||
/**
|
||||
* Parse full pipe string to get name and parameters.
|
||||
*
|
||||
* @param string $pipe
|
||||
* @param string $pipe
|
||||
* @return array
|
||||
*/
|
||||
protected function parsePipeString($pipe)
|
||||
{
|
||||
list($name, $parameters) = array_pad(explode(':', $pipe, 2), 2, []);
|
||||
[$name, $parameters] = array_pad(explode(':', $pipe, 2), 2, []);
|
||||
|
||||
if (is_string($parameters)) {
|
||||
$parameters = explode(',', $parameters);
|
||||
@@ -167,10 +205,21 @@ class Pipeline implements PipelineContract
|
||||
return [$name, $parameters];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the array of configured pipes.
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
protected function pipes()
|
||||
{
|
||||
return $this->pipes;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the container instance.
|
||||
*
|
||||
* @return \Illuminate\Contracts\Container\Container
|
||||
*
|
||||
* @throws \RuntimeException
|
||||
*/
|
||||
protected function getContainer()
|
||||
@@ -181,4 +230,42 @@ class Pipeline implements PipelineContract
|
||||
|
||||
return $this->container;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the container instance.
|
||||
*
|
||||
* @param \Illuminate\Contracts\Container\Container $container
|
||||
* @return $this
|
||||
*/
|
||||
public function setContainer(Container $container)
|
||||
{
|
||||
$this->container = $container;
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle the value returned from each pipe before passing it to the next.
|
||||
*
|
||||
* @param mixed $carry
|
||||
* @return mixed
|
||||
*/
|
||||
protected function handleCarry($carry)
|
||||
{
|
||||
return $carry;
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle the given exception.
|
||||
*
|
||||
* @param mixed $passable
|
||||
* @param \Throwable $e
|
||||
* @return mixed
|
||||
*
|
||||
* @throws \Throwable
|
||||
*/
|
||||
protected function handleException($passable, Throwable $e)
|
||||
{
|
||||
throw $e;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,18 +2,12 @@
|
||||
|
||||
namespace Illuminate\Pipeline;
|
||||
|
||||
use Illuminate\Support\ServiceProvider;
|
||||
use Illuminate\Contracts\Pipeline\Hub as PipelineHubContract;
|
||||
use Illuminate\Contracts\Support\DeferrableProvider;
|
||||
use Illuminate\Support\ServiceProvider;
|
||||
|
||||
class PipelineServiceProvider extends ServiceProvider
|
||||
class PipelineServiceProvider extends ServiceProvider implements DeferrableProvider
|
||||
{
|
||||
/**
|
||||
* Indicates if loading of the provider is deferred.
|
||||
*
|
||||
* @var bool
|
||||
*/
|
||||
protected $defer = true;
|
||||
|
||||
/**
|
||||
* Register the service provider.
|
||||
*
|
||||
|
||||
@@ -14,9 +14,9 @@
|
||||
}
|
||||
],
|
||||
"require": {
|
||||
"php": ">=5.6.4",
|
||||
"illuminate/contracts": "5.4.*",
|
||||
"illuminate/support": "5.4.*"
|
||||
"php": "^8.0.2",
|
||||
"illuminate/contracts": "^9.0",
|
||||
"illuminate/support": "^9.0"
|
||||
},
|
||||
"autoload": {
|
||||
"psr-4": {
|
||||
@@ -25,7 +25,7 @@
|
||||
},
|
||||
"extra": {
|
||||
"branch-alias": {
|
||||
"dev-master": "5.4-dev"
|
||||
"dev-master": "9.x-dev"
|
||||
}
|
||||
},
|
||||
"config": {
|
||||
|
||||
Reference in New Issue
Block a user