2024-07-15 16:12:09 +08:00
using AxibugEmuOnline.Web.Common ;
using Microsoft.AspNetCore.Mvc ;
using MySql.Data.MySqlClient ;
2024-11-28 18:01:27 +08:00
using Mysqlx.Crud ;
2024-07-15 16:12:09 +08:00
namespace AxibugEmuOnline.Web.Controllers
{
public class ApiController : Controller
{
private readonly ILogger < ApiController > _logger ;
public ApiController ( ILogger < ApiController > logger )
{
_logger = logger ;
}
2024-09-12 14:35:44 +08:00
[HttpGet]
public JsonResult CheckStandInfo ( int platform , string version )
{
Resp_CheckStandInfo resp = new Resp_CheckStandInfo ( )
{
needUpdateClient = 0 ,
clientVersion = Config . cfg . ClientVersion ,
serverIp = Config . cfg . ServerIp ,
serverPort = Config . cfg . ServerPort ,
downLoadUrl = ""
} ;
return new JsonResult ( resp ) ;
}
2024-07-15 16:12:09 +08:00
[HttpGet]
2025-01-07 10:51:12 +08:00
public JsonResult RomList ( string SearchKey , int Ptype , int GType , int Page , int PageSize )
2024-07-15 16:12:09 +08:00
{
string searchPattern = $"%{SearchKey}%" ;
Resp_GameList resp = new Resp_GameList ( ) ;
2024-08-16 10:09:45 +08:00
resp . gameList = new List < Resp_RomInfo > ( ) ;
2025-01-07 10:51:12 +08:00
MySqlConnection conn = Haoyue_SQLPoolManager . DequeueSQLConn ( "RomList" ) ;
2024-07-15 16:12:09 +08:00
{
2025-01-07 10:51:12 +08:00
string platformCond = "" ;
if ( GType > 0 )
{
platformCond = $" and PlatformType = '{Ptype}' " ;
}
2024-08-16 10:09:45 +08:00
GameType SearchGType = ( GameType ) GType ;
string GameTypeCond = "" ;
switch ( SearchGType )
{
case GameType . NONE :
GameTypeCond = string . Empty ;
break ;
case GameType . ALLINONE :
GameTypeCond = $" and GameType = '<27> Ͽ<EFBFBD> ' " ;
break ;
default :
GameTypeCond = $" and GameType = '{SearchGType.ToString()}' " ;
break ;
}
2025-01-07 10:51:12 +08:00
string query = "SELECT count(id) FROM romlist where `Name` like ?searchPattern " + platformCond + GameTypeCond ;
2024-07-15 16:12:09 +08:00
using ( var command = new MySqlCommand ( query , conn ) )
{
// <20> <> <EFBFBD> ò<EFBFBD> <C3B2> <EFBFBD> ֵ
command . Parameters . AddWithValue ( "?searchPattern" , searchPattern ) ;
// ִ<> в<EFBFBD> ѯ<EFBFBD> <D1AF> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
using ( var reader = command . ExecuteReader ( ) )
{
while ( reader . Read ( ) )
{
2024-08-16 10:09:45 +08:00
resp . resultAllCount = reader . GetInt32 ( 0 ) ;
resp . page = Page ;
resp . maxPage = ( int ) Math . Ceiling ( ( float ) resp . resultAllCount / PageSize ) ;
2024-07-15 16:12:09 +08:00
}
}
}
2024-11-28 18:01:27 +08:00
string HotOrderBy = "ORDER BY playcount DESC, id ASC" ;
2025-01-07 10:51:12 +08:00
query = $"SELECT id,`Name`,GameType,Note,RomUrl,ImgUrl,`Hash`,`playcount`,`stars`,`PlatformType` FROM romlist where `Name` like ?searchPattern {platformCond} {GameTypeCond} {HotOrderBy} LIMIT ?offset, ?pageSize;" ;
2024-07-15 16:12:09 +08:00
using ( var command = new MySqlCommand ( query , conn ) )
{
// <20> <> <EFBFBD> ò<EFBFBD> <C3B2> <EFBFBD> ֵ
command . Parameters . AddWithValue ( "?searchPattern" , searchPattern ) ;
command . Parameters . AddWithValue ( "?offset" , Page * PageSize ) ;
command . Parameters . AddWithValue ( "?pageSize" , PageSize ) ;
// ִ<> в<EFBFBD> ѯ<EFBFBD> <D1AF> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
using ( var reader = command . ExecuteReader ( ) )
{
2024-08-22 14:24:11 +08:00
int orderIndex = Page * PageSize ;
2024-07-15 16:12:09 +08:00
while ( reader . Read ( ) )
{
2024-08-16 10:09:45 +08:00
resp . gameList . Add ( new Resp_RomInfo ( )
{
2024-08-22 14:24:11 +08:00
orderid = orderIndex + + ,
2024-08-16 10:09:45 +08:00
id = reader . GetInt32 ( 0 ) ,
romName = ! reader . IsDBNull ( 1 ) ? reader . GetString ( 1 ) : string . Empty ,
gType = ! reader . IsDBNull ( 2 ) ? reader . GetString ( 2 ) : string . Empty ,
desc = ! reader . IsDBNull ( 3 ) ? reader . GetString ( 3 ) : string . Empty ,
url = ! reader . IsDBNull ( 4 ) ? reader . GetString ( 4 ) : string . Empty ,
imgUrl = ! reader . IsDBNull ( 5 ) ? reader . GetString ( 5 ) : string . Empty ,
hash = ! reader . IsDBNull ( 6 ) ? reader . GetString ( 6 ) : string . Empty ,
2024-11-28 18:01:27 +08:00
playcount = reader . GetInt32 ( 7 ) ,
stars = reader . GetInt32 ( 8 ) ,
2025-01-07 10:51:12 +08:00
ptype = reader . GetInt32 ( 9 ) ,
2024-07-15 16:12:09 +08:00
} ) ;
}
}
}
Haoyue_SQLPoolManager . EnqueueSQLConn ( conn ) ;
}
return new JsonResult ( resp ) ;
}
2024-09-18 12:54:13 +08:00
[HttpGet]
public JsonResult RomInfo ( int Ptype , int RomID )
{
string searchPattern = $"%{RomInfo}%" ;
Resp_RomInfo resp = new Resp_RomInfo ( ) ;
MySqlConnection conn = Haoyue_SQLPoolManager . DequeueSQLConn ( "NesRomList" ) ;
{
2025-01-07 10:51:12 +08:00
string query = $"SELECT id,`Name`,GameType,Note,RomUrl,ImgUrl,`Hash`,`playcount`,`stars`,`PlatformType` FROM romlist where id = ?romid;" ;
2024-09-18 12:54:13 +08:00
using ( var command = new MySqlCommand ( query , conn ) )
{
// <20> <> <EFBFBD> ò<EFBFBD> <C3B2> <EFBFBD> ֵ
command . Parameters . AddWithValue ( "?romid" , RomID ) ;
// ִ<> в<EFBFBD> ѯ<EFBFBD> <D1AF> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
using ( var reader = command . ExecuteReader ( ) )
{
while ( reader . Read ( ) )
{
resp . id = reader . GetInt32 ( 0 ) ;
resp . romName = ! reader . IsDBNull ( 1 ) ? reader . GetString ( 1 ) : string . Empty ;
resp . gType = ! reader . IsDBNull ( 2 ) ? reader . GetString ( 2 ) : string . Empty ;
resp . desc = ! reader . IsDBNull ( 3 ) ? reader . GetString ( 3 ) : string . Empty ;
resp . url = ! reader . IsDBNull ( 4 ) ? reader . GetString ( 4 ) : string . Empty ;
resp . imgUrl = ! reader . IsDBNull ( 5 ) ? reader . GetString ( 5 ) : string . Empty ;
resp . hash = ! reader . IsDBNull ( 6 ) ? reader . GetString ( 6 ) : string . Empty ;
2024-11-28 19:54:59 +08:00
resp . playcount = reader . GetInt32 ( 7 ) ;
resp . stars = reader . GetInt32 ( 8 ) ;
2025-01-07 10:51:12 +08:00
resp . ptype = reader . GetInt32 ( 9 ) ;
2024-09-18 12:54:13 +08:00
}
}
}
Haoyue_SQLPoolManager . EnqueueSQLConn ( conn ) ;
}
return new JsonResult ( resp ) ;
}
2024-08-16 10:09:45 +08:00
enum GameType : byte
{
NONE = 0 ,
ACT ,
ARPG ,
AVG ,
ETC ,
FTG ,
PUZ ,
RAC ,
RPG ,
SLG ,
SPG ,
SRPG ,
STG ,
TAB ,
/// <summary>
/// <20> Ͽ<EFBFBD>
/// </summary>
ALLINONE ,
}
2024-07-15 16:12:09 +08:00
2024-09-12 14:35:44 +08:00
class Resp_CheckStandInfo
{
public int needUpdateClient { get ; set ; }
public string serverIp { get ; set ; }
public ushort serverPort { get ; set ; }
public string clientVersion { get ; set ; }
public string downLoadUrl { get ; set ; }
}
2024-07-15 16:12:09 +08:00
class Resp_GameList
{
2024-08-16 10:09:45 +08:00
public int page { get ; set ; }
public int maxPage { get ; set ; }
public int resultAllCount { get ; set ; }
public List < Resp_RomInfo > gameList { get ; set ; }
2024-07-15 16:12:09 +08:00
}
public class Resp_RomInfo
{
2024-08-22 14:24:11 +08:00
public int orderid { get ; set ; }
2024-08-16 10:09:45 +08:00
public int id { get ; set ; }
2025-01-07 10:51:12 +08:00
public int ptype { get ; set ; }
2024-09-18 12:54:13 +08:00
public string romName { get ; set ; }
2024-08-16 10:09:45 +08:00
public string gType { get ; set ; }
public string desc { get ; set ; }
public string url { get ; set ; }
public string imgUrl { get ; set ; }
public string hash { get ; set ; }
public int stars { get ; set ; }
2024-11-28 18:01:27 +08:00
public int playcount { get ; set ; }
2024-07-15 16:12:09 +08:00
}
}
}