public override async Task <IScriptCommand> ExecuteAsync(ParameterDic pm) { var pdv = pm.GetValue <IProgress <TransferProgress> >("{Progress}", NullTransferProgress.Instance); string url = pm.GetValue <string>(UrlKey); if (url == null) { return(ResultCommand.Error(new ArgumentException("Unspecified Url."))); } try { using (var httpClient = pm.ContainsKey(HttpClientKey) && pm[HttpClientKey] is Func <HttpClient>?((Func <HttpClient>)pm[HttpClientKey])() : new HttpClient()) { var response = await httpClient.GetAsync(url, HttpCompletionOption.ResponseHeadersRead, pm.CancellationToken); if (!response.IsSuccessStatusCode) { throw new WebException(String.Format("{0} when downloading {1}", response.StatusCode, url)); } MemoryStream destStream = new MemoryStream(); logger.Info(String.Format("{0} = Stream of {1}", DestinationKey, url)); using (Stream srcStream = await response.Content.ReadAsStreamAsync()) { pdv.Report(TransferProgress.From(url)); byte[] buffer = new byte[1024]; ulong totalBytesRead = 0; ulong totalBytes = 0; try { totalBytes = (ulong)srcStream.Length; } catch (NotSupportedException) { } int byteRead = await srcStream.ReadAsync(buffer, 0, buffer.Length, pm.CancellationToken); while (byteRead > 0) { await destStream.WriteAsync(buffer, 0, byteRead, pm.CancellationToken); totalBytesRead = totalBytesRead + (uint)byteRead; short percentCompleted = (short)((float)totalBytesRead / (float)totalBytes * 100.0f); pdv.Report(TransferProgress.UpdateCurrentProgress(percentCompleted)); byteRead = await srcStream.ReadAsync(buffer, 0, buffer.Length, pm.CancellationToken); } await destStream.FlushAsync(); } pm.SetValue(DestinationKey, destStream.ToByteArray()); return(NextCommand); } } catch (Exception ex) { return(ResultCommand.Error(ex)); } }
private async Task <IScriptCommand> transferAsync(ParameterDic pm, IEntryModel[] ems, IProgress <TransferProgress> progress, IScriptCommand thenCommand) { Dictionary <string, Stream> compressDic = new Dictionary <string, Stream>(); IDiskProfile srcProfile = _srcModel.Profile as IDiskProfile; string srcParentPath = srcProfile.Path.GetDirectoryName(_srcModel.FullPath); foreach (var em in ems) { string relativePath = em.FullPath.Replace(srcParentPath, "").TrimStart('\\'); compressDic.Add(relativePath, await srcProfile.DiskIO.OpenStreamAsync(em, Defines.FileAccess.Read, pm.CancellationToken)); } var destProfile = _destDirModel.Profile as SzsProfile; string archiveType = destProfile.Path.GetExtension(_destDirModel.Name); using (await destProfile.WorkingLock.LockAsync()) await Task.Run(async() => { Progress <Defines.ProgressEventArgs> progress1 = new Progress <Defines.ProgressEventArgs>( (pea) => { if (!String.IsNullOrEmpty(pea.Message)) { progress.Report(TransferProgress.SetMessage(Defines.ProgressType.Running, pea.Message)); } if (!String.IsNullOrEmpty(pea.File)) { progress.Report(TransferProgress.From(pea.File)); } if (pea.CurrentProgress != -1 && pea.TotalProgress != -1) { progress.Report(TransferProgress.UpdateCurrentProgress((short)((float)pea.CurrentProgress / (float)pea.TotalProgress * 100.0))); } } ); progress.Report(TransferProgress.To(_destDirModel.Name)); using (var stream = await destProfile.DiskIO.OpenStreamAsync(_destDirModel, Defines.FileAccess.ReadWrite, pm.CancellationToken)) destProfile.Wrapper.CompressMultiple(archiveType, stream, compressDic, progress1); }); return(thenCommand); }
public override async Task <IScriptCommand> ExecuteAsync(ParameterDic pm) { Dictionary <string, Stream> compressDic = new Dictionary <string, Stream>(); try { IEntryModel[] srcEntries = await pm.GetValueAsEntryModelArrayAsync(SourceEntryKey); ISzsItemModel destEntry = await pm.GetValueAsEntryModelAsync(DestinationDirectoryEntryKey, null) as ISzsItemModel; //If destination is not SzsRoot, use DiskTransfer instead. SzsProfile destProfile = destEntry.Profile as SzsProfile; if (destProfile == null) { logger.Warn(String.Format("{0} isn't Szs based entry, DiskTransfer is used instead.", destEntry.Name)); return(IOScriptCommands.DiskTransfer(SourceEntryKey, DestinationDirectoryEntryKey, null, RemoveOriginal, false, NextCommand)); } if (!destEntry.IsDirectory) { return(ResultCommand.Error(new ArgumentException(DestinationDirectoryEntryKey + " is not a folder."))); } Func <IEntryModel, bool> fileAndArchiveOnly = em => !em.IsDirectory || (em is SzsRootModel); Func <IEntryModel, bool> lookupDirectoryNotArchiveFilter = em => em.IsDirectory && !(em is SzsRootModel); IProgress <TransferProgress> progress = pm.GetProgress(); string archiveType = destProfile.Path.GetExtension((destEntry as ISzsItemModel).Root.Name); logger.Info(String.Format("Compressing {0} -> {1} using SzsDiskTransfer", srcEntries.GetDescription(), destEntry.Name)); await Task.Run(async() => { #region OpenStream of files foreach (var srcEntry in srcEntries) { IDiskProfile srcProfile = srcEntry.Profile as IDiskProfile; if (srcProfile == null) { break; } if (fileAndArchiveOnly(srcEntry)) { logger.Debug(String.Format("Added to Dictionary : {0} -> {1}", srcEntry.FullPath, srcEntry.Name)); progress.Report(TransferProgress.SetMessage(ProgressType.Running, srcEntry.Name)); compressDic.Add(srcEntry.Name, await srcProfile.DiskIO .OpenStreamAsync(srcEntry, Defines.FileAccess.Read, pm.CancellationToken)); } else { IList <IEntryModel> srcSubEntries = await srcProfile.ListRecursiveAsync(srcEntry, pm.CancellationToken, fileAndArchiveOnly, lookupDirectoryNotArchiveFilter, false); foreach (var srcSubEntry in srcSubEntries) { string relativePath = destProfile.Path.Combine( destEntry.RelativePath, srcSubEntry.FullPath.Replace(srcEntry.Parent.FullPath, "").TrimStart('\\') ); logger.Debug(String.Format("Added to Dictionary : {0} -> {1}", srcSubEntry.FullPath, relativePath)); progress.Report(TransferProgress.SetMessage(ProgressType.Running, relativePath)); compressDic.Add(relativePath, await srcProfile.DiskIO .OpenStreamAsync(srcSubEntry, Defines.FileAccess.Read, pm.CancellationToken)); } } } #endregion Progress <Defines.ProgressEventArgs> progress1 = new Progress <Defines.ProgressEventArgs>( (pea) => { if (!String.IsNullOrEmpty(pea.Message)) { progress.Report(TransferProgress.SetMessage(Defines.ProgressType.Running, pea.Message)); } if (!String.IsNullOrEmpty(pea.File)) { progress.Report(TransferProgress.From(pea.File)); } if (pea.CurrentProgress != -1 && pea.TotalProgress != -1) { progress.Report(TransferProgress.UpdateCurrentProgress((short)((float)pea.CurrentProgress / (float)pea.TotalProgress * 100.0))); } } ); progress.Report(TransferProgress.To(destEntry.Name)); using (await destProfile.WorkingLock.LockAsync()) using (var stream = await destProfile.DiskIO.OpenStreamAsync(destEntry, Defines.FileAccess.ReadWrite, pm.CancellationToken)) destProfile.Wrapper.CompressMultiple(archiveType, stream, compressDic, progress1); logger.Info(String.Format("{0} items transfered", compressDic.Count())); return(CoreScriptCommands.NotifyEntryChanged(ChangeType.Changed, destEntry, NextCommand)); }); return(NextCommand); } finally { #region Dispose Streams if (compressDic != null) { foreach (var stream in compressDic.Values) { stream.Dispose(); } } #endregion } }
public void ProgressDialog() { ScriptRunner.RunScript( WPFScriptCommands.ShowProgress(_windowManager, "Testing", WPFScriptCommands.ReportProgress(TransferProgress.From("C:\\Demo\\FileExplorer3.txt", "http://fileexplorer.codeplex.com/FileExplorer3.txt"), WPFScriptCommands.ReportProgress(TransferProgress.IncrementTotalEntries(100), WPFScriptCommands.ReportProgress(TransferProgress.IncrementProcessedEntries(20), WPFScriptCommands.ReportProgress(TransferProgress.UpdateCurrentProgress(50)))))) ); //_windowManager.ShowDialog(new ProgressDialogViewModel(new ParameterDic() //{ //})); }