| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620 | using System;using System.Collections.Generic;using System.Diagnostics;using System.IO;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Windows;using System.Xml;using Aitex.Common.Util;using Aitex.Core.RT.ConfigCenter;using Aitex.Core.RT.DataCenter;using Aitex.Core.RT.Event;using Aitex.Core.RT.Log;using Aitex.Core.RT.OperationCenter;using Aitex.Core.RT.SCCore;using Aitex.Core.Util;using MECF.Framework.Common.Equipment;using Venus_Core;namespace MECF.Framework.Common.SCCore{    public class SystemConfigManager : Singleton<SystemConfigManager>, ISCManager    {        private Dictionary<string, SCConfigItem> _items = new Dictionary<string, SCConfigItem>();        private object _itemLocker = new object();        private string _scConfigFile  ;        private string _scDataFile = PathManager.GetCfgDir() + "_sc.data";        private string _scDataBackupFile = PathManager.GetCfgDir() + "_sc.data.bak";        private string _scDataErrorFile = PathManager.GetCfgDir() + "_sc.data.err.";         public void Initialize(string scConfigPathName,ConfigType configType)        {            if (configType == ConfigType.Other)            {                _scDataFile = PathManager.GetCfgDir() + "_sc.data";                _scDataBackupFile = PathManager.GetCfgDir() + "_sc.data.bak";                _scDataErrorFile = PathManager.GetCfgDir() + "_sc.data.err.";            }            else            {                _scDataFile = PathManager.GetCfgDir() + $"_sc_{configType}.data";                _scDataBackupFile = PathManager.GetCfgDir() + $"_sc.data_{configType}.bak";                //_scDataErrorFile = PathManager.GetCfgDir() + $"_sc.data.err._{configType}";            }            _scConfigFile =  scConfigPathName;            BuildItems(_scConfigFile);            BackupAndRecoverDataFile();            CustomData();            GenerateDataFile();            foreach (var item in _items)            {                CONFIG.Subscribe("", item.Key, ()=>item.Value.Value);            }            OP.Subscribe("System.SetConfig", InvokeSetConfig);            SC.Manager = this;        }        private bool InvokeSetConfig(string cmd, object[] parameters)        {            string key = (string) parameters[0];            object old = GetConfigValueAsObject(key);            if ((string)parameters[0] == "PMB.Chiller.ChillerSameWithPMA" && (string)parameters[1] == "true")            {                if (_items["PMA.Chiller.EnableChiller"].Value.ToString() == "False") return true;            }            if (InitializeItemValue(_items[(string)parameters[0]], (string)parameters[1]))            {                GenerateDataFile();                LOG.Write(eEvent.EV_SYSTEM_CONFIG, ModuleName.System, string.Format("SC {0} value changed from {1} to {2}", key, old, parameters[1]));            }            if ((string)parameters[0] == "PMA.Chiller.EnableChiller" && (string)parameters[1] == "false")            {                if (_items["PMB.Chiller.ChillerSameWithPMA"].Value.ToString() == "False") return true;                if (InitializeItemValue(_items["PMB.Chiller.ChillerSameWithPMA"], "False"))                {                    GenerateDataFile();                    LOG.Write(eEvent.EV_SYSTEM_CONFIG, ModuleName.System, string.Format("SC {0} value changed from {1} to {2}", "PMB.Chiller.ChillerSameWithPMA", "true", "false"));                }            }            if ((string)parameters[0] == "PMB.Chiller.EnableChiller" && (string)parameters[1] == "false")            {                if (_items["PMB.Chiller.ChillerSameWithPMA"].Value.ToString() == "False") return true;                if (InitializeItemValue(_items["PMB.Chiller.EnableChiller"], "true"))                {                    GenerateDataFile();                    LOG.Write(eEvent.EV_SYSTEM_CONFIG, ModuleName.System, string.Format("SC {0} value changed from {1} to {2}", "PMB.Chiller.EnableChiller", "false", "true"));                }            }            if ((string)parameters[0] == "PMB.Chiller.ChillerSameWithPMA" && (string)parameters[1] == "true")            {                if (_items["PMB.Chiller.EnableChiller"].Value.ToString() == "True") return true;                if (InitializeItemValue(_items["PMB.Chiller.EnableChiller"], "true"))                {                    GenerateDataFile();                    LOG.Write(eEvent.EV_SYSTEM_CONFIG, ModuleName.System, string.Format("SC {0} value changed from {1} to {2}", "PMB.Chiller.EnableChiller", "false", "true"));                }            }            return true;        }        public void Terminate()        {        }        public string GetFileContent()        {            if (!File.Exists(_scConfigFile))                return "";            StringBuilder s = new StringBuilder();            try            {                using (StreamReader sr = new StreamReader(_scConfigFile))                {                    while (!sr.EndOfStream)                    {                        s.Append(sr.ReadLine());                    }                }            }            catch (Exception ex)            {                LOG.WriteExeption(ex);                return "";            }            return s.ToString();        }        private void BuildItems(string xmlFile)        {            XmlDocument xml = new XmlDocument();            try            {                var _sc_stream = File.Open(xmlFile, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.Read);                xml.Load(_sc_stream);                XmlNodeList nodeConfigs = xml.SelectNodes("root/configs");                foreach (XmlElement nodeConfig in nodeConfigs)                {                    BuildPathConfigs(nodeConfig.GetAttribute("name"), nodeConfig as XmlElement);                }            }            catch (Exception ex)            {                LOG.WriteExeption(ex);            }        }        private void BuildPathConfigs(string parentPath, XmlElement configElement)        {            XmlNodeList nodeConfigsList = configElement.SelectNodes("configs");            foreach (XmlElement nodeConfig in nodeConfigsList)            {                if (string.IsNullOrEmpty(parentPath))                {                    BuildPathConfigs(nodeConfig.GetAttribute("name"), nodeConfig as XmlElement);                }                else                {                    BuildPathConfigs(parentPath + "." + nodeConfig.GetAttribute("name"), nodeConfig as XmlElement);                }            }            XmlNodeList nodeConfigs = configElement.SelectNodes("config");            foreach (XmlElement nodeConfig in nodeConfigs)            {                SCConfigItem item = new SCConfigItem()                {                    Default = nodeConfig.GetAttribute("default"),                    Name = nodeConfig.GetAttribute("name"),                    Description = nodeConfig.GetAttribute("description"),                    Max = nodeConfig.GetAttribute("max"),                    Min = nodeConfig.GetAttribute("min"),                    Parameter = nodeConfig.GetAttribute("paramter"),                    Path = parentPath,                    Tag = nodeConfig.GetAttribute("tag"),                    Type = nodeConfig.GetAttribute("type"),                    Unit = nodeConfig.GetAttribute("unit"),                };                InitializeItemValue(item, item.Default);                if (_items.ContainsKey(item.PathName))                {                    //LOG.Error("Duplicated SC item, "+ item.PathName);                }                _items[item.PathName] = item;            }        }        private void BackupAndRecoverDataFile()        {            try            {                if (File.Exists(_scDataFile) && IsXmlFileLoadable(_scDataFile))                {                    File.Copy(_scDataFile, _scDataBackupFile, true);                }                else if (File.Exists(_scDataBackupFile) && IsXmlFileLoadable(_scDataBackupFile))                {                    if (File.Exists(_scDataFile))                    {                        File.Copy(_scDataFile, _scDataErrorFile + DateTime.Now.ToString("yyyyMMdd_HHmmss"), true);                    }                    File.Copy(_scDataBackupFile, _scDataFile, true);                }            }            catch (Exception ex)            {                LOG.WriteExeption(ex);            }        }        private void CustomData()        {            Dictionary<string, string> values = new Dictionary<string, string>();            try            {                if (File.Exists(_scDataFile))                {                    XmlDocument xmlData = new XmlDocument();                    var _sc_stream = File.Open(_scDataFile, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.Read);                    xmlData.Load(_sc_stream);                    XmlNodeList scdatas = xmlData.SelectNodes("root/scdata");                    foreach (XmlElement nodedata in scdatas)                    {                        string name = nodedata.GetAttribute("name");                        if (_items.ContainsKey(name))                        {                            InitializeItemValue(_items[name], nodedata.GetAttribute("value"));                        }                    }                }            }            catch (Exception ex)            {                LOG.WriteExeption(ex);            }        }        private void GenerateDataFile()        {            try            {                XmlDocument xml = new XmlDocument();                xml.LoadXml("<?xml version=\"1.0\" encoding=\"utf-8\"?><root></root>");                XmlElement nodeRoot = xml.SelectSingleNode("root") as XmlElement;                foreach (var scConfigItem in _items)                {                    XmlElement node = xml.CreateElement("scdata");                    node.SetAttribute("name", scConfigItem.Key);                    node.SetAttribute("value", scConfigItem.Value.Value.ToString());                    nodeRoot.AppendChild(node);                }                if (File.Exists(_scDataFile) && IsXmlFileLoadable(_scDataFile))                {                    File.Copy(_scDataFile, _scDataBackupFile, true);                    //File.Delete(_scDataFile);                }                using (FileStream fsFileStream = new FileStream(_scDataFile,                    FileMode.OpenOrCreate, FileAccess.Write, FileShare.None, 1024, FileOptions.WriteThrough))                {                    fsFileStream.SetLength(0);                    XmlWriterSettings settings = new XmlWriterSettings();                    settings.Indent = true;                    settings.OmitXmlDeclaration = false;                                         using (XmlWriter xmlWrite = XmlWriter.Create(fsFileStream, settings))                    {                        xml.Save(xmlWrite);                    }                }            }            catch (Exception ex)            {                LOG.WriteExeption(ex);            }        }        private bool IsXmlFileLoadable(string file)        {            try            {                XmlDocument xml = new XmlDocument();                xml.Load(file);            }            catch (Exception ex)            {                LOG.WriteExeption(ex);                return false;            }            return true;        }        public SCConfigItem GetConfigItem(string name)        {            //Debug.Assert(_items.ContainsKey(name), "can not find sc name, "+name);            if (!_items.ContainsKey(name))            {                return null;            }            return _items[name];        }        public bool ContainsItem(string name)        {            return _items.ContainsKey(name);        }        public object GetConfigValueAsObject(string name)        {            SCConfigItem item = GetConfigItem(name);            if(item == null)            {                return null;            }            switch (item.Type)            {                case "Bool": return item.BoolValue;                case "Integer": return item.IntValue;                case "Double": return item.DoubleValue;                case "String": return item.StringValue;            }            return null;        }        public T GetValue<T>(string name) where T : struct         {            try            {                if (typeof(T) == typeof(bool))                    return (T)(object)_items[name].BoolValue;                if (typeof(T) == typeof(int))                    return (T)(object)_items[name].IntValue;                if (typeof(T) == typeof(double))                    return (T)(object)_items[name].DoubleValue;            }            catch (KeyNotFoundException)            {                MessageBox.Show($"Can not find system config item {name}");                return default(T);            }            catch (Exception)            {                MessageBox.Show($"Can not get valid system config item value {name}");                return default(T);            }            Debug.Assert(false, "unsupported type");            return default(T);        }        public string GetStringValue(string name)        {            if (!_items.ContainsKey(name))                return null;            return _items[name].StringValue;        }        public List<SCConfigItem> GetItemList()        {            return _items.Values.ToList();        }        public void SetItemValueFromString(string name, string value)        {             if (InitializeItemValue(_items[name], value))            {                GenerateDataFile();            }        }        private bool InitializeItemValue(SCConfigItem item, string value)        {            bool changed = false;            switch (item.Type)            {                case "Bool":                    bool boolValue;                    if (bool.TryParse(value, out boolValue) && boolValue != item.BoolValue)                    {                        item.BoolValue = boolValue;                        changed = true;                    }                    break;                case "Integer":                    int intValue;                    if (int.TryParse(value, out intValue) && intValue != item.IntValue)                    {                                                 int.TryParse(item.Min, out int min);                        int.TryParse(item.Max, out int max);                        if (intValue <min  || intValue > max)                        {                            LOG.Write(eEvent.WARN_SYSTEM_CONFIG, ModuleName.System, $"SC {item.PathName} value  {intValue} out of setting range ({item.Min}, {item.Max})");                            break;                        }                        item.IntValue = intValue;                        changed = true;                    }                    break;                case "Double":                    double doubleValue;                    if (double.TryParse(value, out doubleValue) && Math.Abs(doubleValue - item.DoubleValue) > 0.0001)                    {                        double.TryParse(item.Min, out double min);                        double.TryParse(item.Max, out double max);                        if (doubleValue < min || doubleValue > max)                        {                            LOG.Write(eEvent.WARN_SYSTEM_CONFIG, ModuleName.System, $"SC {item.PathName}  value  {doubleValue} out of setting range ({item.Min}, {item.Max})");                            break;                        }                        item.DoubleValue = doubleValue;                        changed = true;                    }                    break;                case "String":                    if (value != item.StringValue)                    {                        item.StringValue = value;                        changed = true;                    }                    break;            }            return changed;        }        public void SetItemValue(string name, object value)        {            Debug.Assert(_items.ContainsKey(name), "can not find sc name, " + name);            if (!_items.ContainsKey(name))            {                return;            }            bool changed = false;            switch (_items[name].Type)            {                case "Bool":                    bool boolValue = (bool)value;                    if (boolValue != _items[name].BoolValue)                    {                        _items[name].BoolValue = boolValue;                        changed = true;                    }                    break;                case "Integer":                    int intValue = (int)value;                    if (intValue != _items[name].IntValue)                    {                        _items[name].IntValue = intValue;                        changed = true;                    }                    break;                case "Double":                    double doubleValue = (double)value;                    if (Math.Abs(doubleValue - _items[name].DoubleValue) > 0.0001)                    {                        _items[name].DoubleValue = doubleValue;                        changed = true;                    }                    break;                case "String":                    string stringValue = (string)value;                    if (stringValue != _items[name].StringValue)                    {                        _items[name].StringValue = stringValue;                        changed = true;                    }                    break;            }            if (changed)            {                GenerateDataFile();            }        }        public void SetItemValueStringFormat(string name, string value)        {            Debug.Assert(_items.ContainsKey(name), "can not find sc name, " + name);            if (!_items.ContainsKey(name))            {                return;            }            bool changed = false;            switch (_items[name].Type)            {                case "Bool":                    bool boolValue = Convert.ToBoolean(value);                    if (boolValue != _items[name].BoolValue)                    {                        _items[name].BoolValue = boolValue;                        changed = true;                    }                    break;                case "Integer":                    int intValue = Convert.ToInt32(value);                    if (intValue != _items[name].IntValue)                    {                        _items[name].IntValue = intValue;                        changed = true;                    }                    break;                case "Double":                    double doubleValue = Convert.ToDouble(value);                    if (Math.Abs(doubleValue - _items[name].DoubleValue) > 0.0001)                    {                        _items[name].DoubleValue = doubleValue;                        changed = true;                    }                    break;                case "String":                    string stringValue = (string)value;                    if (stringValue != _items[name].StringValue)                    {                        _items[name].StringValue = stringValue;                        changed = true;                    }                    break;            }            if (changed)            {                GenerateDataFile();            }        }        public void SetItemValue(string name, bool value)        {            Debug.Assert(_items.ContainsKey(name), "can not find sc name, " + name);            Debug.Assert(_items[name].Type=="Bool", "sc type not bool, defined as" + _items[name].Type);            if (value != _items[name].BoolValue)            {                _items[name].BoolValue = value;                GenerateDataFile();            }        }        public void SetItemValue(string name, int value)        {            Debug.Assert(_items.ContainsKey(name), "can not find sc name, " + name);            Debug.Assert(_items[name].Type == "Integer", "sc type not bool, defined as" + _items[name].Type);            if (value != _items[name].IntValue)            {                _items[name].IntValue = value;                GenerateDataFile();            }        }        public void SetItemValue(string name, double value)        {            Debug.Assert(_items.ContainsKey(name), "can not find sc name, " + name);            Debug.Assert(_items[name].Type == "Double", "sc type not bool, defined as" + _items[name].Type);            if (Math.Abs(value - _items[name].DoubleValue) > 0.0001)            {                _items[name].DoubleValue = value;                GenerateDataFile();            }        }        public void SetItemValue(string name, string value)        {            Debug.Assert(_items.ContainsKey(name), "can not find sc name, " + name);             if (value != _items[name].StringValue)            {                _items[name].StringValue = value;                GenerateDataFile();            }        }    }}
 |