<?php
/**
* This software is intended for use with Oxwall Free Community Software http://www.oxwall.org/ and is
* licensed under The BSD license.
* ---
* Copyright (c) 2011, Oxwall Foundation
* All rights reserved.
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
* following conditions are met:
*
* - Redistributions of source code must retain the above copyright notice, this list of conditions and
* the following disclaimer.
*
* - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and
* the following disclaimer in the documentation and/or other materials provided with the distribution.
*
* - Neither the name of the Oxwall Foundation nor the names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
$config = OW::getConfig();
if ( !$config->configExists('forum', 'enable_attachments') )
{
$config->addConfig('forum', 'enable_attachments', 1, 'Enable file attachments');
}
if ( !$config->configExists('forum', 'uninstall_inprogress') )
{
$config->addConfig('forum', 'uninstall_inprogress', 0, 'Plugin is being uninstalled');
}
if ( !$config->configExists('forum', 'uninstall_cron_busy') )
{
$config->addConfig('forum', 'uninstall_cron_busy', 0, 'Uninstall queue is busy');
}
if ( !$config->configExists('forum', 'update_search_index_cron_busy') )
{
$config->addConfig('forum', 'update_search_index_cron_busy', 0, 'Update search index queue is busy');
}
if ( !$config->configExists('forum', 'delete_search_index_cron') )
{
$config->addConfig('forum', 'delete_search_index_cron', 0, 'Delete search index');
}
if ( !$config->configExists('forum', 'maintenance_mode_state') )
{
$state = (int) $config->getValue('base', 'maintenance');
$config->addConfig('forum', 'maintenance_mode_state', $state, 'Stores site maintenance mode config before plugin uninstallation');
}
$dbPref = OW_DB_PREFIX;
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_edit_post` (
`id` int(11) NOT NULL auto_increment,
`postId` int(11) NOT NULL,
`userId` int(11) NOT NULL,
`editStamp` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `postId` (`postId`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_group` (
`id` int(11) NOT NULL auto_increment,
`sectionId` int(11) NOT NULL,
`name` text NOT NULL,
`description` text NOT NULL,
`order` int(11) NOT NULL,
`entityId` int(11) default NULL,
`isPrivate` TINYINT(1) NULL DEFAULT '0',
`roles` TEXT NULL DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `sectionId` (`sectionId`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_post` (
`id` int(11) NOT NULL auto_increment,
`topicId` int(11) NOT NULL,
`userId` int(11) NOT NULL,
`text` text NOT NULL,
`createStamp` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `topicId` (`topicId`),
KEY `createStamp` (`createStamp`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_post_attachment` (
`id` int(11) NOT NULL auto_increment,
`postId` int(11) NOT NULL,
`hash` varchar(13) NOT NULL,
`fileName` varchar(255) NOT NULL,
`fileNameClean` VARCHAR(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`fileSize` int(10) NOT NULL default '0',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_read_topic` (
`id` int(11) NOT NULL auto_increment,
`topicId` int(11) NOT NULL,
`userId` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `topicId` (`topicId`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_section` (
`id` int(11) NOT NULL auto_increment,
`name` text NOT NULL,
`order` int(11) NOT NULL,
`entity` varchar(255) default NULL,
`isHidden` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_topic` (
`id` int(11) NOT NULL auto_increment,
`groupId` int(11) NOT NULL,
`userId` int(11) NOT NULL,
`title` text NOT NULL,
`locked` tinyint(1) NOT NULL default '0',
`sticky` tinyint(1) NOT NULL default '0',
`temp` TINYINT(1) NOT NULL DEFAULT '0',
`viewCount` int(11) NOT NULL default '0',
`lastPostId` int(11) NOT NULL default '0',
`status` enum('approval','approved') NOT NULL DEFAULT 'approved',
PRIMARY KEY (`id`),
KEY `groupId` (`groupId`),
KEY `lastPostId` (`lastPostId`),
KEY `status` (`status`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_subscription` (
`id` int(11) NOT NULL auto_increment,
`userId` int(11) NOT NULL,
`topicId` int(11) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `userId` (`userId`,`topicId`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
// Add default section
$sql = "INSERT INTO `".$dbPref."forum_section`
(`name`, `order`, `entity`, `isHidden`)
VALUES ('General', 1, NULL, 0);";
$sectionId = OW::getDbo()->insert($sql);
if ( $sectionId )
{
// Default group
$sql = "INSERT INTO `".$dbPref."forum_group`
(`sectionId`, `name`, `description`, `order`, `entityId`)
VALUES (".$sectionId.", 'General Chat', 'Just about anything', 1, NULL);";
$groupId = OW::getDbo()->insert($sql);
}
$sql = "CREATE TABLE IF NOT EXISTS `".$dbPref."forum_update_search_index` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`type` varchar(50) NOT NULL,
`entityId` int(10) unsigned NOT NULL,
`lastEntityId` int(10) unsigned DEFAULT NULL,
`priority` tinyint(1) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (`id`)
) ENGINE=MyIsam DEFAULT CHARSET=utf8;";
OW::getDbo()->query($sql);
OW::getPluginManager()->addPluginSettingsRouteName('forum', 'forum_admin_config');
OW::getPluginManager()->addUninstallRouteName('forum', 'forum_uninstall');
$authorization = OW::getAuthorization();
$groupName = 'forum';
$authorization->addGroup($groupName);
$authorization->addAction($groupName, 'view', true);
$authorization->addAction($groupName, 'edit');
$authorization->addAction($groupName, 'subscribe');
$path = OW::getPluginManager()->getPlugin('forum')->getRootDir() . 'langs.zip';
OW::getLanguage()->importPluginLangs($path, 'forum');