Completed
Push — develop ( 365e80...8d2e7b )
by Mohamed
15:08 queued 07:59
created

BusServiceProvider::boot()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 8
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1.125

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 8
ccs 3
cts 6
cp 0.5
rs 9.4285
cc 1
eloc 4
nc 1
nop 1
crap 1.125
1
<?php
2
3
/*
4
 * This file is part of the Tinyissue package.
5
 *
6
 * (c) Mohamed Alsharaf <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace Tinyissue\Providers;
13
14
use Illuminate\Bus\Dispatcher;
15
use Illuminate\Support\ServiceProvider;
16
use Tinyissue\Form\FormInterface;
17
use Tinyissue\Http\Requests\Request as FormRequest;
18
use Illuminate\Foundation\Application;
19
20
/**
21
 * BusServiceProvider is the request service provider for bootstrapping and registering services in current request.
22
 *
23
 * @author Mohamed Alsharaf <[email protected]>
24
 */
25
class BusServiceProvider extends ServiceProvider
26
{
27
    /**
28
     * Bootstrap any application services.
29
     *
30
     * @param \Illuminate\Bus\Dispatcher $dispatcher
31
     */
32 62
    public function boot(Dispatcher $dispatcher)
33
    {
34
        $dispatcher->mapUsing(function ($command) {
35
            return Dispatcher::simpleMapping(
36
                            $command, 'Tinyissue\Commands', 'Tinyissue\Handlers\Commands'
37
            );
38 62
        });
39 62
    }
40
41
    /**
42
     * Register any application services.
43
     */
44 62
    public function register()
45
    {
46
        // Resolve form object by injecting the current model being edited
47
        $this->app->resolving(function (FormInterface $form, Application $app) {
0 ignored issues
show
Documentation introduced by
function (\Tinyissue\For...User(auth()->user()); } is of type object<Closure>, but the function expects a string.

It seems like the type of the argument is not accepted by the function/method which you are calling.

In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.

We suggest to add an explicit type cast like in the following example:

function acceptsInteger($int) { }

$x = '123'; // string "123"

// Instead of
acceptsInteger($x);

// we recommend to use
acceptsInteger((integer) $x);
Loading history...
48 49
            $form->setup($app->router->getCurrentRoute()->parameters());
49 49
            $form->setLoggedUser(auth()->user());
50 62
        });
51
52
        // Resolve form request by injecting the current model being edited
53
        $this->app->resolving(function (FormRequest $request, Application $app) {
0 ignored issues
show
Documentation introduced by
function (\Tinyissue\Htt... return $request; } is of type object<Closure>, but the function expects a string.

It seems like the type of the argument is not accepted by the function/method which you are calling.

In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.

We suggest to add an explicit type cast like in the following example:

function acceptsInteger($int) { }

$x = '123'; // string "123"

// Instead of
acceptsInteger($x);

// we recommend to use
acceptsInteger((integer) $x);
Loading history...
54
            $form = array_first($app->router->getCurrentRoute()->parameters(), function ($key, $value) {
55 14
                return $value instanceof FormInterface;
56 27
            }, function () use ($request, $app) {
57 27
                return $app->make($request->getFormClassName());
58 27
            });
59 27
            if ($form) {
60 27
                $form->setup($app->router->getCurrentRoute()->parameters());
61 27
                $form->setLoggedUser(auth()->user());
62 27
                $request->setForm($form);
63 27
            }
64
65 27
            return $request;
66 62
        });
67 62
    }
68
}
69