예제 #1
0
        static void ServiceCore()
        {
            string checkSumFile = null;
            string logFile      = null;

            try
            {
                ConfigGlobal.ReadConfig();
                ConfigGlobal.CloudSubDirectory = DateTime.Now.ToString("yyyyMMdd_HHmmssfff");
                StringBuilder sb            = new StringBuilder();
                var           filesToUpload = Files.GetFilesToUpload(ConfigGlobal.SourceDir, ConfigGlobal.FileRegEx);
                Files.ClearStage(ConfigGlobal.StageDir);

                sb.Append("Quantidade de arquivos encontrados para processamento: ");
                sb.AppendLine(filesToUpload.Count.ToString());
                Logging.Log(sb.ToString(), EventLogEntryType.Information);
                sb.Clear();

                foreach (var fileToUpload in filesToUpload)
                {
                    sb.Append("Arquivo a ser processado: ");
                    sb.AppendLine(fileToUpload);
                    Logging.Log(sb.ToString(), EventLogEntryType.Information);
                    sb.Clear();
                    File.Copy(fileToUpload, Path.Combine(ConfigGlobal.StageDir, Path.GetFileName(fileToUpload)), true);
                    Files.CompressFileToUpload(Path.Combine(ConfigGlobal.StageDir, Path.GetFileName(fileToUpload)));
                    sb.Append("Arquivo compactado como: ");
                    sb.AppendLine(Path.Combine(ConfigGlobal.StageDir, Path.GetFileName(fileToUpload)));
                    Logging.Log(sb.ToString(), EventLogEntryType.Information);
                    sb.Clear();
                }
                var filesFromStageToUpload = Files.GetFilesFromStageToUpload(ConfigGlobal.StageDir);
                foreach (var fileFromStageToUpload in filesFromStageToUpload)
                {
                    Files.UploadFile(fileFromStageToUpload);
                    checkSumFile = Files.CreateCheckSumFile(fileFromStageToUpload);
                    Files.UploadFile(checkSumFile);
                    File.Delete(checkSumFile);
                    logFile = Files.CreateLogFile(fileFromStageToUpload);
                    Files.UploadFile(logFile);
                    File.Delete(logFile);
                }
            }
            catch (Exception e)
            {
                Logging.Log(e.Message, EventLogEntryType.Error);
            }
        }
예제 #2
0
 protected override void OnStart(string[] args)
 {
     try
     {
         ConfigGlobal.ReadConfig();
         Logging.Log("Iniciando serviço de backup de arquivos...", EventLogEntryType.Information);
         //ConfigGlobal.WriteLogGlobalConfig();
         _timer          = new Timer(TimeSpan.FromSeconds(ConfigGlobal.IntervalMs).TotalMilliseconds);
         _timer.Elapsed += new System.Timers.ElapsedEventHandler(timer_Elapsed);
         _timer.Start();
     }
     catch (Exception e)
     {
         Logging.Log(e.Message, EventLogEntryType.Error);
     }
 }