| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- using System;
- using System.Threading.Tasks;
- namespace Model
- {
- public abstract class AMActorHandler<E, Message>: IMActorHandler where E: Entity where Message : AMessage
- {
- protected abstract Task<bool> Run(E entity, Message message);
- public async Task<bool> Handle(Session session, Entity entity, ActorRequest message)
- {
- Message msg = message.AMessage as Message;
- if (msg == null)
- {
- Log.Error($"消息类型转换错误: {message.GetType().FullName} to {typeof (Message).Name}");
- return false;
- }
- E e = entity as E;
- if (e == null)
- {
- Log.Error($"Actor类型转换错误: {entity.GetType().Name} to {typeof(E).Name}");
- return false;
- }
- await this.Run(e, msg);
- // 等回调回来,session可以已经断开了,所以需要判断session id是否为0
- if (session.Id == 0)
- {
- return false;
- }
- ActorResponse response = new ActorResponse
- {
- RpcId = message.RpcId
- };
- session.Reply(response);
- return true;
- }
- public Type GetMessageType()
- {
- return typeof (Message);
- }
- }
- public abstract class AMActorRpcHandler<E, Request, Response>: IMActorHandler where E: Entity where Request : AActorRequest where Response : AActorResponse
- {
- protected static void ReplyError(Response response, Exception e, Action<Response> reply)
- {
- Log.Error(e.ToString());
- response.Error = ErrorCode.ERR_RpcFail;
- response.Message = e.ToString();
- reply(response);
- }
- protected abstract Task<bool> Run(E entity, Request message, Action<Response> reply);
- public async Task<bool> Handle(Session session, Entity entity, ActorRequest message)
- {
- try
- {
- Request request = message.AMessage as Request;
- if (request == null)
- {
- Log.Error($"消息类型转换错误: {message.GetType().FullName} to {typeof (Request).Name}");
- return false;
- }
- E e = entity as E;
- if (e == null)
- {
- Log.Error($"Actor类型转换错误: {entity.GetType().Name} to {typeof(E).Name}");
- return false;
- }
- return await this.Run(e, request, response =>
- {
- // 等回调回来,session可以已经断开了,所以需要判断session id是否为0
- if (session.Id == 0)
- {
- return;
- }
- response.RpcId = message.RpcId;
- session.Reply(response);
- });
- }
- catch (Exception e)
- {
- throw new Exception($"解释消息失败: {message.GetType().FullName}", e);
- }
- }
- public Type GetMessageType()
- {
- return typeof (Request);
- }
- }
- }
|