초기커밋
This commit is contained in:
592
GameServer/Contents/Claim/Action/ClaimAction.cs
Normal file
592
GameServer/Contents/Claim/Action/ClaimAction.cs
Normal file
@@ -0,0 +1,592 @@
|
||||
using Amazon.S3.Model;
|
||||
using Google.Protobuf.WellKnownTypes;
|
||||
using RabbitMQ.Client;
|
||||
using ServerCommon;
|
||||
using ServerCore; using ServerBase;
|
||||
using System;
|
||||
using System.Collections.Concurrent;
|
||||
using System.Collections.Generic;
|
||||
using System.Diagnostics.CodeAnalysis;
|
||||
using System.Linq;
|
||||
using System.Security.Claims;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace GameServer
|
||||
{
|
||||
public class ClaimAction : EntityActionBase
|
||||
{
|
||||
private ConcurrentDictionary<Int32, ServerCommon.Claim> m_normal_claim { get; set; } = new();
|
||||
private ConcurrentDictionary<Int32, ServerCommon.Claim> m_membership_claim { get; set; } = new();
|
||||
|
||||
private bool m_data_load = false;
|
||||
|
||||
public ClaimAction(EntityBase owner) : base(owner)
|
||||
{
|
||||
}
|
||||
|
||||
public override Task<Result> onInit()
|
||||
{
|
||||
var result = new Result();
|
||||
return Task.FromResult(result);
|
||||
}
|
||||
|
||||
|
||||
public void setDataLoad(bool isLoad)
|
||||
{
|
||||
m_data_load = isLoad;
|
||||
}
|
||||
public bool getDataLoad()
|
||||
{
|
||||
return m_data_load;
|
||||
}
|
||||
|
||||
|
||||
public Result setClaimFromDoc(ClaimDoc doc)
|
||||
{
|
||||
var result = new Result();
|
||||
var owner = getOwner();
|
||||
NullReferenceCheckHelper.throwIfNull(owner, () => $"owner is null !!!");
|
||||
|
||||
EntityBase claim;
|
||||
|
||||
var claim_attrib = doc.getAttrib<ClaimAttrib>();
|
||||
NullReferenceCheckHelper.throwIfNull(claim_attrib, () => $"claim_attrib is null !!!");
|
||||
claim = new ServerCommon.Claim(owner, claim_attrib.ClaimType);
|
||||
|
||||
var claim_attribute = claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(claim_attribute, () => $"claim_attribute is null !!!");
|
||||
|
||||
if (false == doc.getAttribWrappers().TryGetValue(typeof(ClaimAttrib), out var to_copy_doc_attrib))
|
||||
{
|
||||
var err_msg = $"Fail to get ClaimAttrib";
|
||||
result.setFail(ServerErrorCode.EntityAttributeNotFound, err_msg);
|
||||
return result;
|
||||
}
|
||||
var attrib_base = to_copy_doc_attrib.getAttribBase();
|
||||
var doc_attrib = attrib_base as ClaimAttrib;
|
||||
if (doc_attrib is null)
|
||||
{
|
||||
var err_msg = $"Fail to get ClaimAttrib";
|
||||
result.setFail(ServerErrorCode.EntityAttributeNotFound, err_msg);
|
||||
return result;
|
||||
}
|
||||
|
||||
claim_attribute.ClaimType = doc_attrib.ClaimType;
|
||||
claim_attribute.ActiveRewardIdx = doc_attrib.ActiveRewardIdx;
|
||||
claim_attribute.ActiveTime = doc_attrib.ActiveTime;
|
||||
claim_attribute.CreateTime = doc_attrib.CreateTime;
|
||||
claim_attribute.CompleteTime = doc_attrib.CompleteTime;
|
||||
claim_attribute.IsComplete = doc_attrib.IsComplete;
|
||||
|
||||
claim_attribute.syncOriginDocBaseWithNewDoc<ClaimAttribute>(doc);
|
||||
|
||||
Int32 claim_id = claim_attribute.ClaimId = doc_attrib.ClaimId;
|
||||
|
||||
var casted_claim = claim as ServerCommon.Claim;
|
||||
NullReferenceCheckHelper.throwIfNull(casted_claim, () => $"casted_claim is null !!!");
|
||||
if (claim_attrib.ClaimType == MetaAssets.ClaimType.Normal)
|
||||
{
|
||||
m_normal_claim.TryAdd(claim_id, casted_claim);
|
||||
}
|
||||
else
|
||||
{
|
||||
m_membership_claim.TryAdd(claim_id, casted_claim);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
public async Task<(Result, List<ClaimMetaData>, List<Int32>)> update()
|
||||
{
|
||||
var result = new Result();
|
||||
var owner = getOwner() as Player;
|
||||
NullReferenceCheckHelper.throwIfNull(owner, () => $"owner is null !!!");
|
||||
|
||||
(var acceptable_claims, var old_claims) = getUpdatableClaims();
|
||||
if (acceptable_claims.Count == 0 && old_claims.Count == 0) return (result, new(), new());
|
||||
|
||||
result = await owner.runTransactionRunnerSafelyWithTransGuid( owner.getUserGuid()
|
||||
, TransactionIdType.PrivateContents, "ClaimUpdate", delegateUpdateClaim);
|
||||
if (result.isFail())
|
||||
{
|
||||
string err_msg = $"Failed to runTransactionRunnerSafelyWithTransGuid() !!! : {result.toBasicString()} - {owner.toBasicString()}";
|
||||
Log.getLogger().error(err_msg);
|
||||
return (result, new(), new());
|
||||
}
|
||||
return (result, acceptable_claims, old_claims);
|
||||
|
||||
async Task<Result> delegateUpdateClaim() => await updateClaim(owner, acceptable_claims, old_claims);
|
||||
|
||||
}
|
||||
|
||||
public (List<ClaimMetaData>, List<Int32>) getUpdatableClaims()
|
||||
{
|
||||
var acceptable_claims = getAcceptableClaims();
|
||||
var old_claims = getOldClaim();
|
||||
return (acceptable_claims, old_claims);
|
||||
}
|
||||
|
||||
public static List<ClaimMetaData> getOldClaims()
|
||||
{
|
||||
List<ClaimMetaData> rets = new();
|
||||
DateTime nowDt = DateTimeHelper.Current;
|
||||
|
||||
foreach (ClaimMetaData metaData in MetaData.Instance._ClaimMetaTable.Values)
|
||||
{
|
||||
if (metaData.EndTime < nowDt)
|
||||
{
|
||||
rets.Add(metaData);
|
||||
}
|
||||
}
|
||||
return rets;
|
||||
}
|
||||
|
||||
private async Task<Result> updateClaim(Player owner, List<ClaimMetaData> acceptableClaim, List<Int32> oldClaim)
|
||||
{
|
||||
(var result, var new_claims) = updateClaims(acceptableClaim, oldClaim);
|
||||
if (result.isFail()) return result;
|
||||
|
||||
var server_logic = GameServerApp.getServerLogic();
|
||||
|
||||
var batch = new QueryBatchEx<QueryRunnerWithDocument>(owner, LogActionType.None, server_logic.getDynamoDbClient());
|
||||
{
|
||||
batch.addQuery(new DBQWriteToAttributeAllWithTransactionRunner());
|
||||
}
|
||||
|
||||
result = await QueryHelper.sendQueryAndBusinessLog(batch);
|
||||
if (result.isFail())
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
foreach (var new_claim in new_claims)
|
||||
{
|
||||
var claim_attribute = new_claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(claim_attribute, () => $"claim_attribute is null !!!");
|
||||
|
||||
if (claim_attribute.ClaimType == MetaAssets.ClaimType.Normal)
|
||||
{
|
||||
m_normal_claim.TryAdd(claim_attribute.ClaimId, new_claim as ServerCommon.Claim);
|
||||
}
|
||||
else
|
||||
{
|
||||
m_membership_claim.TryAdd(claim_attribute.ClaimId, new_claim as ServerCommon.Claim);
|
||||
}
|
||||
}
|
||||
|
||||
foreach (var old_claim in oldClaim)
|
||||
{
|
||||
m_normal_claim.TryRemove(old_claim, out _);
|
||||
m_membership_claim.TryRemove(old_claim, out _);
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
private (Result, List<ServerCommon.Claim>) updateClaims(List<ClaimMetaData> acceptable_claims, List<Int32> oldClaims)
|
||||
{
|
||||
var result = new Result();
|
||||
|
||||
DateTime now = DateTimeHelper.Current;
|
||||
List<ServerCommon.Claim> claims = new();
|
||||
|
||||
foreach (var meta in acceptable_claims)
|
||||
{
|
||||
var claim_id = meta.ClaimId;
|
||||
var claim_type = meta.ClaimType;
|
||||
|
||||
if (claim_type == MetaAssets.ClaimType.Normal)
|
||||
{
|
||||
if (m_normal_claim.ContainsKey(claim_id)) continue;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (m_membership_claim.ContainsKey(claim_id)) continue;
|
||||
}
|
||||
|
||||
var new_claim = makeNewClaim(now, meta);
|
||||
claims.Add(new_claim);
|
||||
//m_normal_claim.TryAdd(claim_id, normal_claim);
|
||||
}
|
||||
|
||||
foreach (var old_claim in oldClaims)
|
||||
{
|
||||
if (false == m_normal_claim.TryGetValue(old_claim, out var normal_claim)) continue;
|
||||
NullReferenceCheckHelper.throwIfNull(normal_claim, () => $"normal_claim is null !!!");
|
||||
var normal_claim_attribute = normal_claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(normal_claim_attribute, () => $"normal_claim_attribute is null !!!");
|
||||
normal_claim_attribute.deleteEntityAttribute();
|
||||
}
|
||||
foreach (var old_claim in oldClaims)
|
||||
{
|
||||
if (false == m_membership_claim.TryGetValue(old_claim, out var membership_claim)) continue;
|
||||
NullReferenceCheckHelper.throwIfNull(membership_claim, () => $"membership_claim is null !!!");
|
||||
var membership_claim_attribute = membership_claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(membership_claim_attribute, () => $"membership_claim_attribute is null !!!");
|
||||
membership_claim_attribute.deleteEntityAttribute();
|
||||
}
|
||||
|
||||
return (result, claims);
|
||||
}
|
||||
|
||||
private ServerCommon.Claim resetClaim(ServerCommon.Claim claim, ClaimMetaData metaData)
|
||||
{
|
||||
var owner = getOwner() as Player;
|
||||
|
||||
DateTime now = DateTimeHelper.Current;
|
||||
var claim_attribute = claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(claim_attribute, () => $"claim_attribute is null !!!");
|
||||
claim_attribute.ActiveRewardIdx = metaData.DetailInfo.First().Value.Idx;
|
||||
claim_attribute.ActiveTime = now;
|
||||
claim_attribute.CreateTime = now;
|
||||
claim_attribute.CompleteTime = now;
|
||||
claim_attribute.IsComplete = 0;
|
||||
claim_attribute.modifiedEntityAttribute();
|
||||
|
||||
return claim;
|
||||
}
|
||||
|
||||
private ServerCommon.Claim updateClaimRewardable(ServerCommon.Claim claim, ClaimMetaData metaData)
|
||||
{
|
||||
var owner = getOwner() as Player;
|
||||
|
||||
DateTime now = DateTimeHelper.Current;
|
||||
|
||||
var claim_attribute = claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(claim_attribute, () => $"claim_attribute is null !!!");
|
||||
claim_attribute.ActiveTime = now.AddSeconds(-86400);
|
||||
claim_attribute.modifiedEntityAttribute();
|
||||
|
||||
return claim;
|
||||
}
|
||||
|
||||
private ServerCommon.Claim makeNewClaim(DateTime now, ClaimMetaData metaData)
|
||||
{
|
||||
var owner = getOwner() as Player;
|
||||
NullReferenceCheckHelper.throwIfNull(owner, () => $"owner is null !!!");
|
||||
|
||||
var claim = new ServerCommon.Claim(getOwner(), metaData.ClaimType);
|
||||
|
||||
var claim_attribute = claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(claim_attribute, () => $"claim_attribute is null !!!");
|
||||
|
||||
claim_attribute.ClaimId = metaData.ClaimId;
|
||||
claim_attribute.ClaimType = metaData.ClaimType;
|
||||
claim_attribute.ActiveRewardIdx = metaData.DetailInfo.First().Value.Idx;
|
||||
claim_attribute.ActiveTime = now;
|
||||
claim_attribute.CreateTime = now;
|
||||
claim_attribute.CompleteTime = now;
|
||||
claim_attribute.IsComplete = 0;
|
||||
|
||||
var new_claim_doc = new ClaimDoc(owner.getUserGuid(), metaData.ClaimType, metaData.ClaimId);
|
||||
claim_attribute.syncOriginDocBaseWithNewDoc<ClaimAttribute>(new_claim_doc);
|
||||
|
||||
var claim_attrib = new_claim_doc.getAttrib<ClaimAttrib>();
|
||||
NullReferenceCheckHelper.throwIfNull(claim_attrib, () => $"claim_attrib is null !!!");
|
||||
|
||||
claim_attrib.ClaimId = metaData.ClaimId;
|
||||
claim_attrib.ClaimType = metaData.ClaimType;
|
||||
claim_attrib.ActiveRewardIdx = metaData.DetailInfo.First().Value.Idx;
|
||||
claim_attrib.ActiveTime = now;
|
||||
claim_attrib.CreateTime = now;
|
||||
claim_attrib.CompleteTime = now;
|
||||
claim_attrib.IsComplete = 0;
|
||||
|
||||
claim_attribute.newEntityAttribute();
|
||||
|
||||
return claim;
|
||||
}
|
||||
|
||||
|
||||
private List<ClaimMetaData> getAcceptableClaims()
|
||||
{
|
||||
var owner = getOwner() as Player;
|
||||
NullReferenceCheckHelper.throwIfNull(owner, () => $"owner is null !!!");
|
||||
|
||||
List<ClaimMetaData> rets = new();
|
||||
|
||||
var current_metas = ClaimRewardHelper.getCurrentClaims();
|
||||
|
||||
foreach (var metaData in current_metas)
|
||||
{
|
||||
var claim_id = metaData.GetMetaId();
|
||||
if (m_normal_claim.ContainsKey(claim_id)) continue;
|
||||
rets.Add(metaData);
|
||||
}
|
||||
return rets;
|
||||
}
|
||||
|
||||
public List<Int32> getOldClaim()
|
||||
{
|
||||
List<ClaimMetaData> old_metas = getOldClaims();
|
||||
List<Int32> old_claims = new();
|
||||
|
||||
foreach (var meta in old_metas)
|
||||
{
|
||||
var claim_id = meta.ClaimId;
|
||||
if (m_normal_claim.ContainsKey(claim_id))
|
||||
{
|
||||
old_claims.Add(claim_id);
|
||||
}
|
||||
}
|
||||
|
||||
return old_claims;
|
||||
}
|
||||
|
||||
|
||||
public async Task cheatClaimReset()
|
||||
{
|
||||
var player = getOwner() as Player;
|
||||
NullReferenceCheckHelper.throwIfNull(player, () => $"player is null !!!");
|
||||
|
||||
var server_logic = GameServerApp.getServerLogic();
|
||||
|
||||
var result = new Result();
|
||||
|
||||
|
||||
var fn_reset_claim = async delegate ()
|
||||
{
|
||||
var result = new Result();
|
||||
var err_msg = string.Empty;
|
||||
|
||||
List<ILogInvoker> log_invokers = new();
|
||||
|
||||
foreach (var normal_claim in m_normal_claim.Values)
|
||||
{
|
||||
var normal_claim_attribute = normal_claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(normal_claim_attribute, () => $"normal_claim_attribute is null !!!");
|
||||
var claim_id = normal_claim_attribute.ClaimId;
|
||||
(result, var claim_meta) = ClaimRewardHelper.getClaimMeta(claim_id, MetaAssets.ClaimType.Normal);
|
||||
if (result.isFail())continue;
|
||||
NullReferenceCheckHelper.throwIfNull(claim_meta, () => $"claim_meta is null !!!");
|
||||
resetClaim(normal_claim, claim_meta);
|
||||
|
||||
var log_invoker = new CheatClaimResetBusinessLog(MetaAssets.ClaimType.Normal, claim_id, normal_claim_attribute.ActiveRewardIdx);
|
||||
log_invokers.Add(log_invoker);
|
||||
}
|
||||
|
||||
foreach (var membership_claim in m_membership_claim.Values)
|
||||
{
|
||||
var membership_claim_attribute = membership_claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(membership_claim_attribute, () => $"normal_claim_attribute is null !!!");
|
||||
var claim_id = membership_claim_attribute.ClaimId;
|
||||
(result, var claim_meta) = ClaimRewardHelper.getClaimMeta(claim_id, MetaAssets.ClaimType.Membership);
|
||||
if (result.isFail()) continue;
|
||||
NullReferenceCheckHelper.throwIfNull(claim_meta, () => $"claim_meta is null !!!");
|
||||
resetClaim(membership_claim, claim_meta);
|
||||
|
||||
var log_invoker = new CheatClaimResetBusinessLog(MetaAssets.ClaimType.Membership, claim_id, membership_claim_attribute.ActiveRewardIdx);
|
||||
log_invokers.Add(log_invoker);
|
||||
}
|
||||
|
||||
var batch = new QueryBatchEx<QueryRunnerWithDocument>(player, LogActionType.CheatCommandClaimReset, server_logic.getDynamoDbClient());
|
||||
{
|
||||
batch.addQuery(new DBQWriteToAttributeAllWithTransactionRunner());
|
||||
}
|
||||
result = await QueryHelper.sendQueryAndBusinessLog(batch);
|
||||
if (result.isFail())
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
foreach (var normal_claim in m_normal_claim.Values)
|
||||
{
|
||||
var normal_claim_attribute = normal_claim.getEntityAttribute<ClaimAttribute>();
|
||||
if (normal_claim_attribute is null) continue;
|
||||
|
||||
var claim_id = normal_claim_attribute.ClaimId;
|
||||
|
||||
}
|
||||
send_GS2C_NTF_CLAIM_UPDATE();
|
||||
|
||||
return result;
|
||||
};
|
||||
|
||||
result = await player.runTransactionRunnerSafely(TransactionIdType.PrivateContents, "CheatResetClaim", fn_reset_claim);
|
||||
if (result.isFail())
|
||||
{
|
||||
var err_msg = $"Failed to runTransactionRunnerSafely() !!! : {result.toBasicString()} - {player.toBasicString()}";
|
||||
Log.getLogger().error(err_msg);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
public async Task cheatClaimUpdateRewardable()
|
||||
{
|
||||
var player = getOwner() as Player;
|
||||
NullReferenceCheckHelper.throwIfNull(player, () => $"server_logic is null !!!");
|
||||
|
||||
var server_logic = GameServerApp.getServerLogic();
|
||||
|
||||
var result = new Result();
|
||||
|
||||
var fn_claim_update_rewardable = async delegate ()
|
||||
{
|
||||
var result = new Result();
|
||||
var err_msg = string.Empty;
|
||||
|
||||
List<ILogInvoker> log_invokers = new();
|
||||
foreach (var normal_claim in m_normal_claim.Values)
|
||||
{
|
||||
var normal_claim_attribute = normal_claim.getEntityAttribute<ClaimAttribute>();
|
||||
if (normal_claim_attribute is null) continue;
|
||||
var claim_id = normal_claim_attribute.ClaimId;
|
||||
(result, var claim_meta) = ClaimRewardHelper.getClaimMeta(claim_id, MetaAssets.ClaimType.Normal);
|
||||
if (result.isFail()) continue;
|
||||
NullReferenceCheckHelper.throwIfNull(claim_meta, () => $"claim_meta is null !!!");
|
||||
updateClaimRewardable(normal_claim, claim_meta);
|
||||
|
||||
var log_invoker = new CheatClaimRewardableBusinessLog(MetaAssets.ClaimType.Normal, claim_id, normal_claim_attribute.ActiveRewardIdx);
|
||||
log_invokers.Add(log_invoker);
|
||||
}
|
||||
|
||||
foreach (var membership_claim in m_membership_claim.Values)
|
||||
{
|
||||
var membership_claim_attribute = membership_claim.getEntityAttribute<ClaimAttribute>();
|
||||
if (membership_claim_attribute is null) continue;
|
||||
var claim_id = membership_claim_attribute.ClaimId;
|
||||
(result, var claim_meta) = ClaimRewardHelper.getClaimMeta(claim_id, MetaAssets.ClaimType.Membership);
|
||||
if (result.isFail()) continue;
|
||||
NullReferenceCheckHelper.throwIfNull(claim_meta, () => $"claim_meta is null !!!");
|
||||
updateClaimRewardable(membership_claim, claim_meta);
|
||||
var log_invoker = new CheatClaimRewardableBusinessLog(MetaAssets.ClaimType.Membership, claim_id, membership_claim_attribute.ActiveRewardIdx);
|
||||
log_invokers.Add(log_invoker);
|
||||
}
|
||||
|
||||
var batch = new QueryBatchEx<QueryRunnerWithDocument>(player, LogActionType.CheatCommandClaimUpdate, server_logic.getDynamoDbClient());
|
||||
{
|
||||
batch.addQuery(new DBQWriteToAttributeAllWithTransactionRunner());
|
||||
}
|
||||
batch.appendBusinessLogs(log_invokers);
|
||||
|
||||
result = await QueryHelper.sendQueryAndBusinessLog(batch);
|
||||
if (result.isFail())
|
||||
{
|
||||
return result;
|
||||
}
|
||||
|
||||
foreach (var normal_claim in m_normal_claim.Values)
|
||||
{
|
||||
var normal_claim_attribute = normal_claim.getEntityAttribute<ClaimAttribute>();
|
||||
if(normal_claim_attribute is null) continue;
|
||||
var claim_id = normal_claim_attribute.ClaimId;
|
||||
|
||||
}
|
||||
send_GS2C_NTF_CLAIM_UPDATE();
|
||||
|
||||
return result;
|
||||
};
|
||||
|
||||
result = await player.runTransactionRunnerSafely(TransactionIdType.PrivateContents, "CheatClaimUpdateRewardable", fn_claim_update_rewardable);
|
||||
if (result.isFail())
|
||||
{
|
||||
var err_msg = $"Failed to runTransactionRunnerSafely() !!! : {result.toBasicString()} - {player.toBasicString()}";
|
||||
Log.getLogger().error(err_msg);
|
||||
return;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public ConcurrentDictionary<Int32, ServerCommon.Claim> getClaims(MetaAssets.ClaimType type)
|
||||
{
|
||||
if (type == MetaAssets.ClaimType.Normal)
|
||||
{
|
||||
|
||||
return m_normal_claim;
|
||||
}
|
||||
else
|
||||
{
|
||||
return m_membership_claim;
|
||||
}
|
||||
}
|
||||
|
||||
public Result getClaim(Int32 claimId, MetaAssets.ClaimType type, [MaybeNullWhen(false)] out ServerCommon.Claim? claim)
|
||||
{
|
||||
var result = new Result();
|
||||
if (type == MetaAssets.ClaimType.Normal)
|
||||
{
|
||||
|
||||
result = getNormalClaim(claimId, out claim);
|
||||
}
|
||||
else
|
||||
{
|
||||
result = getMembershipClaim(claimId, out claim);
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
public ConcurrentDictionary<Int32, ServerCommon.Claim> getNormalClaims()
|
||||
{
|
||||
return m_normal_claim;
|
||||
}
|
||||
|
||||
public Result getNormalClaim(Int32 claimId, [MaybeNullWhen(false)] out ServerCommon.Claim? claim)
|
||||
{
|
||||
var result = new Result();
|
||||
if (false == m_normal_claim.TryGetValue(claimId, out claim))
|
||||
{
|
||||
var err_msg = $"m_normal_claim claimId : {claimId} not exist, {getOwner().toBasicString()}";
|
||||
result.setFail(ServerErrorCode.ClaimInfoNotExist, err_msg);
|
||||
Log.getLogger().error(result.toBasicString());
|
||||
return result;
|
||||
}
|
||||
NullReferenceCheckHelper.throwIfNull(claim, () => $"claim is null !!!");
|
||||
return result;
|
||||
}
|
||||
|
||||
public ConcurrentDictionary<Int32, ServerCommon.Claim> getMembershipClaims()
|
||||
{
|
||||
return m_membership_claim;
|
||||
}
|
||||
|
||||
public Result getMembershipClaim(Int32 claimId, [MaybeNullWhen(false)] out ServerCommon.Claim? claim)
|
||||
{
|
||||
var result = new Result();
|
||||
if (false == m_membership_claim.TryGetValue(claimId, out claim))
|
||||
{
|
||||
var err_msg = $"m_membership_claim claimId : {claimId} not exist, {getOwner().toBasicString()}";
|
||||
result.setFail(ServerErrorCode.ClaimInfoNotExist, err_msg);
|
||||
Log.getLogger().error(result.toBasicString());
|
||||
return result;
|
||||
}
|
||||
NullReferenceCheckHelper.throwIfNull(claim, () => $"claim is null !!!");
|
||||
return result;
|
||||
}
|
||||
|
||||
public override void onClear()
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
public void send_GS2C_NTF_CLAIM_UPDATE()
|
||||
{
|
||||
var player = getOwner() as Player;
|
||||
NullReferenceCheckHelper.throwIfNull(player, () => $"player is null !!!");
|
||||
|
||||
var server_logic = GameServerApp.getServerLogic();
|
||||
NullReferenceCheckHelper.throwIfNull(server_logic, () => $"server_logic is null !!!");
|
||||
|
||||
var normal_claim_infos = ClaimRewardHelper.MakeClaimSendInfo(player, MetaAssets.ClaimType.Normal);
|
||||
var membership_claim_infos = ClaimRewardHelper.MakeClaimSendInfo(player, MetaAssets.ClaimType.Membership);
|
||||
|
||||
foreach (var info in normal_claim_infos)
|
||||
{
|
||||
ClientToGame ntf_packet = new();
|
||||
ntf_packet.Message = new();
|
||||
ntf_packet.Message.ClaimUpdateNoti = new();
|
||||
ntf_packet.Message.ClaimUpdateNoti.ClaimId = info.Key;
|
||||
ntf_packet.Message.ClaimUpdateNoti.NormalInfo = info.Value;
|
||||
ntf_packet.Message.ClaimUpdateNoti.MembershipInfo = membership_claim_infos.TryGetValue(info.Key, out var membership_info) ? membership_info : new();
|
||||
if (false == server_logic.onSendPacket(player, ntf_packet))
|
||||
{
|
||||
Log.getLogger().error($"SendPacket Fail");
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
193
GameServer/Contents/Claim/Action/ClaimRewardAction.cs
Normal file
193
GameServer/Contents/Claim/Action/ClaimRewardAction.cs
Normal file
@@ -0,0 +1,193 @@
|
||||
using GameServer.Reward;
|
||||
using ServerCommon;
|
||||
using ServerControlCenter;
|
||||
using ServerCore; using ServerBase;
|
||||
|
||||
namespace GameServer
|
||||
{
|
||||
public class ClaimRewardReference
|
||||
{
|
||||
public string m_user_guid { get; set; } = string.Empty;
|
||||
public Int32 m_claim_id { get; set; } = 0;
|
||||
public MetaAssets.ClaimType m_claim_type { get; set; } = MetaAssets.ClaimType.Normal;
|
||||
public Int32 m_reward_group_id { get; set; } = 0;
|
||||
public List<MetaAssets.Reward> m_reward_data { get; set; } = new();
|
||||
public ClaimMetaData? m_meta_data { get; set; } = null;
|
||||
|
||||
public ServerCommon.Claim? m_claim { get; set; } = null;
|
||||
|
||||
public List<MetaAssets.Reward> m_rewared_money { get; set; } = new();
|
||||
public List<Item> m_rewarded_items { get; set; } = new();
|
||||
|
||||
public CommonResult m_common_result { get; set; } = new();
|
||||
|
||||
}
|
||||
|
||||
public class ClaimRewardAction : EntityActionBase
|
||||
{
|
||||
public ClaimRewardAction(EntityBase owner)
|
||||
: base(owner)
|
||||
{
|
||||
}
|
||||
|
||||
public override void onClear()
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
public override async Task<Result> onInit()
|
||||
{
|
||||
await Task.CompletedTask;
|
||||
|
||||
var result = new Result();
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
public async Task<Result> rewardClaim(ClaimRewardReference claimRewardRef)
|
||||
{
|
||||
var owner = getOwner() as Player;
|
||||
NullReferenceCheckHelper.throwIfNull(owner, () => $"owner is null !!!");
|
||||
|
||||
setActiveIdx(claimRewardRef);
|
||||
IReward reward_proc = new RewardClaim(owner, claimRewardRef.m_user_guid, claimRewardRef);
|
||||
var result = await RewardManager.It.proceedRewardProcess(reward_proc);
|
||||
if (result.isFail())
|
||||
{
|
||||
return result;
|
||||
}
|
||||
RewardManager.It.postRewardProcess(reward_proc);
|
||||
return new();
|
||||
}
|
||||
|
||||
|
||||
private void setActiveIdx(ClaimRewardReference claimRewardRef)
|
||||
{
|
||||
DateTime now = DateTimeHelper.Current;
|
||||
NullReferenceCheckHelper.throwIfNull(claimRewardRef.m_meta_data, () => $"claimRewardRef.m_meta_data is null !!!");
|
||||
NullReferenceCheckHelper.throwIfNull(claimRewardRef.m_claim, () => $"claimRewardRef.m_claim is null !!!");
|
||||
|
||||
int lastRewarIdx = claimRewardRef.m_meta_data.DetailInfo.Last().Value.Idx;
|
||||
var claimAttribute = claimRewardRef.m_claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(claimAttribute, () => $"claimAttribute is null !!!");
|
||||
|
||||
claimAttribute.ActiveTime = now;
|
||||
int nextActiveIdx = claimAttribute.ActiveRewardIdx + 1;
|
||||
if (nextActiveIdx > lastRewarIdx)
|
||||
{
|
||||
claimAttribute.IsComplete = 1;
|
||||
nextActiveIdx = 0;
|
||||
}
|
||||
claimAttribute.ActiveRewardIdx = nextActiveIdx;
|
||||
claimAttribute.modifiedEntityAttribute();
|
||||
}
|
||||
|
||||
|
||||
public Result claimRewardConditionCheck(ref ClaimRewardReference claimRewardRef)
|
||||
{
|
||||
var owner = getOwner() as Player;
|
||||
NullReferenceCheckHelper.throwIfNull(owner, () => $"owner is null !!!");
|
||||
|
||||
MetaAssets.ClaimType type = claimRewardRef.m_claim_type;
|
||||
(var result, var claim_meta) = ClaimRewardHelper.getClaimMeta(claimRewardRef.m_claim_id, type);
|
||||
if (result.isFail()) return result;
|
||||
|
||||
claimRewardRef.m_meta_data = claim_meta;
|
||||
|
||||
var claim_action = owner.getEntityAction<ClaimAction>();
|
||||
result = claim_action.getClaim(claimRewardRef.m_claim_id, type, out var claim);
|
||||
if (result.isFail()) return result;
|
||||
|
||||
claimRewardRef.m_claim = claim;
|
||||
|
||||
result = timeConditionCheck(ref claimRewardRef);
|
||||
if (result.isFail()) return result;
|
||||
|
||||
result = rewardConditionCheck(ref claimRewardRef);
|
||||
if (result.isFail()) return result;
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
|
||||
private Result timeConditionCheck(ref ClaimRewardReference claimRewardRef)
|
||||
{
|
||||
var result = new Result();
|
||||
|
||||
NullReferenceCheckHelper.throwIfNull(claimRewardRef.m_claim, () => $"claimRewardRef.m_claim is null !!!");
|
||||
NullReferenceCheckHelper.throwIfNull(claimRewardRef.m_meta_data, () => $"claimRewardRef.m_meta_data is null !!!");
|
||||
|
||||
var attribute = claimRewardRef.m_claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(attribute, () => $"attribute is null !!!");
|
||||
|
||||
var active_idx = attribute.ActiveRewardIdx;
|
||||
|
||||
if (false == claimRewardRef.m_meta_data.DetailInfo.TryGetValue(active_idx, out var detailInfo))
|
||||
{
|
||||
var err_msg = $"detailInfo activeIdx = {active_idx} Data not exist";
|
||||
result.setFail(ServerErrorCode.ClaimInfoNotExist, err_msg);
|
||||
return result;
|
||||
}
|
||||
|
||||
var cool_time = detailInfo.CoolTime;
|
||||
var now_dt = DateTimeHelper.Current;
|
||||
var active_time = attribute.ActiveTime;
|
||||
|
||||
if (now_dt < claimRewardRef.m_meta_data.StartTime || claimRewardRef.m_meta_data.EndTime < now_dt)
|
||||
{
|
||||
var err_msg = $"Claim Not Correct Time activeIdx = {active_idx} metaData.StartTime : {claimRewardRef.m_meta_data.StartTime}, metaData.EndTime : {claimRewardRef.m_meta_data.EndTime} ";
|
||||
result.setFail(ServerErrorCode.ClaimRewardEventEnd, err_msg);
|
||||
Log.getLogger().error(result.toBasicString());
|
||||
return result;
|
||||
}
|
||||
|
||||
var apply_cool_second = active_time.AddSeconds(cool_time);
|
||||
|
||||
if (apply_cool_second > now_dt)
|
||||
{
|
||||
var err_msg = $"HandleClaimRewardReq not enough Time to activeIdx = {active_idx} Data not exist";
|
||||
result.setFail(ServerErrorCode.ClaimRewardNotEnoughTime, err_msg);
|
||||
return result;
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
private Result rewardConditionCheck(ref ClaimRewardReference claimRewardRef)
|
||||
{
|
||||
var result = new Result();
|
||||
NullReferenceCheckHelper.throwIfNull(claimRewardRef.m_claim, () => $"claimRewardRef.m_claim is null !!!");
|
||||
NullReferenceCheckHelper.throwIfNull(claimRewardRef.m_meta_data, () => $"claimRewardRef.m_meta_data is null !!!");
|
||||
|
||||
var attribute = claimRewardRef.m_claim.getEntityAttribute<ClaimAttribute>();
|
||||
NullReferenceCheckHelper.throwIfNull(attribute, () => $"attribute is null !!!");
|
||||
|
||||
var active_idx = attribute.ActiveRewardIdx;
|
||||
|
||||
if (false == claimRewardRef.m_meta_data.DetailInfo.TryGetValue(active_idx, out var detailInfo))
|
||||
{
|
||||
var err_msg = $"detailInfo activeIdx = {active_idx} Data not exist";
|
||||
result.setFail(ServerErrorCode.ClaimInfoNotExist, err_msg);
|
||||
return result;
|
||||
}
|
||||
|
||||
int rewardGroupId = detailInfo.RewardGroupId;
|
||||
if (!MetaData.Instance._RewardMetaTable.TryGetValue(rewardGroupId, out var rewardList))
|
||||
{
|
||||
var err_msg = $"_RewardDataTable not exist info rewardGroupId = {rewardGroupId}";
|
||||
result.setFail(ServerErrorCode.RewardInfoNotExist, err_msg);
|
||||
return result;
|
||||
}
|
||||
claimRewardRef.m_reward_group_id = rewardGroupId;
|
||||
claimRewardRef.m_reward_data.Clear();
|
||||
foreach (var reward in rewardList)
|
||||
{
|
||||
claimRewardRef.m_reward_data.Add(reward.Reward);
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user