Move argument conversion for json into JsonNetInvocationAdapter
This commit is contained in:
parent
d00f1f93b2
commit
7d6b247780
|
|
@ -184,13 +184,7 @@ namespace Microsoft.AspNetCore.SignalR
|
|||
|
||||
try
|
||||
{
|
||||
var arguments = invocationDescriptor.Arguments ?? EmptyArray;
|
||||
|
||||
var args = arguments
|
||||
.Zip(parameters, (a, p) => Convert.ChangeType(a, p.ParameterType))
|
||||
.ToArray();
|
||||
|
||||
var result = methodInfo.Invoke(hub, args);
|
||||
var result = methodInfo.Invoke(hub, invocationDescriptor.Arguments);
|
||||
var resultTask = result as Task;
|
||||
if (resultTask != null)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -3,8 +3,10 @@
|
|||
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Threading.Tasks;
|
||||
using Newtonsoft.Json;
|
||||
using Newtonsoft.Json.Linq;
|
||||
|
||||
namespace Microsoft.AspNetCore.SignalR
|
||||
{
|
||||
|
|
@ -16,11 +18,30 @@ namespace Microsoft.AspNetCore.SignalR
|
|||
{
|
||||
}
|
||||
|
||||
public async Task<InvocationDescriptor> ReadInvocationDescriptorAsync(Stream stream, Func<string, Type[]> getParams)
|
||||
public Task<InvocationDescriptor> ReadInvocationDescriptorAsync(Stream stream, Func<string, Type[]> getParams)
|
||||
{
|
||||
var reader = new JsonTextReader(new StreamReader(stream));
|
||||
// REVIEW: Task.Run()
|
||||
return await Task.Run(() => _serializer.Deserialize<InvocationDescriptor>(reader));
|
||||
return Task.Run(() =>
|
||||
{
|
||||
var jsonInvocation = _serializer.Deserialize<JsonNetInvocationDescriptor>(reader);
|
||||
var invocation = new InvocationDescriptor
|
||||
{
|
||||
Id = jsonInvocation.Id,
|
||||
Method = jsonInvocation.Method,
|
||||
};
|
||||
|
||||
var paramTypes = getParams(jsonInvocation.Method);
|
||||
invocation.Arguments = new object[paramTypes.Length];
|
||||
|
||||
for (int i = 0; i < paramTypes.Length; i++)
|
||||
{
|
||||
var paramType = paramTypes[i];
|
||||
invocation.Arguments[i] = jsonInvocation.Arguments[i].ToObject(paramType, _serializer);
|
||||
}
|
||||
|
||||
return invocation;
|
||||
});
|
||||
}
|
||||
|
||||
public Task WriteInvocationResultAsync(InvocationResultDescriptor resultDescriptor, Stream stream)
|
||||
|
|
@ -41,5 +62,14 @@ namespace Microsoft.AspNetCore.SignalR
|
|||
_serializer.Serialize(writer, value);
|
||||
writer.Flush();
|
||||
}
|
||||
|
||||
private class JsonNetInvocationDescriptor
|
||||
{
|
||||
public string Id { get; set; }
|
||||
|
||||
public string Method { get; set; }
|
||||
|
||||
public JArray Arguments { get; set; }
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue