AMActorRpcHandler.cs 1.5 KB

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