-
Notifications
You must be signed in to change notification settings - Fork 3
/
WbmQueryManager.php
78 lines (66 loc) · 2.45 KB
/
WbmQueryManager.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<?php
/**
* Query Manager
* Copyright (c) Webmatch GmbH
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
namespace WbmQueryManager;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Shopware\Components\Plugin\Context\ActivateContext;
use Shopware\Components\Plugin\Context\InstallContext;
use Shopware\Components\Plugin\Context\UpdateContext;
/**
* Class WbmQueryManager
* @package WbmQueryManager
*/
class WbmQueryManager extends \Shopware\Components\Plugin
{
/**
* @param ContainerBuilder $container
*/
public function build(ContainerBuilder $container)
{
$container->setParameter('wbm_query_manager.plugin_dir', $this->getPath());
parent::build($container);
}
/**
* @param InstallContext $context
*/
public function install(InstallContext $context)
{
$sql = file_get_contents($this->getPath() . '/Resources/sql/install.sql');
$this->container->get('shopware.db')->query($sql, array($context->getPlugin()->getId()));
}
/**
* @param ActivateContext $context
*/
public function activate(ActivateContext $context)
{
$context->scheduleClearCache(InstallContext::CACHE_LIST_ALL);
}
/**
* @param UpdateContext $context
*/
public function update(UpdateContext $context)
{
if(version_compare($context->getCurrentVersion(), '2.0.0', '<')) {
$sql = "ALTER TABLE `wbm_query_manager` CHANGE `interval` `interval_int` INT(11) NULL DEFAULT '0';
ALTER TABLE `wbm_query_manager` CHANGE `sql` `sql_string` LONGTEXT NOT NULL;";
$this->container->get('shopware.db')->query($sql);
}
if(version_compare($context->getCurrentVersion(), '2.0.3', '<')) {
$sql = "ALTER TABLE `wbm_query_manager` ADD `mail_recipient` VARCHAR (255) NULL DEFAULT NULL AFTER `last_run`;";
$this->container->get('shopware.db')->query($sql);
}
$context->scheduleClearCache(InstallContext::CACHE_LIST_ALL);
}
}