using AircraftPlantBusinessLogic.BusinessLogics;
using AircraftPlantBusinessLogic.OfficePackage.Implements;
using AircraftPlantBusinessLogic.OfficePackage;
using AircraftPlantContracts.BusinessLogicsContracts;
using AircraftPlantContracts.StoragesContracts;
using AircraftPlantDatabaseImplement.Implements;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using NLog.Extensions.Logging;
using System;
using AircraftPlantBusinessLogic.MailWorker;
using AircraftPlantContracts.BindingModels;
using AircraftPlantContracts.DependencyInjections;
namespace AircraftPlantView
{
internal static class Program
{
///
/// The main entry point for the application.
///
[STAThread]
static void Main()
{
// To customize application configuration such as set high DPI settings or default font,
// see https://aka.ms/applicationconfiguration.
ApplicationConfiguration.Initialize();
InitDependency();
// Настройка для отправки писем
try
{
var mailSender = DependencyManager.Instance.Resolve();
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, 60000);
}
catch (Exception ex)
{
var logger = DependencyManager.Instance.Resolve();
logger?.LogError(ex, "Ошибка работы с почтой");
}
Application.Run(DependencyManager.Instance.Resolve());
}
///
/// Инициализация зависимостей
///
///
private static void InitDependency()
{
DependencyManager.InitDependency();
DependencyManager.Instance.AddLogging(option =>
{
option.SetMinimumLevel(LogLevel.Information);
option.AddNLog("nlog.config");
});
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType(true);
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
DependencyManager.Instance.RegisterType();
}
///
/// Проверка почты
///
///
private static void MailCheck(object obj) => DependencyManager.Instance.Resolve()?.MailCheck();
}
}