Exemplo n.º 1
0
        private Domain.Configuration ProcessFile(Domain.Configuration configuration, Domain.FileSettings fileSettings)
        {
            try
            {
                var restClient = new RestClient(configuration);
                Domain.ConfigurationResponse configurationResponse = null;

                if (Utilities.FileSystem.IsDirectory(fileSettings.Name))
                {
                    var filesNames = Utilities.FileSystem.GetFilesList(fileSettings.Name);
                    var files      = filesNames.Select
                                     (
                        fi =>
                        new Domain.File
                    {
                        Content      = null,
                        Name         = fi.FullName,
                        SizeBytes    = fi.Length,
                        TimeStampUtc = fi.LastWriteTimeUtc,
                    }

                                     );

                    configurationResponse = restClient.SelectFile(new Domain.SelectFileRequest(configuration, fileSettings, files));
                }
                else
                {
                    Utilities.Logger.Log(NLog.LogLevel.Trace, Resources.Messages.StartProcessFile, fileSettings.Name, System.Threading.Thread.CurrentThread.ManagedThreadId);
                    System.Diagnostics.Stopwatch stopWatch = System.Diagnostics.Stopwatch.StartNew();
                    Processor._filesProcessed++;
                    Domain.File            file            = Domain.File.Load(configuration, fileSettings);
                    Domain.PostFileRequest postFileRequest = new Domain.PostFileRequest(configuration, file);
                    configurationResponse = restClient.UploadFile(postFileRequest);
                    Processor._filesUploaded++;
                    Utilities.Logger.Log(NLog.LogLevel.Info, Resources.Messages.FileUploaded, fileSettings.Name, Utilities.Logger.GetTimeElapsed(stopWatch));
                }

                configuration.UpdateLocalConfiguration(configurationResponse);
                return(configuration);
            }
            catch (Exception ex)
            {
                Utilities.Logger.Log(ex);
                return(null);
            }
        }
Exemplo n.º 2
0
 private Domain.Configuration ProcessFileAsync(Domain.Configuration configuration, Domain.FileSettings fileSettings)
 {
     try
     {
         Func <Domain.Configuration> operation = new Func <Domain.Configuration>(() => ProcessFile(configuration, fileSettings));
         return(Utilities.Threading.AsyncCallWithTimeout(operation, configuration.ThreadTimeToLiveSec * 1000));
     }
     catch (Exception ex)
     {
         Utilities.Logger.Log(ex);
         return(null);
     }
 }