Updated download system
This commit is contained in:
@@ -138,29 +138,8 @@ namespace DiscordBot
|
||||
|
||||
}
|
||||
string path = "./Data/Plugins/" + info[0] + "s/" + name + ".dll";
|
||||
progress = new Progress<float>(percent =>
|
||||
{
|
||||
prg = (int)percent;
|
||||
/*Console.Title = $"Downloading: {Lname} ({MathF.Round(percent, 2)}%)";*/
|
||||
});
|
||||
pbar = new Console_Utilities.ProgressBar(100, "Downloading Plugin");
|
||||
Console.WriteLine();
|
||||
t = new Task(async () =>
|
||||
{
|
||||
while (true)
|
||||
{
|
||||
if (prg == 100) break;
|
||||
pbar.Update(prg);
|
||||
|
||||
Thread.Sleep(500);
|
||||
}
|
||||
|
||||
});
|
||||
new Thread(t.Start).Start();
|
||||
await ServerCom.DownloadFileAsync(info[1], path, progress);
|
||||
//Console.WriteLine();
|
||||
pbar.Update(100);
|
||||
prg = 100;
|
||||
await ServerCom.DownloadFileAsync(info[1], path);
|
||||
Console.WriteLine("\n");
|
||||
|
||||
// check requirements if any
|
||||
@@ -176,31 +155,9 @@ namespace DiscordBot
|
||||
{
|
||||
string[] split = line.Split(',');
|
||||
Console.WriteLine($"\nDownloading item: {split[1]}");
|
||||
progress = new Progress<float>(percent =>
|
||||
{
|
||||
prg = (int)percent;
|
||||
});
|
||||
|
||||
pbar = new Console_Utilities.ProgressBar(100, "Downloading Requirements");
|
||||
bool finish = false;
|
||||
t = new Task(async () =>
|
||||
{
|
||||
while (!finish)
|
||||
{
|
||||
pbar.Update(prg);
|
||||
//if (prg == 100) break;
|
||||
Thread.Sleep(500);
|
||||
}
|
||||
|
||||
});
|
||||
new Thread(t.Start).Start();
|
||||
await ServerCom.DownloadFileAsync(split[0], "./" + split[1], progress);
|
||||
// prg = 100;
|
||||
finish = true;
|
||||
pbar.Update(100);
|
||||
|
||||
|
||||
|
||||
await ServerCom.DownloadFileAsync(split[0], "./" + split[1]);
|
||||
Console.WriteLine();
|
||||
i++;
|
||||
}
|
||||
@@ -241,29 +198,7 @@ namespace DiscordBot
|
||||
|
||||
string path2 = Functions.langFolder + Lname + ".lng";
|
||||
|
||||
progress = new Progress<float>(percent =>
|
||||
{
|
||||
prg = (int)percent;
|
||||
/*Console.Title = $"Downloading: {Lname} ({MathF.Round(percent, 2)}%)";*/
|
||||
});
|
||||
pbar = new Console_Utilities.ProgressBar(100, "Downloading Language");
|
||||
|
||||
t = new Task(async () =>
|
||||
{
|
||||
while (true)
|
||||
{
|
||||
if (prg == 100) break;
|
||||
pbar.Update(prg);
|
||||
|
||||
Thread.Sleep(500);
|
||||
}
|
||||
|
||||
});
|
||||
new Thread(t.Start).Start();
|
||||
|
||||
await ServerCom.DownloadFileAsync(link[0], path2, progress);
|
||||
pbar.Update(100);
|
||||
prg = 100;
|
||||
await ServerCom.DownloadFileAsync(link[0], path2);
|
||||
Console.WriteLine("\n");
|
||||
}
|
||||
else Console_Utilities.WriteColorText("The language you are trying to download (&b" + Lname + "&c) is not compatible with the version of this bot. User &glistlang &ccommand in order to see all available languages for your current version !\n" + link[1]);
|
||||
|
||||
@@ -18,7 +18,8 @@ namespace PluginManager.Online.Helpers
|
||||
/// <param name="progress">The <see cref="IProgress{T}"/> that is used to track the download progress</param>
|
||||
/// <param name="cancellation">The cancellation token</param>
|
||||
/// <returns></returns>
|
||||
internal static async Task DownloadFileAsync(this HttpClient client, string url, Stream destination, IProgress<float> progress = null, CancellationToken cancellation = default)
|
||||
internal static async Task DownloadFileAsync(this HttpClient client, string url, Stream destination,
|
||||
IProgress<float> progress = null, IProgress<long> downloadedBytes = null, CancellationToken cancellation = default)
|
||||
{
|
||||
using (var response = await client.GetAsync(url, HttpCompletionOption.ResponseHeadersRead))
|
||||
{
|
||||
@@ -36,7 +37,11 @@ namespace PluginManager.Online.Helpers
|
||||
}
|
||||
|
||||
// Convert absolute progress (bytes downloaded) into relative progress (0% - 100%)
|
||||
var relativeProgress = new Progress<long>(totalBytes => progress.Report((float)totalBytes / contentLength.Value * 100));
|
||||
var relativeProgress = new Progress<long>(totalBytes =>
|
||||
{
|
||||
progress.Report((float)totalBytes / contentLength.Value * 100);
|
||||
downloadedBytes.Report(totalBytes);
|
||||
});
|
||||
// Use extension method to report progress while downloading
|
||||
await download.CopyToOtherStreamAsync(destination, 81920, relativeProgress, cancellation);
|
||||
progress.Report(1);
|
||||
|
||||
@@ -33,7 +33,7 @@ namespace PluginManager.Online
|
||||
/// <param name="location">The location where to store the downloaded data</param>
|
||||
/// <param name="progress">The <see cref="IProgress{T}"/> to track the download</param>
|
||||
/// <returns></returns>
|
||||
public static async Task DownloadFileAsync(string URL, string location, IProgress<float> progress)
|
||||
public static async Task DownloadFileAsync(string URL, string location, IProgress<float> progress, IProgress<long> downloadedBytes)
|
||||
{
|
||||
using (var client = new System.Net.Http.HttpClient())
|
||||
{
|
||||
@@ -41,9 +41,76 @@ namespace PluginManager.Online
|
||||
|
||||
using (var file = new FileStream(location, FileMode.Create, FileAccess.Write, FileShare.None))
|
||||
{
|
||||
await client.DownloadFileAsync(URL, file, progress);
|
||||
await client.DownloadFileAsync(URL, file, progress, downloadedBytes);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Download file from url
|
||||
/// </summary>
|
||||
/// <param name="URL">The url to the file</param>
|
||||
/// <param name="location">The location where to store the downloaded data</param>
|
||||
/// <returns></returns>
|
||||
public static async Task DownloadFileAsync(string URL, string location)
|
||||
{
|
||||
bool isDownloading = true;
|
||||
int c_progress = 0;
|
||||
|
||||
long secondsPast = 0;
|
||||
long m_dwBytes = 0;
|
||||
double c_downloadSpeed = 0f;
|
||||
string c_downloadUnit = "MB";
|
||||
|
||||
Others.Console_Utilities.ProgressBar pbar = new Others.Console_Utilities.ProgressBar(100, "");
|
||||
|
||||
IProgress<float> progress = new Progress<float>(percent =>
|
||||
{
|
||||
c_progress = (int)percent;
|
||||
});
|
||||
|
||||
IProgress<long> progress_downloaded = new Progress<long>(downloadedBytes =>
|
||||
{
|
||||
m_dwBytes = downloadedBytes;
|
||||
});
|
||||
|
||||
Task updateProgressBarTask = new Task(async () =>
|
||||
{
|
||||
while (isDownloading)
|
||||
{
|
||||
//pbar.Update(c_progress, c_downloadSpeed, c_downloadUnit);
|
||||
pbar.Update(c_progress);
|
||||
if (c_progress == 100)
|
||||
break;
|
||||
System.Threading.Thread.Sleep(500);
|
||||
}
|
||||
});
|
||||
|
||||
Task calculateDownloadSpeed = new Task(async () =>
|
||||
{
|
||||
|
||||
while (isDownloading)
|
||||
{
|
||||
secondsPast++;
|
||||
c_downloadSpeed = m_dwBytes / secondsPast;
|
||||
|
||||
c_downloadSpeed /= 1024; // in KB
|
||||
c_downloadSpeed /= 1024; // in MB
|
||||
|
||||
c_downloadSpeed = Math.Round(c_downloadSpeed, 2, MidpointRounding.AwayFromZero);
|
||||
|
||||
System.Threading.Thread.Sleep(1000);
|
||||
}
|
||||
});
|
||||
|
||||
// new System.Threading.Thread(calculateDownloadSpeed.Start).Start();
|
||||
new System.Threading.Thread(updateProgressBarTask.Start).Start();
|
||||
await DownloadFileAsync(URL, location, progress, progress_downloaded);
|
||||
|
||||
isDownloading = false;
|
||||
c_progress = 100;
|
||||
pbar.Update(100);
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -24,7 +24,7 @@ namespace PluginManager.Others
|
||||
Message = message;
|
||||
}
|
||||
|
||||
public async void Update(int progress, bool r = false)
|
||||
public async void Update(int progress, double speed = -1, string unit = null)
|
||||
{
|
||||
|
||||
//progress bar
|
||||
@@ -53,10 +53,17 @@ namespace PluginManager.Others
|
||||
|
||||
Console.CursorLeft = 35;
|
||||
Console.BackgroundColor = ConsoleColor.Black;
|
||||
Console.Write(progress.ToString() + " of " + Max.ToString() + " ");
|
||||
if (speed == -1 || unit == null)
|
||||
{
|
||||
if (progress == Max)
|
||||
Console.Write(progress.ToString() + " % ✓");
|
||||
else Console.Write(progress.ToString() + " % ");
|
||||
}
|
||||
else
|
||||
Console.Write(progress.ToString() + $"{speed} {unit}/s ");
|
||||
|
||||
if (r == false)
|
||||
Update(progress, true);
|
||||
//if (r == false)
|
||||
//Update(progress, true);
|
||||
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user