Updated download system

This commit is contained in:
2022-05-05 20:39:31 +03:00
parent d787457753
commit d3d687ea2f
4 changed files with 90 additions and 76 deletions

View File

@@ -138,29 +138,8 @@ namespace DiscordBot
} }
string path = "./Data/Plugins/" + info[0] + "s/" + name + ".dll"; 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); await ServerCom.DownloadFileAsync(info[1], path);
}
});
new Thread(t.Start).Start();
await ServerCom.DownloadFileAsync(info[1], path, progress);
//Console.WriteLine();
pbar.Update(100);
prg = 100;
Console.WriteLine("\n"); Console.WriteLine("\n");
// check requirements if any // check requirements if any
@@ -176,31 +155,9 @@ namespace DiscordBot
{ {
string[] split = line.Split(','); string[] split = line.Split(',');
Console.WriteLine($"\nDownloading item: {split[1]}"); 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(); Console.WriteLine();
i++; i++;
} }
@@ -241,29 +198,7 @@ namespace DiscordBot
string path2 = Functions.langFolder + Lname + ".lng"; string path2 = Functions.langFolder + Lname + ".lng";
progress = new Progress<float>(percent => await ServerCom.DownloadFileAsync(link[0], path2);
{
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;
Console.WriteLine("\n"); 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]); 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]);

View File

@@ -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="progress">The <see cref="IProgress{T}"/> that is used to track the download progress</param>
/// <param name="cancellation">The cancellation token</param> /// <param name="cancellation">The cancellation token</param>
/// <returns></returns> /// <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)) 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%) // 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 // Use extension method to report progress while downloading
await download.CopyToOtherStreamAsync(destination, 81920, relativeProgress, cancellation); await download.CopyToOtherStreamAsync(destination, 81920, relativeProgress, cancellation);
progress.Report(1); progress.Report(1);

View File

@@ -33,7 +33,7 @@ namespace PluginManager.Online
/// <param name="location">The location where to store the downloaded data</param> /// <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> /// <param name="progress">The <see cref="IProgress{T}"/> to track the download</param>
/// <returns></returns> /// <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()) 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)) 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);
}
} }
} }

View File

@@ -24,7 +24,7 @@ namespace PluginManager.Others
Message = message; 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 //progress bar
@@ -53,10 +53,17 @@ namespace PluginManager.Others
Console.CursorLeft = 35; Console.CursorLeft = 35;
Console.BackgroundColor = ConsoleColor.Black; 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) //if (r == false)
Update(progress, true); //Update(progress, true);
} }