forked from PGR/ascnet
framework to hepl when managing gacha system
This commit is contained in:
parent
2e8eee0977
commit
770e8fe8e1
|
@ -0,0 +1,34 @@
|
|||
using MessagePack;
|
||||
|
||||
namespace AscNet.GameServer
|
||||
{
|
||||
|
||||
#region MsgPackScheme
|
||||
#pragma warning disable CS8618 // Non-nullable field must contain a non-null value when exiting constructor. Consider declaring as nullable.
|
||||
[MessagePackObject(true)]
|
||||
public class SweepRequest
|
||||
{
|
||||
public int StageId { get; set; }
|
||||
public int Count { get; set; }
|
||||
}
|
||||
|
||||
[MessagePackObject(true)]
|
||||
public class SweepResponse
|
||||
{
|
||||
public int Code { get; set; }
|
||||
}
|
||||
#pragma warning restore CS8618 // Non-nullable field must contain a non-null value when exiting constructor. Consider declaring as nullable.
|
||||
#endregion
|
||||
|
||||
internal class AutoFightModule
|
||||
{
|
||||
[RequestPacketHandler("SweepRequest")]
|
||||
public static void SweepRequestHandler(Session session, Packet.Request packet)
|
||||
{
|
||||
// TODO: Export FightSettle handler to another a function that can be used by this guy too
|
||||
SweepRequest request = packet.Deserialize<SweepRequest>();
|
||||
|
||||
session.SendResponse(new SweepResponse() { Code = 1 }, packet.Id);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,80 @@
|
|||
using AscNet.Common.Database;
|
||||
using AscNet.Common.Util;
|
||||
using AscNet.GameServer.Handlers;
|
||||
using AscNet.Table.V2.client.draw;
|
||||
using AscNet.Table.V2.share.character;
|
||||
|
||||
namespace AscNet.GameServer.Game
|
||||
{
|
||||
internal class DrawManager
|
||||
{
|
||||
public static readonly List<DrawSceneTable> drawSceneTables = TableReaderV2.Parse<DrawSceneTable>();
|
||||
public static readonly List<CharacterTable> charactersTables = TableReaderV2.Parse<CharacterTable>();
|
||||
|
||||
#region DrawTags
|
||||
public const int TagBase = 1;
|
||||
public const int TagEvent = 2;
|
||||
public const int TagSpecialEvent = 3;
|
||||
public const int TagTargetUniframe = 4;
|
||||
public const int TagCollab = 5;
|
||||
public const int TagEndlessSummerBlue = 6;
|
||||
public const int TagCUB = 7;
|
||||
#endregion
|
||||
|
||||
#region Groups
|
||||
public const int GroupMemberTarget = 1;
|
||||
public const int GroupWeaponResearch = 2;
|
||||
public const int GroupTargetWeaponResearch = 4;
|
||||
public const int GroupDormitoryResearch = 6;
|
||||
public const int GroupThemedTargetWeapon = 10;
|
||||
public const int GroupThemedEventConstruct = 11;
|
||||
public const int GroupArrivalConstruct = 12;
|
||||
public const int GroupFateArrivalConstruct = 13;
|
||||
public const int GroupArrivalEventConstruct = 14;
|
||||
public const int GroupFateThemedConstruct = 15;
|
||||
public const int GroupTargetUniframe = 16;
|
||||
public const int GroupAnniversary = 17;
|
||||
public const int GroupFateAnniversaryLimited = 18;
|
||||
public const int GroupCollabTarget = 19;
|
||||
public const int GroupFateCollabTarget = 20;
|
||||
public const int GroupCollabWeaponTarget = 21;
|
||||
public const int GroupCUBTarget = 22;
|
||||
public const int GroupWishingTarget = 23;
|
||||
public const int GroupFateWishingTarget = 24;
|
||||
#endregion
|
||||
|
||||
private readonly Dictionary<int, int> selectedDrawUp = new();
|
||||
|
||||
public void SetUpDrawByGroupId(int groupId, int drawId)
|
||||
{
|
||||
if (selectedDrawUp.ContainsKey(groupId))
|
||||
selectedDrawUp[groupId] = drawId;
|
||||
else
|
||||
selectedDrawUp.Add(groupId, drawId);
|
||||
}
|
||||
|
||||
public static List<DrawInfo> GetDrawInfosByGroup(int groupId)
|
||||
{
|
||||
List<DrawInfo> infos = new();
|
||||
|
||||
switch (groupId)
|
||||
{
|
||||
case GroupArrivalConstruct:
|
||||
// Querying every character scene that is omniframe.
|
||||
infos.AddRange(drawSceneTables.Where(x => x.Type == 1 && charactersTables.Any(y => y.Type == 1 && y.Id == x.ModelId)).DistinctBy(x => x.ModelId).Select(x => new DrawInfo()
|
||||
{
|
||||
Id = x.Id,
|
||||
UseItemId = Inventory.FreeGem,
|
||||
UseItemCount = 1,
|
||||
GroupId = 12,
|
||||
BtnDrawCount = { 1, 10 },
|
||||
Banner = "Assets/Product/Ui/Scene3DPrefab/UiMain3dXiahuo.prefab",
|
||||
EndTime = DateTimeOffset.Now.ToUnixTimeSeconds() * 2
|
||||
}));
|
||||
break;
|
||||
}
|
||||
|
||||
return infos;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,4 +1,9 @@
|
|||
using MessagePack;
|
||||
using AscNet.Common.Database;
|
||||
using AscNet.Common.Util;
|
||||
using AscNet.GameServer.Game;
|
||||
using AscNet.Table.V2.client.draw;
|
||||
using MessagePack;
|
||||
using static AscNet.GameServer.Packet;
|
||||
|
||||
namespace AscNet.GameServer.Handlers
|
||||
{
|
||||
|
@ -51,6 +56,12 @@ namespace AscNet.GameServer.Handlers
|
|||
public long StartTime { get; set; }
|
||||
public long EndTime { get; set; }
|
||||
}
|
||||
|
||||
[MessagePackObject(true)]
|
||||
public class DrawGetDrawInfoListRequest
|
||||
{
|
||||
public int GroupId { get; set; }
|
||||
}
|
||||
#pragma warning restore CS8618 // Non-nullable field must contain a non-null value when exiting constructor. Consider declaring as nullable.
|
||||
#endregion
|
||||
|
||||
|
@ -60,16 +71,19 @@ namespace AscNet.GameServer.Handlers
|
|||
public static void DrawGetDrawGroupListRequestHandler(Session session, Packet.Request packet)
|
||||
{
|
||||
var rsp = new DrawGetDrawGroupListResponse();
|
||||
rsp.DrawGroupInfoList.Add(new()
|
||||
|
||||
{
|
||||
Id = 1,
|
||||
SwitchDrawIdCount = 1,
|
||||
UseDrawId = 1,
|
||||
Order = 1,
|
||||
Tag = 1,
|
||||
EndTime = DateTimeOffset.Now.ToUnixTimeSeconds() * 2,
|
||||
BannerEndTime = DateTimeOffset.Now.ToUnixTimeSeconds() * 2
|
||||
});
|
||||
var drawInfos = DrawManager.GetDrawInfosByGroup(DrawManager.GroupArrivalConstruct);
|
||||
rsp.DrawGroupInfoList.Add(new()
|
||||
{
|
||||
Id = DrawManager.GroupArrivalConstruct,
|
||||
UseDrawId = drawInfos.Count > 0 ? drawInfos.First().Id : 0,
|
||||
Order = 1,
|
||||
Tag = DrawManager.TagEvent,
|
||||
EndTime = DateTimeOffset.Now.ToUnixTimeSeconds() * 2,
|
||||
BannerEndTime = DateTimeOffset.Now.ToUnixTimeSeconds() * 2
|
||||
});
|
||||
}
|
||||
|
||||
session.SendResponse(rsp, packet.Id);
|
||||
}
|
||||
|
@ -77,17 +91,10 @@ namespace AscNet.GameServer.Handlers
|
|||
[RequestPacketHandler("DrawGetDrawInfoListRequest")]
|
||||
public static void DrawGetDrawInfoListRequestHandler(Session session, Packet.Request packet)
|
||||
{
|
||||
DrawGetDrawInfoListRequest request = packet.Deserialize<DrawGetDrawInfoListRequest>();
|
||||
|
||||
DrawGetDrawInfoListResponse rsp = new();
|
||||
rsp.DrawInfoList.Add(new()
|
||||
{
|
||||
Id = 101,
|
||||
UseItemId = 1,
|
||||
UseItemCount = 10,
|
||||
GroupId = 1,
|
||||
BtnDrawCount = { 1, 10 },
|
||||
Banner = "Assets/Product/Ui/Scene3DPrefab/UiMain3dWuqi.prefab",
|
||||
EndTime = DateTimeOffset.Now.ToUnixTimeSeconds() * 2
|
||||
});
|
||||
rsp.DrawInfoList.AddRange(DrawManager.GetDrawInfosByGroup(request.GroupId));
|
||||
|
||||
session.SendResponse(rsp, packet.Id);
|
||||
}
|
||||
|
|
|
@ -306,7 +306,7 @@ namespace AscNet.GameServer.Handlers
|
|||
public static void FightSettleRequestHandler(Session session, Packet.Request packet)
|
||||
{
|
||||
FightSettleRequest req = MessagePackSerializer.Deserialize<FightSettleRequest>(packet.Content);
|
||||
Table.V2.share.fuben.StageTable? stageTable = TableReaderV2.Parse<Table.V2.share.fuben.StageTable>().FirstOrDefault(x => x.StageId == req.Result.StageId);
|
||||
StageTable? stageTable = TableReaderV2.Parse<StageTable>().FirstOrDefault(x => x.StageId == req.Result.StageId);
|
||||
if (stageTable is null)
|
||||
{
|
||||
// FightCheckManagerSettleCodeNotMatch
|
||||
|
|
Loading…
Reference in New Issue