1<?php 2/** 3 * webtrees: online genealogy 4 * Copyright (C) 2016 webtrees development team 5 * This program is free software: you can redistribute it and/or modify 6 * it under the terms of the GNU General Public License as published by 7 * the Free Software Foundation, either version 3 of the License, or 8 * (at your option) any later version. 9 * This program is distributed in the hope that it will be useful, 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 * GNU General Public License for more details. 13 * You should have received a copy of the GNU General Public License 14 * along with this program. If not, see <http://www.gnu.org/licenses/>. 15 */ 16namespace Fisharebest\Webtrees\Schema; 17 18use Fisharebest\Webtrees\Database; 19 20/** 21 * Upgrade the database schema from version 17 to version 18. 22 */ 23class Migration17 implements MigrationInterface { 24 /** 25 * Upgrade to to the next version 26 */ 27 public function upgrade() { 28 // Add table to control site access 29 Database::exec( 30 "CREATE TABLE IF NOT EXISTS `##site_access_rule` (" . 31 " site_access_rule_id INTEGER NOT NULL AUTO_INCREMENT," . 32 " ip_address_start INTEGER UNSIGNED NOT NULL DEFAULT 0," . 33 " ip_address_end INTEGER UNSIGNED NOT NULL DEFAULT 4294967295," . 34 " user_agent_pattern VARCHAR(255) NOT NULL," . 35 " rule ENUM('allow', 'deny', 'robot', 'unknown') NOT NULL DEFAULT 'unknown'," . 36 " comment VARCHAR(255) NOT NULL," . 37 " updated TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP," . 38 " PRIMARY KEY (site_access_rule_id)" . 39 ") ENGINE=InnoDB COLLATE=utf8_unicode_ci" 40 ); 41 42 Database::exec( 43 "INSERT IGNORE INTO `##site_access_rule` (user_agent_pattern, rule, comment) VALUES" . 44 " ('Mozilla/5.0 (%) Gecko/% %/%', 'allow', 'Gecko-based browsers')," . 45 " ('Mozilla/5.0 (%) AppleWebKit/% (KHTML, like Gecko)%', 'allow', 'WebKit-based browsers')," . 46 " ('Opera/% (%) Presto/% Version/%', 'allow', 'Presto-based browsers')," . 47 " ('Mozilla/% (compatible; MSIE %', 'allow', 'Trident-based browsers')," . 48 " ('Mozilla/5.0 (compatible; Konqueror/%', 'allow', 'Konqueror browser')" 49 ); 50 } 51} 52