added changes to the public store plugin with a readme
This commit is contained in:
parent
9524a6550a
commit
d50914c54a
35
zrstore/README.md
Normal file
35
zrstore/README.md
Normal file
@ -0,0 +1,35 @@
|
||||
url: https://github.com/nuclearsilo583/zephyrus-store-preview-new-syntax
|
||||
what is changed?
|
||||
|
||||
store/sql.sp and store/db.sp
|
||||
char m_szQuery[1024]; buffer size 512 is not enough. this is related to the query
|
||||
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);
|
||||
|
||||
|
||||
|
||||
not executing the query
|
||||
|
||||
DELETE store_items, store_equipment "
|
||||
... "FROM store_items, store_equipment "
|
||||
... "WHERE store_items.unique_id = store_equipment.unique_id "
|
||||
... "AND store_items.player_id = store_equipment.player_id "
|
||||
... "AND store_items.date_of_expiration != 0 "
|
||||
... "AND store_items.date_of_expiration < %d", GetTime());
|
||||
|
||||
DELETE FROM store_items WHERE date_of_expiration != 0 AND date_of_expiration < %d
|
||||
because its performing bad, also all our stuff is permanent.
|
||||
|
||||
fuck these jewish niggers edit to the include/zephstocks file, they added tabbing inside quotes that fuck up compiling when retabbing the indentation of the whole file.
|
||||
|
||||
|
1208
zrstore/scripting/include/zephstocks.inc
Normal file
1208
zrstore/scripting/include/zephstocks.inc
Normal file
File diff suppressed because it is too large
Load Diff
98
zrstore/scripting/store/db.sp
Normal file
98
zrstore/scripting/store/db.sp
Normal file
@ -0,0 +1,98 @@
|
||||
Handle g_hDatabase = INVALID_HANDLE;
|
||||
bool g_bMySQL = false;
|
||||
|
||||
#include "store/sql.sp"
|
||||
|
||||
void Store_DB_ConfigsExecuted_ConnectDatabase()
|
||||
{
|
||||
if(g_hDatabase == INVALID_HANDLE)
|
||||
SQL_TConnect(SQLCallback_Connect, g_eCvars[g_cvarDatabaseEntry].sCache);
|
||||
// If database has been connected. Skip connection and do some housekeeping here
|
||||
else Store_DB_HouseKeeping(g_hDatabase);
|
||||
|
||||
if(g_eCvars[g_cvarDatabaseRetries].aCache > 0)
|
||||
CreateTimer(view_as<float>(g_eCvars[g_cvarDatabaseTimeout].aCache), Timer_DatabaseTimeout);
|
||||
}
|
||||
|
||||
public Action Timer_DatabaseTimeout(Handle timer, any userid)
|
||||
{
|
||||
// Database is connected successfully
|
||||
if(g_hDatabase != INVALID_HANDLE)
|
||||
return Plugin_Stop;
|
||||
|
||||
if(g_iDatabaseRetries < g_eCvars[g_cvarDatabaseRetries].aCache)
|
||||
{
|
||||
SQL_TConnect(SQLCallback_Connect, g_eCvars[g_cvarDatabaseEntry].sCache);
|
||||
CreateTimer(view_as<float>(g_eCvars[g_cvarDatabaseTimeout].aCache), Timer_DatabaseTimeout);
|
||||
++g_iDatabaseRetries;
|
||||
}
|
||||
else
|
||||
{
|
||||
SetFailState("Database connection failed to initialize after %d retrie(s)", g_eCvars[g_cvarDatabaseRetries].aCache);
|
||||
}
|
||||
|
||||
return Plugin_Stop;
|
||||
}
|
||||
|
||||
void Store_DB_HouseKeeping(Handle db)
|
||||
{
|
||||
// Do some housekeeping
|
||||
char m_szQuery[600], m_szLogCleaningQuery[256];
|
||||
|
||||
char m_szDriver[12];
|
||||
SQL_ReadDriver(db, STRING(m_szDriver));
|
||||
|
||||
// Remove expired and equipped items
|
||||
if (StrEqual(m_szDriver, "mysql"))
|
||||
{
|
||||
// This query removes expired items that are equipped, and also remove the rows from store_equipment - it doesnt remove unequipped items!
|
||||
Format(STRING(m_szQuery), "DELETE store_items, store_equipment "
|
||||
... "FROM store_items, store_equipment "
|
||||
... "WHERE store_items.unique_id = store_equipment.unique_id "
|
||||
... "AND store_items.player_id = store_equipment.player_id "
|
||||
... "AND store_items.date_of_expiration != 0 "
|
||||
... "AND store_items.date_of_expiration < %d", GetTime());
|
||||
// Ugly syntax, but MySQL DOES allow DELETE clauses between multiple tables in a single query
|
||||
}
|
||||
else
|
||||
{
|
||||
// This query removes rows from store_equipment that are linked to items that are expired, BUT DOESNT ACTUALLY REMOVE EXPIRED ITEMS FROM PLAYERS INVENTORIES! - This is done by the query after this one.
|
||||
// ^ NOTE THAT THE BEHAVIOR OF THIS QUERY DIFFERS FROM THE MySQL ONE!
|
||||
// For easier copy-pasting: DELETE FROM store_equipment WHERE ROWID IN (SELECT store_equipment.ROWID FROM store_items, store_equipment WHERE store_items.unique_id = store_equipment.unique_id AND store_items.player_id = store_equipment.player_id AND store_items.date_of_expiration != 0 AND store_items.date_of_expiration < %d);
|
||||
Format(STRING(m_szQuery), "DELETE FROM store_equipment "
|
||||
... "WHERE ROWID IN "
|
||||
... "("
|
||||
... "SELECT store_equipment.ROWID "
|
||||
... "FROM store_items, store_equipment "
|
||||
... "WHERE store_items.unique_id = store_equipment.unique_id "
|
||||
... "AND store_items.player_id = store_equipment.player_id "
|
||||
... "AND store_items.date_of_expiration != 0 "
|
||||
... "AND store_items.date_of_expiration < %d"
|
||||
... ") ", GetTime());
|
||||
// SQLite doesnt allow DELETE clauses between multiple tables in a single query. GRRRR!!!
|
||||
|
||||
// Btw, ROWID is the default hidden SQLite primary key, because the store_equipment table doesnt have one
|
||||
}
|
||||
//SQL_TVoid(db, m_szQuery); //these just waste time. everything is permanent anyways on unloze
|
||||
|
||||
// Remove expired and unequipped items
|
||||
Format(STRING(m_szQuery), "DELETE FROM store_items WHERE date_of_expiration != 0 AND date_of_expiration < %d", GetTime());
|
||||
//SQL_TVoid(db, m_szQuery); //these just waste time. everything is permanent anyways on unloze
|
||||
|
||||
|
||||
if (g_eCvars[g_cvarLogLast].aCache>0)
|
||||
{
|
||||
if (StrEqual(m_szDriver, "mysql"))
|
||||
{
|
||||
Format(STRING(m_szLogCleaningQuery), "DELETE FROM store_plugin_logs WHERE `date` < CURDATE()-%i", g_eCvars[g_cvarLogLast].aCache);
|
||||
SQL_TVoid(db, m_szLogCleaningQuery);
|
||||
Format(STRING(m_szLogCleaningQuery), "DELETE FROM store_logs WHERE `date` < CURDATE()-%i", g_eCvars[g_cvarLogLast].aCache);
|
||||
SQL_TVoid(db, m_szLogCleaningQuery);
|
||||
}
|
||||
else
|
||||
{
|
||||
Format(STRING(m_szLogCleaningQuery), "DELETE FROM store_plugin_logs WHERE `date` < (SELECT DATETIME('now', '-%i day'))", g_eCvars[g_cvarLogLast].aCache);
|
||||
SQL_TVoid(db, m_szLogCleaningQuery);
|
||||
}
|
||||
}
|
||||
}
|
461
zrstore/scripting/store/sql.sp
Normal file
461
zrstore/scripting/store/sql.sp
Normal file
@ -0,0 +1,461 @@
|
||||
//////////////////////////////
|
||||
// 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);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user