forked from symphonycms/selectbox_link_field
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathextension.driver.php
More file actions
93 lines (79 loc) · 2.23 KB
/
extension.driver.php
File metadata and controls
93 lines (79 loc) · 2.23 KB
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
<?php
Class extension_selectbox_link_field extends Extension{
public function about(){
return array('name' => 'Field: Select Box Link',
'version' => '1.18',
'release-date' => '2010-02-02',
'author' => array('name' => 'Symphony Team',
'website' => 'http://www.symphony-cms.com',
'email' => 'team@symphony-cms.com')
);
}
public function uninstall(){
if(parent::uninstall() == true){
Symphony::Database()->query("DROP TABLE `tbl_fields_selectbox_link`");
return true;
}
return false;
}
public function update($previousVersion){
try{
if(version_compare($previousVersion, '1.6', '<')){
Symphony::Database()->query(
"ALTER TABLE `tbl_fields_selectbox_link`
ADD `limit` INT(4) UNSIGNED NOT NULL DEFAULT '20'"
);
}
}
catch(Exception $e){
// Discard
}
if(version_compare($previousVersion, '1.15', '<')){
try{
$fields = Symphony::Database()->fetchCol('field_id',
"SELECT `field_id` FROM `tbl_fields_selectbox_link`"
);
}
catch(Exception $e){
// Discard
}
if(is_array($fields) && !empty($fields)){
foreach($fields as $field_id){
try{
Symphony::Database()->query(
"ALTER TABLE `tbl_entries_data_{$field_id}`
CHANGE `relation_id` `relation_id` INT(11) UNSIGNED NULL DEFAULT NULL"
);
}
catch(Exception $e){
// Discard
}
}
}
}
try{
Symphony::Database()->query("ALTER TABLE `tbl_fields_selectbox_link` CHANGE `related_field_id` `related_field_id` VARCHAR(255) NOT NULL");
}
catch(Exception $e){
// Discard
}
return true;
}
public function install(){
try{
Symphony::Database()->query("CREATE TABLE IF NOT EXISTS `tbl_fields_selectbox_link` (
`id` int(11) unsigned NOT NULL auto_increment,
`field_id` int(11) unsigned NOT NULL,
`allow_multiple_selection` enum('yes','no') NOT NULL default 'no',
`related_field_id` VARCHAR(255) NOT NULL,
`limit` int(4) unsigned NOT NULL default '20',
PRIMARY KEY (`id`),
KEY `field_id` (`field_id`)
)");
}
catch(Exception $e){
return false;
}
return true;
}
}