forked from thelia-modules/Selection
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSelection.php
106 lines (89 loc) · 3.62 KB
/
Selection.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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<?php
/*************************************************************************************/
/* This file is part of the Thelia package. */
/* */
/* Copyright (c) OpenStudio */
/* email : dev@thelia.net */
/* web : http://www.thelia.net */
/* */
/* For the full copyright and license information, please view the LICENSE.txt */
/* file that was distributed with this source code. */
/*************************************************************************************/
namespace Selection;
use Propel\Runtime\Connection\ConnectionInterface;
use Selection\Model\SelectionImageQuery;
use Selection\Model\SelectionContentQuery;
use Selection\Model\SelectionProductQuery;
use Selection\Model\SelectionQuery;
use Symfony\Component\Finder\Finder;
use Thelia\Install\Database;
use Thelia\Model\Resource;
use Thelia\Model\ResourceQuery;
use Thelia\Module\BaseModule;
class Selection extends BaseModule
{
/** @var string */
const DOMAIN_NAME = 'selection';
const ROUTER = 'router.selection';
const RESOURCES_SELECTION = 'admin.selection';
const CONFIG_ALLOW_PROFILE_ID = 'admin_profile_id';
public function preActivation(ConnectionInterface $con = null)
{
$injectSql = false;
try {
$item = SelectionQuery::create()->findOne();
} catch (\Exception $ex) {
// The table does not exist
$injectSql = true;
}
if (true === $injectSql) {
$database = new Database($con);
$database->insertSql(null, [__DIR__ . '/Config/thelia.sql']);
}
return true;
}
public function postActivation(ConnectionInterface $con = null)
{
try {
SelectionQuery::create()->findOne();
SelectionProductQuery::create()->findOne();
SelectionImageQuery::create()->findOne();
SelectionContentQuery::create()->findOne();
} catch (\Exception $e) {
$database = new Database($con);
$database->insertSql(null, [__DIR__ . '/Config/thelia.sql']);
}
$this->addRessource(self::RESOURCES_SELECTION);
//Initialize the module_config
self::setConfigValue(self::CONFIG_ALLOW_PROFILE_ID, '');
}
public function destroy(ConnectionInterface $con = null, $deleteModuleData = false)
{
$database = new Database($con);
$database->insertSql(null, [__DIR__ . '/Config/destroy.sql']);
}
public function update($currentVersion, $newVersion, ConnectionInterface $con = null)
{
$finder = Finder::create()
->name('*.sql')
->depth(0)
->sortByName()
->in(__DIR__ . DS . 'Config' . DS . 'update');
$database = new Database($con);
/** @var \SplFileInfo $file */
foreach ($finder as $file) {
if (version_compare($currentVersion, $file->getBasename('.sql'), '<')) {
$database->insertSql(null, $file->getPathname());
}
}
}
protected function addRessource($code)
{
if (null === ResourceQuery::create()->findOneByCode($code)) {
$resource = new Resource();
$resource->setCode($code);
$resource->setTitle($code);
$resource->save();
}
}
}