GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Completed
Branch develop (0737e3)
by Maximilian
11:49
created

Ma27ApiKeyAuthenticationExtension::loadPassword()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 8
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 8
rs 9.4285
c 0
b 0
f 0
ccs 5
cts 5
cp 1
cc 1
eloc 5
nc 1
nop 3
crap 1
1
<?php
2
3
namespace Ma27\ApiKeyAuthenticationBundle\DependencyInjection;
4
5
use Symfony\Component\Config\FileLocator;
6
use Symfony\Component\DependencyInjection\Alias;
7
use Symfony\Component\DependencyInjection\ContainerBuilder;
8
use Symfony\Component\DependencyInjection\Loader;
9
use Symfony\Component\HttpKernel\DependencyInjection\Extension;
10
11
/**
12
 * This is the class that loads and manages your bundle configuration.
13
 *
14
 * To learn more see {@link http://symfony.com/doc/current/cookbook/bundles/extension.html}
15
 */
16
class Ma27ApiKeyAuthenticationExtension extends Extension
17
{
18
    /**
19
     * {@inheritdoc}
20
     */
21 6
    public function load(array $configs, ContainerBuilder $container)
22
    {
23 6
        $configuration = new Configuration();
24 6
        $config = $this->processConfiguration($configuration, $configs);
25
26 6
        $container->setParameter('ma27_api_key_authentication.key_header', $config['key_header']);
27 6
        $container->setParameter('ma27_api_key_authentication.response_values', $config['response']);
28 6
29 6
        $loader = new Loader\YamlFileLoader($container, new FileLocator(__DIR__.'/../Resources/config'));
30 6
31
        $this->loadCore($container, $loader, $config['user']);
32 6
        $this->loadServices($loader);
33
34 6
        if ($this->isConfigEnabled($container, $config['api_key_purge'])) {
35 6
            $this->loadApiKeyPurger($container, $loader, $config['api_key_purge']);
36
        }
37 6
38 2
        $services = array_filter($config['services']);
39 2
        if (!empty($services)) {
40
            $this->overrideServices($container, $services);
41 6
        }
42 6
43 1
        if ($config['user']['metadata_cache']) {
44 1
            $cacheDir = $container->getParameter('kernel.cache_dir');
45 6
46
            $container->getDefinition('ma27_api_key_authentication.class_metadata_factory')
47
                ->replaceArgument(3, sprintf('%s/ma27_api_key_authentication/metadata_dump', $cacheDir));
48
        }
49
    }
50
51
    /**
52
     * Loads the user and core related stuff of the bundle.
53
     *
54 6
     * @param ContainerBuilder      $container
55
     * @param Loader\YamlFileLoader $loader
56 6
     * @param array                 $config
57 6
     */
58 6
    private function loadCore(ContainerBuilder $container, Loader\YamlFileLoader $loader, $config)
59
    {
60 6
        $isCacheEnabled = $config['metadata_cache'];
61 6
62
        $container->setParameter('ma27_api_key_authentication.model_name', $config['model_name']);
63
        $container->setParameter('ma27_api_key_authentication.object_manager', $config['object_manager']);
64
        $container->setParameter('ma27_api_key_authentication.property.apiKeyLength', $config['api_key_length']);
65
        $container->setParameter('ma27_api_key_authentication.metadata_cache_enabled', $isCacheEnabled);
66
67
        if ($isCacheEnabled) {
68 6
            $loader->load('metadata_cache_warmer.yml');
69
        }
70 6
71 6
        $this->loadPassword($container, $config['password'], $loader);
72 6
    }
73 6
74
    /**
75
     * Loads the password strategy.
76
     *
77
     * @param ContainerBuilder      $container
78
     * @param string                $passwordConfig
79
     * @param Loader\YamlFileLoader $loader
80
     */
81
    private function loadPassword(ContainerBuilder $container, $passwordConfig, Loader\YamlFileLoader $loader)
82 2
    {
83
        $container->setParameter('ma27_api_key_authentication.password_hashing_service', $passwordConfig['strategy']);
84 2
        $container->setParameter('ma27_api_key_authentication.password_hasher.phpass.iteration_length', 8);
85 2
        $container->setParameter('ma27_api_key_authentication.password_hasher.php55.cost', 12);
86
87 2
        $loader->load('hashers.yml');
88 2
    }
89 2
90 2
    /**
91
     * Loads all internal services.
92
     *
93
     * @param Loader\YamlFileLoader $loader
94
     */
95
    private function loadServices(Loader\YamlFileLoader $loader)
96
    {
97
        foreach (array('security_key', 'authentication', 'security', 'annotation') as $file) {
98 1
            $loader->load(sprintf('%s.yml', $file));
99
        }
100
    }
101 1
102 1
    /**
103 1
     * Loads the purger job command into the container.
104
     *
105 1
     * @param ContainerBuilder      $container
106 1
     * @param Loader\YamlFileLoader $loader
107 1
     * @param string[]              $purgerConfig
108
     */
109
    private function loadApiKeyPurger(ContainerBuilder $container, Loader\YamlFileLoader $loader, array $purgerConfig)
110 1
    {
111 1
        $container->setParameter('ma27_api_key_authentication.cleanup_command.date_time_rule', $purgerConfig['outdated_rule']);
112 1
        $loader->load('session_cleanup.yml');
113 1
114
        if ($this->isConfigEnabled($container, $purgerConfig['last_action_listener'])) {
0 ignored issues
show
Documentation introduced by
$purgerConfig['last_action_listener'] is of type string, but the function expects a array.

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...
115
            $loader->load('last_action_listener.yml');
116
        }
117
    }
118
119
    /**
120
     * Processes the service override configuration into the container.
121
     *
122
     * @param ContainerBuilder $container
123
     * @param array            $services
124
     */
125
    private function overrideServices(ContainerBuilder $container, array $services)
126
    {
127
        $serviceConfig = array(
128
            'auth_handler' => 'ma27_api_key_authentication.auth_handler',
129
            'key_factory'  => 'ma27_api_key_authentication.key_factory',
130
        );
131
132
        foreach ($serviceConfig as $configIndex => $replaceableServiceId) {
133
            if (!isset($services[$configIndex]) || null === $serviceId = $services[$configIndex]) {
134
                continue;
135
            }
136
137
            $container->removeDefinition($replaceableServiceId);
138
            $container->setAlias($replaceableServiceId, new Alias($serviceId));
139
        }
140
    }
141
}
142