2020-05-09 22:16:16 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Data;
|
|
|
|
|
using Dapper;
|
2021-09-27 12:42:46 +00:00
|
|
|
|
using Wabbajack.DTOs;
|
|
|
|
|
using Wabbajack.DTOs.CDN;
|
|
|
|
|
using Wabbajack.DTOs.DownloadStates;
|
|
|
|
|
using Wabbajack.DTOs.JsonConverters;
|
|
|
|
|
using Wabbajack.Hashing.xxHash64;
|
|
|
|
|
using Wabbajack.Paths;
|
2020-05-09 22:16:16 +00:00
|
|
|
|
|
|
|
|
|
namespace Wabbajack.Server.DataLayer
|
|
|
|
|
{
|
|
|
|
|
public partial class SqlService
|
|
|
|
|
{
|
2021-09-27 12:42:46 +00:00
|
|
|
|
private static DTOSerializer _dtoStatic;
|
2020-05-09 22:16:16 +00:00
|
|
|
|
static SqlService()
|
|
|
|
|
{
|
|
|
|
|
SqlMapper.AddTypeHandler(new HashMapper());
|
|
|
|
|
SqlMapper.AddTypeHandler(new RelativePathMapper());
|
2021-09-27 12:42:46 +00:00
|
|
|
|
SqlMapper.AddTypeHandler(new JsonMapper<IDownloadState>());
|
|
|
|
|
SqlMapper.AddTypeHandler(new JsonMapper<FileDefinition>());
|
2020-07-15 22:29:43 +00:00
|
|
|
|
SqlMapper.AddTypeHandler(new JsonMapper<ModlistMetadata>());
|
2020-05-09 22:16:16 +00:00
|
|
|
|
SqlMapper.AddTypeHandler(new VersionMapper());
|
|
|
|
|
SqlMapper.AddTypeHandler(new GameMapper());
|
2020-05-12 23:19:54 +00:00
|
|
|
|
SqlMapper.AddTypeHandler(new DateTimeHandler());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Needed to make sure dates are all in UTC format
|
|
|
|
|
/// </summary>
|
|
|
|
|
private class DateTimeHandler : SqlMapper.TypeHandler<DateTime>
|
|
|
|
|
{
|
|
|
|
|
public override void SetValue(IDbDataParameter parameter, DateTime value)
|
|
|
|
|
{
|
|
|
|
|
parameter.Value = value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override DateTime Parse(object value)
|
|
|
|
|
{
|
|
|
|
|
return DateTime.SpecifyKind((DateTime)value, DateTimeKind.Utc);
|
|
|
|
|
}
|
2020-05-09 22:16:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class JsonMapper<T> : SqlMapper.TypeHandler<T>
|
|
|
|
|
{
|
|
|
|
|
public override void SetValue(IDbDataParameter parameter, T value)
|
|
|
|
|
{
|
2021-09-27 12:42:46 +00:00
|
|
|
|
parameter.Value = _dtoStatic.Serialize(value);
|
2020-05-09 22:16:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override T Parse(object value)
|
|
|
|
|
{
|
2021-09-27 12:42:46 +00:00
|
|
|
|
return _dtoStatic.Deserialize<T>((string)value)!;
|
2020-05-09 22:16:16 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class RelativePathMapper : SqlMapper.TypeHandler<RelativePath>
|
|
|
|
|
{
|
|
|
|
|
public override void SetValue(IDbDataParameter parameter, RelativePath value)
|
|
|
|
|
{
|
2021-09-27 12:42:46 +00:00
|
|
|
|
parameter.Value = value.ToString();
|
2020-05-09 22:16:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override RelativePath Parse(object value)
|
|
|
|
|
{
|
|
|
|
|
return (RelativePath)(string)value;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class HashMapper : SqlMapper.TypeHandler<Hash>
|
|
|
|
|
{
|
|
|
|
|
public override void SetValue(IDbDataParameter parameter, Hash value)
|
|
|
|
|
{
|
|
|
|
|
parameter.Value = (long)value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override Hash Parse(object value)
|
|
|
|
|
{
|
|
|
|
|
return Hash.FromLong((long)value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class VersionMapper : SqlMapper.TypeHandler<Version>
|
|
|
|
|
{
|
|
|
|
|
public override void SetValue(IDbDataParameter parameter, Version value)
|
|
|
|
|
{
|
|
|
|
|
parameter.Value = value.ToString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override Version Parse(object value)
|
|
|
|
|
{
|
|
|
|
|
return Version.Parse((string)value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class GameMapper : SqlMapper.TypeHandler<Game>
|
|
|
|
|
{
|
|
|
|
|
public override void SetValue(IDbDataParameter parameter, Game value)
|
|
|
|
|
{
|
|
|
|
|
parameter.Value = value.ToString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override Game Parse(object value)
|
|
|
|
|
{
|
|
|
|
|
return GameRegistry.GetByFuzzyName((string)value).Game;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|