moved manifests code to this solution
This commit is contained in:
69
minecraft-launcher-server/Manifests.cs
Normal file
69
minecraft-launcher-server/Manifests.cs
Normal file
@@ -0,0 +1,69 @@
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using DTLib;
|
||||
using DTLib.Extensions;
|
||||
using DTLib.Filesystem;
|
||||
using static launcher_server.Server;
|
||||
|
||||
namespace launcher_server;
|
||||
|
||||
public static class Manifests
|
||||
{
|
||||
static object manifestLocker = new();
|
||||
|
||||
public static void CreateManifest(IOPath dir)
|
||||
{
|
||||
if(!Directory.Exists(dir))
|
||||
{
|
||||
Directory.Create(dir);
|
||||
return;
|
||||
}
|
||||
|
||||
StringBuilder manifestBuilder = new();
|
||||
Hasher hasher = new();
|
||||
var manifestPath = Path.Concat(dir, "manifest.dtsod");
|
||||
if (Directory.GetFiles(dir).Contains(manifestPath))
|
||||
File.Delete(manifestPath);
|
||||
foreach (var _file in Directory.GetAllFiles(dir))
|
||||
{
|
||||
var file = _file.Remove(0, dir.Length);
|
||||
manifestBuilder.Append(file);
|
||||
manifestBuilder.Append(": \"");
|
||||
byte[] hash = hasher.HashFile(Path.Concat(dir, file));
|
||||
manifestBuilder.Append(hash.HashToString());
|
||||
manifestBuilder.Append("\";\n");
|
||||
}
|
||||
File.WriteAllText(manifestPath, manifestBuilder.ToString().Replace('\\','/'));
|
||||
}
|
||||
|
||||
public static void CreateAllManifests()
|
||||
{
|
||||
lock (manifestLocker)
|
||||
{
|
||||
var sync_and_remove_dir = Path.Concat(shared_dir, "sync_and_remove");
|
||||
CreateManifest(Path.Concat(shared_dir, "download_if_not_exist"));
|
||||
CreateManifest(Path.Concat(shared_dir, "sync_always"));
|
||||
if (!Directory.Exists(sync_and_remove_dir))
|
||||
Directory.Create(sync_and_remove_dir);
|
||||
else foreach (var dir in Directory.GetDirectories(sync_and_remove_dir))
|
||||
CreateManifest(dir);
|
||||
StringBuilder dirlist_content_builder = new("dirs: [\n");
|
||||
|
||||
var dirs = Directory.GetDirectories(sync_and_remove_dir);
|
||||
for (var i = 0; i < dirs.Length-1; i++)
|
||||
{
|
||||
dirlist_content_builder
|
||||
.Append("\t\"")
|
||||
.Append(dirs[i].RemoveBase(sync_and_remove_dir).Str.Replace('\\','/'))
|
||||
.Append("\",\n");
|
||||
}
|
||||
dirlist_content_builder
|
||||
.Append("\t\"")
|
||||
.Append(dirs[dirs.Length-1].RemoveBase(sync_and_remove_dir).Str.Replace('\\','/'))
|
||||
.Append("\"\n");
|
||||
|
||||
dirlist_content_builder.Append("];");
|
||||
File.WriteAllText(Path.Concat(sync_and_remove_dir, "dirlist.dtsod"), dirlist_content_builder.ToString());
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -18,9 +18,8 @@ static class Server
|
||||
new ConsoleLogger());
|
||||
static readonly Socket mainSocket = new(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
|
||||
static DtsodV23 config = null!;
|
||||
private static readonly IOPath shared_dir = "public";
|
||||
public static readonly IOPath shared_dir = "public";
|
||||
|
||||
static object manifestLocker = new();
|
||||
|
||||
static void Main(string[] args)
|
||||
{
|
||||
@@ -37,7 +36,7 @@ static class Server
|
||||
logger.LogInfo("Main", $"port: {config["local_port"]}");
|
||||
mainSocket.Bind(new IPEndPoint(IPAddress.Parse(config["local_ip"]), config["local_port"]));
|
||||
mainSocket.Listen(1000);
|
||||
CreateManifests();
|
||||
Manifests.CreateAllManifests();
|
||||
logger.LogInfo("Main", "server started succesfully");
|
||||
// запуск отдельного потока для каждого юзера
|
||||
logger.LogInfo("Main", "waiting for users");
|
||||
@@ -115,27 +114,5 @@ static class Server
|
||||
}
|
||||
}
|
||||
|
||||
static void CreateManifests()
|
||||
{
|
||||
lock (manifestLocker)
|
||||
{
|
||||
var sync_and_remove_dir = Path.Concat(shared_dir, "sync_and_remove");
|
||||
FSP.CreateManifest(Path.Concat(shared_dir, "download_if_not_exist"));
|
||||
FSP.CreateManifest(Path.Concat(shared_dir, "sync_always"));
|
||||
if (!Directory.Exists(sync_and_remove_dir))
|
||||
Directory.Create(sync_and_remove_dir);
|
||||
else foreach (var dir in Directory.GetDirectories(sync_and_remove_dir))
|
||||
FSP.CreateManifest(dir);
|
||||
string dirlist_content = "dirs: [ ];";
|
||||
if(Directory.GetDirectories(sync_and_remove_dir).Length > 0)
|
||||
{
|
||||
dirlist_content = "dirs: [\""
|
||||
+ Directory.GetDirectories(sync_and_remove_dir)
|
||||
.MergeToString("\", \"")
|
||||
.Replace(sync_and_remove_dir.Str, "")
|
||||
+ "\"];";
|
||||
}
|
||||
File.WriteAllText(Path.Concat(sync_and_remove_dir, "dirlist.dtsod"), dirlist_content);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user