462 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			SourcePawn
		
	
	
	
	
	
			
		
		
	
	
			462 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			SourcePawn
		
	
	
	
	
	
| //////////////////////////////
 | |
| //		SQL CALLBACKS		//
 | |
| //////////////////////////////
 | |
| public void SQLCallback_Connect(Handle owner, Handle hndl, const char[] error, any data)
 | |
| {
 | |
| 	if(hndl==INVALID_HANDLE)
 | |
| 	{
 | |
| 		SetFailState("Failed to connect to SQL database. Error: %s", error);
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		// If it's already connected we are good to go
 | |
| 		if(g_hDatabase != INVALID_HANDLE)
 | |
| 			return;
 | |
| 
 | |
| 		g_hDatabase = hndl;
 | |
| 		char m_szDriver[2];
 | |
| 		SQL_ReadDriver(g_hDatabase, STRING(m_szDriver));
 | |
| 
 | |
| 		if(m_szDriver[0] == 'm')
 | |
| 		{
 | |
| 			g_bMySQL = true;
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_players` (\
 | |
| 										  `id` int(11) NOT NULL AUTO_INCREMENT,\
 | |
| 										  `authid` varchar(32) NOT NULL,\
 | |
| 										  `name` varchar(64) NOT NULL,\
 | |
| 										  `credits` int(11) NOT NULL,\
 | |
| 										  `date_of_join` int(11) NOT NULL,\
 | |
| 										  `date_of_last_join` int(11) NOT NULL,\
 | |
| 										  PRIMARY KEY (`id`),\
 | |
| 										  UNIQUE KEY `id` (`id`),\
 | |
| 										  UNIQUE KEY `authid` (`authid`)\
 | |
| 										) ENGINE=InnoDB AUTO_INCREMENT=0 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci");
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_items` (\
 | |
| 										  `id` int(11) NOT NULL AUTO_INCREMENT,\
 | |
| 										  `player_id` int(11) NOT NULL,\
 | |
| 										  `type` varchar(16) NOT NULL,\
 | |
| 										  `unique_id` varchar(256) NOT NULL,\
 | |
| 										  `date_of_purchase` int(11) NOT NULL,\
 | |
| 										  `date_of_expiration` int(11) NOT NULL,\
 | |
| 										  PRIMARY KEY (`id`)\
 | |
| 										) ENGINE=InnoDB AUTO_INCREMENT=0 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci");
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_equipment` (\
 | |
| 										  `player_id` int(11) NOT NULL,\
 | |
| 										  `type` varchar(16) NOT NULL,\
 | |
| 										  `unique_id` varchar(256) NOT NULL,\
 | |
| 										  `slot` int(11) NOT NULL\
 | |
| 										) ENGINE=InnoDB CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci");
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_logs` (\
 | |
| 										  `id` int(11) NOT NULL AUTO_INCREMENT,\
 | |
| 										  `player_id` int(11) NOT NULL,\
 | |
| 										  `credits` int(11) NOT NULL,\
 | |
| 										  `reason` varchar(256) NOT NULL,\
 | |
| 										  `date` timestamp NOT NULL,\
 | |
| 										  PRIMARY KEY (`id`)\
 | |
| 										) ENGINE=InnoDB AUTO_INCREMENT=0 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci");
 | |
| 
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_plugin_logs` (\
 | |
| 										  `id` int(11) NOT NULL AUTO_INCREMENT,\
 | |
| 										  `level` varchar(8) NOT NULL,\
 | |
| 										   name varchar(64) NOT NULL default '',\
 | |
| 										   steam varchar(64) NOT NULL default '',\
 | |
| 										  `player_id` int(11) NOT NULL,\
 | |
| 										  `reason` varchar(256) NOT NULL,\
 | |
| 										  `date` timestamp NOT NULL,\
 | |
| 										  PRIMARY KEY (`id`),\
 | |
| 										  UNIQUE KEY `id` (`id`)\
 | |
| 										) ENGINE=InnoDB AUTO_INCREMENT=0 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci");
 | |
| 
 | |
| 			SQL_TQuery(g_hDatabase, SQLCallback_NoError, "ALTER TABLE store_items ADD COLUMN price_of_purchase int(11)");
 | |
| 			// Edit exist date column
 | |
| 			SQL_TQuery(g_hDatabase, SQLCallback_CheckError, "ALTER TABLE store_logs MODIFY COLUMN date TIMESTAMP NOT NULL");
 | |
| 			
 | |
| 			SQL_TQuery(g_hDatabase, SQLCallback_CheckError, "ALTER TABLE store_players CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;");
 | |
| 			SQL_TQuery(g_hDatabase, SQLCallback_CheckError, "ALTER TABLE store_plugin_logs CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;");
 | |
| 			char m_szQuery[1024];
 | |
| 			Format(STRING(m_szQuery), "CREATE TABLE IF NOT EXISTS `%s` (\
 | |
| 										  `id` int(11) NOT NULL AUTO_INCREMENT,\
 | |
| 										  `parent_id` int(11) NOT NULL DEFAULT '-1',\
 | |
| 										  `item_price` int(32) NOT NULL,\
 | |
| 										  `item_type` varchar(64) NOT NULL,\
 | |
| 										  `item_flag` varchar(64) NOT NULL,\
 | |
| 										  `item_name` varchar(64) NOT NULL,\
 | |
| 										  `additional_info` text NOT NULL,\
 | |
| 										  `item_status` tinyint(1) NOT NULL,\
 | |
| 										  `supported_game` varchar(64) NOT NULL,\
 | |
| 										  PRIMARY KEY (`id`)\
 | |
| 										) ENGINE=InnoDB AUTO_INCREMENT=0 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci", g_eCvars[g_cvarItemsTable].sCache);
 | |
| 			SQL_TVoid(g_hDatabase, m_szQuery);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_players` (\
 | |
| 										  `id` INTEGER PRIMARY KEY AUTOINCREMENT,\
 | |
| 										  `authid` varchar(32) NOT NULL,\
 | |
| 										  `name` varchar(64) NOT NULL,\
 | |
| 										  `credits` int(11) NOT NULL,\
 | |
| 										  `date_of_join` int(11) NOT NULL,\
 | |
| 										  `date_of_last_join` int(11) NOT NULL\
 | |
| 										)");
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_items` (\
 | |
| 										  `id` INTEGER PRIMARY KEY AUTOINCREMENT,\
 | |
| 										  `player_id` int(11) NOT NULL,\
 | |
| 										  `type` varchar(16) NOT NULL,\
 | |
| 										  `unique_id` varchar(256) NOT NULL,\
 | |
| 										  `date_of_purchase` int(11) NOT NULL,\
 | |
| 										  `date_of_expiration` int(11) NOT NULL\
 | |
| 										)");
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_equipment` (\
 | |
| 										  `player_id` int(11) NOT NULL,\
 | |
| 										  `type` varchar(16) NOT NULL,\
 | |
| 										  `unique_id` varchar(256) NOT NULL,\
 | |
| 										  `slot` int(11) NOT NULL\
 | |
| 										)");
 | |
| 			SQL_TVoid(g_hDatabase, "CREATE TABLE IF NOT EXISTS `store_plugin_logs` (\
 | |
| 										  `id` INTEGER PRIMARY KEY AUTOINCREMENT,\
 | |
| 										  `level` varchar(8) NOT NULL,\
 | |
| 										   name varchar(64) NOT NULL default '',\
 | |
| 										   steam varchar(64) NOT NULL default '',\
 | |
| 										  `player_id` int(11) NOT NULL,\
 | |
| 										  `reason` varchar(256) NOT NULL,\
 | |
| 										  `date` timestamp NOT NULL\
 | |
| 										)");	
 | |
| 			SQL_TQuery(g_hDatabase, SQLCallback_NoError, "ALTER TABLE store_items ADD COLUMN price_of_purchase int(11)");
 | |
| 			if(strcmp(g_eCvars[g_cvarItemSource].sCache, "database")==0)
 | |
| 			{
 | |
| 	
 | |
| 				SetFailState("Database item source can only be used with MySQL databases");
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		// Do some housekeeping
 | |
| 		Store_DB_HouseKeeping(g_hDatabase);
 | |
| 		
 | |
| 		if(!SQL_SetCharset(g_hDatabase, "utf8mb4")){
 | |
| 			SQL_SetCharset(g_hDatabase, "utf8");
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| public void SQLCallback_CheckError(Handle owner, Handle hndl, const char[] error, any userid)
 | |
| {
 | |
| 	if(!StrEqual("", error))
 | |
| 		LogError("Error happened. Error: %s", error);
 | |
| }
 | |
| 
 | |
| public void SQLCallback_LoadClientInventory_Credits(Handle owner, Handle hndl, const char[] error, any userid)
 | |
| {
 | |
| 	if(hndl==INVALID_HANDLE)
 | |
| 		LogError("Error happened. Error: %s", error);
 | |
| 	else
 | |
| 	{
 | |
| 		int client = GetClientOfUserId(userid);
 | |
| 		if (!client || !IsClientInGame(client))
 | |
| 			return;
 | |
| 		
 | |
| 		char m_szQuery[256];
 | |
| 		char m_szSteamID[32];
 | |
| 		int m_iTime = GetTime();
 | |
| 		g_eClients[client].iUserId = userid;
 | |
| 		g_eClients[client].iItems = -1;
 | |
| 		GetLegacyAuthString(client, STRING(m_szSteamID), false);
 | |
| 		//strcopy(g_eClients[client].szAuthId, 32, m_szSteamID[8]);
 | |
| 		strcopy(g_eClients[client].szAuthId, sizeof(Client_Data::szAuthId), m_szSteamID[8]);
 | |
| 		GetClientName(client, g_eClients[client].szName_Client, 64);
 | |
| 		SQL_EscapeString(g_hDatabase, g_eClients[client].szName_Client, g_eClients[client].szNameEscaped, 128);
 | |
| 		
 | |
| 		if(SQL_FetchRow(hndl))
 | |
| 		{
 | |
| 			g_eClients[client].iId_Client = SQL_FetchInt(hndl, 0);
 | |
| 			g_eClients[client].iCredits = SQL_FetchInt(hndl, 3);
 | |
| 			g_eClients[client].iOriginalCredits = SQL_FetchInt(hndl, 3);
 | |
| 			g_eClients[client].iDateOfJoin = SQL_FetchInt(hndl, 4);
 | |
| 			g_eClients[client].iDateOfLastJoin = m_iTime;
 | |
| 			
 | |
| 			Format(STRING(m_szQuery), "SELECT * FROM store_items WHERE `player_id`=%d", g_eClients[client].iId_Client);
 | |
| 			SQL_TQuery(g_hDatabase, SQLCallback_LoadClientInventory_Items, m_szQuery, userid);
 | |
| 
 | |
| 			Store_LogMessage(client, g_eClients[client].iCredits, "Amount of credits when the player joined");
 | |
| 			
 | |
| 			Store_SaveClientData(client);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			Format(STRING(m_szQuery), "INSERT INTO store_players (`authid`, `name`, `credits`, `date_of_join`, `date_of_last_join`) VALUES('%s', '%s', %d, %d, %d)",
 | |
| 						g_eClients[client].szAuthId, g_eClients[client].szNameEscaped, g_eCvars[g_cvarStartCredits].aCache, m_iTime, m_iTime);
 | |
| 			SQL_TQuery(g_hDatabase, SQLCallback_InsertClient, m_szQuery, userid);
 | |
| 			g_eClients[client].iCredits = g_eCvars[g_cvarStartCredits].aCache;
 | |
| 			g_eClients[client].iOriginalCredits = g_eCvars[g_cvarStartCredits].aCache;
 | |
| 			g_eClients[client].iDateOfJoin = m_iTime;
 | |
| 			g_eClients[client].iDateOfLastJoin = m_iTime;
 | |
| 			g_eClients[client].bLoaded= true;
 | |
| 			g_eClients[client].iItems = 0;
 | |
| 
 | |
| 			if(g_eCvars[g_cvarStartCredits].aCache > 0)
 | |
| 				Store_LogMessage(client, g_eCvars[g_cvarStartCredits].aCache, "Start credits");
 | |
| 		}
 | |
| 		
 | |
| 		g_eClients[client].hCreditTimer = Store_CreditTimer(client);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| public void SQLCallback_LoadClientInventory_Items(Handle owner, Handle hndl, const char[] error, any userid)
 | |
| {
 | |
| 	if(hndl==INVALID_HANDLE)
 | |
| 		LogError("Error happened. Error: %s", error);
 | |
| 	else
 | |
| 	{	
 | |
| 		int client = GetClientOfUserId(userid);
 | |
| 		if (!client || !IsClientInGame(client))
 | |
| 			return;
 | |
| 
 | |
| 		char m_szQuery[256];
 | |
| 		Format(STRING(m_szQuery), "SELECT * FROM store_equipment WHERE `player_id`=%d", g_eClients[client].iId_Client);
 | |
| 		SQL_TQuery(g_hDatabase, SQLCallback_LoadClientInventory_Equipment, m_szQuery, userid);
 | |
| 
 | |
| 		if(!SQL_GetRowCount(hndl))
 | |
| 		{
 | |
| 			g_eClients[client].bLoaded = true;
 | |
| 			g_eClients[client].iItems = 0;
 | |
| 			return;
 | |
| 		}
 | |
| 		
 | |
| 		char m_szUniqueId[PLATFORM_MAX_PATH];
 | |
| 		char m_szType[16];
 | |
| 		int m_iExpiration;
 | |
| 		int m_iUniqueId;
 | |
| 		int m_iTime = GetTime();
 | |
| 		
 | |
| 		int i = 0;
 | |
| 		while(SQL_FetchRow(hndl))
 | |
| 		{
 | |
| 			m_iUniqueId = -1;
 | |
| 			m_iExpiration = SQL_FetchInt(hndl, 5);
 | |
| 			if(m_iExpiration && m_iExpiration<=m_iTime)
 | |
| 				continue;
 | |
| 			
 | |
| 			SQL_FetchString(hndl, 2, STRING(m_szType));
 | |
| 			SQL_FetchString(hndl, 3, STRING(m_szUniqueId));
 | |
| 			while((m_iUniqueId = Store_GetItemId(m_szType, m_szUniqueId, m_iUniqueId))!=-1)
 | |
| 			{
 | |
| 				g_eClientItems[client][i].iId_Client_Item = SQL_FetchInt(hndl, 0);
 | |
| 				g_eClientItems[client][i].iUniqueId = m_iUniqueId;
 | |
| 				g_eClientItems[client][i].bSynced = true;
 | |
| 				g_eClientItems[client][i].bDeleted = false;
 | |
| 				g_eClientItems[client][i].iDateOfPurchase = SQL_FetchInt(hndl, 4);
 | |
| 				g_eClientItems[client][i].iDateOfExpiration = m_iExpiration;
 | |
| 				g_eClientItems[client][i].iPriceOfPurchase = SQL_FetchInt(hndl, 6);
 | |
| 			
 | |
| 				++i;
 | |
| 			}
 | |
| 		}
 | |
| 		g_eClients[client].iItems = i;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| public void SQLCallback_LoadClientInventory_Equipment(Handle owner, Handle hndl, const char[] error, any userid)
 | |
| {
 | |
| 	if(hndl==INVALID_HANDLE)
 | |
| 		LogError("Error happened. Error: %s", error);
 | |
| 	else
 | |
| 	{
 | |
| 		int client = GetClientOfUserId(userid);
 | |
| 		if (!client || !IsClientInGame(client))
 | |
| 			return;
 | |
| 		
 | |
| 		char m_szUniqueId[PLATFORM_MAX_PATH];
 | |
| 		char m_szType[16];
 | |
| 		int m_iUniqueId;
 | |
| 		//int m_iFlags = GetUserFlagBits(client);
 | |
| 		
 | |
| 		while(SQL_FetchRow(hndl))
 | |
| 		{
 | |
| 			SQL_FetchString(hndl, 1, STRING(m_szType));
 | |
| 			SQL_FetchString(hndl, 2, STRING(m_szUniqueId));
 | |
| 			m_iUniqueId = Store_GetItemId(m_szType, m_szUniqueId);
 | |
| 			if(m_iUniqueId == -1)
 | |
| 				continue;
 | |
| 			
 | |
| 			// Client Dont have the item
 | |
| 			if(!Store_HasClientItem(client, m_iUniqueId)) 
 | |
| 			{
 | |
| 				//PrintToChat(client, "You dont have item/ unequip");
 | |
| 				Store_UnequipItem(client, m_iUniqueId);
 | |
| 			}
 | |
| 			// Client has item but VIP period is expired.
 | |
| 			else if(Store_HasClientItem(client, m_iUniqueId) && !GetClientPrivilege(client, g_eItems[m_iUniqueId].iFlagBits))
 | |
| 			{
 | |
| 				//PrintToChat(client, "You ahve have item but no flag/ Sold.");
 | |
| 				if (g_eCvars[g_cvarSellRestricted].aCache)
 | |
| 				{
 | |
| 					Store_SellItem(client, m_iUniqueId); // Sell the item.
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					Store_UnequipItem(client, m_iUniqueId); // Just prevent the player from equipping it.
 | |
| 				}
 | |
| 			}
 | |
| 			// Client has item and has access to the item.
 | |
| 			else 
 | |
| 			{
 | |
| 				//PrintToChat(client, "You have item/ equip");
 | |
| 				Store_UseItem(client, m_iUniqueId, true, SQL_FetchInt(hndl, 3)); 
 | |
| 			}
 | |
| 		}
 | |
| 		g_eClients[client].bLoaded = true;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| public void SQLCallback_RefreshCredits(Handle owner, Handle hndl, const char[] error, any userid)
 | |
| {
 | |
| 	if(hndl==INVALID_HANDLE)
 | |
| 		LogError("Error happened. Error: %s", error);
 | |
| 	else
 | |
| 	{
 | |
| 		int client = GetClientOfUserId(userid);
 | |
| 		if(!client)
 | |
| 			return;
 | |
| 			
 | |
| 		if(SQL_FetchRow(hndl))
 | |
| 		{
 | |
| 			g_eClients[client].iCredits = SQL_FetchInt(hndl, 3);
 | |
| 			g_eClients[client].iOriginalCredits = SQL_FetchInt(hndl, 3);
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| public void SQLCallback_InsertClient(Handle owner, Handle hndl, const char[] error, any userid)
 | |
| {
 | |
| 	if(hndl==INVALID_HANDLE)
 | |
| 		LogError("Error happened. Error: %s", error);
 | |
| 	else
 | |
| 	{
 | |
| 		int client = GetClientOfUserId(userid);
 | |
| 		if(!client)
 | |
| 			return;
 | |
| 			
 | |
| 		g_eClients[client].iId_Client = SQL_GetInsertId(hndl);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| public void SQLCallback_ReloadConfig(Handle owner, Handle hndl, const char[] error, any userid)
 | |
| {
 | |
| 	if(hndl==INVALID_HANDLE)
 | |
| 	{
 | |
| 		SetFailState("Error happened reading the config table. The plugin cannot continue.", error);
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		char m_szType[64];
 | |
| 		char m_szFlag[64];
 | |
| 		char m_szInfo[2048];
 | |
| 		char m_szKey[64];
 | |
| 		char m_szValue[256];
 | |
| 		
 | |
| 		Handle m_hKV;
 | |
| 		
 | |
| 		bool m_bSuccess;
 | |
| 		
 | |
| 		int m_iLength;
 | |
| 		int m_iHandler;
 | |
| 		int m_iIndex = 0;
 | |
| 	
 | |
| 		while(SQL_FetchRow(hndl))
 | |
| 		{
 | |
| 			if(g_iItems == STORE_MAX_ITEMS)
 | |
| 				return;
 | |
| 				
 | |
| 			if(!SQL_FetchInt(hndl, 7))
 | |
| 				continue;
 | |
| 			
 | |
| 			g_eItems[g_iItems].iId = SQL_FetchInt(hndl, 0);
 | |
| 			g_eItems[g_iItems].iParent = SQL_FetchInt(hndl, 1);
 | |
| 			g_eItems[g_iItems].iPrice = SQL_FetchInt(hndl, 2);
 | |
| 			
 | |
| 			IntToString(g_eItems[g_iItems].iId, g_eItems[g_iItems].szUniqueId, PLATFORM_MAX_PATH);
 | |
| 			
 | |
| 			SQL_FetchString(hndl, 3, STRING(m_szType));
 | |
| 			m_iHandler = Store_GetTypeHandler(m_szType);
 | |
| 			if(m_iHandler == -1)
 | |
| 				continue;
 | |
| 			
 | |
| 			g_eItems[g_iItems].iHandler = m_iHandler;
 | |
| 			
 | |
| 			SQL_FetchString(hndl, 4, STRING(m_szFlag));
 | |
| 			g_eItems[g_iItems].iFlagBits = ReadFlagString(m_szFlag);
 | |
| 			
 | |
| 			SQL_FetchString(hndl, 5, g_eItems[g_iItems].szName, ITEM_NAME_LENGTH);
 | |
| 			SQL_FetchString(hndl, 6, STRING(m_szInfo));
 | |
| 			
 | |
| 			m_hKV = CreateKeyValues("Additional Info");
 | |
| 			
 | |
| 			m_iLength = strlen(m_szInfo);
 | |
| 			while(m_iIndex != m_iLength)
 | |
| 			{
 | |
| 				m_iIndex += strcopy(m_szKey, StrContains(m_szInfo[m_iIndex], "="), m_szInfo[m_iIndex])+2;
 | |
| 				m_iIndex += strcopy(m_szValue, StrContains(m_szInfo[m_iIndex], "\";"), m_szInfo[m_iIndex])+2; // \"
 | |
| 				
 | |
| 				KvJumpToKey(m_hKV, m_szKey, true);
 | |
| 				KvSetString(m_hKV, m_szKey, m_szValue);
 | |
| 				
 | |
| 				m_bSuccess = true;
 | |
| 				if(g_eTypeHandlers[m_iHandler].fnConfig!=INVALID_FUNCTION)
 | |
| 				{
 | |
| 					Call_StartFunction(g_eTypeHandlers[m_iHandler].hPlugin, g_eTypeHandlers[m_iHandler].fnConfig);
 | |
| 					Call_PushCellRef(m_hKV);
 | |
| 					Call_PushCell(g_iItems);
 | |
| 					Call_Finish(m_bSuccess); 
 | |
| 				}
 | |
| 				
 | |
| 				if(m_bSuccess)
 | |
| 					++g_iItems;
 | |
| 			}
 | |
| 			CloseHandle(m_hKV);
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| public void SQLCallback_ResetPlayer(Handle owner, Handle hndl, const char[] error, any userid)
 | |
| {
 | |
| 	if(hndl==INVALID_HANDLE)
 | |
| 		LogError("Error happened. Error: %s", error);
 | |
| 	else
 | |
| 	{
 | |
| 		int client = GetClientOfUserId(userid);
 | |
| 
 | |
| 		if(SQL_GetRowCount(hndl))
 | |
| 		{
 | |
| 			SQL_FetchRow(hndl);
 | |
| 			int id = SQL_FetchInt(hndl, 0);
 | |
| 			char m_szAuthId[32];
 | |
| 			SQL_FetchString(hndl, 1, STRING(m_szAuthId));
 | |
| 
 | |
| 			char m_szQuery[512];
 | |
| 			Format(STRING(m_szQuery), "DELETE FROM store_players WHERE id=%d", id);
 | |
| 			SQL_TVoid(g_hDatabase, m_szQuery);
 | |
| 			Format(STRING(m_szQuery), "DELETE FROM store_items WHERE player_id=%d", id);
 | |
| 			SQL_TVoid(g_hDatabase, m_szQuery);
 | |
| 			Format(STRING(m_szQuery), "DELETE FROM store_equipment WHERE player_id=%d", id);
 | |
| 			SQL_TVoid(g_hDatabase, m_szQuery);
 | |
| 
 | |
| 			//ChatAll("%t", "Player Resetted", m_szAuthId);
 | |
| 			CPrintToChatAll("%s%t", g_sChatPrefix, "Player Resetted", m_szAuthId);
 | |
| 
 | |
| 		}
 | |
| 		else
 | |
| 			if(client)
 | |
| 			{
 | |
| 				//Chat(client, "%t", "Credit No Match");
 | |
| 				CPrintToChat(client, "%s%t", g_sChatPrefix, "Credit No Match");
 | |
| 			}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| public void SQLCallback_Void_Error(Handle owner, Handle hndl, const char[] error, any data)
 | |
| {
 | |
| 	if (owner == null)
 | |
| 	{
 | |
| 		StoreLogMessage(0, LOG_ERROR, "SQLCallback_Void_Error: %s", error);
 | |
| 	}
 | |
| }
 |