101 lines
5.1 KiB
C#
Raw Normal View History

2023-03-06 17:15:03 +04:00
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using SecuritySystemContracts.BusinessLogicsContracts;
2023-05-01 18:29:41 +04:00
using SecuritySystemContracts.StorageContracts;
2023-05-16 01:43:26 +04:00
using SecuritySystemView;
using SecuritySystemDatabaseImplement.Implements;
using NLog.Extensions.Logging;
using SecuritySystemBusinessLogic.BusinessLogics;
using System;
using SecuritySystemBusinessLogic.OfficePackage.Implements;
using SecuritySystemBusinessLogic.OfficePackage;
2023-05-02 11:03:29 +04:00
using SecuritySystemBusinessLogic.MailWorker;
using SecuritySystemContracts.BindingModels;
2023-05-16 01:43:26 +04:00
using SecuritySystemContracts.DI;
using SecureCompanyBusinessLogic.BusinessLogics;
using SecuritySystemBusinessLogic.BusinessLogics;
using SecuritySystemBusinessLogic.MailWorker;
using SecuritySystemBusinessLogic.OfficePackage.Implements;
using SecuritySystemBusinessLogic.OfficePackage;
using SecuritySystemContracts.BindingModels;
using SecuritySystemContracts.BusinessLogicsContracts;
using SecuritySystemView;
2023-03-06 17:15:03 +04:00
2023-05-16 01:43:26 +04:00
namespace SecuritySystem
2023-02-07 08:42:04 +04:00
{
internal static class Program
{
[STAThread]
static void Main()
{
ApplicationConfiguration.Initialize();
2023-03-06 17:15:03 +04:00
var services = new ServiceCollection();
2023-05-16 01:43:26 +04:00
InitDependency();
2023-05-02 11:03:29 +04:00
try
{
2023-05-16 01:43:26 +04:00
var mailSender = DependencyManager.Instance.Resolve<AbstractMailWorker>();
2023-05-02 11:03:29 +04:00
mailSender?.MailConfig(new MailConfigBindingModel
{
MailLogin =
System.Configuration.ConfigurationManager.AppSettings["MailLogin"] ?? string.Empty,
MailPassword =
System.Configuration.ConfigurationManager.AppSettings["MailPassword"] ?? string.Empty,
SmtpClientHost =
System.Configuration.ConfigurationManager.AppSettings["SmtpClientHost"] ?? string.Empty,
SmtpClientPort = Convert.ToInt32(System.Configuration.ConfigurationManager.AppSettings["SmtpClientPort"]),
PopHost = System.Configuration.ConfigurationManager.AppSettings["PopHost"] ?? string.Empty,
PopPort = Convert.ToInt32(System.Configuration.ConfigurationManager.AppSettings["PopPort"])
});
var timer = new System.Threading.Timer(new TimerCallback(MailCheck!), null, 0, 100000);
// ServiceProvider?.GetService<AbstractMailWorker>()?.MailCheck();
}
catch (Exception ex)
{
2023-05-16 01:43:26 +04:00
var logger = DependencyManager.Instance.Resolve<ILogger>();
2023-05-02 11:03:29 +04:00
logger?.LogError(ex, "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
}
2023-05-16 01:43:26 +04:00
Application.Run(DependencyManager.Instance.Resolve<FormMain>());
2023-03-06 17:15:03 +04:00
}
2023-05-16 01:43:26 +04:00
private static void InitDependency()
2023-03-06 17:15:03 +04:00
{
2023-05-16 01:43:26 +04:00
DependencyManager.InitDependency();
DependencyManager.Instance.AddLogging(option =>
2023-03-06 17:15:03 +04:00
{
option.SetMinimumLevel(LogLevel.Information);
option.AddNLog("nlog.config");
});
2023-05-16 01:43:26 +04:00
DependencyManager.Instance.RegisterType<IComponentLogic, ComponentLogic>();
DependencyManager.Instance.RegisterType<IClientLogic, ClientLogic>();
DependencyManager.Instance.RegisterType<ISecureLogic, SecureLogic>();
DependencyManager.Instance.RegisterType<IOrderLogic, OrderLogic>();
DependencyManager.Instance.RegisterType<IReportLogic, ReportLogic>();
DependencyManager.Instance.RegisterType<IImplementerLogic, ImplementerLogic>();
DependencyManager.Instance.RegisterType<IMessageInfoLogic, MessageInfoLogic>();
DependencyManager.Instance.RegisterType<IWorkProcess, WorkModeling>();
DependencyManager.Instance.RegisterType<AbstractMailWorker, MailKitWorker>(true);
DependencyManager.Instance.RegisterType<IBackUpLogic, BackUpLogic>();
DependencyManager.Instance.RegisterType<AbstractSaveToExcel, SaveToExcel>();
DependencyManager.Instance.RegisterType<AbstractSaveToWord, SaveToWord>();
DependencyManager.Instance.RegisterType<AbstractSaveToPdf, SaveToPdf>();
DependencyManager.Instance.RegisterType<FormMain>();
DependencyManager.Instance.RegisterType<FormComponent>();
DependencyManager.Instance.RegisterType<FormComponents>();
DependencyManager.Instance.RegisterType<FormCreateOrder>();
DependencyManager.Instance.RegisterType<FormSecure>();
DependencyManager.Instance.RegisterType<FormSecureComponent>();
DependencyManager.Instance.RegisterType<FormSecures>();
DependencyManager.Instance.RegisterType<FormReportSecureComponents>();
DependencyManager.Instance.RegisterType<FormReportOrders>();
DependencyManager.Instance.RegisterType<FormClients>();
DependencyManager.Instance.RegisterType<FormImplementers>();
DependencyManager.Instance.RegisterType<FormImplementer>();
DependencyManager.Instance.RegisterType<FormMessageInfos>();
2023-02-07 08:42:04 +04:00
}
2023-05-16 01:43:26 +04:00
private static void MailCheck(object obj) => DependencyManager.Instance.Resolve<AbstractMailWorker>()?.MailCheck();
2023-02-07 08:42:04 +04:00
}
}