108 lines
5.0 KiB
C#
108 lines
5.0 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Data;
|
|
using System.Linq;
|
|
using System.Security.Cryptography;
|
|
using System.Threading.Tasks;
|
|
using gaseous_tools;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
// For more information on enabling MVC for empty projects, visit https://go.microsoft.com/fwlink/?LinkID=397860
|
|
|
|
namespace gaseous_server.Controllers
|
|
{
|
|
[ApiController]
|
|
[Route("api/v1/[controller]/[action]")]
|
|
public class SignaturesController : ControllerBase
|
|
{
|
|
/// <summary>
|
|
/// Get the current signature counts from the database
|
|
/// </summary>
|
|
/// <returns>Number of sources, publishers, games, and rom signatures in the database</returns>
|
|
[HttpGet]
|
|
[ProducesResponseType(StatusCodes.Status200OK)]
|
|
public Models.Signatures_Status Status()
|
|
{
|
|
return new Models.Signatures_Status();
|
|
}
|
|
|
|
[HttpGet]
|
|
[ProducesResponseType(StatusCodes.Status200OK)]
|
|
public List<Models.Signatures_Games> GetSignature(string md5 = "", string sha1 = "")
|
|
{
|
|
if (md5.Length > 0)
|
|
{
|
|
return _GetSignature("Signatures_Roms.md5 = @searchstring", md5);
|
|
} else
|
|
{
|
|
return _GetSignature("Signatures_Roms.sha1 = @searchstring", sha1);
|
|
}
|
|
}
|
|
|
|
[HttpGet]
|
|
[ProducesResponseType(StatusCodes.Status200OK)]
|
|
public List<Models.Signatures_Games> GetByTosecName(string TosecName = "")
|
|
{
|
|
if (TosecName.Length > 0)
|
|
{
|
|
return _GetSignature("Signatures_Roms.name = @searchstring", TosecName);
|
|
} else
|
|
{
|
|
return null;
|
|
}
|
|
}
|
|
|
|
private List<Models.Signatures_Games> _GetSignature(string sqlWhere, string searchString)
|
|
{
|
|
Database db = new gaseous_tools.Database(Database.databaseType.MySql, Config.DatabaseConfiguration.ConnectionString);
|
|
string sql = "SELECT view_Signatures_Games.*, Signatures_Roms.Id AS romid, Signatures_Roms.Name AS romname, Signatures_Roms.Size, Signatures_Roms.CRC, Signatures_Roms.MD5, Signatures_Roms.SHA1, Signatures_Roms.DevelopmentStatus, Signatures_Roms.Attributes, Signatures_Roms.RomType, Signatures_Roms.RomTypeMedia, Signatures_Roms.MediaLabel, Signatures_Roms.MetadataSource FROM Signatures_Roms INNER JOIN view_Signatures_Games ON Signatures_Roms.GameId = view_Signatures_Games.Id WHERE " + sqlWhere;
|
|
Dictionary<string, object> dbDict = new Dictionary<string, object>();
|
|
dbDict.Add("searchString", searchString);
|
|
|
|
DataTable sigDb = db.ExecuteCMD(sql, dbDict);
|
|
|
|
List<Models.Signatures_Games> GamesList = new List<Models.Signatures_Games>();
|
|
|
|
foreach (DataRow sigDbRow in sigDb.Rows)
|
|
{
|
|
Models.Signatures_Games gameItem = new Models.Signatures_Games
|
|
{
|
|
Game = new Models.Signatures_Games.GameItem
|
|
{
|
|
Id = (Int32)sigDbRow["Id"],
|
|
Name = (string)sigDbRow["Name"],
|
|
Description = (string)sigDbRow["Description"],
|
|
Year = (string)sigDbRow["Year"],
|
|
Publisher = (string)sigDbRow["Publisher"],
|
|
Demo = (Models.Signatures_Games.GameItem.DemoTypes)(int)sigDbRow["Demo"],
|
|
System = (string)sigDbRow["Platform"],
|
|
SystemVariant = (string)sigDbRow["SystemVariant"],
|
|
Video = (string)sigDbRow["Video"],
|
|
Country = (string)sigDbRow["Country"],
|
|
Language = (string)sigDbRow["Language"],
|
|
Copyright = (string)sigDbRow["Copyright"]
|
|
},
|
|
Rom = new Models.Signatures_Games.RomItem
|
|
{
|
|
Id = (Int32)sigDbRow["romid"],
|
|
Name = (string)sigDbRow["romname"],
|
|
Size = (Int64)sigDbRow["Size"],
|
|
Crc = (string)sigDbRow["CRC"],
|
|
Md5 = ((string)sigDbRow["MD5"]).ToLower(),
|
|
Sha1 = ((string)sigDbRow["SHA1"]).ToLower(),
|
|
DevelopmentStatus = (string)sigDbRow["DevelopmentStatus"],
|
|
Attributes = Newtonsoft.Json.JsonConvert.DeserializeObject<List<KeyValuePair<string, object>>>((string)Common.ReturnValueIfNull(sigDbRow["Attributes"], "[]")),
|
|
RomType = (Models.Signatures_Games.RomItem.RomTypes)(int)sigDbRow["RomType"],
|
|
RomTypeMedia = (string)sigDbRow["RomTypeMedia"],
|
|
MediaLabel = (string)sigDbRow["MediaLabel"],
|
|
SignatureSource = (gaseous_signature_parser.models.RomSignatureObject.RomSignatureObject.Game.Rom.SignatureSourceType)(Int32)sigDbRow["MetadataSource"]
|
|
}
|
|
};
|
|
GamesList.Add(gameItem);
|
|
}
|
|
return GamesList;
|
|
}
|
|
}
|
|
}
|
|
|