mirror of
https://github.com/Sarjuuk/aowow.git
synced 2025-11-29 15:58:16 +08:00
* hide creatures for internal use from listviews * correct Nightelf Player faction * trying to enforce strict line endings
104 lines
3.9 KiB
PHP
104 lines
3.9 KiB
PHP
<?php
|
|
|
|
if (!defined('AOWOW_REVISION'))
|
|
die('illegal access');
|
|
|
|
if (!CLI)
|
|
die('not in cli mode');
|
|
|
|
/* deps:
|
|
* quest_template
|
|
* game_event_seasonal_questrelation
|
|
* game_event
|
|
* achievement_reward
|
|
*/
|
|
|
|
$customData = array(
|
|
137 => ['gender' => 2],
|
|
138 => ['gender' => 1],
|
|
);
|
|
$reqDBC = ['chartitles'];
|
|
|
|
function titles()
|
|
{
|
|
$titleHoliday = array(
|
|
137 => 201,
|
|
138 => 201,
|
|
124 => 324,
|
|
135 => 423,
|
|
155 => 181,
|
|
133 => 372,
|
|
74 => 327,
|
|
75 => 341,
|
|
76 => 341,
|
|
134 => 141,
|
|
168 => 404
|
|
);
|
|
|
|
$questQuery = '
|
|
SELECT
|
|
qt.RewardTitle AS ARRAY_KEY,
|
|
qt.AllowableRaces,
|
|
IFNULL(ge.eventEntry, 0) AS eventEntry
|
|
FROM
|
|
quest_template qt
|
|
LEFT JOIN
|
|
game_event_seasonal_questrelation sq ON sq.questId = qt.ID
|
|
LEFT JOIN
|
|
game_event ge ON ge.eventEntry = sq.eventEntry
|
|
WHERE
|
|
qt.RewardTitle <> 0';
|
|
|
|
DB::Aowow()->query('REPLACE INTO ?_titles SELECT Id, 0, 0, 0, 0, 0, 0, 0, bitIdx, male_loc0, male_loc2, male_loc3, male_loc6, male_loc8, female_loc0, female_loc2, female_loc3, female_loc6, female_loc8 FROM dbc_chartitles');
|
|
|
|
// hide unused titles
|
|
DB::Aowow()->query('UPDATE ?_titles SET cuFlags = ?d WHERE id BETWEEN 85 AND 123 AND id NOT IN (113, 120, 121, 122)', CUSTOM_EXCLUDE_FOR_LISTVIEW);
|
|
|
|
// set expansion
|
|
DB::Aowow()->query('UPDATE ?_titles SET expansion = 2 WHERE id >= 72 AND id <> 80');
|
|
DB::Aowow()->query('UPDATE ?_titles SET expansion = 1 WHERE id >= 42 AND id <> 46 AND expansion = 0');
|
|
|
|
// set category
|
|
DB::Aowow()->query('UPDATE ?_titles SET category = 1 WHERE id <= 28 OR id IN (42, 43, 44, 45, 47, 48, 62, 71, 72, 80, 82, 126, 127, 128, 157, 163, 167, 169, 177)');
|
|
DB::Aowow()->query('UPDATE ?_titles SET category = 5 WHERE id BETWEEN 96 AND 109 OR id IN (83, 84)');
|
|
DB::Aowow()->query('UPDATE ?_titles SET category = 2 WHERE id BETWEEN 144 AND 156 OR id IN (63, 77, 79, 113, 123, 130, 131, 132, 176)');
|
|
DB::Aowow()->query('UPDATE ?_titles SET category = 6 WHERE id IN (46, 74, 75, 76, 124, 133, 134, 135, 137, 138, 155, 168)');
|
|
DB::Aowow()->query('UPDATE ?_titles SET category = 4 WHERE id IN (81, 125)');
|
|
DB::Aowow()->query('UPDATE ?_titles SET category = 3 WHERE id IN (53, 64, 120, 121, 122, 129, 139, 140, 141, 142) OR (id >= 158 AND category = 0)');
|
|
|
|
// update event
|
|
if ($assoc = DB::World()->selectCol('SELECT holiday AS ARRAY_KEY, eventEntry FROM game_event WHERE holiday IN (?a)', array_values($titleHoliday)))
|
|
foreach ($titleHoliday as $tId => $hId)
|
|
if (!empty($assoc[$hId]))
|
|
DB::Aowow()->query('UPDATE ?_titles SET eventId = ?d WHERE id = ?d', $assoc[$hId], $tId);
|
|
|
|
// update side
|
|
$questInfo = DB::World()->select($questQuery);
|
|
$sideUpd = DB::World()->selectCol('SELECT IF (title_A, title_A, title_H) AS ARRAY_KEY, BIT_OR(IF(title_A, 1, 2)) AS side FROM achievement_reward WHERE (title_A <> 0 AND title_H = 0) OR (title_H <> 0 AND title_A = 0) GROUP BY ARRAY_KEY HAVING side <> 3');
|
|
foreach ($questInfo as $tId => $data)
|
|
{
|
|
if ($data['eventEntry'])
|
|
DB::Aowow()->query('UPDATE ?_titles SET eventId = ?d WHERE id = ?d', $data['eventEntry'], $tId);
|
|
|
|
$side = Util::sideByRaceMask($data['AllowableRaces']);
|
|
if ($side == 3)
|
|
continue;
|
|
|
|
if (!isset($sideUpd[$tId]))
|
|
$sideUpd[$tId] = $side;
|
|
else
|
|
$sideUpd[$tId] |= $side;
|
|
}
|
|
foreach ($sideUpd as $tId => $side)
|
|
if ($side != 3)
|
|
DB::Aowow()->query("UPDATE ?_titles SET side = ?d WHERE id = ?d", $side, $tId);
|
|
|
|
// update side - sourceless titles (maintain query order)
|
|
DB::Aowow()->query('UPDATE ?_titles SET side = 2 WHERE id <= 28 OR id IN (118, 119, 116, 117, 110, 127)');
|
|
DB::Aowow()->query('UPDATE ?_titles SET side = 1 WHERE id <= 14 OR id IN (111, 115, 112, 114, 126)');
|
|
|
|
return true;
|
|
}
|
|
|
|
?>
|