extern int DispenseAdd(int ActualUser, int User, int Ammount, const char *ReasonGiven);
extern int DispenseSet(int ActualUser, int User, int Balance, const char *ReasonGiven);
extern int DispenseDonate(int ActualUser, int User, int Ammount, const char *ReasonGiven);
+extern int DispenseUpdateItem(int User, tItem *Item, const char *NewName, int NewPrice);
// --- Logging ---
extern void Log_Error(const char *Format, ...);
handler = Item->Handler;
+ // KNOWN HACK: Naming a slot "dead" disables it
+ if( strcmp(Item->Name, "dead") == 0 )
+ return 1;
+
// Check if the dispense is possible
if( handler->CanDispense ) {
ret = handler->CanDispense( User, Item->ID );
if( handler->DoDispense ) {
ret = handler->DoDispense( User, Item->ID );
if(ret) {
- Log_Error("Dispense failed (%s dispensing '%s' - %ic)",
- username, Item->Name, Item->Price);
+ Log_Error("Dispense failed (%s dispensing %s:%i '%s')",
+ username, Item->Name, Item->Handler->Name, Item->ID);
free( username );
return -1; // 1: Unknown Error again
}
srcName = Bank_GetAcctName(SrcUser);
dstName = Bank_GetAcctName(DestUser);
- Log_Info("give %i to %s from %s by %s [balances %i, %i] - %s",
- Ammount, dstName, srcName, actualUsername,
+ Log_Info("give %i from %s to %s by %s [balances %i, %i] - %s",
+ Ammount, srcName, dstName, actualUsername,
Bank_GetBalance(SrcUser), Bank_GetBalance(DestUser),
ReasonGiven
);
return 0;
}
+#if 0 // Dead Code
/**
* \brief Move money from one user to another (Admin Only)
*/
srcName = Bank_GetAcctName(SrcUser);
dstName = Bank_GetAcctName(DestUser);
- Log_Info("move %i to %s from %s by %s [balances %i, %i] - %s",
- Ammount, dstName, srcName, actualUsername,
+ Log_Info("move %i from %s to %s by %s [balances %i, %i] - %s",
+ Ammount, srcName, dstName, actualUsername,
Bank_GetBalance(SrcUser), Bank_GetBalance(DestUser),
ReasonGiven
);
return 0;
}
+#endif
+
/**
* \brief Add money to an account
*/
return 0;
}
+int DispenseUpdateItem(int User, tItem *Item, const char *NewName, int NewPrice)
+{
+ char *username;
+
+ // Sanity checks
+ if( NewPrice < 0 ) return 2;
+ if( !Item ) return 2;
+ if( strlen(NewName) < 1 ) return 2;
+
+ // Update the item
+ free(Item->Name);
+ Item->Name = strdup(NewName);
+ Item->Price = NewPrice;
+
+ username = Bank_GetAcctName(User);
+
+ Log_Info("item %s:%i updated to '%s' %i by %s",
+ Item->Handler->Name, Item->ID,
+ NewName, NewPrice, username
+ );
+
+ free(username);
+
+ // Update item file
+ Items_UpdateFile();
+
+ return 0;
+}
+
// --- Internal Functions ---
int _GetMinBalance(int Account)
{
}
}
+ // KNOWN HACK: Naming a slot 'dead' disables it
+ if( strcmp(Item->Name, "dead") == 0 )
+ status = "sold"; // Another status?
+
sendf(Client->Socket,
"202 Item %s:%i %s %i %s\n",
Item->Handler->Name, Item->ID, status, Item->Price, Item->Name
sendf(Client->Socket, "407 Invalid price set\n");
}
- // Update the item
- free(item->Name);
- item->Name = strdup(description);
- item->Price = price;
-
- // Update item file
- Items_UpdateFile();
-
- // Return OK
- sendf(Client->Socket, "200 Item updated\n");
+ switch( DispenseUpdateItem( Client->UID, item, description, price ) )
+ {
+ case 0:
+ // Return OK
+ sendf(Client->Socket, "200 Item updated\n");
+ break;
+ default:
+ break;
+ }
}
// --- INTERNAL HELPERS ---