|
@@ -4,7 +4,7 @@ namespace ET.Server
|
|
{
|
|
{
|
|
public abstract class AMRpcHandler<Request, Response>: IMHandler where Request : class, IRequest where Response : class, IResponse
|
|
public abstract class AMRpcHandler<Request, Response>: IMHandler where Request : class, IRequest where Response : class, IResponse
|
|
{
|
|
{
|
|
- protected abstract ETTask Run(Session session, Request request, Response response);
|
|
+ protected abstract ETTask Run(Session session, Request request, Response response, Action reply);
|
|
|
|
|
|
public void Handle(Session session, object message)
|
|
public void Handle(Session session, object message)
|
|
{
|
|
{
|
|
@@ -22,29 +22,34 @@ namespace ET.Server
|
|
}
|
|
}
|
|
|
|
|
|
int rpcId = request.RpcId;
|
|
int rpcId = request.RpcId;
|
|
|
|
+
|
|
long instanceId = session.InstanceId;
|
|
long instanceId = session.InstanceId;
|
|
|
|
|
|
Response response = Activator.CreateInstance<Response>();
|
|
Response response = Activator.CreateInstance<Response>();
|
|
|
|
|
|
|
|
+ void Reply()
|
|
|
|
+ {
|
|
|
|
+
|
|
|
|
+ if (session.InstanceId != instanceId)
|
|
|
|
+ {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ response.RpcId = rpcId;
|
|
|
|
+ session.Send(response);
|
|
|
|
+ }
|
|
|
|
+
|
|
try
|
|
try
|
|
{
|
|
{
|
|
- await this.Run(session, request, response);
|
|
+ await this.Run(session, request, response, Reply);
|
|
}
|
|
}
|
|
catch (Exception exception)
|
|
catch (Exception exception)
|
|
{
|
|
{
|
|
Log.Error(exception);
|
|
Log.Error(exception);
|
|
response.Error = ErrorCore.ERR_RpcFail;
|
|
response.Error = ErrorCore.ERR_RpcFail;
|
|
response.Message = exception.ToString();
|
|
response.Message = exception.ToString();
|
|
|
|
+ Reply();
|
|
}
|
|
}
|
|
-
|
|
|
|
-
|
|
|
|
- if (session.InstanceId != instanceId)
|
|
|
|
- {
|
|
|
|
- return;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- response.RpcId = rpcId;
|
|
|
|
- session.Send(response);
|
|
|
|
}
|
|
}
|
|
catch (Exception e)
|
|
catch (Exception e)
|
|
{
|
|
{
|