iotgateway/Plugins/Drivers/PLC.AllenBradley/DeviceAllenBradley.cs

176 lines
6.0 KiB
C#
Raw Normal View History

using PluginInterface;
using IoTClient.Clients.PLC;
using Microsoft.Extensions.Logging;
2022-01-24 15:10:56 +00:00
namespace PLC.AllenBradley
2022-01-24 15:10:56 +00:00
{
[DriverSupported("AllenBradley")]
[DriverInfo("AllenBradley", "V1.0.0", "Copyright IoTGateway.net 20230220")]
public class DeviceAllenBradley : IDriver
2022-01-24 15:10:56 +00:00
{
private AllenBradleyClient? _plc;
public ILogger _logger { get; set; }
2022-08-08 07:15:09 +00:00
private readonly string _device;
2022-08-10 08:53:07 +00:00
2022-01-24 15:10:56 +00:00
#region
2022-08-10 08:53:07 +00:00
[ConfigParameter("设备Id")] public string DeviceId { get; set; }
2022-01-24 15:10:56 +00:00
2022-08-10 08:53:07 +00:00
[ConfigParameter("IP地址")] public string IpAddress { get; set; } = "127.0.0.1";
2022-01-24 15:10:56 +00:00
[ConfigParameter("端口号")] public int Port { get; set; } = 44818;
2022-01-24 15:10:56 +00:00
2022-08-10 08:53:07 +00:00
[ConfigParameter("超时时间ms")] public int Timeout { get; set; } = 3000;
2022-01-24 15:10:56 +00:00
2022-08-10 08:53:07 +00:00
[ConfigParameter("最小通讯周期ms")] public uint MinPeriod { get; set; } = 3000;
2022-01-24 15:10:56 +00:00
#endregion
#region
public DeviceAllenBradley(string device, ILogger logger)
2022-01-24 15:10:56 +00:00
{
_device = device;
_logger = logger;
_logger.LogInformation($"Device:[{device}],Create()");
2022-01-24 15:10:56 +00:00
}
public bool IsConnected => _plc is { Connected: true };
2022-01-24 15:10:56 +00:00
public bool Connect()
{
try
{
_logger.LogInformation($"Device:[{_device}],Connect()");
_plc = new AllenBradleyClient(IpAddress, Port);
2022-08-10 08:53:07 +00:00
_plc.Open();
2022-01-24 15:10:56 +00:00
}
catch (Exception)
{
return false;
}
2022-08-10 08:53:07 +00:00
2022-01-24 15:10:56 +00:00
return IsConnected;
}
public bool Close()
{
try
{
_logger.LogInformation($"Device:[{_device}],Close()");
2022-08-10 08:53:07 +00:00
_plc?.Close();
2022-01-24 15:10:56 +00:00
return !IsConnected;
}
catch (Exception ex)
2022-01-24 15:10:56 +00:00
{
_logger.LogError(ex,$"Device:[{_device}],Close()");
2022-01-24 15:10:56 +00:00
return false;
}
}
public void Dispose()
{
try
{
2022-08-10 08:53:07 +00:00
_plc = null;
// Suppress finalization.
GC.SuppressFinalize(this);
_logger.LogInformation($"Device:[{_device}],Dispose()");
2022-01-24 15:10:56 +00:00
}
catch (Exception ex)
2022-01-24 15:10:56 +00:00
{
_logger.LogError(ex, $"Device:[{_device}],Dispose(),Error");
2022-01-24 15:10:56 +00:00
}
}
#endregion
#region
2022-01-24 15:10:56 +00:00
[Method("读AllenBradleyPLC标准地址", description: "读AllenBradleyPLC标准地址")]
2022-01-24 15:10:56 +00:00
public DriverReturnValueModel Read(DriverAddressIoArgModel ioarg)
{
var ret = new DriverReturnValueModel { StatusType = VaribaleStatusTypeEnum.Good };
2022-08-10 08:53:07 +00:00
if (_plc != null && this.IsConnected)
2022-01-24 15:10:56 +00:00
{
try
{
switch (ioarg.ValueType)
{
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Bit:
ret.Value = _plc.ReadBoolean(ioarg.Address).Value ? 1 : 0;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Bool:
ret.Value = _plc.ReadBoolean(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.UByte:
ret.Value = _plc.ReadByte(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Byte:
ret.Value = (sbyte)_plc.ReadByte(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Uint16:
ret.Value = _plc.ReadUInt16(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Int16:
ret.Value = _plc.ReadInt16(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Uint32:
ret.Value = _plc.ReadUInt32(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Int32:
ret.Value = _plc.ReadInt32(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Float:
ret.Value = _plc.ReadFloat(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Double:
ret.Value = _plc.ReadDouble(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Uint64:
ret.Value = _plc.ReadUInt64(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Int64:
ret.Value = _plc.ReadInt64(ioarg.Address).Value;
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.AsciiString:
ret.Value = _plc.ReadString(ioarg.Address);
2022-01-24 15:10:56 +00:00
break;
2022-08-10 08:53:07 +00:00
case DataTypeEnum.Utf8String:
ret.Value = _plc.ReadString(ioarg.Address);
2022-01-24 15:10:56 +00:00
break;
default:
2022-08-10 08:53:07 +00:00
ret.StatusType = VaribaleStatusTypeEnum.Bad;
ret.Message = $"不支持的类型";
2022-01-24 15:10:56 +00:00
break;
}
}
catch (Exception ex)
{
ret.StatusType = VaribaleStatusTypeEnum.Bad;
ret.Message = $"读取失败,{ex.Message}";
}
}
else
{
ret.StatusType = VaribaleStatusTypeEnum.Bad;
ret.Message = "连接失败";
}
2022-08-10 08:53:07 +00:00
2022-01-24 15:10:56 +00:00
return ret;
}
2022-08-10 08:53:07 +00:00
public async Task<RpcResponse> WriteAsync(string requestId, string method, DriverAddressIoArgModel ioarg)
2022-04-13 09:01:24 +00:00
{
RpcResponse rpcResponse = new() { IsSuccess = false, Description = "设备驱动内未实现写入功能" };
await Task.CompletedTask;
2022-04-13 09:01:24 +00:00
return rpcResponse;
}
#endregion
2022-01-24 15:10:56 +00:00
}
}