Passed
Push — master ( ece31d...41b8a6 )
by Paul
10:20 queued 04:17
created

Upgrade_4_0_0::migrateSettings()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 19
Code Lines 17

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 12

Importance

Changes 2
Bugs 0 Features 1
Metric Value
cc 3
eloc 17
nc 3
nop 0
dl 0
loc 19
ccs 0
cts 19
cp 0
crap 12
rs 9.7
c 2
b 0
f 1
1
<?php
2
3
namespace GeminiLabs\SiteReviews\Modules\Upgrader;
4
5
use GeminiLabs\SiteReviews\Application;
6
use GeminiLabs\SiteReviews\Database\OptionManager;
7
use GeminiLabs\SiteReviews\Defaults\CreateReviewDefaults;
8
use GeminiLabs\SiteReviews\Helper;
9
10
class Upgrade_4_0_0
11
{
12
    public function __construct()
13
    {
14
        $this->migrateSettings();
15
        $this->protectMetaKeys();
16
        $this->deleteSessions();
17
        delete_transient(Application::ID.'_cloudflare_ips');
18
    }
19
20
    /**
21
     * @return void
22
     */
23
    public function deleteSessions()
24
    {
25
        global $wpdb;
26
        $wpdb->query("
27
            DELETE
28
            FROM {$wpdb->options}
29
            WHERE option_name LIKE '_glsr_session%'
30
        ");
31
    }
32
33
    /**
34
     * @return void
35
     */
36
    public function migrateSettings()
37
    {
38
        if ($settings = get_option(OptionManager::databaseKey(3))) {
39
            $multilingual = 'yes' == glsr(Helper::class)->dataGet($settings, 'settings.general.support.polylang')
40
                ? 'polylang'
41
                : '';
42
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.general.multilingual', $multilingual);
43
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.general.rebusify', 'no');
44
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.general.rebusify_email', '');
45
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.general.rebusify_serial', '');
46
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.reviews.name.format', '');
47
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.reviews.name.initial', '');
48
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.submissions.blacklist.integration', '');
49
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.submissions.limit', '');
50
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.submissions.limit_whitelist.email', '');
51
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.submissions.limit_whitelist.ip_address', '');
52
            $settings = glsr(Helper::class)->dataSet($settings, 'settings.submissions.limit_whitelist.username', '');
53
            unset($settings['settings']['general']['support']);
54
            update_option(OptionManager::databaseKey(4), $settings);
55
        }
56
    }
57
58
    /**
59
     * @return void
60
     */
61
    public function protectMetaKeys()
62
    {
63
        global $wpdb;
64
        $keys = array_keys(glsr(CreateReviewDefaults::class)->defaults());
65
        $keys = implode("','", $keys);
66
        $postType = Application::POST_TYPE;
67
        $wpdb->query("
68
            UPDATE {$wpdb->postmeta} pm
69
            INNER JOIN {$wpdb->posts} p ON p.id = pm.post_id
70
            SET pm.meta_key = CONCAT('_', pm.meta_key)
71
            WHERE pm.meta_key IN ('{$keys}')
72
            AND p.post_type = '{$postType}'
73
        ");
74
    }
75
}
76