1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381 |
- /* ATTENTION: You don't need to run or use this file! The upgrade.php script does everything for you! */
- /******************************************************************************/
- --- Adding Open ID support.
- /******************************************************************************/
- ---# Adding Open ID Assocation table...
- CREATE TABLE {$db_prefix}openid_assoc (
- server_url text NOT NULL,
- handle varchar(255) NOT NULL,
- secret text NOT NULL,
- issued int NOT NULL,
- expires int NOT NULL,
- assoc_type varchar(64) NOT NULL,
- PRIMARY KEY (server_url, handle)
- );
- ---#
- /******************************************************************************/
- --- Updating custom fields.
- /******************************************************************************/
- ---# Adding search ability to custom fields.
- ---{
- if ($smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}custom_fields
- ADD COLUMN can_search smallint");
- upgrade_query("
- UPDATE {$db_prefix}custom_fields
- SET can_search = 0");
- upgrade_query("
- ALTER TABLE {$db_prefix}custom_fields
- ALTER COLUMN can_search SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}custom_fields
- ALTER COLUMN can_search SET default '0'");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}custom_fields
- ADD COLUMN can_search smallint NOT NULL default '0'");
- }
- ---}
- ---#
- ---# Enhancing privacy settings for custom fields.
- ---{
- if (isset($modSettings['smfVersion']) && $modSettings['smfVersion'] <= '2.0 Beta 1')
- {
- upgrade_query("
- UPDATE {$db_prefix}custom_fields
- SET private = 2
- WHERE private = 1");
- }
- if (isset($modSettings['smfVersion']) && $modSettings['smfVersion'] < '2.0 Beta 4')
- {
- upgrade_query("
- UPDATE {$db_prefix}custom_fields
- SET private = 3
- WHERE private = 2");
- }
- ---}
- ---#
- ---# Changing default_values column to a larger field type...
- ALTER TABLE {$db_prefix}custom_fields
- ALTER COLUMN default_value TYPE varchar(255);
- ---#
- ---# Adding new custom fields columns.
- ALTER TABLE {$db_prefix}custom_fields
- ADD enclose text NOT NULL;
- ALTER TABLE {$db_prefix}custom_fields
- ADD placement smallint NOT NULL default '0';
- ---#
- ---# Fixing default value for the "show_profile" column
- ALTER TABLE {$db_prefix}custom_fields
- ALTER COLUMN show_profile SET DEFAULT 'forumprofile';
- UPDATE {$db_prefix}custom_fields
- SET show_profile='forumprofile' WHERE show_profile='forumProfile';
- ---#
- /******************************************************************************/
- --- Adding new board specific features.
- /******************************************************************************/
- ---# Implementing board redirects.
- ---{
- if ($db_type == 'postgresql' && $smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}boards
- ADD COLUMN redirect varchar(255)");
- upgrade_query("
- UPDATE {$db_prefix}boards
- SET redirect = ''");
- upgrade_query("
- ALTER TABLE {$db_prefix}boards
- ALTER COLUMN redirect SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}boards
- ALTER COLUMN redirect SET default ''");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}boards
- ADD COLUMN redirect varchar(255) NOT NULL DEFAULT ''");
- }
- ---}
- ---#
- /******************************************************************************/
- --- Adding search engine tracking.
- /******************************************************************************/
- ---# Creating spider sequence.
- CREATE SEQUENCE {$db_prefix}spiders_seq;
- ---#
- ---# Creating spider table.
- CREATE TABLE {$db_prefix}spiders (
- id_spider smallint NOT NULL default nextval('{$db_prefix}spiders_seq'),
- spider_name varchar(255) NOT NULL,
- user_agent varchar(255) NOT NULL,
- ip_info varchar(255) NOT NULL,
- PRIMARY KEY (id_spider)
- );
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (1, 'Google', 'googlebot', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (2, 'Yahoo!', 'slurp', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (3, 'MSN', 'msnbot', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (4, 'Google (Mobile)', 'Googlebot-Mobile', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (5, 'Google (Image)', 'Googlebot-Image', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (6, 'Google (AdSense)', 'Mediapartners-Google', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (7, 'Google (Adwords)', 'AdsBot-Google', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (8, 'Yahoo! (Mobile)', 'YahooSeeker/M1A1-R2D2', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (9, 'Yahoo! (Image)', 'Yahoo-MMCrawler', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (10, 'MSN (Mobile)', 'MSNBOT_Mobile', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (11, 'MSN (Media)', 'msnbot-media', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (12, 'Cuil', 'twiceler', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (13, 'Ask', 'Teoma', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (14, 'Baidu', 'Baiduspider', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (15, 'Gigablast', 'Gigabot', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (16, 'InternetArchive', 'ia_archiver-web.archive.org', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (17, 'Alexa', 'ia_archiver', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (18, 'Omgili', 'omgilibot', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (19, 'EntireWeb', 'Speedy Spider', '');
- INSERT INTO {$db_prefix}spiders (id_spider, spider_name, user_agent, ip_info) VALUES (20, 'Yandex', 'yandex', '');
- ---#
- ---# Removing a spider.
- ---{
- upgrade_query("
- DELETE FROM {$db_prefix}spiders
- WHERE user_agent = 'yahoo'
- AND spider_name = 'Yahoo! (Publisher)'
- ");
- ---}
- ---#
- ---# Sequence for table log_spider_hits.
- CREATE SEQUENCE {$db_prefix}log_spider_hits_seq;
- ---#
- ---# Creating spider hit tracking table.
- CREATE TABLE {$db_prefix}log_spider_hits (
- id_hit int default nextval('{$db_prefix}log_spider_hits_seq'),
- id_spider smallint NOT NULL default '0',
- log_time int NOT NULL,
- url varchar(255) NOT NULL,
- processed smallint NOT NULL default '0'
- );
- CREATE INDEX {$db_prefix}log_spider_hits_id_spider ON {$db_prefix}log_spider_hits (id_spider);
- CREATE INDEX {$db_prefix}log_spider_hits_log_time ON {$db_prefix}log_spider_hits (log_time);
- CREATE INDEX {$db_prefix}log_spider_hits_processed ON {$db_prefix}log_spider_hits (processed);
- ---#
- ---# Creating spider statistic table.
- CREATE TABLE {$db_prefix}log_spider_stats (
- id_spider smallint NOT NULL default '0',
- page_hits smallint NOT NULL default '0',
- last_seen int NOT NULL default '0',
- stat_date date NOT NULL default '0001-01-01',
- PRIMARY KEY (stat_date, id_spider)
- );
- ---#
- /******************************************************************************/
- --- Adding new forum settings.
- /******************************************************************************/
- ---# Enable cache if upgrading from 2.0 beta 1 and lower.
- ---{
- if (isset($modSettings['smfVersion']) && $modSettings['smfVersion'] <= '2.0 Beta 1')
- {
- $request = upgrade_query("
- SELECT value
- FROM {$db_prefix}settings
- WHERE variable = 'cache_enable'");
- list ($cache_enable) = $smcFunc['db_fetch_row']($request);
- // No cache before
- if ($smcFunc['db_num_rows']($request) == 0)
- upgrade_query("
- INSERT INTO {$db_prefix}settings
- (variable, value)
- VALUES ('cache_enable', '1')");
- elseif (empty($cache_enable))
- upgrade_query("
- UPDATE {$db_prefix}settings
- SET value = '1'
- WHERE variable = 'cache_enable'");
- }
- ---}
- ---#
- ---# Ensuring forum width setting present...
- ---{
- // Don't do this twice!
- $smcFunc['db_insert']('ignore',
- '{db_prefix}themes',
- array('id_theme' => 'int', 'variable' => 'string-255', 'value' => 'string-255'),
- array(1, 'forum_width', '90%'),
- array('id_theme', 'variable', 'value')
- );
- ---}
- ---#
- /******************************************************************************/
- --- Adding misc functionality.
- /******************************************************************************/
- ---# Converting "log_online".
- ALTER TABLE {$db_prefix}log_online DROP CONSTRAINT {$db_prefix}log_online_log_time;
- ALTER TABLE {$db_prefix}log_online DROP CONSTRAINT {$db_prefix}log_online_id_member;
- DROP TABLE {$db_prefix}log_online;
- CREATE TABLE {$db_prefix}log_online (
- session varchar(32) NOT NULL default '',
- log_time int NOT NULL default '0',
- id_member int NOT NULL default '0',
- id_spider smallint NOT NULL default '0',
- ip int NOT NULL default '0',
- url text NOT NULL,
- PRIMARY KEY (session)
- );
- CREATE INDEX {$db_prefix}log_online_log_time ON {$db_prefix}log_online (log_time);
- CREATE INDEX {$db_prefix}log_online_id_member ON {$db_prefix}log_online (id_member);
- ---#
- ---# Adding guest voting - part 1...
- ---{
- if ($smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ADD COLUMN guest_vote smallint");
- upgrade_query("
- UPDATE {$db_prefix}polls
- SET guest_vote = 0");
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ALTER COLUMN guest_vote SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ALTER COLUMN guest_vote SET default '0'");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ADD COLUMN guest_vote smallint NOT NULL default '0'");
- }
- ---}
- ---#
- ---# Adding guest voting - part 2...
- DELETE FROM {$db_prefix}log_polls
- WHERE id_member < 0;
- ALTER TABLE {$db_prefix}log_polls DROP CONSTRAINT {$db_prefix}log_polls_pkey;
- CREATE INDEX {$db_prefix}log_polls_id_poll ON {$db_prefix}log_polls (id_poll, id_member, id_choice);
- ---#
- ---# Adding admin log...
- ---{
- if ($db_type == 'postgresql' && $smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}log_actions
- ADD COLUMN id_log smallint");
- upgrade_query("
- UPDATE {$db_prefix}log_actions
- SET id_log = 1");
- upgrade_query("
- ALTER TABLE {$db_prefix}log_actions
- ALTER COLUMN id_log SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}log_actions
- ALTER COLUMN id_log SET default '1'");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}log_actions
- ADD COLUMN id_log smallint NOT NULL default '1'");
- }
- ---}
- ---#
- ---# Adding search ability to custom fields.
- ---{
- if ($smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}members
- ADD COLUMN passwd_flood varchar(12)");
- upgrade_query("
- UPDATE {$db_prefix}members
- SET passwd_flood = ''");
- upgrade_query("
- ALTER TABLE {$db_prefix}members
- ALTER COLUMN passwd_flood SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}members
- ALTER COLUMN passwd_flood SET default ''");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}members
- ADD COLUMN passwd_flood varchar(12) NOT NULL default ''");
- }
- ---}
- ---#
- /******************************************************************************/
- --- Adding weekly maintenance task.
- /******************************************************************************/
- ---# Adding weekly maintenance task...
- INSERT INTO {$db_prefix}scheduled_tasks (next_time, time_offset, time_regularity, time_unit, disabled, task) VALUES (0, 0, 1, 'w', 0, 'weekly_maintenance');
- ---#
- ---# Setting the birthday email template if not set...
- ---{
- if (!isset($modSettings['birthday_email']))
- {
- upgrade_query("
- INSERT INTO {$db_prefix}settings
- (variable, value)
- VALUES
- ('birthday_email', 'happy_birthday')");
- }
- ---}
- ---#
- /******************************************************************************/
- --- Adding log pruning.
- /******************************************************************************/
- ---# Adding pruning option...
- INSERT INTO {$db_prefix}settings (variable, value) VALUES ('pruningOptions', '30,180,180,180,30');
- ---#
- /******************************************************************************/
- --- Updating mail queue functionality.
- /******************************************************************************/
- ---# Adding private to mail queue...
- ---{
- if ($smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}mail_queue
- ADD COLUMN private smallint");
- upgrade_query("
- UPDATE {$db_prefix}mail_queue
- SET private = 0");
- upgrade_query("
- ALTER TABLE {$db_prefix}mail_queue
- ALTER COLUMN private SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}mail_queue
- ALTER COLUMN private SET default '0'");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}mail_queue
- ADD COLUMN private smallint NOT NULL default '0'");
- }
- ---}
- ---#
- /******************************************************************************/
- --- Updating attachments.
- /******************************************************************************/
- ---# Adding multiple attachment path functionality.
- ---{
- if ($smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}attachments
- ADD COLUMN id_folder smallint");
- upgrade_query("
- UPDATE {$db_prefix}attachments
- SET id_folder = 1");
- upgrade_query("
- ALTER TABLE {$db_prefix}attachments
- ALTER COLUMN id_folder SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}attachments
- ALTER COLUMN id_folder SET default '1'");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}attachments
- ADD COLUMN id_folder smallint NOT NULL default '1'");
- }
- ---}
- ---#
- ---# Adding file hash.
- ---{
- upgrade_query("
- ALTER TABLE {$db_prefix}attachments
- ADD COLUMN file_hash varchar(40) NOT NULL default ''");
- ---}
- ---#
- /******************************************************************************/
- --- Adding restore topic from recycle.
- /******************************************************************************/
- ---# Adding restore topic from recycle feature...
- ---{
- if ($db_type == 'postgresql' && $smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}topics
- ADD COLUMN id_previous_board smallint");
- upgrade_query("
- ALTER TABLE {$db_prefix}topics
- ADD COLUMN id_previous_topic int");
- upgrade_query("
- UPDATE {$db_prefix}topics
- SET
- id_previous_board = 0,
- id_previous_topic = 0");
- upgrade_query("
- ALTER TABLE {$db_prefix}topics
- ALTER COLUMN id_previous_board SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}topics
- ALTER COLUMN id_previous_topic SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}topics
- ALTER COLUMN id_previous_board SET default '0'");
- upgrade_query("
- ALTER TABLE {$db_prefix}topics
- ALTER COLUMN id_previous_topic SET default '0'");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}topics
- ADD COLUMN id_previous_board smallint NOT NULL default '0'");
- upgrade_query("
- ALTER TABLE {$db_prefix}topics
- ADD COLUMN id_previous_topic int NOT NULL default '0'");
- }
- ---}
- ---#
- /******************************************************************************/
- --- Making changes to the package manager.
- /******************************************************************************/
- ---# Changing URL to SMF package server...
- UPDATE {$db_prefix}package_servers
- SET url = 'http://custom.simplemachines.org/packages/mods'
- WHERE url = 'http://mods.simplemachines.org';
- ---#
- /******************************************************************************/
- --- Adding new indexes to the topics table.
- /******************************************************************************/
- ---# Adding index member_started...
- CREATE INDEX {$db_prefix}topics_member_started ON {$db_prefix}topics (id_member_started, id_board);
- ---#
- ---# Adding index last_message_sticky...
- CREATE INDEX {$db_prefix}topics_last_message_sticky ON {$db_prefix}topics (id_board, is_sticky, id_last_msg);
- ---#
- ---# Adding index board_news...
- CREATE INDEX {$db_prefix}topics_board_news ON {$db_prefix}topics (id_board, id_first_msg);
- ---#
- /******************************************************************************/
- --- Adding new indexes to members table.
- /******************************************************************************/
- ---# Adding index on total_time_logged_in...
- CREATE INDEX {$db_prefix}members_total_time_logged_in ON {$db_prefix}members (total_time_logged_in);
- ---#
- ---# Adding index on id_theme...
- CREATE INDEX {$db_prefix}members_id_theme ON {$db_prefix}members (id_theme);
- ---#
- ---# Adding index on real_name...
- CREATE INDEX {$db_prefix}members_real_name ON {$db_prefix}members (real_name);
- ---#
- /******************************************************************************/
- --- Adding new indexes to messages table.
- /******************************************************************************/
- ---# Adding index id_member_msg...
- CREATE INDEX {$db_prefix}messages_id_member_msg ON {$db_prefix}messages (id_member, approved, id_msg);
- ---#
- ---# Adding index current_topic...
- CREATE INDEX {$db_prefix}messages_current_topic ON {$db_prefix}messages (id_topic, id_msg, id_member, approved);
- ---#
- ---# Adding index related_ip...
- CREATE INDEX {$db_prefix}messages_related_ip ON {$db_prefix}messages (id_member, poster_ip, id_msg);
- ---#
- /******************************************************************************/
- --- Adding new indexes to attachments table.
- /******************************************************************************/
- ---# Adding index on attachment_type...
- CREATE INDEX {$db_prefix}attachments_attachment_type ON {$db_prefix}attachments (attachment_type);
- ---#
- /******************************************************************************/
- --- Providing more room for ignoring boards.
- /******************************************************************************/
- ---# Changing ignore_boards column to a larger field type...
- ALTER TABLE {$db_prefix}members
- ALTER COLUMN ignore_boards TYPE text;
- ---#
- /******************************************************************************/
- --- Adding default values to a couple of columns in log_subscribed
- /******************************************************************************/
- ---# Adding default value for pending_details column
- ALTER TABLE {$db_prefix}log_subscribed
- ALTER COLUMN pending_details
- SET DEFAULT '';
- ---#
- ---# Adding default value for vendor_ref column
- ALTER TABLE {$db_prefix}log_subscribed
- ALTER COLUMN vendor_ref
- SET DEFAULT '';
- ---#
- /*****************************************************************************/
- --- Fixing aim on members for longer nicks.
- /*****************************************************************************/
- ---# Changing 'aim' to varchar to allow using email...
- ALTER TABLE {$db_prefix}members
- ALTER COLUMN aim TYPE varchar(255);
- ALTER TABLE {$db_prefix}members
- ALTER COLUMN aim SET DEFAULT '';
- ---#
- /*****************************************************************************/
- --- Fixing column types in log_errors
- /*****************************************************************************/
- ---# Changing 'ip' from char to varchar
- ALTER TABLE {$db_prefix}log_errors
- ALTER COLUMN ip TYPE varchar(16);
- ALTER TABLE {$db_prefix}log_errors
- ALTER COLUMN ip SET DEFAULT '';
- ---#
- ---# Changing 'error_type' from char to varchar
- ALTER TABLE {$db_prefix}log_errors
- ALTER COLUMN error_type TYPE varchar(15);
- ---#
- /******************************************************************************/
- --- Allow for longer calendar event/holiday titles.
- /******************************************************************************/
- ---# Changing event title column to a larger field type...
- ALTER TABLE {$db_prefix}calendar
- ALTER COLUMN title TYPE varchar(255);
- ---#
- ---# Changing holiday title column to a larger field type...
- ALTER TABLE {$db_prefix}calendar_holidays
- ALTER COLUMN title TYPE varchar(255);
- ---#
- /******************************************************************************/
- --- Providing more room for apf options.
- /******************************************************************************/
- ---# Changing field_options column to a larger field type...
- ALTER TABLE {$db_prefix}custom_fields
- ALTER COLUMN field_options TYPE text;
- ---#
- /******************************************************************************/
- --- Adding extra columns to polls.
- /******************************************************************************/
- ---# Adding reset poll timestamp and guest voters counter.
- ---{
- if ($smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ADD COLUMN reset_poll int");
- upgrade_query("
- UPDATE {$db_prefix}polls
- SET reset_poll = '0'
- WHERE reset_poll < 1");
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ALTER COLUMN reset_poll SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ALTER COLUMN reset_poll SET default '0'");
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ADD COLUMN num_guest_voters int");
- upgrade_query("
- UPDATE {$db_prefix}polls
- SET num_guest_voters = '0'
- WHERE num_guest_voters < 1");
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ALTER COLUMN num_guest_voters SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ALTER COLUMN num_guest_voters SET default '0'");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ADD COLUMN reset_poll int NOT NULL default '0'");
- upgrade_query("
- ALTER TABLE {$db_prefix}polls
- ADD COLUMN num_guest_voters int NOT NULL default '0'");
- }
- ---}
- ---#
- ---# Fixing guest voter tallys on existing polls...
- ---{
- $request = upgrade_query("
- SELECT p.id_poll, count(lp.id_member) as guest_voters
- FROM {$db_prefix}polls AS p
- LEFT JOIN {$db_prefix}log_polls AS lp ON (lp.id_poll = p.id_poll AND lp.id_member = 0)
- WHERE lp.id_member = 0
- AND p.num_guest_voters = 0
- GROUP BY p.id_poll");
- while ($request && $row = $smcFunc['db_fetch_assoc']($request))
- upgrade_query("
- UPDATE {$db_prefix}polls
- SET num_guest_voters = ". $row['guest_voters']. "
- WHERE id_poll = " . $row['id_poll'] . "
- AND num_guest_voters = 0");
- ---}
- ---#
- /*****************************************************************************/
- --- Fixing a bug with the inet_aton() function.
- /*****************************************************************************/
- ---# Changing inet_aton function to use bigint instead of int...
- CREATE OR REPLACE FUNCTION INET_ATON(text) RETURNS bigint AS
- 'SELECT
- CASE WHEN
- $1 !~ ''^[0-9]?[0-9]?[0-9]?\.[0-9]?[0-9]?[0-9]?\.[0-9]?[0-9]?[0-9]?\.[0-9]?[0-9]?[0-9]?$'' THEN 0
- ELSE
- split_part($1, ''.'', 1)::int8 * (256 * 256 * 256) +
- split_part($1, ''.'', 2)::int8 * (256 * 256) +
- split_part($1, ''.'', 3)::int8 * 256 +
- split_part($1, ''.'', 4)::int8
- END AS result'
- LANGUAGE 'sql';
- ---#
- /*****************************************************************************/
- --- Making additional changes to handle results from fixed inet_aton().
- /*****************************************************************************/
- ---# Adding an IFNULL to handle 8-bit integers returned by inet_aton
- CREATE OR REPLACE FUNCTION IFNULL(int8, int8) RETURNS int8 AS
- 'SELECT COALESCE($1, $2) AS result'
- LANGUAGE 'sql';
- ---#
- ---# Changing ip column in log_online to int8
- ALTER TABLE {$db_prefix}log_online
- ALTER COLUMN ip TYPE int8;
- ---#
- /******************************************************************************/
- --- Dropping unnecessary indexes...
- /******************************************************************************/
- ---# Removing index on hits...
- ---{
- $smcFunc['db_remove_index']($db_prefix . 'log_activity', $db_prefix . 'log_activity_hits');
- ---}
- ---#
- /******************************************************************************/
- --- Adding new personal message setting.
- /******************************************************************************/
- ---# Adding column that stores the PM receiving setting...
- ---{
- upgrade_query("
- ALTER TABLE {$db_prefix}members
- ADD COLUMN pm_receive_from smallint NOT NULL default '1'");
- ---}
- ---#
- ---# Enable the buddy and ignore lists if we have not done so thus far...
- ---{
- // Don't do this if we've done this already.
- if (empty($modSettings['dont_repeat_buddylists']))
- {
- // Make sure the pm_receive_from column has the right default value - early adoptors might have a '0' set here.
- upgrade_query("
- ALTER TABLE {$db_prefix}members
- ALTER COLUMN pm_receive_from SET DEFAULT '1'");
- // Update previous ignore lists if they're set to ignore all.
- upgrade_query("
- UPDATE {$db_prefix}members
- SET pm_receive_from = 3, pm_ignore_list = ''
- WHERE pm_ignore_list = '*'");
- // Enable buddy and ignore lists.
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('enable_buddylist', '1'),
- array('variable', 'value')
- );
- // Ignore posts made by ignored users by default, too.
- $smcFunc['db_insert']('replace',
- '{db_prefix}themes',
- array('id_member' => 'int', 'id_theme' => 'int', 'variable' => 'string-255', 'value' => 'string-255'),
- array(-1, 1, 'posts_apply_ignore_list', '1'),
- array('id_member', 'id_theme', 'variable', 'value')
- );
- // Make sure not to skip this step next time we run this.
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('dont_repeat_buddylists', '1'),
- array('variable', 'value')
- );
- }
- // And yet, and yet... We might have a small hiccup here...
- if (!empty($modSettings['dont_repeat_buddylists']) && !isset($modSettings['enable_buddylist']))
- {
- // Correct RC3 adopters setting here...
- if (isset($modSettings['enable_buddylists']))
- {
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('enable_buddylist', $modSettings['enable_buddylists']),
- array('variable', 'value')
- );
- }
- else
- {
- // This should never happen :)
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('enable_buddylist', '1'),
- array('variable', 'value')
- );
- }
- }
- ---}
- ---#
- /******************************************************************************/
- --- Adding settings for attachments and avatars.
- /******************************************************************************/
- ---# Add new security settings for attachments and avatars...
- ---{
- // Don't do this if we've done this already.
- if (!isset($modSettings['attachment_image_reencode']))
- {
- // Enable image re-encoding by default.
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('attachment_image_reencode', '1'),
- array('variable', 'value')
- );
- }
- if (!isset($modSettings['attachment_image_paranoid']))
- {
- // Disable draconic checks by default.
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('attachment_image_paranoid', '0'),
- array('variable', 'value')
- );
- }
- if (!isset($modSettings['avatar_reencode']))
- {
- // Enable image re-encoding by default.
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('avatar_reencode', '1'),
- array('variable', 'value')
- );
- }
- if (!isset($modSettings['avatar_paranoid']))
- {
- // Disable draconic checks by default.
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('avatar_paranoid', '0'),
- array('variable', 'value')
- );
- }
- ---}
- ---#
- ---# Add other attachment settings...
- ---{
- if (!isset($modSettings['attachment_thumb_png']))
- {
- // Make image attachment thumbnail as PNG by default.
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('attachment_thumb_png', '1'),
- array('variable', 'value')
- );
- }
- ---}
- ---#
- /******************************************************************************/
- --- Installing new default theme...
- /******************************************************************************/
- ---# Installing theme settings...
- ---{
- // This is Grudge's secret "I'm not a developer" theme install code - keep this quiet ;)
- // Firstly, I'm going out of my way to not do this twice!
- if ((!isset($modSettings['smfVersion']) || $modSettings['smfVersion'] <= '2.0 RC2') && empty($modSettings['dont_repeat_theme_core']))
- {
- // Check it's not already here, just in case.
- $theme_request = upgrade_query("
- SELECT id_theme
- FROM {$db_prefix}themes
- WHERE variable = 'theme_dir'
- AND value LIKE '%core'");
- // Only do the upgrade if it doesn't find the theme already.
- if ($smcFunc['db_num_rows']($theme_request) == 0)
- {
- // Try to get some settings from the current default theme.
- $request = upgrade_query("
- SELECT t1.value AS theme_dir, t2.value AS theme_url, t3.value AS images_url
- FROM ({$db_prefix}themes AS t1, {$db_prefix}themes AS t2, {$db_prefix}themes AS t3)
- WHERE t1.id_theme = 1
- AND t1.id_member = 0
- AND t1.variable = 'theme_dir'
- AND t2.id_theme = 1
- AND t2.id_member = 0
- AND t2.variable = 'theme_url'
- AND t3.id_theme = 1
- AND t3.id_member = 0
- AND t3.variable = 'images_url'
- LIMIT 1");
- if ($smcFunc['db_num_rows']($request) != 0)
- {
- $curve = $smcFunc['db_fetch_assoc']($request);
- if (substr_count($curve['theme_dir'], 'default') === 1)
- $core['theme_dir'] = strtr($curve['theme_dir'], array('default' => 'core'));
- if (substr_count($curve['theme_url'], 'default') === 1)
- $core['theme_url'] = strtr($curve['theme_url'], array('default' => 'core'));
- if (substr_count($curve['images_url'], 'default') === 1)
- $core['images_url'] = strtr($curve['images_url'], array('default' => 'core'));
- }
- $smcFunc['db_free_result']($request);
- if (!isset($core['theme_dir']))
- $core['theme_dir'] = addslashes($GLOBALS['boarddir']) . '/Themes/core';
- if (!isset($core['theme_url']))
- $core['theme_url'] = $GLOBALS['boardurl'] . '/Themes/core';
- if (!isset($core['images_url']))
- $core['images_url'] = $GLOBALS['boardurl'] . '/Themes/core/images';
- // Get an available id_theme first...
- $request = upgrade_query("
- SELECT MAX(id_theme) + 1
- FROM {$db_prefix}themes");
- list ($id_core_theme) = $smcFunc['db_fetch_row']($request);
- $smcFunc['db_free_result']($request);
- // Insert the core theme into the tables.
- $smcFunc['db_insert']('ignore',
- '{db_prefix}themes',
- array('id_member' => 'int', 'id_theme' => 'int', 'variable' => 'string-255', 'value' => 'string-255'),
- array(
- array(0, $id_core_theme, 'name', 'Core Theme'),
- array(0, $id_core_theme, 'theme_url', $core['theme_url']),
- array(0, $id_core_theme, 'images_url', $core['images_url']),
- array(0, $id_core_theme, 'theme_dir', $core['theme_dir'])
- ),
- array()
- );
- // Update the name of the default theme in the database.
- upgrade_query("
- UPDATE {$db_prefix}themes
- SET value = 'SMF Default Theme - Curve'
- WHERE id_theme = 1
- AND variable = 'name'");
- $newSettings = array();
- // Now that we have the old theme details - switch anyone who used the default to it (Make sense?!)
- if (!empty($modSettings['theme_default']) && $modSettings['theme_default'] == 1)
- $newSettings[] = "('theme_default', $id_core_theme)";
- // Did guests use to use the default?
- if (!empty($modSettings['theme_guests']) && $modSettings['theme_guests'] == 1)
- $newSettings[] = "('theme_guests', $id_core_theme)";
- // If known themes aren't set, let's just pick all themes available.
- if (empty($modSettings['knownThemes']))
- {
- $request = upgrade_query("
- SELECT DISTINCT id_theme
- FROM {$db_prefix}themes");
- $themes = array();
- while ($row = $smcFunc['db_fetch_assoc']($request))
- $themes[] = $row['id_theme'];
- $modSettings['knownThemes'] = implode(',', $themes);
- upgrade_query("
- UPDATE {$db_prefix}settings
- SET value = '$modSettings[knownThemes]'
- WHERE variable = 'knownThemes'");
- }
- // Known themes.
- $allThemes = explode(',', $modSettings['knownThemes']);
- $allThemes[] = $id_core_theme;
- $newSettings[] = "('knownThemes', '" . implode(',', $allThemes) . "')";
- // Since we want to do a replace, just delete the old settings and re-insert them
- upgrade_query("
- DELETE FROM {$db_prefix}settings
- WHERE variable IN ('theme_default', 'theme_guests', 'knownThemes')");
- foreach ($new_settings AS $a_new_setting)
- {
- upgrade_query("
- INSERT INTO {$db_prefix}settings
- (variable, value)
- VALUES " . implode(', ', $a_new_setting));
- }
- // What about members?
- upgrade_query("
- UPDATE {$db_prefix}members
- SET id_theme = $id_core_theme
- WHERE id_theme = 1");
- // Boards?
- upgrade_query("
- UPDATE {$db_prefix}boards
- SET id_theme = $id_core_theme
- WHERE id_theme = 1");
- // The other themes used to use core as their base theme.
- if (isset($core['theme_dir']) && isset($core['theme_url']))
- {
- $coreBasedThemes = array_diff($allThemes, array(1));
- // Exclude the themes that already have a base_theme_dir.
- $request = upgrade_query("
- SELECT DISTINCT id_theme
- FROM {$db_prefix}themes
- WHERE variable = 'base_theme_dir'");
- while ($row = $smcFunc['db_fetch_assoc']($request))
- $coreBasedThemes = array_diff($coreBasedThemes, array($row['id_theme']));
- $smcFunc['db_free_result']($request);
- // Only base themes if there are templates that need a fall-back.
- $insertRows = array();
- $request = upgrade_query("
- SELECT id_theme, value AS theme_dir
- FROM {$db_prefix}themes
- WHERE id_theme IN (" . implode(', ', $coreBasedThemes) . ")
- AND id_member = 0
- AND variable = 'theme_dir'");
- while ($row = $smcFunc['db_fetch_assoc']($request))
- {
- if (!file_exists($row['theme_dir'] . '/BoardIndex.template.php') || !file_exists($row['theme_dir'] . '/Display.template.php') || !file_exists($row['theme_dir'] . '/index.template.php') || !file_exists($row['theme_dir'] . '/MessageIndex.template.php') || !file_exists($row['theme_dir'] . '/Settings.template.php'))
- {
- $insertRows[] = "(0, $row[id_theme], 'base_theme_dir', '" . addslashes($core['theme_dir']) . "')";
- $insertRows[] = "(0, $row[id_theme], 'base_theme_url', '" . addslashes($core['theme_url']) . "')";
- }
- }
- $smcFunc['db_free_result']($request);
- if (!empty($insertRows))
- upgrade_query("
- INSERT IGNORE INTO {$db_prefix}themes
- (id_member, id_theme, variable, value)
- VALUES
- " . implode(',
- ', $insertRows));
- }
- }
- $smcFunc['db_free_result']($theme_request);
- // This ain't running twice either - not with the risk of log_tables timing us all out!
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('dont_repeat_theme_core', '1'),
- array('variable', 'value')
- );
- }
- ---}
- ---#
- /******************************************************************************/
- --- Installing new smileys sets...
- /******************************************************************************/
- ---# Installing new smiley sets...
- ---{
- // Don't do this twice!
- if (empty($modSettings['installed_new_smiley_sets_20']))
- {
- // First, the entries.
- upgrade_query("
- UPDATE {$db_prefix}settings
- SET value = CONCAT(value, ',aaron,akyhne')
- WHERE variable = 'smiley_sets_known'");
- // Second, the names.
- upgrade_query("
- UPDATE {$db_prefix}settings
- SET value = CONCAT(value, '\nAaron\nAkyhne')
- WHERE variable = 'smiley_sets_names'");
- // This ain't running twice either.
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('installed_new_smiley_sets_20', '1'),
- array('variable', 'value')
- );
- }
- ---}
- ---#
- /*****************************************************************************/
- --- Adding additional functions
- /*****************************************************************************/
- ---# Adding instr()
- ---{
- if ($smcFunc['db_server_info'] < 8.2)
- {
- $request = upgrade_query("
- SELECT type_udt_name
- FROM information_schema.routines
- WHERE routine_name = 'inet_aton'
- ");
- // Assume there's only one such function called inet_aton()
- $return_type = $smcFunc['db_fetch_assoc']($request);
- // No point in dropping and recreating it if it's already what we want
- if ($return_type['type_udt_name'] != 'int4')
- {
- upgrade_query("
- DROP FUNCTION INSTR(text, text)");
- }
- }
- else
- {
- upgrade_query("
- DROP FUNCTION IF EXISTS INSTR(text, text)");
- }
- ---}
- CREATE OR REPLACE FUNCTION INSTR(text, text) RETURNS integer AS
- 'SELECT POSITION($2 IN $1) AS result'
- LANGUAGE 'sql';
- ---#
- ---# Adding date_format()
- CREATE OR REPLACE FUNCTION DATE_FORMAT (timestamp, text) RETURNS text AS '
- SELECT
- REPLACE(
- REPLACE($2, ''%m'', to_char($1, ''MM'')),
- ''%d'', to_char($1, ''DD'')) AS result'
- LANGUAGE 'sql';
- ---#
- ---# Adding day()
- CREATE OR REPLACE FUNCTION day(date) RETURNS integer AS
- 'SELECT EXTRACT(DAY FROM DATE($1))::integer AS result'
- LANGUAGE 'sql';
- ---#
- ---# Adding IFNULL(varying, varying)
- CREATE OR REPLACE FUNCTION IFNULL (character varying, character varying) RETURNS character varying AS
- 'SELECT COALESCE($1, $2) AS result'
- LANGUAGE 'sql';
- ---#
- ---# Adding IFNULL(varying, bool)
- CREATE OR REPLACE FUNCTION IFNULL(character varying, boolean) RETURNS character varying AS
- 'SELECT COALESCE($1, CAST(CAST($2 AS int) AS varchar)) AS result'
- LANGUAGE 'sql';
- ---#
- ---# Adding IFNULL(int, bool)
- CREATE OR REPLACE FUNCTION IFNULL(int, boolean) RETURNS int AS
- 'SELECT COALESCE($1, CAST($2 AS int)) AS result'
- LANGUAGE 'sql';
- ---#
- ---# Adding bool_not_eq_int()
- CREATE OR REPLACE FUNCTION bool_not_eq_int (boolean, integer) RETURNS boolean AS
- 'SELECT CAST($1 AS integer) != $2 AS result'
- LANGUAGE 'sql';
- ---#
- ---# Creating operator bool_not_eq_int()
- ---{
- $result = upgrade_query("SELECT oprname FROM pg_operator WHERE oprcode='bool_not_eq_int'::regproc");
- if($smcFunc['db_num_rows']($result) == 0)
- {
- upgrade_query("
- CREATE OPERATOR != (PROCEDURE = bool_not_eq_int, LEFTARG = boolean, RIGHTARG = integer)");
- }
- ---}
- ---#
- ---# Recreating function FIND_IN_SET()
- ---{
- if ($smcFunc['db_server_info'] < 8.2)
- {
- $query = upgrade_query("SELECT * FROM pg_proc WHERE proname = 'find_in_set' AND proargtypes = '25 25'");
- if ($smcFunc['db_num_rows']($query) != 0)
- {
- upgrade_query("DROP FUNCTION FIND_IN_SET(text, text)");
- }
- $query = upgrade_query("SELECT * FROM pg_proc WHERE proname = 'find_in_set' AND proargtypes = '23 1043'");
- if ($smcFunc['db_num_rows']($query) != 0)
- {
- upgrade_query("DROP FUNCTION FIND_IN_SET(integer, character varying)");
- }
- }
- else
- {
- upgrade_query("DROP FUNCTION IF EXISTS FIND_IN_SET(text, text)");
- upgrade_query("DROP FUNCTION IF EXISTS FIND_IN_SET(integer, character varying)");
- }
- ---}
- CREATE OR REPLACE FUNCTION FIND_IN_SET(needle text, haystack text) RETURNS integer AS '
- SELECT i AS result
- FROM generate_series(1, array_upper(string_to_array($2,'',''), 1)) AS g(i)
- WHERE (string_to_array($2,'',''))[i] = $1
- UNION ALL
- SELECT 0
- LIMIT 1'
- LANGUAGE 'sql';
- CREATE OR REPLACE FUNCTION FIND_IN_SET(needle integer, haystack text) RETURNS integer AS '
- SELECT i AS result
- FROM generate_series(1, array_upper(string_to_array($2,'',''), 1)) AS g(i)
- WHERE (string_to_array($2,'',''))[i] = CAST($1 AS text)
- UNION ALL
- SELECT 0
- LIMIT 1'
- LANGUAGE 'sql';
- ---#
- CREATE OR REPLACE FUNCTION DATE_FORMAT (timestamp, text) RETURNS text AS '
- SELECT
- REPLACE(
- REPLACE($2, ''%m'', to_char($1, ''MM'')),
- ''%d'', to_char($1, ''DD'')) AS result'
- LANGUAGE 'sql';
- ---# Updating TO_DAYS()
- CREATE OR REPLACE FUNCTION TO_DAYS (timestamp) RETURNS integer AS
- 'SELECT DATE_PART(''DAY'', $1 - ''0001-01-01bc'')::integer AS result'
- LANGUAGE 'sql';
- ---#
- /******************************************************************************/
- --- Adding extra columns to reported post comments
- /******************************************************************************/
- ---# Adding email address and member ip columns...
- ---{
- if ($smcFunc['db_server_info'] < 8.0)
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}log_reported_comments
- ADD COLUMN email_address varchar(255)");
- upgrade_query("
- UPDATE {$db_prefix}log_reported_comments
- SET email_address = ''");
- upgrade_query("
- ALTER TABLE {$db_prefix}log_reported_comments
- ALTER COLUMN email_address SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}log_reported_comments
- ALTER COLUMN email_address SET default ''");
- upgrade_query("
- ALTER TABLE {$db_prefix}log_reported_comments
- ADD COLUMN member_ip varchar(255)");
- upgrade_query("
- UPDATE {$db_prefix}log_reported_comments
- SET member_ip = ''");
- upgrade_query("
- ALTER TABLE {$db_prefix}log_reported_comments
- ALTER COLUMN member_ip SET NOT NULL");
- upgrade_query("
- ALTER TABLE {$db_prefix}log_reported_comments
- ALTER COLUMN member_ip SET default ''");
- }
- else
- {
- upgrade_query("
- ALTER TABLE {$db_prefix}log_reported_comments
- ADD COLUMN email_address varchar(255) NOT NULL default ''");
- upgrade_query("
- ALTER TABLE {$db_prefix}log_reported_comments
- ADD COLUMN member_ip varchar(255) NOT NULL default ''");
- }
- ---}
- ---#
- /******************************************************************************/
- --- Adjusting group types.
- /******************************************************************************/
- ---# Fixing the group types.
- ---{
- // Get the admin group type.
- $request = upgrade_query("
- SELECT group_type
- FROM {$db_prefix}membergroups
- WHERE id_group = 1
- LIMIT 1");
- list ($admin_group_type) = pg_fetch_row($request);
- pg_free_result($request);
- // Not protected means we haven't updated yet!
- if ($admin_group_type != 1)
- {
- // Increase by one.
- upgrade_query("
- UPDATE {$db_prefix}membergroups
- SET group_type = group_type + 1
- WHERE group_type > 0");
- }
- ---}
- ---#
- ---# Changing the group type for Administrator group.
- UPDATE {$db_prefix}membergroups
- SET group_type = 1
- WHERE id_group = 1;
- ---#
- /******************************************************************************/
- --- Adjusting calendar maximum year.
- /******************************************************************************/
- ---# Adjusting calendar maximum year.
- ---{
- if (!isset($modSettings['cal_maxyear']) || $modSettings['cal_maxyear'] == '2010')
- {
- $smcFunc['db_insert']('replace',
- '{db_prefix}settings',
- array('variable' => 'string-255', 'value' => 'string-255'),
- array('cal_maxyear', '2020'),
- array('variable', 'value')
- );
- }
- ---}
- ---#
|