초기커밋
This commit is contained in:
390
ServerCommon/Entity/Attribute/FarmingEffectAttribute.cs
Normal file
390
ServerCommon/Entity/Attribute/FarmingEffectAttribute.cs
Normal file
@@ -0,0 +1,390 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
|
||||
using Newtonsoft.Json;
|
||||
|
||||
|
||||
using ServerCore; using ServerBase;
|
||||
|
||||
|
||||
using SESSION_ID = System.Int32;
|
||||
using WORLD_ID = System.UInt32;
|
||||
using META_ID = System.UInt32;
|
||||
using ENTITY_GUID = System.String;
|
||||
using ACCOUNT_ID = System.String;
|
||||
using OWNER_GUID = System.String;
|
||||
using USER_GUID = System.String;
|
||||
using CHARACTER_GUID = System.String;
|
||||
using ITEM_GUID = System.String;
|
||||
using ENTITY_UNIQUE_ID = System.String;
|
||||
using ANCHOR_META_GUID = System.String;
|
||||
using NPC_UNIQUE_ID = System.String;
|
||||
using FARMING_ENTITY_GUID = System.String;
|
||||
using LOCATION_UNIQUE_ID = System.String;
|
||||
|
||||
|
||||
namespace ServerCommon
|
||||
{
|
||||
public class FarmingEffectAttribute : EntityAttributeBase, ICopyEntityAttributeFromDoc, IMergeWithEntityAttribute
|
||||
{
|
||||
[JsonProperty]
|
||||
public ANCHOR_META_GUID AnchorMetaGuid { get; set; } = string.Empty;
|
||||
[JsonProperty]
|
||||
public LOCATION_UNIQUE_ID LocationUniqueId { get; set; } = string.Empty;
|
||||
[JsonProperty]
|
||||
public META_ID FarmingPropMetaId { get; set; } = 0;
|
||||
|
||||
// 파밍 효과를 요청한 OwnerEntityType.User
|
||||
[JsonProperty]
|
||||
public OwnerEntityType OwnerEntityType { get; set; } = OwnerEntityType.None;
|
||||
// 파밍 효과를 요청한 OwnerEntityType.User GUID
|
||||
[JsonProperty]
|
||||
public OWNER_GUID OwnerGuid { get; set; } = string.Empty;
|
||||
[JsonProperty]
|
||||
public FarmingSummonedEntityType FarmingSummonedEntityType { get; set; } = FarmingSummonedEntityType.None;
|
||||
|
||||
// FarmingSummonedEntityType.User: UserGuid, FarmingSummonedEntityType.Beacon: UgcNpcMetaGuid:
|
||||
[JsonProperty]
|
||||
public FARMING_ENTITY_GUID FarmingEntityGuid { get; set; } = string.Empty;
|
||||
[JsonProperty]
|
||||
public FarmingStateType FarmingState { get; set; } = FarmingStateType.None;
|
||||
|
||||
[JsonProperty]
|
||||
public Int16 FarmingActionReqTryCount { get; set; } = 0;
|
||||
[JsonProperty]
|
||||
public Int16 CompletedRewardCount { get; set; } = 0;
|
||||
|
||||
public DateTime FarmingLastUpdateTime { get; set; } = DateTimeHelper.MinTime;
|
||||
[JsonProperty]
|
||||
public DateTime FarmingStartTime { get; set; } = DateTimeHelper.MinTime;
|
||||
[JsonProperty]
|
||||
public DateTime FarmingEndTime { get; set; } = DateTimeHelper.MinTime;
|
||||
|
||||
public DateTime FarmingRespawnTime { get; set; } = DateTimeHelper.MinTime;
|
||||
|
||||
|
||||
|
||||
public FarmingEffectAttribute(EntityBase owner, EntityBase entityOfOwnerEntityType)
|
||||
: base(owner, entityOfOwnerEntityType)
|
||||
{
|
||||
OwnerEntityType = entityOfOwnerEntityType.onGetOwnerEntityType();
|
||||
OwnerGuid = entityOfOwnerEntityType.onGetGuidOfOwnerEntityType();
|
||||
FarmingState = FarmingStateType.StandBy;
|
||||
}
|
||||
|
||||
public async Task<(Result, EntityHelper.MasterProfile?)> getMasterProfile<TMasterEntity>()
|
||||
where TMasterEntity : EntityBase
|
||||
{
|
||||
var owner = getOwner();
|
||||
var root_parent = owner.getRootParent();
|
||||
|
||||
var server_logic = ServerLogicApp.getServerLogicApp();
|
||||
var server_config = server_logic.getServerConfig();
|
||||
var dynamo_db_client = server_logic.getDynamoDbClient();
|
||||
|
||||
var table_name = ServerBase.DynamoDbDefine.TableNames.Main;
|
||||
|
||||
var result = new Result();
|
||||
var err_msg = string.Empty;
|
||||
|
||||
(result, var master_profile) = EntityHelper.getMasterProfile<TMasterEntity>(root_parent);
|
||||
if (result.isFail())
|
||||
{
|
||||
err_msg = $"Failed to EntityHelper.getMasterProfile<TMasterEntity>() !!! : {result.toBasicString()} - {owner.toBasicString()}";
|
||||
Log.getLogger().debug(err_msg);
|
||||
|
||||
if(OwnerEntityType.User != OwnerEntityType)
|
||||
{
|
||||
err_msg = $"Invalid OwnerEntityType !!! : OwnerEntityType.User == OwnerEntityType - {owner.toBasicString()}";
|
||||
result.setFail(ServerErrorCode.OwnerEntityTypeInvalid, err_msg);
|
||||
Log.getLogger().error(result.toBasicString());
|
||||
|
||||
return (result, null);
|
||||
}
|
||||
|
||||
if (true == OwnerGuid.isNullOrWhiteSpace())
|
||||
{
|
||||
err_msg = $"Invalid OwnerGuid !!! : OwnerGuid:{OwnerGuid} - {owner.toBasicString()}";
|
||||
result.setFail(ServerErrorCode.OwnerGuidInvalid, err_msg);
|
||||
Log.getLogger().error(result.toBasicString());
|
||||
|
||||
return (result, null);
|
||||
}
|
||||
|
||||
(result, var found_nickname_attrib) = await dynamo_db_client.simpleQueryDocTypeToAttrib<NicknameDoc, NicknameAttrib>(table_name, OwnerGuid);
|
||||
if (result.isFail())
|
||||
{
|
||||
return (result, null);
|
||||
}
|
||||
NullReferenceCheckHelper.throwIfNull(found_nickname_attrib, () => $"found_nickname_attrib in null !!! - {owner.toBasicString()}");
|
||||
|
||||
master_profile = new EntityHelper.MasterProfile();
|
||||
master_profile.MasterGuid = OwnerGuid;
|
||||
master_profile.MasterNickname = found_nickname_attrib.Nickname;
|
||||
}
|
||||
|
||||
return (result, master_profile);
|
||||
}
|
||||
|
||||
public override void newEntityAttribute()
|
||||
{
|
||||
base.newEntityAttribute();
|
||||
}
|
||||
|
||||
public override void onClear()
|
||||
{
|
||||
AnchorMetaGuid = string.Empty;
|
||||
LocationUniqueId = string.Empty;
|
||||
FarmingPropMetaId = 0;
|
||||
OwnerEntityType = OwnerEntityType.None;
|
||||
OwnerGuid = string.Empty;
|
||||
|
||||
FarmingSummonedEntityType = FarmingSummonedEntityType.None;
|
||||
FarmingEntityGuid = string.Empty;
|
||||
FarmingState = FarmingStateType.None;
|
||||
|
||||
FarmingActionReqTryCount = 0;
|
||||
CompletedRewardCount = 0;
|
||||
FarmingLastUpdateTime = DateTimeHelper.MinTime;
|
||||
|
||||
FarmingStartTime = DateTimeHelper.MinTime;
|
||||
FarmingEndTime = DateTimeHelper.MinTime;
|
||||
FarmingRespawnTime = DateTimeHelper.MinTime;
|
||||
|
||||
getAttributeState().reset();
|
||||
}
|
||||
|
||||
public override EntityAttributeBase onCloned()
|
||||
{
|
||||
var owner = getOwner();
|
||||
|
||||
var entity_of_owner_entity_type = getEntityOfOwnerEntityType();
|
||||
NullReferenceCheckHelper.throwIfNull(entity_of_owner_entity_type, () => $"entity_of_owner_entity_type is null !!! - {owner.toBasicString()}");
|
||||
|
||||
var cloned = new FarmingEffectAttribute(getOwner(), entity_of_owner_entity_type);
|
||||
|
||||
cloned.deepCopyFromBase(this);
|
||||
|
||||
cloned.AnchorMetaGuid = AnchorMetaGuid;
|
||||
cloned.LocationUniqueId = LocationUniqueId;
|
||||
cloned.FarmingPropMetaId = FarmingPropMetaId;
|
||||
cloned.OwnerEntityType = OwnerEntityType;
|
||||
cloned.OwnerGuid = OwnerGuid;
|
||||
cloned.FarmingSummonedEntityType = FarmingSummonedEntityType;
|
||||
cloned.FarmingEntityGuid = FarmingEntityGuid;
|
||||
cloned.FarmingState = FarmingState;
|
||||
cloned.FarmingActionReqTryCount = FarmingActionReqTryCount;
|
||||
cloned.CompletedRewardCount = CompletedRewardCount;
|
||||
cloned.FarmingLastUpdateTime = FarmingLastUpdateTime;
|
||||
cloned.FarmingStartTime = FarmingStartTime;
|
||||
cloned.FarmingEndTime = FarmingEndTime;
|
||||
cloned.FarmingRespawnTime = FarmingRespawnTime;
|
||||
|
||||
return cloned;
|
||||
}
|
||||
|
||||
public override IEntityAttributeTransactor onNewEntityAttributeTransactor()
|
||||
{
|
||||
return new FarmingEffectAttributeTransactor(getOwner());
|
||||
}
|
||||
|
||||
public override async Task<(Result, DynamoDbDocBase?)> toDocBase(bool isForQuery = true)
|
||||
{
|
||||
var result = new Result();
|
||||
|
||||
var owner = getOwner();
|
||||
|
||||
//=====================================================================================
|
||||
// Attribute => try pending Doc
|
||||
//=====================================================================================
|
||||
var try_pending_doc = getTryPendingDocBase() as FarmingEffectDoc;
|
||||
if (null == try_pending_doc)
|
||||
{
|
||||
var to_copy_doc = new FarmingEffectDoc( AnchorMetaGuid, LocationUniqueId
|
||||
, FarmingPropMetaId
|
||||
, FarmingSummonedEntityType, FarmingEntityGuid
|
||||
, FarmingState
|
||||
, FarmingActionReqTryCount
|
||||
, FarmingStartTime, FarmingEndTime);
|
||||
|
||||
var origin_doc = getOriginDocBase<FarmingEffectAttribute>();
|
||||
if (null != origin_doc)
|
||||
{
|
||||
to_copy_doc.copyTimestampsFromOriginDocBase(origin_doc);
|
||||
}
|
||||
|
||||
try_pending_doc = to_copy_doc;
|
||||
|
||||
setTryPendingDocBase(try_pending_doc);
|
||||
}
|
||||
|
||||
var to_copy_doc_farming_effect_attrib = try_pending_doc.getAttrib<FarmingEffectAttrib>();
|
||||
NullReferenceCheckHelper.throwIfNull(to_copy_doc_farming_effect_attrib, () => $"to_copy_doc_farming_effect_attrib is null !!! - {owner.toBasicString()}");
|
||||
|
||||
to_copy_doc_farming_effect_attrib.AnchorMetaGuid = AnchorMetaGuid;
|
||||
to_copy_doc_farming_effect_attrib.LocationUniqueId = LocationUniqueId;
|
||||
to_copy_doc_farming_effect_attrib.FarmingPropMetaId = FarmingPropMetaId;
|
||||
to_copy_doc_farming_effect_attrib.FarmingSummonedEntityType = FarmingSummonedEntityType;
|
||||
to_copy_doc_farming_effect_attrib.FarmingEntityGuid = FarmingEntityGuid;
|
||||
to_copy_doc_farming_effect_attrib.FarmingState = FarmingState;
|
||||
to_copy_doc_farming_effect_attrib.FarmingActionReqTryCount = FarmingActionReqTryCount;
|
||||
to_copy_doc_farming_effect_attrib.CompletedRewardCount = CompletedRewardCount;
|
||||
to_copy_doc_farming_effect_attrib.FarmingLastUpdateTime = FarmingLastUpdateTime;
|
||||
to_copy_doc_farming_effect_attrib.FarmingStartTime = FarmingStartTime;
|
||||
to_copy_doc_farming_effect_attrib.FarmingEndTime = FarmingEndTime;
|
||||
to_copy_doc_farming_effect_attrib.FarmingRespawnTime = FarmingRespawnTime;
|
||||
|
||||
if (false == isForQuery)
|
||||
{
|
||||
return (result, try_pending_doc);
|
||||
}
|
||||
|
||||
//=====================================================================================
|
||||
// Doc QueryType 반영
|
||||
//=====================================================================================
|
||||
(result, var to_query_doc) = await applyDoc4Query(try_pending_doc);
|
||||
if (result.isFail())
|
||||
{
|
||||
return (result, null);
|
||||
}
|
||||
|
||||
return (result, to_query_doc);
|
||||
}
|
||||
|
||||
public Result onMerge(EntityAttributeBase otherEntityAttribute)
|
||||
{
|
||||
var owner = getOwner();
|
||||
|
||||
var result = new Result();
|
||||
var err_msg = string.Empty;
|
||||
|
||||
if (null == otherEntityAttribute)
|
||||
{
|
||||
err_msg = $"Invalid Param !!!, otherEntityAttribute is null";
|
||||
result.setFail(ServerErrorCode.FunctionParamNull, err_msg);
|
||||
Log.getLogger().error(result.toBasicString());
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
//=====================================================================================
|
||||
// OtherAttribute => Origin Attribute
|
||||
//=====================================================================================
|
||||
var other_farming_effect_attribute = otherEntityAttribute as FarmingEffectAttribute;
|
||||
if (null == other_farming_effect_attribute)
|
||||
{
|
||||
err_msg = $"Failed to cast FarmingEffectAttribute !!!, other_farming_effect_attribute is null - {owner.toBasicString()}";
|
||||
result.setFail(ServerErrorCode.ClassTypeCastIsNull, err_msg);
|
||||
Log.getLogger().error(result.toBasicString());
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
AnchorMetaGuid = other_farming_effect_attribute.AnchorMetaGuid;
|
||||
LocationUniqueId = other_farming_effect_attribute.LocationUniqueId;
|
||||
FarmingPropMetaId = other_farming_effect_attribute.FarmingPropMetaId;
|
||||
OwnerEntityType = other_farming_effect_attribute.OwnerEntityType;
|
||||
OwnerGuid = other_farming_effect_attribute.OwnerGuid;
|
||||
FarmingSummonedEntityType = other_farming_effect_attribute.FarmingSummonedEntityType;
|
||||
FarmingEntityGuid = other_farming_effect_attribute.FarmingEntityGuid;
|
||||
FarmingState = other_farming_effect_attribute.FarmingState;
|
||||
FarmingActionReqTryCount = other_farming_effect_attribute.FarmingActionReqTryCount;
|
||||
CompletedRewardCount = other_farming_effect_attribute.CompletedRewardCount;
|
||||
FarmingLastUpdateTime = other_farming_effect_attribute.FarmingLastUpdateTime;
|
||||
FarmingStartTime = other_farming_effect_attribute.FarmingStartTime;
|
||||
FarmingEndTime = other_farming_effect_attribute.FarmingEndTime;
|
||||
FarmingRespawnTime = other_farming_effect_attribute.FarmingRespawnTime;
|
||||
|
||||
//=====================================================================================
|
||||
// Attribute Try Pending Doc => Origin Doc
|
||||
//=====================================================================================
|
||||
var try_pending_doc = other_farming_effect_attribute.getTryPendingDocBase() as FarmingEffectDoc;
|
||||
if (null != try_pending_doc)
|
||||
{
|
||||
other_farming_effect_attribute.resetTryPendingDocBase();
|
||||
|
||||
syncOriginDocBaseWithNewDoc<FarmingEffectAttribute>(try_pending_doc);
|
||||
}
|
||||
|
||||
var origin_doc_base = getOriginDocBase<FarmingEffectAttribute>();
|
||||
if (null == origin_doc_base)
|
||||
{
|
||||
// DB 에 저장되어 있지 않는 경우 OriginDoc은 null 이다 !!!
|
||||
return result;
|
||||
}
|
||||
|
||||
var farming_effect_attrib = origin_doc_base.getAttrib<FarmingEffectAttrib>();
|
||||
NullReferenceCheckHelper.throwIfNull(farming_effect_attrib, () => $"farming_effect_attrib is null !!! - {owner.toBasicString()}");
|
||||
|
||||
farming_effect_attrib.AnchorMetaGuid = AnchorMetaGuid;
|
||||
farming_effect_attrib.LocationUniqueId = LocationUniqueId;
|
||||
farming_effect_attrib.FarmingPropMetaId = FarmingPropMetaId;
|
||||
farming_effect_attrib.FarmingSummonedEntityType = FarmingSummonedEntityType;
|
||||
farming_effect_attrib.FarmingEntityGuid = FarmingEntityGuid;
|
||||
farming_effect_attrib.FarmingState = FarmingState;
|
||||
farming_effect_attrib.FarmingActionReqTryCount = FarmingActionReqTryCount;
|
||||
farming_effect_attrib.CompletedRewardCount = CompletedRewardCount;
|
||||
farming_effect_attrib.FarmingLastUpdateTime = FarmingLastUpdateTime;
|
||||
farming_effect_attrib.FarmingStartTime = FarmingStartTime;
|
||||
farming_effect_attrib.FarmingEndTime = FarmingEndTime;
|
||||
farming_effect_attrib.FarmingRespawnTime = FarmingRespawnTime;
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
public bool copyEntityAttributeFromDoc(DynamoDbDocBase? docBase)
|
||||
{
|
||||
var err_msg = string.Empty;
|
||||
|
||||
var owner = getOwner();
|
||||
|
||||
var to_cast_string = typeof(FarmingEffectDoc).Name;
|
||||
|
||||
var farming_effect_doc = docBase as FarmingEffectDoc;
|
||||
if (null == farming_effect_doc)
|
||||
{
|
||||
err_msg = $"Failed to copyEntityAttributeFromDoc() !!!, farming_effect_doc is null :{to_cast_string} - {owner.toBasicString}";
|
||||
Log.getLogger().error(err_msg);
|
||||
return false;
|
||||
}
|
||||
//=====================================================================================
|
||||
// New Doc => Origin Doc
|
||||
//=====================================================================================
|
||||
syncOriginDocBaseWithNewDoc<FarmingEffectAttribute>(farming_effect_doc);
|
||||
|
||||
//=====================================================================================
|
||||
// Doc => Attribute
|
||||
//=====================================================================================
|
||||
var farming_effect_attrib = farming_effect_doc.getAttrib<FarmingEffectAttrib>();
|
||||
NullReferenceCheckHelper.throwIfNull(farming_effect_attrib, () => $"farming_effect_attrib is null !!! - {owner.toBasicString()}");
|
||||
|
||||
AnchorMetaGuid = farming_effect_attrib.AnchorMetaGuid;
|
||||
LocationUniqueId = farming_effect_attrib.LocationUniqueId;
|
||||
FarmingPropMetaId = farming_effect_attrib.FarmingPropMetaId;
|
||||
FarmingSummonedEntityType = farming_effect_attrib.FarmingSummonedEntityType;
|
||||
FarmingEntityGuid = farming_effect_attrib.FarmingEntityGuid;
|
||||
FarmingState = farming_effect_attrib.FarmingState;
|
||||
FarmingActionReqTryCount = farming_effect_attrib.FarmingActionReqTryCount;
|
||||
CompletedRewardCount = farming_effect_attrib.CompletedRewardCount;
|
||||
FarmingLastUpdateTime = farming_effect_attrib.FarmingLastUpdateTime;
|
||||
FarmingStartTime = farming_effect_attrib.FarmingStartTime;
|
||||
FarmingEndTime = farming_effect_attrib.FarmingEndTime;
|
||||
FarmingRespawnTime = farming_effect_attrib.FarmingRespawnTime;
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
public class FarmingEffectAttributeTransactor : EntityAttributeTransactorBase<FarmingEffectAttribute>
|
||||
{
|
||||
public FarmingEffectAttributeTransactor(EntityBase owner)
|
||||
: base(owner)
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user