AMActorRpcHandler.cs 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. using System;
  2. namespace ETModel
  3. {
  4. public abstract class AMActorRpcHandler<E, Request, Response>: IMActorHandler where E: Entity where Request: class, IActorRequest where Response : class, IActorResponse
  5. {
  6. protected static void ReplyError(Response response, Exception e, Action<Response> reply)
  7. {
  8. Log.Error(e);
  9. response.Error = ErrorCode.ERR_RpcFail;
  10. response.Message = e.ToString();
  11. reply(response);
  12. }
  13. protected abstract ETTask Run(E unit, Request message, Action<Response> reply);
  14. public async ETTask Handle(Session session, Entity entity, object actorMessage)
  15. {
  16. try
  17. {
  18. Request request = actorMessage as Request;
  19. if (request == null)
  20. {
  21. Log.Error($"消息类型转换错误: {actorMessage.GetType().FullName} to {typeof (Request).Name}");
  22. return;
  23. }
  24. E e = entity as E;
  25. if (e == null)
  26. {
  27. Log.Error($"Actor类型转换错误: {entity.GetType().Name} to {typeof(E).Name}");
  28. return;
  29. }
  30. int rpcId = request.RpcId;
  31. long instanceId = session.InstanceId;
  32. await this.Run(e, request, response =>
  33. {
  34. // 等回调回来,session可以已经断开了,所以需要判断session InstanceId是否一样
  35. if (session.InstanceId != instanceId)
  36. {
  37. return;
  38. }
  39. response.RpcId = rpcId;
  40. session.Reply(response);
  41. });
  42. }
  43. catch (Exception e)
  44. {
  45. throw new Exception($"解释消息失败: {actorMessage.GetType().FullName}", e);
  46. }
  47. }
  48. public Type GetMessageType()
  49. {
  50. return typeof (Request);
  51. }
  52. }
  53. }