Passed
Push — master ( 702f24...55adc1 )
by Yannick
09:28
created

SecuritySettingsSchema::settingArrayHelpValue()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 24
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 7
nc 2
nop 1
dl 0
loc 24
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
/* For licensing terms, see /license.txt */
6
7
namespace Chamilo\CoreBundle\Settings;
8
9
use Chamilo\CoreBundle\Form\Type\YesNoType;
10
use Sylius\Bundle\SettingsBundle\Schema\AbstractSettingsBuilder;
11
use Symfony\Component\Form\Extension\Core\Type\TextareaType;
12
use Symfony\Component\Form\Extension\Core\Type\TextType;
13
use Symfony\Component\Form\FormBuilderInterface;
14
15
class SecuritySettingsSchema extends AbstractSettingsSchema
16
{
17
    public function buildSettings(AbstractSettingsBuilder $builder): void
18
    {
19
        $builder->setDefaults([
20
            'filter_terms' => '',
21
            'admins_can_set_users_pass' => '',
22
            'allow_strength_pass_checker' => 'true',
23
            'allow_captcha' => 'false',
24
            'user_reset_password' => 'false',
25
            'user_reset_password_token_limit' => '3600',
26
            'captcha_number_mistakes_to_block_account' => '',
27
            'captcha_time_to_block' => '',
28
            'prevent_multiple_simultaneous_login' => 'false',
29
            'check_password' => 'false',
30
            'security_strict_transport' => 'strict-transport-security: max-age=31536000; includeSubDomains',
31
            'security_content_policy' => "default-src 'self'; script-src 'self' 'unsafe-eval' 'unsafe-inline'; style-src 'self' 'unsafe-inline'; child-src 'self' *.youtube.com yt.be *.vimeo.com *.slideshare.com;",
32
            'security_content_policy_report_only' => "default-src 'self'; script-src *://*.google.com:*",
33
            'security_public_key_pins' => '',
34
            'security_public_key_pins_report_only' => '',
35
            'security_x_frame_options' => 'SAMEORIGIN',
36
            'security_xss_protection' => '1; mode=block',
37
            'security_x_content_type_options' => 'nosniff',
38
            'security_referrer_policy' => 'origin-when-cross-origin',
39
            'security_block_inactive_users_immediately' => 'false',
40
            'password_requirements' => '',
41
            'allow_online_users_by_status' => '',
42
            'security_session_cookie_samesite_none' => 'false',
43
            'anonymous_autoprovisioning' => 'false',
44
            'access_to_personal_file_for_all' => 'false',
45
        ]);
46
47
        $allowedTypes = [
48
            'allow_strength_pass_checker' => ['string'],
49
        ];
50
        $this->setMultipleAllowedTypes($allowedTypes, $builder);
51
    }
52
53
    public function buildForm(FormBuilderInterface $builder): void
54
    {
55
        $builder
56
            ->add('filter_terms', TextareaType::class)
57
            ->add('admins_can_set_users_pass', YesNoType::class)
58
            ->add('allow_strength_pass_checker', YesNoType::class)
59
            ->add('allow_captcha', YesNoType::class)
60
            ->add('user_reset_password', YesNoType::class)
61
            ->add('user_reset_password_token_limit')
62
            ->add('captcha_number_mistakes_to_block_account', TextType::class)
63
            ->add('captcha_time_to_block')
64
            ->add('prevent_multiple_simultaneous_login', YesNoType::class)
65
            ->add('check_password', YesNoType::class)
66
            ->add('security_strict_transport', TextType::class)
67
            ->add('security_content_policy', TextType::class)
68
            ->add('security_content_policy_report_only', TextType::class)
69
            ->add('security_public_key_pins', TextType::class)
70
            ->add('security_public_key_pins_report_only', TextType::class)
71
            ->add('security_x_frame_options', TextType::class)
72
            ->add('security_xss_protection', TextType::class)
73
            ->add('security_x_content_type_options', TextType::class)
74
            ->add('security_referrer_policy', TextType::class)
75
            ->add('security_block_inactive_users_immediately', YesNoType::class)
76
            ->add('password_requirements', TextareaType::class)
77
            ->add('allow_online_users_by_status', TextareaType::class)
78
            ->add('security_session_cookie_samesite_none', YesNoType::class)
79
            ->add('anonymous_autoprovisioning', YesNoType::class)
80
            ->add('access_to_personal_file_for_all', YesNoType::class)
81
        ;
82
83
        $this->updateFormFieldsFromSettingsInfo($builder);
84
    }
85
}
86