iotgateway/Plugins/Drivers/DriverMTConnect/MTConnectClient.cs
iioter 9c71e1a286 1.合并@sugerlcc的Modbus驱动写入PR
2.引入NLog,默认写入本地
3.Driver构造函数增加Logger和Device参数,用于记录日志
2022-08-06 18:21:00 +08:00

117 lines
3.0 KiB
C#

using PluginInterface;
using System;
using Microsoft.Extensions.Logging;
using OpenNETCF.MTConnect;
using Device = IoTGateway.Model.Device;
namespace DriverMTConnect
{
internal class MTConnectClient : IDriver
{
#region
[ConfigParameter("设备Id")]
public Guid DeviceId { get; set; }
[ConfigParameter("uri")]
public string Uri { get; set; }
[ConfigParameter("超时时间ms")]
public int Timeout { get; set; } = 3000;
[ConfigParameter("最小通讯周期ms")]
public uint MinPeriod { get; set; } = 3000;
public bool IsConnected { get; set; }
#endregion
EntityClient m_client = null;
public ILogger _logger { get; set; }
private readonly Device _device;
public MTConnectClient(Device device, ILogger logger)
{
_device = device;
_logger = logger;
_logger.LogInformation($"Device:[{_device.DeviceName}],Create()");
}
public bool Close()
{
try
{
m_client = null;
IsConnected = false;
return true;
}
catch (Exception)
{
return false;
}
}
public bool Connect()
{
try
{
m_client = new EntityClient(Uri);
m_client.RequestTimeout = Timeout;
IsConnected = true;
}
catch (Exception)
{
IsConnected = false;
}
return IsConnected;
}
public void Dispose()
{
return;
}
[Method("读MTConnect", description: "读MTConnect ID")]
public DriverReturnValueModel ReadById(DriverAddressIoArgModel Ioarg)
{
var ret = new DriverReturnValueModel { StatusType = VaribaleStatusTypeEnum.Good };
if (IsConnected)
{
try
{
var dataValue = m_client.GetDataItemById(Ioarg.Address).Value;
ret.Value = dataValue;
}
catch (Exception ex)
{
ret.StatusType = VaribaleStatusTypeEnum.Bad;
ret.Message = $"读取失败,{ex.Message}";
}
}
else
{
ret.StatusType = VaribaleStatusTypeEnum.Bad;
ret.Message = "连接失败";
}
return ret;
}
public DriverReturnValueModel Read(DriverAddressIoArgModel Ioarg)
{
var ret = new DriverReturnValueModel { StatusType = VaribaleStatusTypeEnum.Good };
return ret;
}
public async Task<RpcResponse> WriteAsync(string RequestId, string Method, DriverAddressIoArgModel Ioarg)
{
RpcResponse rpcResponse = new() { IsSuccess = false, Description = "设备驱动内未实现写入功能" };
return rpcResponse;
}
}
}