using ConfectioneryDatabaseImplement.Implements; using ConfectioneryDatabaseImplement; using ConfectioneryBusinessLogic.BusinessLogics; using ConfectioneryContracts.BusinessLogicsContracts; using ConfectioneryContracts.DI; using NLog.Extensions.Logging; using ConfectioneryBusinessLogic; using ConfectioneryBusinessLogic.OfficePackage.Implements; using ConfectioneryBusinessLogic.OfficePackage; using ConfectioneryBusinessLogic.MailWorker; using ConfectioneryContracts.BindingModels; using Microsoft.Extensions.Logging; namespace ConfectioneryView { internal static class Program { /// <summary> /// The main entry point for the application. /// </summary> [STAThread] static void Main() { // To customize application configuration such as set high DPIsettings or default font, // see https://aka.ms/applicationconfiguration. ApplicationConfiguration.Initialize(); InitDependency(); try { var mailSender = DependencyManager.Instance.Resolve<AbstractMailWorker>(); 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); } catch (Exception ex) { var logger = DependencyManager.Instance.Resolve<ILogger>(); logger?.LogError(ex, "������ ������ � ������"); } Application.Run(DependencyManager.Instance.Resolve<FormMain>()); } private static void InitDependency() { DependencyManager.InitDependency(); DependencyManager.Instance.AddLogging(option => { option.SetMinimumLevel(LogLevel.Information); option.AddNLog("nlog.config"); }); DependencyManager.Instance.RegisterType<IComponentLogic, ComponentLogic>(); DependencyManager.Instance.RegisterType<IOrderLogic, OrderLogic>(); DependencyManager.Instance.RegisterType<IPastryLogic, PastryLogic>(); DependencyManager.Instance.RegisterType<IReportLogic, ReportLogic>(); DependencyManager.Instance.RegisterType<IClientLogic, ClientLogic>(); DependencyManager.Instance.RegisterType<IImplementerLogic, ImplementerLogic>(); DependencyManager.Instance.RegisterType<IMessageInfoLogic, MessageInfoLogic>(); DependencyManager.Instance.RegisterType<IWorkProcess, WorkModeling>(); DependencyManager.Instance.RegisterType<IBackUpLogic, BackUpLogic>(); DependencyManager.Instance.RegisterType<AbstractMailWorker, MailKitWorker>(true); 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<FormPastry>(); DependencyManager.Instance.RegisterType<FormPastryComponent>(); DependencyManager.Instance.RegisterType<FormViewPastry>(); DependencyManager.Instance.RegisterType<FormReportPastryComponents>(); DependencyManager.Instance.RegisterType<FormReportOrders>(); DependencyManager.Instance.RegisterType<FormViewClients>(); DependencyManager.Instance.RegisterType<FormViewImplementers>(); DependencyManager.Instance.RegisterType<FormImplementer>(); DependencyManager.Instance.RegisterType<FormViewMail>(); } private static void MailCheck(object obj) => DependencyManager.Instance.Resolve<AbstractMailWorker>()?.MailCheck(); } }