Beispiel #1
0
        /// <summary>
        /// Разархивирование архива с изображениями
        /// </summary>
        /// <param name="archive"></param>
        private FileInfo[] ExtractArchive(FileInfo archive, string tempPath)
        {
            FileInfo[] result = null;
            try
            {
                SrvcLogger.Info("{work}", $"распаковка архива: {archive.Name}");
                Importer.EmailBody += $"<p>распаковка архива: <b>{archive.Name}</b></p>";
                ZipFile.ExtractToDirectory(archive.FullName, tempPath, Encoding.UTF8);

                DirectoryInfo di = new DirectoryInfo(tempPath);
                if (di != null)
                {
                    if (di.GetDirectories().Count() > 0)
                    {
                        List <FileInfo> files = new List <FileInfo>();
                        foreach (var dir in di.GetDirectories())
                        {
                            files.AddRange(dir.GetFiles());
                        }
                        result = files.ToArray();
                    }
                    else
                    {
                        result = di.GetFiles();
                    }
                }
                if (result != null)
                {
                    SrvcLogger.Info("{work}", $"архив распакован, кол-во файлов: {result.Count()}");
                }
            }
            catch (Exception e)
            {
                SrvcLogger.Error("{error}", e.ToString());
            }
            return(result);
        }
Beispiel #2
0
        /// <summary>
        /// Обрабатывает изображения
        /// </summary>
        public void Execute(FileInfo archive)
        {
            if (archive.Name.ToLower().Contains("certi"))
            {
                prefixFolder = @"Certificates\";
                isImages     = false;
            }
            string tempPath = $"{ParamsHelper.SaveDirName}{prefixFolder}temp\\";

            if (Directory.Exists(tempPath))
            {
                Directory.Delete(tempPath, true);
            }
            if (!Directory.Exists(tempPath))
            {
                Directory.CreateDirectory(tempPath);
            }
            archive.CopyTo($"{tempPath}{archive.Name}");

            var files = ExtractArchive(new FileInfo($"{tempPath}{archive.Name}"), tempPath);

            if (files != null && files.Count() > 0)
            {
                Importer.Log.Insert(0, $"Кол-во изображений в архиве: {files.Count()}");
                Importer.EmailBody += $"<p>кол-во изображений в архиве <b>{archive.Name}</b>: {files.Count()}</p>";
                ResizingImages(files);
                Importer.Step++;
                Importer.UpdateCurrentStep();
            }
            else
            {
                SrvcLogger.Info("{work}", $"распаковка {archive.Name} не дала результатов");
                Importer.EmailBody += $"<p>распаковка <b>{archive.Name}</b> не дала результатов</p>";
                Importer.CountFalse++;
            }

            #region удаляет временную директорию
            if (Directory.Exists(tempPath))
            {
                try
                {
                    Directory.Delete(tempPath, true);
                    SrvcLogger.Info("{work}", $"директория {tempPath} удалена");
                }
                catch (IOException)
                {
                    Directory.Delete(tempPath, true);
                    SrvcLogger.Info("{work}", $"директория {tempPath} удалена");
                }
                catch (UnauthorizedAccessException)
                {
                    Directory.Delete(tempPath, true);
                    SrvcLogger.Info("{work}", $"директория {tempPath} удалена");
                }
                catch (Exception e)
                {
                    SrvcLogger.Error("{error}", e.ToString());
                }
            }
            #endregion
        }