AMActorRpcHandler.cs 1.5 KB

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