ServiceCenter.cs 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. using SqlSugar;
  2. using WCS.Entity;
  3. namespace ServiceCenter
  4. {
  5. /// <summary>
  6. /// 服务中心
  7. /// </summary>
  8. public static class ServiceHub
  9. {
  10. #region 配置中心
  11. /// <summary>
  12. /// 数据库连接字符串集合
  13. /// </summary>
  14. public static List<DataBaseConnectionString>? DbConnectionStrings { get; set; } = null!;
  15. /// <summary>
  16. /// Redis连接字符串集合
  17. /// </summary>
  18. public static List<DataBaseConnectionString>? RedisConnectionStrings { get; set; } = null!;
  19. /// <summary>
  20. /// 设备信息集合
  21. /// </summary>
  22. public static List<WCS_DeviceInfo> deviceInfos { get; set; } = null!;
  23. /// <summary>
  24. /// 仓库名称
  25. /// </summary>
  26. private static string _WarehouseName { get; set; } = null!;
  27. /// <summary>
  28. /// Http请求超时时间
  29. /// </summary>
  30. private static int _HttpTimeout { get; set; }
  31. /// <summary>
  32. /// Http请求超时时间
  33. /// </summary>
  34. public static int HttpTimeout
  35. {
  36. get
  37. {
  38. return _HttpTimeout;
  39. }
  40. }
  41. /// <summary>
  42. /// 仓库名称
  43. /// </summary>
  44. public static string WarehouseName
  45. {
  46. get
  47. {
  48. return _WarehouseName;
  49. }
  50. }
  51. /// <summary>
  52. /// 设置仓库名称
  53. /// </summary>
  54. /// <param name="warehouseName"></param>
  55. public static void SetWarehouseName(string warehouseName)
  56. {
  57. _WarehouseName = warehouseName;
  58. }
  59. /// <summary>
  60. /// 设置Http请求超时时间
  61. /// </summary>
  62. /// <param name="timeout"></param>
  63. public static void SetHttpTimeout(int timeout)
  64. {
  65. _HttpTimeout = timeout;
  66. }
  67. #endregion 配置中心
  68. #region 系统运行模式
  69. /// <summary>
  70. /// 系统运行模式
  71. /// </summary>
  72. private static List<SystemMode> SystemModes { get; set; } = new List<SystemMode>();
  73. /// <summary>
  74. /// 添加一种模式
  75. /// </summary>
  76. /// <param name="mode">系统模式</param>
  77. public static void AddSystemMode(SystemMode mode)
  78. {
  79. if (SystemModes.Contains(mode)) return;
  80. SystemModes.Add(mode);
  81. }
  82. /// <summary>
  83. /// 是否包含传入模式
  84. /// </summary>
  85. /// <param name="mode">系统模式</param>
  86. /// <returns></returns>
  87. public static bool Any(SystemMode mode)
  88. {
  89. return SystemModes.Contains(mode);
  90. }
  91. #endregion 系统运行模式
  92. }
  93. /// <summary>
  94. /// 系统模式
  95. /// </summary>
  96. public enum SystemMode
  97. {
  98. /// <summary>
  99. /// 虚拟plc,启用该模式后,将在Redis中建立一个虚拟PLC用于流程测试
  100. /// </summary>
  101. 虚拟plc = 1,
  102. }
  103. /// <summary>
  104. /// 数据库连接
  105. /// </summary>
  106. public class DataBaseConnectionString
  107. {
  108. /// <summary>
  109. /// 构造函数
  110. /// </summary>
  111. /// <param name="key">连接对应的Key</param>
  112. /// <param name="connectionString">连接字符串</param>
  113. /// <param name="dbType">数据库类型</param>
  114. /// <param name="isDefault">是否为默认数据库连接</param>
  115. public DataBaseConnectionString(string key, string connectionString, DbType dbType, bool isDefault)
  116. {
  117. Key = key;
  118. ConnectionString = connectionString;
  119. DbType = dbType;
  120. IsDefault = isDefault;
  121. }
  122. /// <summary>
  123. /// 连接对应的Key
  124. /// </summary>
  125. public string Key { get; set; }
  126. /// <summary>
  127. /// 连接字符串
  128. /// </summary>
  129. public string ConnectionString { get; set; }
  130. /// <summary>
  131. /// 数据库类型
  132. /// </summary>
  133. public DbType DbType { get; set; }
  134. /// <summary>
  135. /// 是否为默认数据库连接
  136. /// </summary>
  137. public bool IsDefault { get; set; }
  138. }
  139. }