MoneyServer/addon-modules/OpenSim-Data-MySQL-MySQLMon.../OpenSim.Data.MySQL.MySQLMon.../MySQLMoneyManager.cs

1628 lines
49 KiB
C#
Raw Normal View History

2020-06-03 15:27:40 +00:00
/*
* Copyright (c) Contributors, http://opensimulator.org/, http://www.nsl.tuis.ac.jp/
* See CONTRIBUTORS.TXT for a full list of copyright holders.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of the OpenSim Project nor the
* names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
using System;
using System.Data;
using System.Reflection;
using System.Collections;
using System.Collections.Generic;
using System.Text;
using System.Text.RegularExpressions;
using log4net;
using MySql.Data.MySqlClient;
using OpenMetaverse;
namespace OpenSim.Data.MySQL.MySQLMoneyDataWrapper
{
public class MySQLMoneyManager:IMoneyManager
{
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
private string Table_of_Balances = "balances";
private string Table_of_Transactions = "transactions";
private string Table_of_TotalSales = "totalsales";
private string Table_of_UserInfo = "userinfo";
private int balances_rev = 0;
private int userinfo_rev = 0;
private string connectString;
private MySqlConnection dbcon;
public MySQLMoneyManager(string hostname,string database,string username ,string password,string cpooling, string port)
{
string s = "Server=" + hostname + ";Port=" + port + ";Database=" + database +
";User ID=" + username + ";Password=" + password + ";Pooling=" + cpooling + ";";
Initialise(s);
}
public MySQLMoneyManager(string connect)
{
Initialise(connect);
}
private void Initialise(string connect)
{
try {
connectString = connect;
dbcon = new MySqlConnection(connectString);
try {
dbcon.Open();
}
catch (Exception e) {
throw new Exception("[MONEY MANAGER]: Connection error while using connection string ["+connectString+"]", e);
}
//m_log.Info("[MONEY MANAGER]: Connection established");
}
catch(Exception e) {
throw new Exception("[MONEY MANAGER]: Error initialising MySql Database: " + e.ToString());
}
try {
Dictionary<string,string> tableList = new Dictionary<string,string>();
tableList = CheckTables();
//
// Balances Table
if (!tableList.ContainsKey(Table_of_Balances)) {
try {
CreateBalancesTable();
}
catch (Exception e) {
throw new Exception("[MONEY MANAGER]: Error creating balances table: " + e.ToString());
}
}
else {
string version = tableList[Table_of_Balances].Trim();
int nVer = getTableVersionNum(version);
balances_rev = nVer;
switch (nVer) {
case 1: //Rev.1
UpdateBalancesTable1();
UpdateBalancesTable2();
UpdateBalancesTable3();
break;
case 2: //Rev.2
UpdateBalancesTable2();
UpdateBalancesTable3();
break;
case 3: //Rev.3
UpdateBalancesTable3();
break;
}
}
//
// UserInfo Table
if (!tableList.ContainsKey(Table_of_UserInfo)) {
try {
CreateUserInfoTable();
}
catch (Exception e) {
throw new Exception("[MONEY MANAGER]: Error creating userinfo table: " + e.ToString());
}
}
else {
string version = tableList[Table_of_UserInfo].Trim();
int nVer = getTableVersionNum(version);
userinfo_rev = nVer;
switch (nVer) {
case 1: //Rev.1
UpdateUserInfoTable1();
UpdateUserInfoTable2();
break;
case 2: //Rev.2
UpdateUserInfoTable2();
break;
}
}
//
// Transactions Table
if (!tableList.ContainsKey(Table_of_Transactions)) {
try {
CreateTransactionsTable();
}
catch (Exception e) {
throw new Exception("[MONEY MANAGER]: Error creating transactions table: " + e.ToString());
}
}
// check transactions table version
else {
string version = tableList[Table_of_Transactions].Trim();
int nVer = getTableVersionNum(version);
switch (nVer) {
case 2: //Rev.2
UpdateTransactionsTable2();
UpdateTransactionsTable3();
UpdateTransactionsTable4();
UpdateTransactionsTable5();
UpdateTransactionsTable6();
UpdateTransactionsTable7();
UpdateTransactionsTable8();
UpdateTransactionsTable9();
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 3: //Rev.3
UpdateTransactionsTable3();
UpdateTransactionsTable4();
UpdateTransactionsTable5();
UpdateTransactionsTable6();
UpdateTransactionsTable7();
UpdateTransactionsTable8();
UpdateTransactionsTable9();
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 4: //Rev.4
UpdateTransactionsTable4();
UpdateTransactionsTable5();
UpdateTransactionsTable6();
UpdateTransactionsTable7();
UpdateTransactionsTable8();
UpdateTransactionsTable9();
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 5: //Rev.5
UpdateTransactionsTable5();
UpdateTransactionsTable6();
UpdateTransactionsTable7();
UpdateTransactionsTable8();
UpdateTransactionsTable9();
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 6: //Rev.6
UpdateTransactionsTable6();
UpdateTransactionsTable7();
UpdateTransactionsTable8();
UpdateTransactionsTable9();
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 7: //Rev.7
UpdateTransactionsTable7();
UpdateTransactionsTable8();
UpdateTransactionsTable9();
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 8: //Rev.8
UpdateTransactionsTable8();
UpdateTransactionsTable9();
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 9: //Rev.9
UpdateTransactionsTable9();
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 10: //Rev.10
UpdateTransactionsTable10();
UpdateTransactionsTable11();
break;
case 11: //Rev.11
UpdateTransactionsTable11();
break;
}
}
//
// TotalSales Table
if (!tableList.ContainsKey(Table_of_TotalSales)) {
try {
CreateTotalSalesTable();
}
catch (Exception e) {
throw new Exception("[MONEY MANAGER]: Error creating totalsales table: " + e.ToString());
}
}
else {
string version = tableList[Table_of_TotalSales].Trim();
int nVer = getTableVersionNum(version);
switch (nVer) {
case 1: //Rev.1
UpdateTotalSalesTable1();
UpdateTotalSalesTable2();
break;
case 2: //Rev.2
UpdateTotalSalesTable2();
break;
}
}
}
catch (Exception e) {
m_log.Error("[MONEY MANAGER]: Error checking or creating tables: " + e.ToString());
throw new Exception("[MONEY MANAGER]: Error checking or creating tables: " + e.ToString());
}
}
private int getTableVersionNum(string version)
{
int nVer = 0;
Regex _commentPattenRegex = new Regex(@"\w+\.(?<ver>\d+)");
Match m = _commentPattenRegex.Match(version);
if (m.Success) {
string ver = m.Groups["ver"].Value;
nVer = Convert.ToInt32(ver);
}
return nVer;
}
///////////////////////////////////////////////////////////////////////
// create Tables
private void CreateBalancesTable()
{
string sql = string.Empty;
sql = "CREATE TABLE `" + Table_of_Balances + "` (";
sql += "`user` varchar(36) NOT NULL,";
sql += "`balance` int(10) NOT NULL,";
sql += "`status` tinyint(2) DEFAULT NULL,";
sql += "`type` tinyint(2) NOT NULL DEFAULT 0,";
sql += "PRIMARY KEY(`user`))";
sql += "Engine=InnoDB DEFAULT CHARSET=utf8 ";
///////////////////////////////////////////////
sql += "COMMENT='Rev.4';";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
private void CreateUserInfoTable()
{
string sql = string.Empty;
sql = "CREATE TABLE `" + Table_of_UserInfo + "` (";
sql += "`user` varchar(36) NOT NULL,";
sql += "`simip` varchar(64) NOT NULL,";
sql += "`avatar` varchar(50) NOT NULL,";
sql += "`pass` varchar(36) NOT NULL DEFAULT '',";
sql += "`type` tinyint(2) NOT NULL DEFAULT 0,";
sql += "`class` tinyint(2) NOT NULL DEFAULT 0,";
sql += "`serverurl` varchar(255) NOT NULL DEFAULT '',";
sql += "PRIMARY KEY(`user`))";
sql += "Engine=InnoDB DEFAULT CHARSET=utf8 ";
///////////////////////////////////////////////
sql += "COMMENT='Rev.3';";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
private void CreateTransactionsTable()
{
string sql = string.Empty;
sql = "CREATE TABLE `" + Table_of_Transactions + "`(";
sql += "`UUID` varchar(36) NOT NULL,";
sql += "`sender` varchar(36) NOT NULL,";
sql += "`receiver` varchar(36) NOT NULL,";
sql += "`amount` int(10) NOT NULL,";
sql += "`senderBalance` int(10) NOT NULL DEFAULT -1,";
sql += "`receiverBalance` int(10) NOT NULL DEFAULT -1,";
sql += "`objectUUID` varchar(36) DEFAULT NULL,";
sql += "`objectName` varchar(255) DEFAULT NULL,";
sql += "`regionHandle` varchar(36) NOT NULL,";
sql += "`regionUUID` varchar(36) NOT NULL,";
sql += "`type` int(10) NOT NULL,";
sql += "`time` int(11) NOT NULL,";
sql += "`secure` varchar(36) NOT NULL,";
sql += "`status` tinyint(1) NOT NULL,";
sql += "`commonName` varchar(128) NOT NULL,";
sql += "`description` varchar(255) DEFAULT NULL,";
sql += "PRIMARY KEY(`UUID`))";
sql += "Engine=InnoDB DEFAULT CHARSET=utf8 ";
///////////////////////////////////////////////
sql += "COMMENT='Rev.12';";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
private void CreateTotalSalesTable()
{
string sql = string.Empty;
sql = "CREATE TABLE `" + Table_of_TotalSales + "` (";
sql += "`UUID` varchar(36) NOT NULL,";
sql += "`user` varchar(36) NOT NULL,";
sql += "`objectUUID` varchar(36) NOT NULL,";
sql += "`type` int(10) NOT NULL,";
sql += "`TotalCount` int(10) NOT NULL DEFAULT 0,";
sql += "`TotalAmount` int(10) NOT NULL DEFAULT 0,";
sql += "`time` int(11) NOT NULL,";
sql += "PRIMARY KEY(`UUID`))";
sql += "Engine=InnoDB DEFAULT CHARSET=utf8 ";
///////////////////////////////////////////////
sql += "COMMENT='Rev.3';";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
initTotalSalesTable();
}
///////////////////////////////////////////////////////////////////////
// update Balances Table
private void UpdateBalancesTable1()
{
m_log.Info("[MONEY MANAGER]: Converting Balance Table...");
string sql = string.Empty;
sql = "SELECT COUNT(*) FROM " + Table_of_Balances;
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
int resultCount = int.Parse(cmd.ExecuteScalar().ToString());
cmd.Dispose();
sql = "SELECT * FROM " + Table_of_Balances;
cmd = new MySqlCommand(sql, dbcon);
MySqlDataReader dbReader = cmd.ExecuteReader();
int l = 0;
string[,] row = new string[resultCount, dbReader.FieldCount];
while (dbReader.Read()) {
for (int i=0; i<dbReader.FieldCount; i++) {
row[l, i] = dbReader.GetString(i);
}
l++;
}
dbReader.Close();
cmd.Dispose();
bool updatedb = true;
for (int i=0; i<resultCount; i++) {
string uuid = Regex.Replace(row[i, 0], @"@.+$", "");
if (uuid!=row[i, 0]) {
int amount = int.Parse(row[i,1]);
int balance = getBalance(uuid);
if (balance>=0) {
amount += balance;
updatedb = updateBalance(uuid, amount);
}
else {
updatedb = addUser(uuid, amount, int.Parse(row[i,2]), 0);
}
if (!updatedb) break;
}
}
// Delete
if (updatedb) {
for (int i=0; i<resultCount; i++) {
string uuid = Regex.Replace(row[i, 0], @"@.+$", "");
if (uuid!=row[i, 0]) {
sql = "DELETE FROM " + Table_of_Balances + " WHERE user = ?uuid";
cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?uuid", row[i,0]);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
}
//
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Balances + "` ";
sql += "COMMENT = 'Rev.2';";
sql += "COMMIT;";
cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
}
private void UpdateBalancesTable2()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Balances + "` ";
sql += "MODIFY COLUMN `user` varchar(36) NOT NULL,";
sql += "COMMENT = 'Rev.3';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
private void UpdateBalancesTable3()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Balances + "` ";
sql += "ADD `type` tinyint(2) NOT NULL DEFAULT 0 AFTER `status`,";
sql += "COMMENT = 'Rev.4';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
///////////////////////////////////////////////////////////////////////
// update User Info Table
private void UpdateUserInfoTable1()
{
//m_log.Info("[MONEY MANAGER]: Converting UserInfo Table...");
string sql = string.Empty;
sql = "SELECT COUNT(*) FROM " + Table_of_UserInfo;
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
int resultCount = int.Parse(cmd.ExecuteScalar().ToString());
cmd.Dispose();
sql = "SELECT * FROM " + Table_of_UserInfo;
cmd = new MySqlCommand(sql, dbcon);
MySqlDataReader dbReader = cmd.ExecuteReader();
int l = 0;
string[,] row = new string[resultCount, dbReader.FieldCount];
while (dbReader.Read()) {
for (int i=0; i<dbReader.FieldCount; i++) {
row[l, i] = dbReader.GetString(i);
}
l++;
}
dbReader.Close();
cmd.Dispose();
// UniversalID -> uuid, url, name, pass
bool updatedb = true;
for (int i=0; i<resultCount; i++) {
string uuid = Regex.Replace(row[i, 0], @"@.+$", "");
if (uuid!=row[i, 0]) {
UserInfo userInfo = fetchUserInfo(uuid);
if (userInfo==null) {
userInfo = new UserInfo();
userInfo.UserID = uuid;
userInfo.SimIP = row[i,1];
userInfo.Avatar = row[i,2];
userInfo.PswHash = row[i,3];
updatedb = addUserInfo(userInfo);
}
}
}
// Delete
if (updatedb) {
for (int i=0; i<resultCount; i++) {
string uuid = Regex.Replace(row[i, 0], @"@.+$", "");
if (uuid!=row[i, 0]) {
sql = "DELETE FROM " + Table_of_UserInfo + " WHERE user = ?uuid";
cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?uuid", row[i,0]);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
}
//
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_UserInfo + "` ";
sql += "COMMENT = 'Rev.2';";
sql += "COMMIT;";
cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
}
private void UpdateUserInfoTable2()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_UserInfo + "` ";
sql += "MODIFY COLUMN `user` varchar(36) NOT NULL,";
sql += "MODIFY COLUMN `pass` varchar(36) NOT NULL DEFAULT '',";
sql += "ADD `type` tinyint(2) NOT NULL DEFAULT 0 AFTER `pass`,";
sql += "ADD `class` tinyint(2) NOT NULL DEFAULT 0 AFTER `type`,";
sql += "ADD `serverurl` varchar(255) NOT NULL DEFAULT '' AFTER `class`,";
sql += "COMMENT = 'Rev.3';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
///////////////////////////////////////////////////////////////////////
// update Transactions Table
/// <summary>
/// update transactions table from Rev.2 to Rev.3
/// </summary>
private void UpdateTransactionsTable2()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "ADD(`objectUUID` varchar(36) DEFAULT NULL AFTER `amount`),";
sql += "COMMENT = 'Rev.3';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.3 to Rev.4
/// </summary>
private void UpdateTransactionsTable3()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "ADD(`secure` varchar(36) NOT NULL AFTER `time`),";
sql += "COMMENT = 'Rev.4';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.4 to Rev.5
/// </summary>
private void UpdateTransactionsTable4()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "ADD(`regionHandle` varchar(36) NOT NULL AFTER `objectUUID`),";
sql += "COMMENT = 'Rev.5';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.5 to Rev.6
/// </summary>
private void UpdateTransactionsTable5()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "ADD(`commonName` varchar(128) NOT NULL AFTER `status`),";
sql += "COMMENT = 'Rev.6';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.6 to Rev.7
/// </summary>
private void UpdateTransactionsTable6()
{
//m_log.Info("[MONEY MANAGER]: Converting Transaction Table...");
string sql = string.Empty;
sql = "SELECT COUNT(*) FROM " + Table_of_Transactions;
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
int resultCount = int.Parse(cmd.ExecuteScalar().ToString());
cmd.Dispose();
sql = "SELECT UUID,sender,receiver FROM " + Table_of_Transactions;
cmd = new MySqlCommand(sql, dbcon);
MySqlDataReader dbReader = cmd.ExecuteReader();
int l = 0;
string[,] row = new string[resultCount, dbReader.FieldCount];
while (dbReader.Read()) {
for (int i=0; i<dbReader.FieldCount; i++) {
row[l, i] = dbReader.GetString(i);
}
l++;
}
dbReader.Close();
cmd.Dispose();
sql = "UPDATE " + Table_of_Transactions + " SET sender = ?sender , receiver = ?receiver WHERE UUID = ?uuid;";
for (int i=0; i<resultCount; i++) {
string sender = Regex.Replace(row[i, 1], @"@.+$", "");
string receiver = Regex.Replace(row[i, 2], @"@.+$", "");
cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?uuid", row[i,0]);
cmd.Parameters.AddWithValue("?sender", sender);
cmd.Parameters.AddWithValue("?receiver", receiver);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "COMMENT = 'Rev.7';";
sql += "COMMIT;";
cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.7 to Rev.8
/// </summary>
private void UpdateTransactionsTable7()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "ADD `objectName` varchar(255) DEFAULT NULL AFTER `objectUUID`,";
sql += "COMMENT = 'Rev.8';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.8 to Rev.9
/// </summary>
private void UpdateTransactionsTable8()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "ADD `senderBalance` int(10) NOT NULL DEFAULT -1 AFTER `amount`,";
sql += "ADD `receiverBalance` int(10) NOT NULL DEFAULT -1 AFTER `senderBalance`,";
sql += "COMMENT = 'Rev.9';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.9 to Rev.10
/// </summary>
private void UpdateTransactionsTable9()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "MODIFY COLUMN `sender` varchar(36) NOT NULL,";
sql += "MODIFY COLUMN `receiver` varchar(36) NOT NULL,";
sql += "COMMENT = 'Rev.10';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.10 to Rev.11
/// change type of BirthGift from 1000 to 900
/// </summary>
private void UpdateTransactionsTable10()
{
//m_log.Info("[MONEY MANAGER]: Converting Transaction Table...");
string sql = string.Empty;
sql = "SELECT COUNT(*) FROM `" + Table_of_Transactions + "` WHERE type=1000";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
int resultCount = int.Parse(cmd.ExecuteScalar().ToString());
cmd.Dispose();
if (resultCount>0) {
sql = "SELECT UUID FROM `" + Table_of_Transactions + "` WHERE type=1000";
cmd = new MySqlCommand(sql, dbcon);
MySqlDataReader dbReader = cmd.ExecuteReader();
int l = 0;
string[] row = new string[resultCount];
while (dbReader.Read()) {
row[l] = dbReader.GetString(0);
l++;
}
dbReader.Close();
cmd.Dispose();
sql = "UPDATE `" + Table_of_Transactions + "` SET type=900 WHERE UUID=?uuid";
for (int i=0; i<resultCount; i++) {
cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?uuid", row[i]);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
}
//
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "COMMENT = 'Rev.11';";
sql += "COMMIT;";
cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
/// <summary>
/// update transactions table from Rev.11 to Rev.12
/// </summary>
private void UpdateTransactionsTable11()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_Transactions + "` ";
sql += "ADD `regionUUID` varchar(36) NOT NULL AFTER `regionHandle`,";
sql += "COMMENT = 'Rev.12';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
///////////////////////////////////////////////////////////////////////
// update Total Sales Table
private void UpdateTotalSalesTable1()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_TotalSales + "` ";
sql += "ADD `time` int(11) NOT NULL AFTER `TotalAmount`,";
sql += "COMMENT = 'Rev.2';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
deleteTotalSalesTable();
initTotalSalesTable();
}
private void UpdateTotalSalesTable2()
{
string sql = string.Empty;
sql = "BEGIN;";
sql += "ALTER TABLE `" + Table_of_TotalSales + "` ";
sql += "MODIFY COLUMN `user` varchar(36) NOT NULL,";
sql += "COMMENT = 'Rev.3';";
sql += "COMMIT;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
///////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////
//
private Dictionary<string,string> CheckTables()
{
Dictionary<string,string> tableDic = new Dictionary<string,string>();
lock (dbcon) {
string sql = string.Empty;
sql = "SELECT TABLE_NAME,TABLE_COMMENT FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA=?dbname";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?dbname", dbcon.Database);
using (MySqlDataReader r = cmd.ExecuteReader()) {
while (r.Read()) {
try {
string tableName = (string)r["TABLE_NAME"];
string comment = (string)r["TABLE_COMMENT"];
tableDic.Add(tableName, comment);
}
catch (Exception e) {
throw new Exception("[MONEY MANAGER]: Error checking tables" + e.ToString());
}
}
r.Close();
}
cmd.Dispose();
return tableDic;
}
}
/// <summary>
/// Reconnect to the database
/// </summary>
public void Reconnect()
{
m_log.Info("[MONEY MANAGER]: Reconnecting database");
lock (dbcon) {
try {
dbcon.Close();
dbcon = new MySqlConnection(connectString);
dbcon.Open();
m_log.Info("[MONEY MANAGER]: Reconnected database");
}
catch (Exception e) {
m_log.Error("[MONEY MANAGER]: Unable to reconnect to database: " + e.ToString());
}
}
}
///////////////////////////////////////////////////////////////////////
//
// balances
//
/// <summary>
/// Get balance from database. returns -1 if failed.
/// </summary>
/// <param name="userID"></param>
/// <returns></returns>
public int getBalance(string userID)
{
if (userID==UUID.Zero.ToString()) return 999999999; // System
int retValue = -1;
string sql = string.Empty;
sql = "SELECT balance FROM " + Table_of_Balances + " WHERE user = ?userid";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?userid", userID);
using (MySqlDataReader dbReader = cmd.ExecuteReader(CommandBehavior.SingleRow)) {
try {
if (dbReader.Read()) {
retValue = Convert.ToInt32(dbReader["balance"]);
}
}
#pragma warning disable CS0168 // The variable 'e' is declared but never
#pragma warning disable CA1031 // Do not catch general exception types
catch (Exception e) {
m_log.ErrorFormat("[MoneyDB]: MySql failed to fetch balance {0}.", userID);
retValue = -2;
}
#pragma warning restore CA1031 // Do not catch general exception types
#pragma warning restore CS0168 // The variable 'e' is declared but never
dbReader.Close();
}
cmd.Dispose();
return retValue;
}
public bool updateBalance(string userID, int amount)
{
if (userID==UUID.Zero.ToString()) return true; // System
bool bRet = false;
string sql = string.Empty;
sql = "UPDATE " + Table_of_Balances + " SET balance = ?amount WHERE user = ?userID;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?amount", amount);
cmd.Parameters.AddWithValue("?userID", userID);
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
public bool addUser(string userID, int balance, int status, int type)
{
if (userID==UUID.Zero.ToString()) return true; // System
bool bRet = false;
string sql = string.Empty;
if (balances_rev>=4) {
sql = "INSERT INTO " + Table_of_Balances + " (`user`,`balance`,`status`,`type`) VALUES ";
sql += " (?userID,?balance,?status,?type);";
}
else {
sql = "INSERT INTO " + Table_of_Balances + " (`user`,`balance`,`status`) VALUES ";
sql += " (?userID,?balance,?status);";
}
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?userID", userID);
cmd.Parameters.AddWithValue("?balance", balance);
cmd.Parameters.AddWithValue("?status", status);
if (balances_rev>=4) {
cmd.Parameters.AddWithValue("?type", type);
}
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
/// <summary>
/// Here we'll make a withdraw from the sender and update transaction status
/// </summary>
/// <param name="fromID"></param>
/// <param name="toID"></param>
/// <param name="amount"></param>
/// <returns></returns>
public bool withdrawMoney(UUID transactionID, string senderID, int amount)
{
bool bRet = false;
string sql = string.Empty;
MySqlCommand cmd = null;
// System
if (senderID==UUID.Zero.ToString()) {
sql = "BEGIN;";
sql += "UPDATE " + Table_of_Transactions;
sql += " SET senderBalance = 0, status = ?status WHERE UUID = ?tranid;";
sql += "COMMIT;";
cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?status", (int)Status.PENDING_STATUS); //pending
cmd.Parameters.AddWithValue("?tranid", transactionID.ToString());
}
else {
sql = "BEGIN;";
sql += "UPDATE " + Table_of_Transactions + "," + Table_of_Balances;
sql += " SET senderBalance = balance - ?amount, "+ Table_of_Transactions + ".status = ?status, balance = balance - ?amount ";
sql += " WHERE UUID = ?tranid AND user = sender AND user = ?userid;";
sql += "COMMIT;";
cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?amount", amount);
cmd.Parameters.AddWithValue("?userid", senderID);
cmd.Parameters.AddWithValue("?status", (int)Status.PENDING_STATUS); //pending
cmd.Parameters.AddWithValue("?tranid", transactionID.ToString());
}
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
/// <summary>
/// Give money to the receiver and change the transaction status to success.
/// </summary>
/// <param name="transactionID"></param>
/// <param name="receiverID"></param>
/// <param name="amount"></param>
/// <returns></returns>
public bool giveMoney(UUID transactionID, string receiverID, int amount)
{
string sql = string.Empty;
bool bRet = false;
MySqlCommand cmd = null;
// System
if (receiverID==UUID.Zero.ToString()) {
sql = "BEGIN;";
sql += "UPDATE " + Table_of_Transactions;
sql += " SET receiverBalance = 0, status = ?status WHERE UUID = ?tranid;";
sql += "COMMIT;";
cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?status", (int)Status.SUCCESS_STATUS); //Success
cmd.Parameters.AddWithValue("?tranid", transactionID.ToString());
}
else {
sql = "BEGIN;";
sql += "UPDATE " + Table_of_Transactions + "," + Table_of_Balances;
sql += " SET receiverBalance = balance + ?amount, " + Table_of_Transactions + ".status = ?status, balance = balance + ?amount ";
sql += " WHERE UUID = ?tranid AND user = receiver AND user = ?userid;";
sql += "COMMIT;";
cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?amount", amount);
cmd.Parameters.AddWithValue("?userid", receiverID);
cmd.Parameters.AddWithValue("?status", (int)Status.SUCCESS_STATUS); //Success
cmd.Parameters.AddWithValue("?tranid", transactionID.ToString());
}
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
///////////////////////////////////////////////////////////////////////
//
// totalsales
//
private void initTotalSalesTable()
{
m_log.Info("[MONEY MANAGER]: Initailising TotalSales Table...");
string sql = string.Empty;
sql = "SELECT SQL_CALC_FOUND_ROWS receiver,objectUUID,type,COUNT(*),SUM(amount),MIN(time) FROM "+ Table_of_Transactions;
sql += " WHERE sender != receiver AND status = ?status AND sender != ?system";
sql += " GROUP BY receiver,objectUUID,type;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?status", (int)Status.SUCCESS_STATUS);
cmd.Parameters.AddWithValue("?system", UUID.Zero.ToString());
cmd.ExecuteNonQuery();
MySqlCommand cmd2 = new MySqlCommand("SELECT FOUND_ROWS();", dbcon);
int lineCount = int.Parse(cmd2.ExecuteScalar().ToString());
cmd2.Dispose();
if (lineCount<=0) {
cmd.Dispose();
return;
}
MySqlDataReader r = cmd.ExecuteReader();
int l = 0;
string[,] row = new string[lineCount, r.FieldCount];
while (r.Read()) {
for (int i=0; i<r.FieldCount; i++) {
row[l, i] = r.GetString(i);
}
l++;
}
r.Close();
cmd.Dispose();
for (int i=0; i<lineCount; i++) {
string receiver = (string)row[i,0]; // receiver
string objUUID = (string)row[i,1]; // objectUUID
int type = Convert.ToInt32(row[i,2]); // type
int count = Convert.ToInt32(row[i,3]); // COUNT(*)
int amount = Convert.ToInt32(row[i,4]); // SUM(amount)
int tmstamp = Convert.ToInt32(row[i,5]); // MIN(time)
//
setTotalSale(receiver, objUUID, type, count, amount, tmstamp);
}
}
private void deleteTotalSalesTable()
{
//m_log.Info("[MONEY MANAGER]: Deleting TotalSales Table...");
string sql = string.Empty;
sql = "DELETE FROM "+ Table_of_TotalSales;
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?status", (int)Status.SUCCESS_STATUS);
cmd.ExecuteNonQuery();
cmd.Dispose();
return;
}
public bool addTotalSale(string userUUID, string objectUUID, int type, int count, int amount, int tmstamp)
{
bool bRet = false;
string sql = string.Empty;
UUID uuid = UUID.Random();
// オブジェクトを伴う取引のみ記録
// if (objectUUID==UUID.Zero.ToString()) return bRet;
sql = "INSERT INTO " + Table_of_TotalSales;
sql += " (`UUID`,`user`,`objectUUID`,`type`,`TotalCount`,`TotalAmount`,`time`) VALUES";
sql += " (?ID,?userID,?objID,?type,?count,?amount,?time)";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?ID", uuid.ToString());
cmd.Parameters.AddWithValue("?userID", userUUID);
cmd.Parameters.AddWithValue("?objID", objectUUID);
cmd.Parameters.AddWithValue("?type", type);
cmd.Parameters.AddWithValue("?count", count);
cmd.Parameters.AddWithValue("?amount", amount);
cmd.Parameters.AddWithValue("?time", tmstamp);
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
public bool updateTotalSale(UUID saleUUID, int count, int amount, int tmstamp)
{
bool bRet = false;
string sql = string.Empty;
sql = "UPDATE " + Table_of_TotalSales;
sql += " SET TotalCount = TotalCount + ?count, TotalAmount = TotalAmount + ?amount, time = ?time ";
sql += " WHERE UUID = ?uuid;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?uuid", saleUUID.ToString());
cmd.Parameters.AddWithValue("?count", count);
cmd.Parameters.AddWithValue("?amount", amount);
cmd.Parameters.AddWithValue("?time", tmstamp);
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
public bool setTotalSale(string userUUID, string objectUUID, int type, int count, int amount, int tmstamp)
{
bool bRet = false;
string sql = string.Empty;
string uuid = string.Empty;
int dbtm = 0;
sql = "SELECT UUID,time FROM " + Table_of_TotalSales;
sql += " WHERE user = ?userid AND objectUUID = ?objID AND type = ?type;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?userid", userUUID);
cmd.Parameters.AddWithValue("?objID", objectUUID);
cmd.Parameters.AddWithValue("?type", type);
using (MySqlDataReader r = cmd.ExecuteReader()) {
if(r.Read()) {
try {
uuid = (string)r["UUID"];
dbtm = Convert.ToInt32(r["time"]);
}
catch (Exception e) {
m_log.Error("[MONEY MANAGER]: Get sale data from DB failed: " + e.ToString());
r.Close();
cmd.Dispose();
return false;
}
}
r.Close();
}
if (uuid!=string.Empty) {
UUID saleUUID = UUID.Zero;
UUID.TryParse(uuid, out saleUUID);
if (dbtm<tmstamp) tmstamp = dbtm;
bRet = updateTotalSale(saleUUID, count, amount, tmstamp);
}
else {
bRet = addTotalSale(userUUID, objectUUID, type, count, amount, tmstamp);
}
cmd.Dispose();
return bRet;
}
///////////////////////////////////////////////////////////////////////
//
// transactions
//
public bool addTransaction(TransactionData transaction)
{
bool bRet = false;
string sql = string.Empty;
if (transaction.ObjectUUID ==null) transaction.ObjectUUID = UUID.Zero.ToString();
if (transaction.ObjectName ==null) transaction.ObjectName = string.Empty;
if (transaction.Description==null) transaction.Description = string.Empty;
sql = "INSERT INTO " + Table_of_Transactions;
sql += " (`UUID`,`sender`,`receiver`,`amount`,`senderBalance`,`receiverBalance`,`objectUUID`,`objectName`,";
sql += " `regionHandle`,`regionUUID`,`type`,`time`,`secure`,`status`,`commonName`,`description`) VALUES";
sql += " (?transID,?sender,?receiver,?amount,?senderBalance,?receiverBalance,?objID,?objName,?regionHandle,?regionUUID,?type,?time,?secure,?status,?cname,?desc)";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?transID", transaction.TransUUID.ToString());
cmd.Parameters.AddWithValue("?sender", transaction.Sender);
cmd.Parameters.AddWithValue("?receiver", transaction.Receiver);
cmd.Parameters.AddWithValue("?amount", transaction.Amount);
cmd.Parameters.AddWithValue("?senderBalance", -1);
cmd.Parameters.AddWithValue("?receiverBalance", -1);
cmd.Parameters.AddWithValue("?objID", transaction.ObjectUUID);
cmd.Parameters.AddWithValue("?objName", transaction.ObjectName);
cmd.Parameters.AddWithValue("?regionHandle", transaction.RegionHandle);
cmd.Parameters.AddWithValue("?regionUUID", transaction.RegionUUID);
cmd.Parameters.AddWithValue("?type", transaction.Type);
cmd.Parameters.AddWithValue("?time", transaction.Time);
cmd.Parameters.AddWithValue("?secure", transaction.SecureCode);
cmd.Parameters.AddWithValue("?status", transaction.Status);
cmd.Parameters.AddWithValue("?cname", transaction.CommonName);
cmd.Parameters.AddWithValue("?desc", transaction.Description);
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
public bool updateTransactionStatus(UUID transactionID, int status, string description)
{
bool bRet = false;
string sql = string.Empty;
sql = "UPDATE " + Table_of_Transactions + " SET status = ?status,description = ?desc WHERE UUID = ?tranid;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?status", status);
cmd.Parameters.AddWithValue("?desc", description);
cmd.Parameters.AddWithValue("?tranid", transactionID);
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
public bool SetTransExpired(int deadTime)
{
bool bRet = false;
string sql = string.Empty;
sql = "UPDATE " + Table_of_Transactions;
sql += " SET status = ?failedstatus,description = ?desc WHERE time <= ?deadTime AND status = ?pendingstatus;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?failedstatus", (int)Status.FAILED_STATUS);
cmd.Parameters.AddWithValue("?desc", "expired");
cmd.Parameters.AddWithValue("?deadTime", deadTime);
cmd.Parameters.AddWithValue("?pendingstatus", (int)Status.PENDING_STATUS);
if (cmd.ExecuteNonQuery() > 0) bRet = true;
cmd.Dispose();
return bRet;
}
/// <summary>
/// Validate if the transacion is legal
/// </summary>
/// <param name="userID"></param>
/// <param name="transactionID"></param>
/// <returns></returns>
public bool ValidateTransfer(string secureCode, UUID transactionID)
{
bool bRet = false;
string secure = string.Empty;
string sql = string.Empty;
sql = "SELECT secure FROM " + Table_of_Transactions + " WHERE UUID = ?transID;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?transID", transactionID.ToString());
using (MySqlDataReader r = cmd.ExecuteReader()) {
if(r.Read()) {
try {
secure = (string)r["secure"];
}
catch (Exception e) {
m_log.Error("[MONEY MANAGER]: Get transaction from DB failed: " + e.ToString());
}
if (secureCode == secure) bRet = true;
else bRet = false;
}
r.Close();
}
cmd.Dispose();
return bRet;
}
public TransactionData FetchTransaction(UUID transactionID)
{
TransactionData transactionData = new TransactionData();
transactionData.TransUUID = transactionID;
string sql = string.Empty;
sql = "SELECT * FROM " + Table_of_Transactions + " WHERE UUID = ?transID;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?transID", transactionID.ToString());
using (MySqlDataReader r = cmd.ExecuteReader()) {
if (r.Read()) {
try {
transactionData.Sender = (string)r["sender"];
transactionData.Receiver = (string)r["receiver"];
transactionData.Amount = Convert.ToInt32(r["amount"]);
transactionData.SenderBalance = Convert.ToInt32(r["senderBalance"]);
transactionData.ReceiverBalance = Convert.ToInt32(r["receiverBalance"]);
transactionData.Type = Convert.ToInt32(r["type"]);
transactionData.Time = Convert.ToInt32(r["time"]);
transactionData.Status = Convert.ToInt32(r["status"]);
transactionData.CommonName = (string)r["commonName"];
transactionData.RegionHandle = (string)r["regionHandle"];
transactionData.RegionUUID = (string)r["regionUUID"];
//
if (r["objectUUID"] is System.DBNull) transactionData.ObjectUUID = UUID.Zero.ToString();
else transactionData.ObjectUUID = (string)r["objectUUID"];
if (r["objectName"] is System.DBNull) transactionData.ObjectName = string.Empty;
else transactionData.ObjectName = (string)r["objectName"];
if (r["description"] is System.DBNull) transactionData.Description = string.Empty;
else transactionData.Description = (string)r["description"];
}
catch (Exception e) {
m_log.Error("[MONEY MANAGER]: Fetching transaction failed 1: " + e.ToString());
r.Close();
cmd.Dispose();
return null;
}
}
r.Close();
}
cmd.Dispose();
return transactionData;
}
public TransactionData[] FetchTransaction(string userID, int startTime, int endTime, uint index, uint retNum)
{
List<TransactionData> rows = new List<TransactionData>();
string sql = string.Empty;
sql = "SELECT * FROM " + Table_of_Transactions + " WHERE time>=?start AND time<=?end ";
sql += "AND (sender=?user OR receiver=?user) ORDER BY time ASC LIMIT ?index,?num;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?start", startTime);
cmd.Parameters.AddWithValue("?end", endTime);
cmd.Parameters.AddWithValue("?user", userID);
cmd.Parameters.AddWithValue("?index", index);
cmd.Parameters.AddWithValue("?num", retNum);
using (MySqlDataReader r = cmd.ExecuteReader()) {
for (int i = 0; i < retNum; i++) {
if (r.Read()) {
try {
TransactionData transactionData = new TransactionData();
string uuid = (string)r["UUID"];
UUID transUUID;
UUID.TryParse(uuid,out transUUID);
transactionData.TransUUID = transUUID;
transactionData.Sender = (string)r["sender"];
transactionData.Receiver = (string)r["receiver"];
transactionData.Amount = Convert.ToInt32(r["amount"]);
transactionData.SenderBalance = Convert.ToInt32(r["senderBalance"]);
transactionData.ReceiverBalance = Convert.ToInt32(r["receiverBalance"]);
transactionData.Type = Convert.ToInt32(r["type"]);
transactionData.Time = Convert.ToInt32(r["time"]);
transactionData.Status = Convert.ToInt32(r["status"]);
transactionData.CommonName = (string)r["commonName"];
transactionData.RegionHandle = (string)r["regionHandle"];
transactionData.RegionUUID = (string)r["regionUUID"];
//
if (r["objectUUID"] is System.DBNull) transactionData.ObjectUUID = UUID.Zero.ToString();
else transactionData.ObjectUUID = (string)r["objectUUID"];
if (r["objectName"] is System.DBNull) transactionData.ObjectName = string.Empty;
else transactionData.ObjectName = (string)r["objectName"];
if (r["description"] is System.DBNull) transactionData.Description = string.Empty;
else transactionData.Description = (string)r["description"];
//
rows.Add(transactionData);
}
catch (Exception e) {
m_log.Error("[MONEY MANAGER]: Fetching transaction failed 2: " + e.ToString());
r.Close();
cmd.Dispose();
return null;
}
}
}
r.Close();
}
cmd.Dispose();
return rows.ToArray();
}
public int getTransactionNum(string userID, int startTime, int endTime)
{
int iRet = -1;
string sql = string.Empty;
sql = "SELECT COUNT(*) AS number FROM " + Table_of_Transactions + " WHERE time>=?start AND time<=?end ";
sql += "AND (sender=?user OR receiver=?user);";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?start", startTime);
cmd.Parameters.AddWithValue("?end", endTime);
cmd.Parameters.AddWithValue("?user", userID);
using (MySqlDataReader r = cmd.ExecuteReader()) {
if(r.Read()) {
try {
iRet = Convert.ToInt32(r["number"]);
}
catch (Exception e) {
m_log.Error("[MONEY MANAGER]: Unable to get transaction info: " + e.ToString());
}
}
r.Close();
}
cmd.Dispose();
return iRet;
}
///////////////////////////////////////////////////////////////////////
//
// userinfo
//
public bool addUserInfo(UserInfo userInfo)
{
//m_log.Error("[MONEY MANAGER]: Adding UserInfo: " + userInfo.UserID);
bool bRet = false;
string sql = string.Empty;
if (userInfo.Avatar==null) return false;
if (userinfo_rev>=3) {
sql = "INSERT INTO " + Table_of_UserInfo +"(`user`,`simip`,`avatar`,`pass`,`type`,`class`,`serverurl`) VALUES";
sql += "(?user,?simip,?avatar,?password,?type,?class,?serverurl);";
}
else {
sql = "INSERT INTO " + Table_of_UserInfo +"(`user`,`simip`,`avatar`,`pass`) VALUES";
sql += "(?user,?simip,?avatar,?password);";
}
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?user", userInfo.UserID);
cmd.Parameters.AddWithValue("?simip", userInfo.SimIP);
cmd.Parameters.AddWithValue("?avatar", userInfo.Avatar);
cmd.Parameters.AddWithValue("?password", userInfo.PswHash);
if (userinfo_rev>=3) {
cmd.Parameters.AddWithValue("?type", userInfo.Type);
cmd.Parameters.AddWithValue("?class", userInfo.Class);
cmd.Parameters.AddWithValue("?serverurl", userInfo.ServerURL);
}
if (cmd.ExecuteNonQuery()>0) bRet = true;
cmd.Dispose();
return bRet;
}
public UserInfo fetchUserInfo(string userID)
{
//m_log.Error("[MONEY MANAGER]: Fetching UserInfo: " + userID);
UserInfo userInfo = new UserInfo();
userInfo.UserID = null;
string sql = string.Empty;
sql = "SELECT * FROM " + Table_of_UserInfo + " WHERE user = ?userID;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?userID", userID);
using (MySqlDataReader r = cmd.ExecuteReader()) {
if (r.Read()) {
try {
userInfo.UserID = (string)r["user"];
userInfo.SimIP = (string)r["simip"];
userInfo.Avatar = (string)r["avatar"];
userInfo.PswHash = (string)r["pass"];
userInfo.Type = Convert.ToInt32(r["type"]);
userInfo.Class = Convert.ToInt32(r["class"]);
userInfo.ServerURL = (string)r["serverurl"];
}
catch (Exception e) {
m_log.Error("[MONEY MANAGER]: Fetching UserInfo failed: " + e.ToString());
r.Close();
cmd.Dispose();
return null;
}
}
r.Close();
}
cmd.Dispose();
if (userInfo.UserID!=userID) return null;
return userInfo;
}
public bool updateUserInfo(UserInfo userInfo)
{
//m_log.Error("[MONEY MANAGER]: Updating UserInfo: " + userInfo.UserID);
bool bRet = false;
string sql = string.Empty;
sql = "UPDATE " + Table_of_UserInfo + " SET simip=?simip,pass=?pass,class=?class,serverurl=?serverurl WHERE user=?user;";
MySqlCommand cmd = new MySqlCommand(sql, dbcon);
cmd.Parameters.AddWithValue("?simip", userInfo.SimIP);
cmd.Parameters.AddWithValue("?pass", userInfo.PswHash);
cmd.Parameters.AddWithValue("?class", userInfo.Class);
cmd.Parameters.AddWithValue("?serverurl", userInfo.ServerURL);
cmd.Parameters.AddWithValue("?user", userInfo.UserID);
if (cmd.ExecuteNonQuery()>0) bRet = true;
cmd.Dispose();
return bRet;
}
}
}