mirror of
				https://github.com/Znote/ZnoteAAC.git
				synced 2025-10-25 07:04:18 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			65 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
| -- getEternalStorage and setEternalStorage
 | |
| -- can be added to data/global.lua if you want to use eternal storage for another purpose than this.
 | |
| -- Regular TFS global storage values get reset every time server reboots. This does not.
 | |
| local function getEternalStorage(key, parser)
 | |
| 	local value = result.getString(db.storeQuery("SELECT `value` FROM `znote_global_storage` WHERE `key` = ".. key .. ";"), "value")
 | |
| 	if not value then
 | |
| 		if parser then
 | |
| 			return false
 | |
| 		else
 | |
| 			return -1
 | |
| 		end
 | |
| 	end
 | |
| 	result.free(value)
 | |
| 	return tonumber(value) or value
 | |
| end
 | |
| 
 | |
| local function setEternalStorage(key, value)
 | |
| 	if getEternalStorage(key, true) then
 | |
| 		db.query("UPDATE `znote_global_storage` SET `value` = '".. value .. "' WHERE `key` = ".. key .. ";")
 | |
| 	else
 | |
| 		db.query("INSERT INTO `znote_global_storage` (`key`, `value`) VALUES (".. key ..", ".. value ..");")
 | |
| 	end
 | |
| 	return true
 | |
| end
 | |
| 
 | |
| -- SQL Query to execute: --
 | |
| --[[
 | |
| ALTER TABLE `znote_players` ADD `exphist_lastexp` BIGINT UNSIGNED NOT NULL DEFAULT '0',
 | |
| ADD `exphist1` BIGINT UNSIGNED NOT NULL DEFAULT '0',
 | |
| ADD `exphist2` BIGINT UNSIGNED NOT NULL DEFAULT '0',
 | |
| ADD `exphist3` BIGINT UNSIGNED NOT NULL DEFAULT '0',
 | |
| ADD `exphist4` BIGINT UNSIGNED NOT NULL DEFAULT '0',
 | |
| ADD `exphist5` BIGINT UNSIGNED NOT NULL DEFAULT '0',
 | |
| ADD `exphist6` BIGINT UNSIGNED NOT NULL DEFAULT '0',
 | |
| ADD `exphist7` BIGINT UNSIGNED NOT NULL DEFAULT '0',
 | |
| ADD `onlinetimetoday` BIGINT NOT NULL DEFAULT '0',
 | |
| ADD `onlinetime1` BIGINT NOT NULL DEFAULT '0',
 | |
| ADD `onlinetime2` BIGINT NOT NULL DEFAULT '0',
 | |
| ADD `onlinetime3` BIGINT NOT NULL DEFAULT '0',
 | |
| ADD `onlinetime4` BIGINT NOT NULL DEFAULT '0',
 | |
| ADD `onlinetime5` BIGINT NOT NULL DEFAULT '0',
 | |
| ADD `onlinetime6` BIGINT NOT NULL DEFAULT '0',
 | |
| ADD `onlinetime7` BIGINT NOT NULL DEFAULT '0',
 | |
| ADD `onlinetimeall` BIGINT NOT NULL DEFAULT '0';
 | |
| ]]--
 | |
| 
 | |
| -- after that execute: --
 | |
| --[[
 | |
| UPDATE `znote_players` AS `z` INNER JOIN `players` AS `p` ON `p`.`id`=`z`.`player_id` SET `z`.`exphist_lastexp`=`p`.`experience`;
 | |
| ]]--
 | |
| 
 | |
| -- TFS 1.X (data/globalevents.xml)
 | |
| -- <!-- Power Gamers -->
 | |
| -- <globalevent name="PowerGamers" interval="60000" script="powergamers.lua"/>
 | |
| 
 | |
| function onThink(interval, lastExecution, thinkInterval)
 | |
| 	if tonumber(os.date("%d")) ~= getEternalStorage(23856) then
 | |
| 		setEternalStorage(23856, (tonumber(os.date("%d"))))
 | |
| 		db.query("UPDATE `znote_players` SET `onlinetime7`=`onlinetime6`, `onlinetime6`=`onlinetime5`, `onlinetime5`=`onlinetime4`, `onlinetime4`=`onlinetime3`, `onlinetime3`=`onlinetime2`, `onlinetime2`=`onlinetime1`, `onlinetime1`=`onlinetimetoday`, `onlinetimetoday`=0;")
 | |
| 		db.query("UPDATE `znote_players` `z` INNER JOIN `players` `p` ON `p`.`id`=`z`.`player_id` SET `z`.`exphist7`=`z`.`exphist6`, `z`.`exphist6`=`z`.`exphist5`, `z`.`exphist5`=`z`.`exphist4`, `z`.`exphist4`=`z`.`exphist3`, `z`.`exphist3`=`z`.`exphist2`, `z`.`exphist2`=`z`.`exphist1`, `z`.`exphist1`=`p`.`experience`-`z`.`exphist_lastexp`, `z`.`exphist_lastexp`=`p`.`experience`;")
 | |
| 	end
 | |
| 	db.query("UPDATE `znote_players` SET `onlinetimetoday` = `onlinetimetoday` + 60, `onlinetimeall` = `onlinetimeall` + 60 WHERE `player_id` IN (SELECT `player_id` FROM `players_online` WHERE `players_online`.`player_id` = `znote_players`.`player_id`)")
 | |
| 	return true
 | |
| end
 | 
