feat: added support for platform logos

This commit is contained in:
Michael Green
2023-04-09 23:45:48 +10:00
parent 913a7ad1e3
commit 36616caf7b
6 changed files with 62 additions and 14 deletions

View File

@@ -94,7 +94,7 @@ namespace gaseous_server.Classes
//Console.WriteLine(Newtonsoft.Json.JsonConvert.SerializeObject(discoveredSignature)); //Console.WriteLine(Newtonsoft.Json.JsonConvert.SerializeObject(discoveredSignature));
IGDB.Models.Platform determinedPlatform = Platforms.GetPlatform(discoveredSignature.Flags.IGDBPlatformId); IGDB.Models.Platform determinedPlatform = Metadata.Platforms.GetPlatform(discoveredSignature.Flags.IGDBPlatformId);
} }
} }
} }

View File

@@ -0,0 +1,40 @@
using System;
using gaseous_tools;
using IGDB;
using IGDB.Models;
using MySqlX.XDevAPI.Common;
using static gaseous_tools.Config.ConfigFile;
namespace gaseous_server.Classes.Metadata
{
public class PlatformLogos
{
public PlatformLogos()
{
}
private static IGDBClient igdb = new IGDBClient(
// Found in Twitch Developer portal for your app
Config.IGDB.ClientId,
Config.IGDB.Secret
);
public async static void GetPlatformLogo(long Id, string LogoPath)
{
var logo_results = await igdb.QueryAsync<PlatformLogo>(IGDBClient.Endpoints.PlatformLogos, query: "fields alpha_channel,animated,checksum,height,image_id,url,width; where id = " + Id + ";");
var logo_result = logo_results.First();
using (var client = new HttpClient())
{
using (var s = client.GetStreamAsync("https:" + logo_result.Url))
{
using (var fs = new FileStream(LogoPath, FileMode.OpenOrCreate))
{
s.Result.CopyTo(fs);
}
}
}
}
}
}

View File

@@ -96,19 +96,7 @@ namespace gaseous_server.Classes.Metadata
// get platform logo // get platform logo
if (result.PlatformLogo != null) if (result.PlatformLogo != null)
{ {
var logo_results = await igdb.QueryAsync<PlatformLogo>(IGDBClient.Endpoints.PlatformLogos, query: "fields alpha_channel,animated,checksum,height,image_id,url,width; where id = " + result.PlatformLogo.Id + ";"); PlatformLogos.GetPlatformLogo((long)result.PlatformLogo.Id, Path.Combine(Config.LibraryConfiguration.LibraryMetadataDirectory_Platform(result), "platform_logo.jpg"));
var logo_result = logo_results.First();
using (var client = new HttpClient())
{
using (var s = client.GetStreamAsync("https:" + logo_result.Url))
{
using (var fs = new FileStream(Path.Combine(Config.LibraryConfiguration.LibraryMetadataDirectory_Platform(result), "platform_logo.jpg"), FileMode.OpenOrCreate))
{
s.Result.CopyTo(fs);
}
}
}
} }
return result; return result;

View File

@@ -23,6 +23,7 @@
<None Remove="Classes\" /> <None Remove="Classes\" />
<None Remove="Classes\SignatureIngestors\" /> <None Remove="Classes\SignatureIngestors\" />
<None Remove="Support\" /> <None Remove="Support\" />
<None Remove="Classes\Metadata\" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Folder Include="Controllers\" /> <Folder Include="Controllers\" />
@@ -31,6 +32,7 @@
<Folder Include="Classes\SignatureIngestors\" /> <Folder Include="Classes\SignatureIngestors\" />
<Folder Include="Support\" /> <Folder Include="Support\" />
<Folder Include="wwwroot\" /> <Folder Include="wwwroot\" />
<Folder Include="Classes\Metadata\" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\gaseous-tools\gaseous-tools.csproj"> <ProjectReference Include="..\gaseous-tools\gaseous-tools.csproj">

View File

@@ -2,6 +2,7 @@
using System.Data; using System.Data;
using Google.Protobuf.WellKnownTypes; using Google.Protobuf.WellKnownTypes;
using Newtonsoft.Json; using Newtonsoft.Json;
using IGDB.Models;
namespace gaseous_tools namespace gaseous_tools
{ {
@@ -246,6 +247,21 @@ namespace gaseous_tools
} }
} }
public string LibraryMetadataDirectory
{
get
{
return Path.Combine(LibraryRootDirectory, "Metadata");
}
}
public string LibraryMetadataDirectory_Platform(Platform platform)
{
string MetadataPath = Path.Combine(LibraryMetadataDirectory, platform.Slug);
if (!Directory.Exists(MetadataPath)) { Directory.CreateDirectory(MetadataPath); }
return MetadataPath;
}
public string LibrarySignatureImportDirectory public string LibrarySignatureImportDirectory
{ {
get get
@@ -267,6 +283,7 @@ namespace gaseous_tools
if (!Directory.Exists(LibraryRootDirectory)) { Directory.CreateDirectory(LibraryRootDirectory); } if (!Directory.Exists(LibraryRootDirectory)) { Directory.CreateDirectory(LibraryRootDirectory); }
if (!Directory.Exists(LibraryImportDirectory)) { Directory.CreateDirectory(LibraryImportDirectory); } if (!Directory.Exists(LibraryImportDirectory)) { Directory.CreateDirectory(LibraryImportDirectory); }
if (!Directory.Exists(LibraryDataDirectory)) { Directory.CreateDirectory(LibraryDataDirectory); } if (!Directory.Exists(LibraryDataDirectory)) { Directory.CreateDirectory(LibraryDataDirectory); }
if (!Directory.Exists(LibraryMetadataDirectory)) { Directory.CreateDirectory(LibraryMetadataDirectory); }
if (!Directory.Exists(LibrarySignatureImportDirectory)) { Directory.CreateDirectory(LibrarySignatureImportDirectory); } if (!Directory.Exists(LibrarySignatureImportDirectory)) { Directory.CreateDirectory(LibrarySignatureImportDirectory); }
if (!Directory.Exists(LibrarySignatureImportDirectory_TOSEC)) { Directory.CreateDirectory(LibrarySignatureImportDirectory_TOSEC); } if (!Directory.Exists(LibrarySignatureImportDirectory_TOSEC)) { Directory.CreateDirectory(LibrarySignatureImportDirectory_TOSEC); }
} }

View File

@@ -10,6 +10,7 @@
<ItemGroup> <ItemGroup>
<PackageReference Include="MySql.Data" Version="8.0.32.1" /> <PackageReference Include="MySql.Data" Version="8.0.32.1" />
<PackageReference Include="Newtonsoft.Json" Version="13.0.3" /> <PackageReference Include="Newtonsoft.Json" Version="13.0.3" />
<PackageReference Include="IGDB" Version="2.3.1" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<None Remove="Database\" /> <None Remove="Database\" />