1
0
mirror of https://github.com/JKorf/CryptoExchange.Net synced 2025-06-07 16:06:15 +00:00

Updated ConstructRequest method so it can be used by most implementations

This commit is contained in:
JKorf 2018-09-21 15:00:21 +02:00
parent a31184573a
commit b46d74ddf8
5 changed files with 69 additions and 29 deletions

View File

@ -31,14 +31,14 @@ namespace CryptoExchange.Net.UnitTests
{
}
public override string AddAuthenticationToUriString(string uri, bool signed)
public override Dictionary<string, string> AddAuthenticationToHeaders(string uri, string method, Dictionary<string, object> parameters, bool signed)
{
return uri;
return base.AddAuthenticationToHeaders(uri, method, parameters, signed);
}
public override IRequest AddAuthenticationToRequest(IRequest request, bool signed)
public override Dictionary<string, object> AddAuthenticationToParameters(string uri, string method, Dictionary<string, object> parameters, bool signed)
{
return request;
return base.AddAuthenticationToParameters(uri, method, parameters, signed);
}
public override string Sign(string toSign)

View File

@ -1,4 +1,5 @@
using CryptoExchange.Net.Interfaces;
using System.Collections.Generic;
namespace CryptoExchange.Net.Authentication
{
@ -11,14 +12,14 @@ namespace CryptoExchange.Net.Authentication
Credentials = credentials;
}
public virtual string AddAuthenticationToUriString(string uri, bool signed)
public virtual Dictionary<string, object> AddAuthenticationToParameters(string uri, string method, Dictionary<string, object> parameters, bool signed)
{
return uri;
return parameters;
}
public virtual IRequest AddAuthenticationToRequest(IRequest request, bool signed)
public virtual Dictionary<string, string> AddAuthenticationToHeaders(string uri, string method, Dictionary<string, object> parameters, bool signed)
{
return request;
return new Dictionary<string, string>();
}
public virtual string Sign(string toSign)

View File

@ -6,6 +6,7 @@ using System.Net;
using System.Net.NetworkInformation;
using System.Net.Sockets;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
using CryptoExchange.Net.Attributes;
using CryptoExchange.Net.Authentication;
@ -28,6 +29,8 @@ namespace CryptoExchange.Net
protected ApiProxy apiProxy;
protected RateLimitingBehaviour rateLimitBehaviour;
protected PostParameters postParametersPosition = PostParameters.InBody;
protected AuthenticationProvider authProvider;
private List<IRateLimiter> rateLimiters;
@ -165,42 +168,57 @@ namespace CryptoExchange.Net
paramString = paramString.Trim(',');
}
log.Write(LogVerbosity.Debug, $"Sending {(signed ? "signed" : "")} request to {request.Uri} {(paramString ?? "")}");
log.Write(LogVerbosity.Debug, $"Sending {method} {(signed ? "signed" : "")} request to {request.Uri} {(paramString ?? "")}");
var result = await ExecuteRequest(request).ConfigureAwait(false);
return result.Error != null ? new CallResult<T>(null, result.Error) : Deserialize<T>(result.Data);
}
protected virtual IRequest ConstructRequest(Uri uri, string method, Dictionary<string, object> parameters, bool signed)
{
if (parameters == null)
parameters = new Dictionary<string, object>();
var uriString = uri.ToString();
parameters = authProvider.AddAuthenticationToParameters(uriString, method, parameters, signed);
if (parameters != null)
{
if (!uriString.EndsWith("?"))
uriString += "?";
var arraysParameters = parameters.Where(p => p.Value.GetType().IsArray).ToList();
foreach(var arrayEntry in arraysParameters)
{
uriString += $"{string.Join("&", ((object[])arrayEntry.Value).Select(v => $"{arrayEntry.Key}[]={v}"))}&";
}
uriString += $"{string.Join("&", parameters.Where(p => !p.Value.GetType().IsArray).Select(s => $"{s.Key}={s.Value}"))}";
uriString = uriString.TrimEnd('&');
}
if (authProvider != null)
uriString = authProvider.AddAuthenticationToUriString(uriString, signed);
if((method == "GET" || method == "DELETE" || ((method == "POST" || method == "PUT") && postParametersPosition == PostParameters.InUri)) && parameters?.Any() == true)
uriString += parameters.CreateParamString();
var request = RequestFactory.Create(uriString);
request.ContentType = "application/json";
request.Accept = "application/json";
request.Method = method;
if (authProvider != null)
request = authProvider.AddAuthenticationToRequest(request, signed);
var headers = authProvider.AddAuthenticationToHeaders(uriString, method, parameters, signed);
foreach (var header in headers)
request.Headers.Add(header.Key, header.Value);
if ((method == "POST" || method == "PUT") && postParametersPosition != PostParameters.InUri)
{
if(parameters?.Any() == true)
WriteParamBody(request, parameters);
else
WriteParamBody(request, "{}");
}
return request;
}
protected void WriteParamBody(IRequest request, string stringData)
{
var data = Encoding.UTF8.GetBytes(stringData);
request.ContentLength = data.Length;
using (var stream = request.GetRequestStream().Result)
stream.Write(data, 0, data.Length);
}
protected void WriteParamBody(IRequest request, Dictionary<string, object> parameters)
{
var stringData = JsonConvert.SerializeObject(parameters.OrderBy(p => p.Key).ToDictionary(p => p.Key, p => p.Value));
WriteParamBody(request, stringData);
}
private async Task<CallResult<string>> ExecuteRequest(IRequest request)
{
var returnedData = "";

View File

@ -1,5 +1,6 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.InteropServices;
using System.Security;
@ -29,6 +30,20 @@ namespace CryptoExchange.Net
parameters.Add(key, value);
}
public static string CreateParamString(this Dictionary<string, object> parameters)
{
var uriString = "?";
var arraysParameters = parameters.Where(p => p.Value.GetType().IsArray).ToList();
foreach (var arrayEntry in arraysParameters)
{
uriString += $"{string.Join("&", ((object[])arrayEntry.Value).Select(v => $"{arrayEntry.Key}[]={v}"))}&";
}
uriString += $"{string.Join("&", parameters.Where(p => !p.Value.GetType().IsArray).Select(s => $"{s.Key}={s.Value}"))}";
uriString = uriString.TrimEnd('&');
return uriString;
}
public static string GetString(this SecureString source)
{
lock (source)

View File

@ -5,4 +5,10 @@
Fail,
Wait
}
public enum PostParameters
{
InBody,
InUri
}
}