REO-EE/_module/nss/bank_include.nss
Jaysyn904 f82740bbbd Initial commit
Initial commit
2024-02-22 13:22:03 -05:00

262 lines
8.5 KiB
Plaintext

// Created by Zunath
#include "inc_system_const"
#include "inc_mysql_tables"
#include "colors_inc"
///////////////
// CONSTANTS //
///////////////
// Absolute limit to the number of items a single bank table can hold.
// By default, this is 100. Not sure what the exact limit is, but I wouldn't
// try raising this too much or you'll get some lag when PCs open their banks.
const int BANK_HARD_ITEM_CAP = 100;
////////////////////
// BANK FUNCTIONS //
////////////////////
// Returns oPC's unique ID number.
int BANK_GetPCIDNumber(object oPC);
// Creates bank tables if they do not exist in the MySQL
// database. Call this on module load.
void BANK_CreateTables();
// Returns the max number of items oPC can store in bank
// sBank.
int BANK_GetPCMaxSize(object oPC, string sBank);
// Checks PC's bank list to see if their max item size is at least
// 10. If it is lower, then they are set to 10. This is done for
// each bank in the game.
// Call this function on module client enter
void BANK_UpdatePCBankList(object oPC);
// Removes all stored item data from bank table sTable.
// This is called when a PC dies, or when PC is adding/removing
// new items.
void BANK_RemovePCBankData(object oPC, string sTable);
// Cycles through bank placeable and stores items in the database.
// If PC's max item limit is reached, all items afterwards are returned
// to their inventory.
// If no items are in the container, nothing is stored
void BANK_UpdatePCBank(object oPC, object oBank);
// Call on the bank terminal's OnOpen event.
// Loads stored bank items and locks terminal so that other PCs cannot steal
// user's items.
void BANK_BankOnOpened();
// Call on the bank terminal's OnClosed event.
// Destroys all of the bank;s inventory items and unlocks it for the next PC's use.
void BANK_BankOnClosed();
// Sets oPC's item limit for sBank to iLimit.
// oPC must be a player object
// sBank must be a valid bank table name (in MySQL)
// iLimit must be the new item limit for oPC.
// NOTE: Do not set LOWER than PC's current item limit or they may lose items
// NOTE 2: If iLimit is set lower than 1, it will be set to 1. If it is set above the cap,
// it will be set to the cap. (Determined by BANK_HARD_ITEM_CAP constant above)
void BANK_SetPCBankLimit(object oPC, string sBank, int iLimit);
// Internal function - Creates the necessary code to make
// a new bank table. Do not call this on its own.
void BANK_CreateTable(string sTableName);
/////////////////////////////////////////////////////////////
int BANK_GetPCIDNumber(object oPC)
{
object oDatabase = GetItemPossessedBy(oPC, PC_DATABASE);
return GetLocalInt(oDatabase, PC_ID_NUMBER);
}
int BANK_GetPCMaxSize(object oPC, string sBank)
{
object oDatabase = GetItemPossessedBy(oPC, PC_DATABASE);
int iAmount = GetLocalInt(oDatabase, sBank);
return iAmount;
}
void BANK_UpdatePCBankList(object oPC)
{
object oDatabase = GetItemPossessedBy(oPC, PC_DATABASE);
if(GetLocalInt(oDatabase, "BANK_INGLES_WAREHOUSE") < 5)
{
SetLocalInt(oDatabase, "BANK_INGLES_WAREHOUSE", 5);
}
if(GetLocalInt(oDatabase, "BANK_UBCS_CAMPSITE") < 5)
{
SetLocalInt(oDatabase, "BANK_UBCS_CAMPSITE", 5);
}
}
void BANK_RemovePCBankData(object oPC, string sTable)
{
int iID = BANK_GetPCIDNumber(oPC);
string sSQL = "DELETE FROM " + sTable + " WHERE ID=" + IntToString(iID) + ";";
SQLExecDirect(sSQL);
}
void BANK_UpdatePCBank(object oPC, object oBank)
{
string sTable = GetTag(oBank);
int iMaxItems = BANK_GetPCMaxSize(oPC, sTable);
int iID = BANK_GetPCIDNumber(oPC);
string sSQL = "INSERT INTO " + sTable + "(ID, Name, Account, CDKey) VALUES (" + IntToString(iID) + ", '" + SQLEncodeSpecialChars(GetName(oPC)) + "', '" + SQLEncodeSpecialChars(GetPCPlayerName(oPC)) + "', '" + GetPCPublicCDKey(oPC) + "')";
int iCurItem = 1;
int iReachedLimit = FALSE;
// First remove existing data
BANK_RemovePCBankData(oPC, sTable);
// Cycle through bank inventory and store items
object oItem = GetFirstItemInInventory(oBank);
while(GetIsObjectValid(oItem))
{
// Haven't reached the limit yet.
if(iMaxItems >= iCurItem)
{
// Create a new row using their ID, if this is the first item in the bank
if(iCurItem == 1)
{
SQLExecDirect(sSQL);
}
sSQL = "UPDATE " + sTable + " SET Item" + IntToString(iCurItem) + "=%s WHERE ID=" + IntToString(iID) + ";";
SetLocalString(GetModule(), "NWNX!ODBC!SETSCORCOSQL", sSQL);
StoreCampaignObject ("NWNX", "-", oItem);
}
// Reached the limit - return the item
else
{
AssignCommand(oBank, ActionGiveItem(oItem, oPC));
iReachedLimit = TRUE;
}
// Add one to the tally and move to the next item in bank's inventory
iCurItem = iCurItem + 1;
oItem = GetNextItemInInventory(oBank);
}
if(iReachedLimit == TRUE)
{
SendMessageToPC(oPC, ColorTokenRed() + "You have reached your item limit for this item box. Excess items have been returned to you." + ColorTokenEnd());
}
else
{
SendMessageToPC(oPC, ColorTokenWhite() + "Item Limit: " + IntToString(iCurItem-1) + " / " + ColorTokenRed() + IntToString(iMaxItems));
}
}
void BANK_BankOnOpened()
{
object oBank = OBJECT_SELF;
object oPC = GetLastOpenedBy();
object oItem;
string sBank = GetTag(oBank);
string sSQL;
int iCurItem = 1;
int iMaxItems = BANK_GetPCMaxSize(oPC, sBank);
int iID = BANK_GetPCIDNumber(oPC);
// Locks bank so other PC's can't steal player's items
SetLocked(oBank, TRUE);
// Load all bank items into bank terminal's inventory
while(iCurItem <= iMaxItems)
{
sSQL = "SELECT Item" + IntToString(iCurItem) + " FROM " + sBank + " WHERE ID=" + IntToString(iID) +";";
SetLocalString(GetModule(), "NWNX!ODBC!SETSCORCOSQL", sSQL);
oItem = RetrieveCampaignObject ("NWNX", "-", GetLocation(oBank), oBank);
// No need to keep checking the table - there are no more items being stored at the moment
if(!GetIsObjectValid(oItem)){break;}
// Prevent duplication of items in containers
if(GetHasInventory(oItem))
{
object oCycle = GetFirstItemInInventory(oItem);
while(GetIsObjectValid(oCycle))
{
DestroyObject(oCycle);
oCycle = GetNextItemInInventory(oItem);
}
}
iCurItem = iCurItem + 1;
}
// Inform player of how to quit banking
SendMessageToPC(oPC, "To quit storing items, walk away from the item box.");
}
void BANK_BankOnClosed()
{
object oBank = OBJECT_SELF;
object oPC = GetLastClosedBy();
object oInventory = GetFirstItemInInventory();
while(GetIsObjectValid(oInventory))
{
DestroyObject(oInventory);
oInventory = GetNextItemInInventory();
}
// Allow another PC to use it.
SetLocked(oBank, FALSE);
}
void BANK_SetPCBankLimit(object oPC, string sBank, int iLimit)
{
object oDatabase = GetItemPossessedBy(oPC, PC_DATABASE);
// Prevent from going out of the 1-BANK_HARD_ITEM_CAP range
if(iLimit < 1){iLimit = 1;}
else if(iLimit > BANK_HARD_ITEM_CAP){iLimit = BANK_HARD_ITEM_CAP;}
SetLocalInt(oDatabase, sBank, iLimit);
}
void BANK_CreateTable(string sTableName)
{
// Table exists - cancel
if(DoesMySQLTableExist(sTableName)){return;}
int iLoop;
string sSQL = "CREATE TABLE `" + sTableName + "` (" +
"`ID` INTEGER NULL," +
"`Name` TEXT DEFAULT NULL," +
"`Account` TEXT DEFAULT NULL," +
"`CDKey` TEXT DEFAULT NULL," +
"PRIMARY KEY (`ID`))" +
"ENGINE = MyISAM;";
SQLExecDirect(sSQL);
sSQL = "ALTER TABLE `" + sTableName + "` ADD COLUMN `Item1` BLOB DEFAULT NULL AFTER `CDKey`;";
SQLExecDirect(sSQL);
// Now cycle through, creating more columns until the hard cap is reached.
// Probably not the most efficient way, but a single create table call only got me
// to 50 items.
for(iLoop = 1; iLoop <= BANK_HARD_ITEM_CAP; iLoop++)
{
sSQL = "ALTER TABLE `" + sTableName + "` ADD COLUMN `Item" + IntToString(iLoop) + "` BLOB DEFAULT NULL AFTER `Item" + IntToString(iLoop-1) + "`;";
SQLExecDirect(sSQL);
}
}
void BANK_CreateTables()
{
// Add more tables as more banks are created
BANK_CreateTable("BANK_INGLES_WAREHOUSE");
BANK_CreateTable("BANK_UBCS_CAMPSITE");
}
// Error checking
//void main(){}