You've already forked Arcturus-Morningstar-Extended
mirror of
https://github.com/duckietm/Arcturus-Morningstar-Extended.git
synced 2026-06-19 15:06:19 +00:00
343 lines
12 KiB
SQL
343 lines
12 KiB
SQL
-- ============================================================
|
|
-- Custom Prefix System - Complete Setup (safe upgrade version)
|
|
-- ============================================================
|
|
|
|
-- Questo script è pensato per essere rieseguito senza errori
|
|
-- anche se le tabelle esistono già con una struttura parziale.
|
|
|
|
-- ------------------------------------------------------------
|
|
-- 1. Main user prefixes table
|
|
-- ------------------------------------------------------------
|
|
CREATE TABLE IF NOT EXISTS `user_prefixes` (
|
|
`id` INT(11) NOT NULL AUTO_INCREMENT,
|
|
`user_id` INT(11) NOT NULL,
|
|
`text` VARCHAR(50) NOT NULL,
|
|
`color` VARCHAR(255) NOT NULL DEFAULT '#FFFFFF',
|
|
`icon` VARCHAR(50) NOT NULL DEFAULT '',
|
|
`effect` VARCHAR(50) NOT NULL DEFAULT '',
|
|
`font` VARCHAR(50) NOT NULL DEFAULT '',
|
|
`catalog_prefix_id` INT(11) NOT NULL DEFAULT 0,
|
|
`display_name` VARCHAR(100) NOT NULL DEFAULT '',
|
|
`points` INT(11) NOT NULL DEFAULT 0,
|
|
`points_type` INT(11) NOT NULL DEFAULT 0,
|
|
`is_custom` TINYINT(1) NOT NULL DEFAULT 1,
|
|
`active` TINYINT(1) NOT NULL DEFAULT 0,
|
|
PRIMARY KEY (`id`),
|
|
INDEX `idx_user_id` (`user_id`),
|
|
INDEX `idx_user_active` (`user_id`, `active`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
|
|
|
|
-- ------------------------------------------------------------
|
|
-- 2. Catalog table
|
|
-- ------------------------------------------------------------
|
|
CREATE TABLE IF NOT EXISTS `custom_prefixes_catalog` (
|
|
`id` INT(11) NOT NULL AUTO_INCREMENT,
|
|
`display_name` VARCHAR(100) NOT NULL DEFAULT '',
|
|
`text` VARCHAR(50) NOT NULL,
|
|
`color` VARCHAR(255) NOT NULL DEFAULT '#FFFFFF',
|
|
`icon` VARCHAR(50) NOT NULL DEFAULT '',
|
|
`effect` VARCHAR(50) NOT NULL DEFAULT '',
|
|
`font` VARCHAR(50) NOT NULL DEFAULT '',
|
|
`points` INT(11) NOT NULL DEFAULT 0,
|
|
`points_type` INT(11) NOT NULL DEFAULT 0,
|
|
`enabled` TINYINT(1) NOT NULL DEFAULT 1,
|
|
`sort_order` INT(11) NOT NULL DEFAULT 0,
|
|
PRIMARY KEY (`id`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
|
|
|
|
-- ------------------------------------------------------------
|
|
-- 3. User visual settings
|
|
-- ------------------------------------------------------------
|
|
CREATE TABLE IF NOT EXISTS `user_visual_settings` (
|
|
`user_id` INT(11) NOT NULL,
|
|
`display_order` VARCHAR(50) NOT NULL DEFAULT 'icon-prefix-name',
|
|
PRIMARY KEY (`user_id`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
|
|
|
|
-- ------------------------------------------------------------
|
|
-- 4. Prefix settings table
|
|
-- ------------------------------------------------------------
|
|
CREATE TABLE IF NOT EXISTS `custom_prefix_settings` (
|
|
`key_name` VARCHAR(100) NOT NULL,
|
|
`value` VARCHAR(255) NOT NULL,
|
|
PRIMARY KEY (`key_name`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
|
|
|
|
|
|
-- ============================================================
|
|
-- Schema upgrades for existing installations
|
|
-- ============================================================
|
|
|
|
-- ------------------------------------------------------------
|
|
-- user_prefixes: add missing columns safely
|
|
-- ------------------------------------------------------------
|
|
|
|
SET @dbname = DATABASE();
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'user_prefixes'
|
|
AND COLUMN_NAME = 'font'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `user_prefixes` ADD COLUMN `font` VARCHAR(50) NOT NULL DEFAULT '''' AFTER `effect`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'user_prefixes'
|
|
AND COLUMN_NAME = 'catalog_prefix_id'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `user_prefixes` ADD COLUMN `catalog_prefix_id` INT(11) NOT NULL DEFAULT 0 AFTER `font`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'user_prefixes'
|
|
AND COLUMN_NAME = 'display_name'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `user_prefixes` ADD COLUMN `display_name` VARCHAR(100) NOT NULL DEFAULT '''' AFTER `catalog_prefix_id`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'user_prefixes'
|
|
AND COLUMN_NAME = 'points'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `user_prefixes` ADD COLUMN `points` INT(11) NOT NULL DEFAULT 0 AFTER `display_name`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'user_prefixes'
|
|
AND COLUMN_NAME = 'points_type'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `user_prefixes` ADD COLUMN `points_type` INT(11) NOT NULL DEFAULT 0 AFTER `points`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'user_prefixes'
|
|
AND COLUMN_NAME = 'is_custom'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `user_prefixes` ADD COLUMN `is_custom` TINYINT(1) NOT NULL DEFAULT 1 AFTER `points_type`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
-- ------------------------------------------------------------
|
|
-- custom_prefixes_catalog: add missing columns safely
|
|
-- ------------------------------------------------------------
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'custom_prefixes_catalog'
|
|
AND COLUMN_NAME = 'font'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `custom_prefixes_catalog` ADD COLUMN `font` VARCHAR(50) NOT NULL DEFAULT '''' AFTER `effect`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'custom_prefixes_catalog'
|
|
AND COLUMN_NAME = 'points'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `custom_prefixes_catalog` ADD COLUMN `points` INT(11) NOT NULL DEFAULT 0 AFTER `font`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'custom_prefixes_catalog'
|
|
AND COLUMN_NAME = 'points_type'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `custom_prefixes_catalog` ADD COLUMN `points_type` INT(11) NOT NULL DEFAULT 0 AFTER `points`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'custom_prefixes_catalog'
|
|
AND COLUMN_NAME = 'enabled'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `custom_prefixes_catalog` ADD COLUMN `enabled` TINYINT(1) NOT NULL DEFAULT 1 AFTER `points_type`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
SET @sql = (
|
|
SELECT IF(
|
|
EXISTS(
|
|
SELECT 1
|
|
FROM INFORMATION_SCHEMA.COLUMNS
|
|
WHERE TABLE_SCHEMA = @dbname
|
|
AND TABLE_NAME = 'custom_prefixes_catalog'
|
|
AND COLUMN_NAME = 'sort_order'
|
|
),
|
|
'SELECT 1',
|
|
'ALTER TABLE `custom_prefixes_catalog` ADD COLUMN `sort_order` INT(11) NOT NULL DEFAULT 0 AFTER `enabled`'
|
|
)
|
|
);
|
|
PREPARE stmt FROM @sql;
|
|
EXECUTE stmt;
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
-- ============================================================
|
|
-- Default settings
|
|
-- ============================================================
|
|
INSERT IGNORE INTO `custom_prefix_settings` (`key_name`, `value`) VALUES
|
|
('max_length', '15'),
|
|
('min_rank_to_buy', '1'),
|
|
('price_credits', '5'),
|
|
('price_points', '0'),
|
|
('points_type', '0'),
|
|
('font_price_credits', '10'),
|
|
('font_price_points', '0'),
|
|
('font_points_type', '0');
|
|
|
|
-- ============================================================
|
|
-- Default catalog entries
|
|
-- ============================================================
|
|
INSERT IGNORE INTO `custom_prefixes_catalog`
|
|
(`id`, `display_name`, `text`, `color`, `icon`, `effect`, `font`, `points`, `points_type`, `enabled`, `sort_order`) VALUES
|
|
(1, 'VIP', 'VIP', '#FFD700', '', 'glow', '', 10, 0, 1, 1),
|
|
(2, 'Legend', 'Legend', '#8B5CF6', '', 'discord-neon', '', 15, 0, 1, 2),
|
|
(3, 'Staff Pick', 'Staff', '#3B82F6', '*', 'cartoon', '', 20, 0, 1, 3);
|
|
|
|
|
|
-- ============================================================
|
|
-- Notes
|
|
-- ============================================================
|
|
-- Preset prefixes for `:customize` are loaded directly by
|
|
-- UserNickIconsComposer and displayed inside the `:customize` panel.
|
|
--
|
|
-- This setup does not require rows in `catalog_pages`.
|
|
--
|
|
-- Command texts / permission inserts are intentionally omitted
|
|
-- for compatibility with both legacy and normalized permission schemas.
|
|
|
|
INSERT IGNORE INTO `emulator_texts` (`key`, `value`) VALUES
|
|
-- GivePrefix command
|
|
('commands.description.cmd_give_prefix', ':giveprefix <username> <text> <color> [icon] [effect]'),
|
|
('commands.keys.cmd_give_prefix', 'giveprefix'),
|
|
('commands.error.cmd_give_prefix.usage', 'Usage: :giveprefix <username> <text> <color> [icon] [effect]'),
|
|
('commands.error.cmd_give_prefix.invalid_color', 'Invalid color format. Use hex format (#FF0000).'),
|
|
('commands.error.cmd_give_prefix.too_long', 'Prefix text is too long (max 15 characters).'),
|
|
('commands.error.cmd_give_prefix.user_not_found', 'User not found or not online.'),
|
|
('commands.succes.cmd_give_prefix', 'Prefix {%prefix%} successfully given to %user%!'),
|
|
-- ListPrefixes command
|
|
('commands.description.cmd_list_prefixes', ':listprefixes <username>'),
|
|
('commands.keys.cmd_list_prefixes', 'listprefixes'),
|
|
('commands.error.cmd_list_prefixes.usage', 'Usage: :listprefixes <username>'),
|
|
('commands.error.cmd_list_prefixes.user_not_found', 'User not found or not online.'),
|
|
('commands.succes.cmd_list_prefixes.header', 'Prefixes of %user%:'),
|
|
('commands.succes.cmd_list_prefixes.empty', '%user% has no prefixes.'),
|
|
-- RemovePrefix command
|
|
('commands.description.cmd_remove_prefix', ':removeprefix <username> <id|all>'),
|
|
('commands.keys.cmd_remove_prefix', 'removeprefix'),
|
|
('commands.error.cmd_remove_prefix.usage', 'Usage: :removeprefix <username> <id|all>'),
|
|
('commands.error.cmd_remove_prefix.user_not_found', 'User not found or not online.'),
|
|
('commands.error.cmd_remove_prefix.invalid_id', 'Invalid prefix ID. Must be a number or "all".'),
|
|
('commands.error.cmd_remove_prefix.not_found', 'Prefix not found for this user.'),
|
|
('commands.succes.cmd_remove_prefix', 'Prefix #%id% removed from %user%.'),
|
|
('commands.succes.cmd_remove_prefix.all', 'All prefixes removed from %user%.'),
|
|
-- PrefixBlacklist command
|
|
('commands.keys.cmd_prefix_blacklist', 'prefixblacklist'),
|
|
('commands.error.cmd_prefix_blacklist.usage', 'Usage: :prefixblacklist <add|remove|list> [word]'),
|
|
('commands.error.cmd_prefix_blacklist.empty_word', 'Word cannot be empty.'),
|
|
('commands.succes.cmd_prefix_blacklist.header', 'Blacklisted prefix words:'),
|
|
('commands.succes.cmd_prefix_blacklist.empty', 'No blacklisted words.'),
|
|
('commands.succes.cmd_prefix_blacklist.added', 'Word "%word%" added to prefix blacklist.'),
|
|
('commands.succes.cmd_prefix_blacklist.removed', 'Word "%word%" removed from prefix blacklist.');
|
|
|
|
INSERT IGNORE INTO permission_definitions
|
|
(permission_key, max_value, rank_1, rank_2, rank_3, rank_4, rank_5, rank_6, rank_7)
|
|
VALUES
|
|
('cmd_give_prefix', '1', '0', '0', '0', '0', '0', '0', '1'),
|
|
('cmd_list_prefixes', '1', '0', '0', '0', '0', '0', '0', '1'),
|
|
('cmd_remove_prefix', '1', '0', '0', '0', '0', '0', '0', '1'),
|
|
('cmd_prefix_blacklist', '1', '0', '0', '0', '0', '0', '0', '1');
|