Fix Converters
This commit is contained in:
@ -7,7 +7,7 @@
|
||||
<Authors>Glax</Authors>
|
||||
<RepositoryUrl>https://github.com/C9Glax/CShocker</RepositoryUrl>
|
||||
<RepositoryType>git</RepositoryType>
|
||||
<Version>2.1.1</Version>
|
||||
<Version>2.2.0</Version>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
|
@ -1,6 +1,5 @@
|
||||
using CShocker.Devices.Abstract;
|
||||
using CShocker.Devices.APIs;
|
||||
using CShocker.Ranges;
|
||||
using Newtonsoft.Json;
|
||||
using Newtonsoft.Json.Linq;
|
||||
|
||||
@ -16,33 +15,16 @@ public class ApiJsonConverter : JsonConverter
|
||||
public override object ReadJson(JsonReader reader, Type objectType, object? existingValue, JsonSerializer serializer)
|
||||
{
|
||||
JObject jo = JObject.Load(reader);
|
||||
DeviceApi? apiType = (DeviceApi?)jo.SelectToken("ApiType")?.Value<byte>();
|
||||
|
||||
DeviceApi apiType = (DeviceApi)jo.SelectToken("ApiType")!.Value<byte>();
|
||||
|
||||
switch (apiType)
|
||||
{
|
||||
case DeviceApi.OpenShockHttp:
|
||||
return new OpenShockHttp(
|
||||
jo.SelectToken("IntensityRange")!.ToObject<IntensityRange>()!,
|
||||
jo.SelectToken("DurationRange")!.ToObject<DurationRange>()!,
|
||||
jo.SelectToken("ApiKey")!.Value<string>()!,
|
||||
jo.SelectToken("Endpoint")!.Value<string>()!
|
||||
);
|
||||
return jo.ToObject<OpenShockHttp>()!;
|
||||
case DeviceApi.OpenShockSerial:
|
||||
return new OpenShockSerial(
|
||||
jo.SelectToken("IntensityRange")!.ToObject<IntensityRange>()!,
|
||||
jo.SelectToken("DurationRange")!.ToObject<DurationRange>()!,
|
||||
jo.SelectToken("SerialPortI")!.ToObject<SerialPortInfo>()!,
|
||||
jo.SelectToken("ApiKey")!.Value<string>()!,
|
||||
jo.SelectToken("Endpoint")!.Value<string>()!
|
||||
);
|
||||
return jo.ToObject<OpenShockSerial>()!;
|
||||
case DeviceApi.PiShockHttp:
|
||||
return new PiShockHttp(
|
||||
jo.SelectToken("IntensityRange")!.ToObject<IntensityRange>()!,
|
||||
jo.SelectToken("DurationRange")!.ToObject<DurationRange>()!,
|
||||
jo.SelectToken("ApiKey")!.Value<string>()!,
|
||||
jo.SelectToken("Username")!.Value<string>()!,
|
||||
jo.SelectToken("Endpoint")!.Value<string>()!
|
||||
);
|
||||
return jo.ToObject<PiShockHttp>()!;
|
||||
case DeviceApi.PiShockSerial:
|
||||
throw new NotImplementedException();
|
||||
default:
|
||||
|
12
CShocker/Ranges/IntegerRange.cs
Normal file
12
CShocker/Ranges/IntegerRange.cs
Normal file
@ -0,0 +1,12 @@
|
||||
namespace CShocker.Ranges;
|
||||
|
||||
public readonly struct IntegerRange
|
||||
{
|
||||
public readonly int Min, Max;
|
||||
|
||||
public IntegerRange(int min, int max)
|
||||
{
|
||||
this.Min = min;
|
||||
this.Max = max;
|
||||
}
|
||||
}
|
@ -1,5 +1,4 @@
|
||||
using CShocker.Devices.Abstract;
|
||||
using CShocker.Shockers.Abstract;
|
||||
using CShocker.Shockers.Abstract;
|
||||
using Newtonsoft.Json;
|
||||
using Newtonsoft.Json.Linq;
|
||||
|
||||
@ -17,22 +16,11 @@ public class ShockerJsonConverter : JsonConverter
|
||||
JObject jo = JObject.Load(reader);
|
||||
if (jo.ContainsKey("model")) //OpenShockShocker
|
||||
{
|
||||
return new OpenShockShocker(
|
||||
jo.SelectToken("api")!.ToObject<Api>()!,
|
||||
jo.SelectToken("name")!.Value<string>()!,
|
||||
jo.SelectToken("id")!.Value<string>()!,
|
||||
jo.SelectToken("rfId")!.Value<short>(),
|
||||
(OpenShockShocker.OpenShockModel)jo.SelectToken("model")!.Value<byte>(),
|
||||
jo.SelectToken("createdOn")!.Value<DateTime>(),
|
||||
jo.SelectToken("isPaused")!.Value<bool>()
|
||||
);
|
||||
return jo.ToObject<OpenShockShocker>(serializer)!;
|
||||
}
|
||||
else //PiShockShocker
|
||||
{
|
||||
return new PiShockShocker(
|
||||
jo.SelectToken("api")!.ToObject<Api>()!,
|
||||
jo.SelectToken("Code")!.Value<string>()!
|
||||
);
|
||||
return jo.ToObject<PiShockShocker>(serializer)!;
|
||||
}
|
||||
throw new Exception();
|
||||
}
|
||||
|
Reference in New Issue
Block a user