uptime-kuma/extra/exe-builder/DownloadForm.cs

175 lines
5.5 KiB
C#
Raw Normal View History

2022-10-08 04:23:11 -04:00
using System;
using System.Collections.Generic;
using System.ComponentModel;
2022-10-08 11:47:27 -04:00
using System.Diagnostics;
2022-10-08 04:23:11 -04:00
using System.IO;
2022-10-08 11:47:27 -04:00
using System.IO.Compression;
2022-10-08 04:23:11 -04:00
using System.Net;
2022-10-08 11:47:27 -04:00
using System.Threading;
using System.Threading.Tasks;
2022-10-08 04:23:11 -04:00
using System.Windows.Forms;
namespace UptimeKuma {
public partial class DownloadForm : Form {
private readonly Queue<DownloadItem> downloadQueue = new();
private readonly WebClient webClient = new();
2022-10-08 11:47:27 -04:00
private DownloadItem currentDownloadItem;
2022-10-08 04:23:11 -04:00
public DownloadForm() {
InitializeComponent();
}
private void DownloadForm_Load(object sender, EventArgs e) {
webClient.DownloadProgressChanged += DownloadProgressChanged;
webClient.DownloadFileCompleted += DownloadFileCompleted;
2022-10-08 11:47:27 -04:00
if (!Directory.Exists("node")) {
2022-10-08 04:23:11 -04:00
downloadQueue.Enqueue(new DownloadItem {
URL = "https://nodejs.org/dist/v16.17.1/node-v16.17.1-win-x64.zip",
2022-10-08 11:47:27 -04:00
Filename = "node.zip",
TargetFolder = "node"
2022-10-08 04:23:11 -04:00
});
}
2022-10-08 11:47:27 -04:00
if (!Directory.Exists("node")) {
2022-10-08 04:23:11 -04:00
downloadQueue.Enqueue(new DownloadItem {
URL = "https://github.com/louislam/uptime-kuma/archive/refs/tags/1.18.3.zip",
2022-10-08 11:47:27 -04:00
Filename = "core.zip",
TargetFolder = "core"
2022-10-08 04:23:11 -04:00
});
}
DownloadNextFile();
}
void DownloadNextFile() {
if (downloadQueue.Count > 0) {
var item = downloadQueue.Dequeue();
2022-10-08 11:47:27 -04:00
currentDownloadItem = item;
// Download if the zip file is not existing
if (!File.Exists(item.Filename)) {
label.Text = item.URL;
webClient.DownloadFileAsync(new Uri(item.URL), item.Filename);
} else {
progressBar.Value = 100;
label.Text = "Use local " + item.Filename;
DownloadFileCompleted(null, null);
}
2022-10-08 04:23:11 -04:00
} else {
2022-10-08 11:47:27 -04:00
npmSetup();
}
}
void npmSetup() {
if (Directory.Exists("core/node_modules")) {
// Application.Restart();
2022-10-08 04:23:11 -04:00
}
2022-10-08 11:47:27 -04:00
label.Text = "npm run setup";
progressBar.Value = 50;
labelData.Text = "";
var startInfo = new ProcessStartInfo {
FileName = "cmd.exe",
Arguments = "run setup",
RedirectStandardOutput = false,
RedirectStandardError = false,
RedirectStandardInput = true,
UseShellExecute = false,
CreateNoWindow = false,
WorkingDirectory = "core"
};
var process = new Process();
process.StartInfo = startInfo;
process.EnableRaisingEvents = true;
process.Exited += (object _, EventArgs e) => {
// Application.Restart();
progressBar.Value = 100;
if (process.ExitCode == 0) {
label.Text = "Done";
} else {
label.Text = "Failed, exit code: " + process.ExitCode;
}
};
process.Start();
process.StandardInput.WriteLine("\"../node/npm\" run setup");
2022-10-08 04:23:11 -04:00
}
void DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e) {
progressBar.Value = e.ProgressPercentage;
var total = e.TotalBytesToReceive / 1024;
var current = e.BytesReceived / 1024;
2022-10-08 11:47:27 -04:00
if (total > 0) {
labelData.Text = $"{current}KB/{total}KB";
}
2022-10-08 04:23:11 -04:00
}
2022-10-08 11:47:27 -04:00
async void DownloadFileCompleted(object sender, AsyncCompletedEventArgs e) {
Extract(currentDownloadItem);
2022-10-08 04:23:11 -04:00
DownloadNextFile();
}
2022-10-08 11:47:27 -04:00
void Extract(DownloadItem item) {
if (Directory.Exists(item.TargetFolder)) {
var dir = new DirectoryInfo(item.TargetFolder);
dir.Delete(true);
}
if (Directory.Exists("temp")) {
var dir = new DirectoryInfo("temp");
dir.Delete(true);
}
labelData.Text = $"Extracting {item.Filename}...";
ZipFile.ExtractToDirectory(item.Filename, "temp");
string[] dirList;
// Move to the correct level
dirList = Directory.GetDirectories("temp");
if (dirList.Length > 0) {
var dir = dirList[0];
// As sometime ExtractToDirectory is still locking the directory, loop until ok
while (true) {
try {
Directory.Move(dir, item.TargetFolder);
break;
} catch (Exception exception) {
Thread.Sleep(1000);
}
}
} else {
MessageBox.Show("Unexcepted Error: Cannot move extracted files, folder not found.");
}
labelData.Text = $"Extracted";
if (Directory.Exists("temp")) {
var dir = new DirectoryInfo("temp");
dir.Delete(true);
}
File.Delete(item.Filename);
}
2022-10-08 04:23:11 -04:00
}
public class DownloadItem {
public string URL { get; set; }
public string Filename { get; set; }
2022-10-08 11:47:27 -04:00
public string TargetFolder { get; set; }
2022-10-08 04:23:11 -04:00
}
}