-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathinstall.php
More file actions
70 lines (59 loc) · 2.62 KB
/
install.php
File metadata and controls
70 lines (59 loc) · 2.62 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
<?php
// Erstelle Cache-Tabelle mit rex_sql_table für bessere Updatefähigkeit
$table = rex_sql_table::get(rex::getTable('asset_import_cache'));
// Definiere die Struktur der Tabelle
$table
// Basis-Spalten
->ensureColumn(new rex_sql_column('id', 'int(10) unsigned', false, null, 'auto_increment'))
->ensureColumn(new rex_sql_column('provider', 'varchar(191)'))
->ensureColumn(new rex_sql_column('cache_key', 'varchar(32)'))
->ensureColumn(new rex_sql_column('response', 'longtext'))
->ensureColumn(new rex_sql_column('created', 'datetime'))
->ensureColumn(new rex_sql_column('valid_until', 'datetime'))
// Primary Key
->setPrimaryKey('id')
// Index für schnellere Suche
->ensureIndex(new rex_sql_index('provider_cache', ['provider', 'cache_key']));
// Erstelle oder aktualisiere die Tabelle
$table->ensure();
try {
// Hole Medientabelle
$mediaTable = rex_sql_table::get(rex::getTable('media'));
// Prüfe und füge med_copyright Spalte hinzu, wenn sie nicht existiert
if (!$mediaTable->hasColumn('med_copyright')) {
$mediaTable->addColumn(new rex_sql_column('med_copyright', 'text', true));
// Führe die Änderungen aus
$mediaTable->ensure();
}
// Prüfe ob die Metainfo-Tabelle existiert
$sql = rex_sql::factory();
$sql->setQuery('SHOW TABLES LIKE "' . rex::getTable('metainfo_field') . '"');
if ($sql->getRows() > 0) {
// Prüfe ob das Metainfo-Feld bereits existiert
$sql->setQuery('SELECT * FROM ' . rex::getTable('metainfo_field') . ' WHERE name = :name', [':name' => 'med_copyright']);
if (0 == $sql->getRows()) {
// Erstelle Metainfo Feld für med_copyright
$metaField = [
'title' => 'Copyright',
'name' => 'med_copyright',
'priority' => 3,
'attributes' => '',
'type_id' => 1, // Text Input
'params' => '',
'validate' => '',
'restrictions' => '',
'createuser' => rex::getUser()->getLogin(),
'createdate' => date('Y-m-d H:i:s'),
'updateuser' => rex::getUser()->getLogin(),
'updatedate' => date('Y-m-d H:i:s'),
];
$insert = rex_sql::factory();
$insert->setTable(rex::getTable('metainfo_field'));
$insert->setValues($metaField);
$insert->insert();
}
}
} catch (rex_sql_exception $e) {
rex_logger::factory()->log('error', 'med_copyright field creation error - ' . $e->getMessage());
throw new rex_functional_exception($e->getMessage());
}