AMActorHandler.cs 2.2 KB

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