This repository has been archived by the owner on Apr 18, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 22
/
Install.php
65 lines (51 loc) · 1.93 KB
/
Install.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
<?php namespace ostark\upper\migrations;
use craft\db\Migration;
use ostark\upper\Plugin;
/**
* Install migration.
*/
class Install extends Migration
{
/**
* @inheritdoc
*/
public function safeUp()
{
// mysql with fulltext field tags
if ($this->getDb()->getIsMysql()) {
$this->createTable(Plugin::CACHE_TABLE, [
'uid' => $this->string(40)->notNull()->unique(),
'url' => $this->string(255)->notNull(),
'headers' => $this->text()->defaultValue(null),
'tags' => $this->text()->notNull(),
'siteId' => $this->integer(),
'dateCreated' => $this->dateTime()->notNull(),
'dateUpdated' => $this->dateTime()->null()
]);
$this->createIndex('url_idx', Plugin::CACHE_TABLE, 'url', true);
$this->execute("ALTER TABLE " . Plugin::CACHE_TABLE . " ADD FULLTEXT INDEX tags_fulltext (tags ASC)");
}
// pgsql with array field tags
elseif ($this->getDb()->getIsPgsql()) {
$this->createTable(Plugin::CACHE_TABLE, [
'uid' => $this->string(40)->notNull()->unique(),
'url' => $this->string(255)->notNull(),
'headers' => $this->text()->defaultValue(null),
'tags' => 'varchar[]',
'siteId' => $this->integer(),
'dateCreated' => $this->dateTime()->notNull(),
'dateUpdated' => $this->dateTime()->null(),
'PRIMARY KEY(uid)',
]);
$this->createIndex('url_idx', Plugin::CACHE_TABLE, 'url', true);
$this->execute("CREATE INDEX tags_array ON " . Plugin::CACHE_TABLE . " USING GIN(tags)");
}
}
/**
* @inheritdoc
*/
public function safeDown()
{
$this->dropTableIfExists(Plugin::CACHE_TABLE);
}
}