| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- using System;
- using System.Threading.Tasks;
- namespace ETModel
- {
- public abstract class AMActorHandler<E, Message>: IMActorHandler where E: Entity where Message : class
- {
- protected abstract Task Run(E entity, Message message);
- public async Task Handle(Session session, Entity entity, IActorMessage actorRequest)
- {
- Message msg = actorRequest as Message;
- if (msg == null)
- {
- Log.Error($"消息类型转换错误: {actorRequest.GetType().FullName} to {typeof (Message).Name}");
- return;
- }
- E e = entity as E;
- if (e == null)
- {
- Log.Error($"Actor类型转换错误: {entity.GetType().Name} to {typeof(E).Name}");
- return;
- }
- int rpcId = actorRequest.RpcId;
- ActorResponse response = new ActorResponse
- {
- RpcId = rpcId
- };
- session.Reply(response);
- await this.Run(e, msg);
- }
- public Type GetMessageType()
- {
- return typeof (Message);
- }
- }
- public abstract class AMActorRpcHandler<E, Request, Response>: IMActorHandler where E: Entity where Request: class, IActorRequest where Response : class, IActorResponse
- {
- protected static void ReplyError(Response response, Exception e, Action<Response> reply)
- {
- Log.Error(e);
- response.Error = ErrorCode.ERR_RpcFail;
- response.Message = e.ToString();
- reply(response);
- }
- protected abstract Task Run(E unit, Request message, Action<Response> reply);
- public async Task Handle(Session session, Entity entity, IActorMessage actorRequest)
- {
- try
- {
- Request request = actorRequest as Request;
- if (request == null)
- {
- Log.Error($"消息类型转换错误: {actorRequest.GetType().FullName} to {typeof (Request).Name}");
- return;
- }
- E e = entity as E;
- if (e == null)
- {
- Log.Error($"Actor类型转换错误: {entity.GetType().Name} to {typeof(E).Name}");
- return;
- }
- int rpcId = request.RpcId;
-
- long instanceId = session.InstanceId;
-
- await this.Run(e, request, response =>
- {
- // 等回调回来,session可以已经断开了,所以需要判断session InstanceId是否一样
- if (session.InstanceId != instanceId)
- {
- return;
- }
- response.RpcId = rpcId;
-
- session.Reply(response);
- });
- }
- catch (Exception e)
- {
- throw new Exception($"解释消息失败: {actorRequest.GetType().FullName}", e);
- }
- }
- public Type GetMessageType()
- {
- return typeof (Request);
- }
- }
- }
|