Completed
Push — master ( 0e1003...1276c7 )
by Abdelrahman
61:46 queued 59:06
created

UrlGenerator   A

Complexity

Total Complexity 17

Size/Duplication

Total Lines 83
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 4

Importance

Changes 0
Metric Value
wmc 17
lcom 1
cbo 4
dl 0
loc 83
rs 10
c 0
b 0
f 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A to() 0 28 3
A routeUrl() 0 8 3
A previous() 0 4 2
B toRoute() 0 19 9
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Cortex\Foundation\Overrides\Illuminate\Routing;
6
7
use Illuminate\Routing\UrlGenerator as BaseUrlGenerator;
8
use Mcamara\LaravelLocalization\Facades\LaravelLocalization;
9
10
class UrlGenerator extends BaseUrlGenerator
11
{
12
    /**
13
     * Generate an absolute URL to the given path.
14
     *
15
     * @param string    $path
16
     * @param mixed     $extra
17
     * @param bool|null $secure
18
     *
19
     * @return string
20
     */
21
    public function to($path, $extra = [], $secure = null): string
22
    {
23
        if (! config('cortex.foundation.route.trailing_slash')) {
24
            return parent::to($path, $extra, $secure);
25
        }
26
27
        // First we will check if the URL is already a valid URL. If it is we will not
28
        // try to generate a new one but will simply return the URL as is, which is
29
        // convenient since developers do not always have to check if it's valid.
30
        if ($this->isValidUrl($path)) {
31
            return $path;
32
        }
33
34
        $tail = implode('/', array_map(
35
                'rawurlencode', (array) $this->formatParameters($extra))
36
        );
37
38
        // Once we have the scheme we will compile the "tail" by collapsing the values
39
        // into a single string delimited by slashes. This just makes it convenient
40
        // for passing the array of parameters to this URL as a list of segments.
41
        $root = $this->formatRoot($this->formatScheme($secure));
42
43
        [$path, $query] = $this->extractQueryString($path);
0 ignored issues
show
Bug introduced by
The variable $query does not exist. Did you forget to declare it?

This check marks access to variables or properties that have not been declared yet. While PHP has no explicit notion of declaring a variable, accessing it before a value is assigned to it is most likely a bug.

Loading history...
44
45
        return $this->format(
46
                $root, '/'.trim($path.'/'.$tail, '/')
47
            ).'/'.$query;
48
    }
49
50
    /**
51
     * {@inheritdoc}
52
     */
53
    protected function routeUrl()
54
    {
55
        if (config('cortex.foundation.route.trailing_slash') && ! $this->routeGenerator) {
56
            $this->routeGenerator = new RouteUrlGenerator($this, $this->request);
57
        }
58
59
        return parent::routeUrl();
60
    }
61
62
    /**
63
     * {@inheritdoc}
64
     */
65
    public function previous($fallback = false)
66
    {
67
        return ($previousUrl = $this->request->input('previous_url')) ? $this->to($previousUrl) : parent::previous($fallback);
0 ignored issues
show
Bug introduced by
It seems like $previousUrl defined by $this->request->input('previous_url') on line 67 can also be of type array; however, Cortex\Foundation\Overri...ting\UrlGenerator::to() does only seem to accept string, maybe add an additional type check?

If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check:

/**
 * @return array|string
 */
function returnsDifferentValues($x) {
    if ($x) {
        return 'foo';
    }

    return array();
}

$x = returnsDifferentValues($y);
if (is_array($x)) {
    // $x is an array.
}

If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue.

Loading history...
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 126 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
68
    }
69
70
    /**
71
     * {@inheritdoc}
72
     */
73
    protected function toRoute($route, $parameters, $absolute)
74
    {
75
        // Bind {locale} route parameter
76
        if (config('cortex.foundation.route.locale_prefix') && in_array('locale', $route->parameterNames()) && ! isset($parameters['locale'])) {
0 ignored issues
show
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 144 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
77
            $urlLocale = $this->request->segment(1);
78
            $sessionLocale = session('locale', $defaultLocale = app('laravellocalization')->getCurrentLocale());
79
            $parameters['locale'] = app('laravellocalization')->checkLocaleInSupportedLocales($urlLocale) ? $urlLocale
80
                : (app('laravellocalization')->checkLocaleInSupportedLocales($sessionLocale) ? $sessionLocale : $defaultLocale);
0 ignored issues
show
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 128 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
81
        }
82
83
        // Bind {subdomain} route parameter
84
        if (in_array('subdomain', $route->parameterNames()) && ! isset($parameters['subdomain'])) {
85
            $parameters['subdomain'] = $route->hasParameter('subdomain') ? $route->parameter('subdomain') : explode('.', $this->request->getHost())[0];
0 ignored issues
show
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 151 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
86
        }
87
88
        return $this->routeUrl()->to(
89
            $route, $this->formatParameters($parameters), $absolute
90
        );
91
    }
92
}
93