123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using Aitex.Core.RT.Device.Unit;
- using Aitex.Core.RT.Event;
- using Aitex.Core.RT.Log;
- using Aitex.Core.Util;
- using Microsoft.Win32;
- namespace Aitex.Core.RT.Key
- {
- public class KeyManager : Singleton<KeyManager>
- {
- public const string KeyTag = "Jet";
- public const string RegistryKey = "SOFTWARE\\Jet\\Keys";
- public string LocalMachineCode
- {
- get; private set;
- }
- public bool IsExpired
- {
- get
- {
- //return ExpireDateTime < CurrentDateTime;
- return false;
- }
- }
- public int LeftDays
- {
- get
- {
- if (IsExpired)
- return 0;
- return (ExpireDateTime - CurrentDateTime).Days;
- }
- }
- public DateTime CurrentDateTime
- {
- get
- {
- return (_plcDateTime != null && _plcDateTime.IsValid) ? _plcDateTime.CurrentDateTime : DateTime.Now;
- }
- }
- public DateTime ExpireDateTime
- {
- get
- {
- return LastRegisterDateTime + new TimeSpan(LastRegisterDays, 0, 0, 0);
- }
- }
- public DateTime LastRegisterDateTime
- {
- get; set;
- }
- public int LastRegisterDays
- {
- get; set;
- }
- private PeriodicJob _thread;
- private Dictionary<string, string> _historyKeys = new Dictionary<string, string>();
- private IoPlcDateTime _plcDateTime;
- private object _locker = new object();
- private DeviceTimer _timer0Days = new DeviceTimer();
- private R_TRIG _trig0Days = new R_TRIG();
- private DeviceTimer _timer3Days = new DeviceTimer();
- private R_TRIG _trig3Days = new R_TRIG();
- private DeviceTimer _timer7Days = new DeviceTimer();
- private R_TRIG _trig7Days = new R_TRIG();
- private DeviceTimer _timer15Days = new DeviceTimer();
- private R_TRIG _trig15Days = new R_TRIG();
- public void Initialize(IoPlcDateTime plcDateTime)
- {
- _plcDateTime = plcDateTime;
- string code;
- string reason;
- new MachineCoder("JetPlasma").Generate(out code, out reason);
- LocalMachineCode = code;
- UpdateLicenseInformation();
- _thread = new PeriodicJob(10000, OnTimer, "Register Key Thread", true);
- }
- void UpdateLicenseInformation()
- {
- try
- {
- RegistryKey regRoot = Registry.CurrentUser;
- RegistryKey regKeys = regRoot.OpenSubKey(RegistryKey, true);
- if (regKeys == null)
- {
- regKeys = regRoot.CreateSubKey(RegistryKey);
- }
- if (regKeys == null)
- {
- throw new ApplicationException("注册表操作失败,无法进行软件授权操作。\r\n请确保用管理员权限运行程序。");
- }
- foreach (var date in regKeys.GetSubKeyNames())
- {
- RegistryKey sub = regKeys.OpenSubKey(date);
- _historyKeys.Add(date, (string)sub.GetValue("Key"));
- }
- if (_historyKeys.Count == 0)
- {
- string reason;
- if (!Register(7, "---", out reason))
- throw new ApplicationException(reason);
- }
- else
- {
- List<string> date = _historyKeys.Keys.ToList();
- date.Sort();
- string last = date.Last();
- RegistryKey sub = regKeys.OpenSubKey(last);
- int year = int.Parse(last.Substring(0, 4));
- if (year < 100) year += 2000;
- LastRegisterDateTime = new DateTime(year,
- int.Parse(last.Substring(4, 2)),
- int.Parse(last.Substring(6, 2)),
- int.Parse(last.Substring(8, 2)),
- int.Parse(last.Substring(10, 2)),
- int.Parse(last.Substring(12, 2)));
- LastRegisterDays = int.Parse(sub.GetValue("Days").ToString());
- }
- }
- catch (Exception ex)
- {
- throw new ApplicationException(ex.Message);
- }
- }
- bool OnTimer()
- {
- System.Threading.Thread.Sleep(5000);
- try
- {
- _trig0Days.CLK = IsExpired;
- _trig3Days.CLK = LeftDays <= 3 && !IsExpired;
- _trig7Days.CLK = LeftDays <= 7 && LeftDays > 3;
- _trig15Days.CLK = LeftDays <= 15 && LeftDays > 7;
- if (_trig0Days.M) //到期之后,每1个小时提醒一次,预警形式
- {
- if (_trig0Days.Q)
- {
- EV.PostMessage("System", EventEnum.DefaultWarning, string.Format("Software expired at {0} ", ExpireDateTime.ToString()));
- _timer0Days.Start(1000 * 60 * 60 * 1);
- }
- if (_timer0Days.IsTimeout())
- {
- EV.PostMessage("System", EventEnum.DefaultWarning, string.Format("Software expired at {0} ", ExpireDateTime.ToString()));
- _timer0Days.Start(1000 * 60 * 60 * 1);
- }
- }
- if (_trig3Days.M) //3天内到期,每3个小时提醒一次,预警形式
- {
- if (_trig3Days.Q)
- {
- EV.PostMessage("System", EventEnum.DefaultWarning, string.Format("Software will be expired in {0} days, at {1} ", LeftDays, ExpireDateTime.ToString()));
- _timer3Days.Start(1000 * 60 * 60 * 3);
- }
- if (_timer3Days.IsTimeout())
- {
- EV.PostMessage("System", EventEnum.DefaultWarning, string.Format("Software will be expired in {0} days, at {1}", LeftDays, ExpireDateTime.ToString()));
- _timer3Days.Start(1000 * 60 * 60 * 3);
- }
- }
- if (_trig7Days.M)//7天内到期,每8个小时提醒一次,预警形式
- {
- if (_trig7Days.Q)
- {
- EV.PostMessage("System", EventEnum.DefaultWarning, string.Format("Software will be expired in {0} days, at {1} ", LeftDays, ExpireDateTime.ToString()));
- _timer7Days.Start(1000 * 60 * 60 * 8);
- }
- if (_timer7Days.IsTimeout())
- {
- EV.PostMessage("System", EventEnum.DefaultWarning, string.Format("Software will be expired in {0} days, at {1}", LeftDays, ExpireDateTime.ToString()));
- _timer7Days.Start(1000 * 60 * 60 * 8);
- }
- }
- if (_trig15Days.M)//15天内到期,每8个小时提醒一次,信息形式
- {
- if (_trig15Days.Q)
- {
- EV.PostMessage("System", EventEnum.GeneralInfo, string.Format("Software will be expired in {0} days, at {1} ", LeftDays, ExpireDateTime.ToString()));
- _timer15Days.Start(1000 * 60 * 60 * 8);
- }
- if (_timer15Days.IsTimeout())
- {
- EV.PostMessage("System", EventEnum.GeneralInfo, string.Format("Software will be expired in {0} days, at {1}", LeftDays, ExpireDateTime.ToString()));
- _timer15Days.Start(1000 * 60 * 60 * 8);
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- }
- return true;
- }
- bool Register(int days, string key, out string reason)
- {
- try
- {
- if (_historyKeys.ContainsValue(key))
- {
- reason = "注册码已经使用," + key;
- LOG.Write(reason);
- return false;
- }
- if (days < 0)
- {
- reason = "授权天数无效," + days;
- LOG.Write(reason);
- return false;
- }
- RegistryKey regRoot = Registry.CurrentUser;
- RegistryKey regKeys = regRoot.OpenSubKey(RegistryKey, true);
- if (regKeys == null)
- {
- regKeys = regRoot.CreateSubKey(RegistryKey);
- }
- if (regKeys == null)
- {
- reason = "注册表操作失败,无法进行软件授权操作。\r\n请确保用管理员权限运行程序。";
- LOG.Write(reason);
- return false;
- }
- DateTime now = CurrentDateTime;
- string itemName = now.ToString("yyyyMMddHHmmss");
- RegistryKey rkItem = regKeys.CreateSubKey(itemName);
- rkItem.SetValue("Date", itemName);
- rkItem.SetValue("Key", key);
- rkItem.SetValue("Days", days.ToString());
- regKeys.Close();
- _historyKeys.Add(itemName, key);
- LastRegisterDateTime = now;
- LastRegisterDays = days;
- }
- catch (Exception ex)
- {
- reason = "注册码无效," + ex;
- LOG.Write(reason);
- return false;
- }
- reason = "注册成功";
- return true;
- }
- public bool Register(string key, out string reason)
- {
- reason = string.Empty;
- RsaCryption rsa = new RsaCryption();
- string decry = string.Empty;
- try
- {
- decry = rsa.RSADecrypt(JetKey.PrivateKey, key);
- }
- catch (Exception ex)
- {
- reason = "注册码无效";
- LOG.Write(ex);
- return false;
- }
- string[] text = decry.Split(',');
- int days = 0;
- if (text.Length == 3 && text[0] == KeyTag && text[1] == LocalMachineCode && int.TryParse(text[2], out days))
- {
- return Register(days, key, out reason);
- }
- LOG.Error("注册码无效," + decry);
- reason = "注册码无效";
- return false;
- }
- }
- }
|