Tranga-Website/Tranga-API/Program.cs

186 lines
6.5 KiB
C#
Raw Normal View History

2023-05-25 10:25:24 +02:00
using System.Runtime.InteropServices;
2023-05-21 21:12:32 +02:00
using Logging;
using Tranga;
2023-05-25 10:25:24 +02:00
string applicationFolderPath = Path.Join(Environment.GetFolderPath(Environment.SpecialFolder.CommonApplicationData), "Tranga-API");
string downloadFolderPath = RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ? "/Manga" : Path.Join(applicationFolderPath, "Manga");
string logsFolderPath = RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ? "/var/logs/Tranga" : Path.Join(applicationFolderPath, "logs");
2023-05-21 21:12:32 +02:00
string logFilePath = Path.Join(logsFolderPath, $"log-{DateTime.Now:dd-M-yyyy-HH-mm-ss}.txt");
string settingsFilePath = Path.Join(applicationFolderPath, "settings.json");
2023-05-21 21:12:32 +02:00
Directory.CreateDirectory(logsFolderPath);
2023-05-25 14:23:33 +02:00
Logger logger = new(new[] { Logger.LoggerType.FileLogger, Logger.LoggerType.ConsoleLogger }, Console.Out, Console.Out.Encoding, logFilePath);
2023-05-25 10:25:24 +02:00
2023-05-25 14:23:33 +02:00
logger.WriteLine("Tranga", "Loading settings.");
2023-05-21 21:12:32 +02:00
TrangaSettings settings;
2023-05-21 21:12:32 +02:00
if (File.Exists(settingsFilePath))
settings = TrangaSettings.LoadSettings(settingsFilePath, logger);
2023-05-21 21:12:32 +02:00
else
settings = new TrangaSettings(downloadFolderPath, applicationFolderPath, new HashSet<LibraryManager>());
2023-05-21 21:12:32 +02:00
2023-05-25 14:23:33 +02:00
Directory.CreateDirectory(settings.workingDirectory);
Directory.CreateDirectory(settings.downloadLocation);
Directory.CreateDirectory(settings.coverImageCache);
logger.WriteLine("Tranga",$"Application-Folder: {settings.workingDirectory}");
logger.WriteLine("Tranga",$"Settings-File-Path: {settings.settingsFilePath}");
logger.WriteLine("Tranga",$"Download-Folder-Path: {settings.downloadLocation}");
logger.WriteLine("Tranga",$"Logfile-Path: {logFilePath}");
logger.WriteLine("Tranga",$"Image-Cache-Path: {settings.coverImageCache}");
logger.WriteLine("Tranga", "Loading Taskmanager.");
2023-05-21 21:12:32 +02:00
TaskManager taskManager = new (settings, logger);
var builder = WebApplication.CreateBuilder(args);
2023-05-21 22:01:28 +02:00
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
2023-05-21 21:12:32 +02:00
builder.Services.AddControllers().AddNewtonsoftJson();
2023-05-23 13:16:37 +02:00
string corsHeader = "Tranga";
builder.Services.AddCors(options =>
{
options.AddPolicy(name: corsHeader,
policy =>
{
2023-05-24 22:56:10 +02:00
policy.AllowAnyOrigin();
2023-05-23 18:11:18 +02:00
policy.WithMethods("GET", "POST", "DELETE");
2023-05-23 13:16:37 +02:00
});
});
2023-05-21 21:12:32 +02:00
var app = builder.Build();
2023-05-21 22:01:28 +02:00
app.UseSwagger();
app.UseSwaggerUI();
2023-05-21 21:12:32 +02:00
2023-05-23 13:16:37 +02:00
app.UseCors(corsHeader);
2023-05-21 21:12:32 +02:00
app.MapGet("/Tranga/GetAvailableControllers", () => taskManager.GetAvailableConnectors().Keys.ToArray());
2023-05-21 21:12:32 +02:00
app.MapGet("/Tranga/GetKnownPublications", () => taskManager.GetAllPublications());
app.MapGet("/Tranga/GetPublicationsFromConnector", (string connectorName, string title) =>
2023-05-21 21:12:32 +02:00
{
Connector? connector = taskManager.GetAvailableConnectors().FirstOrDefault(con => con.Key == connectorName).Value;
if (connector is null)
return Array.Empty<Publication>();
if(title.Length < 4)
return Array.Empty<Publication>();
return taskManager.GetPublicationsFromConnector(connector, title);
});
app.MapGet("/Tasks/GetTaskTypes", () => Enum.GetNames(typeof(TrangaTask.Task)));
app.MapPost("/Tasks/Create", (string taskType, string? connectorName, string? publicationId, string reoccurrenceTime, string? language) =>
{
TrangaTask.Task task = Enum.Parse<TrangaTask.Task>(taskType);
taskManager.AddTask(task, connectorName, publicationId, TimeSpan.Parse(reoccurrenceTime), language??"");
2023-05-21 21:12:32 +02:00
});
app.MapDelete("/Tasks/Delete", (string taskType, string? connectorName, string? publicationId) =>
2023-05-21 21:12:32 +02:00
{
Publication? publication = taskManager.GetAllPublications().FirstOrDefault(pub => pub.internalId == publicationId);
TrangaTask.Task task = Enum.Parse<TrangaTask.Task>(taskType);
taskManager.DeleteTask(task, connectorName, publication);
});
app.MapGet("/Tasks/Get", (string taskType, string? connectorName, string? searchString) =>
{
try
{
TrangaTask.Task task = Enum.Parse<TrangaTask.Task>(taskType);
return taskManager.GetTasksMatching(task, connectorName:connectorName, searchString:searchString);
}
catch (ArgumentException)
{
return Array.Empty<TrangaTask>();
}
});
2023-05-21 21:12:32 +02:00
2023-06-01 23:08:43 +02:00
app.MapGet("/Tasks/GetTaskProgress", (string taskType, string? connectorName, string? publicationId) =>
{
try
{
TrangaTask.Task pTask = Enum.Parse<TrangaTask.Task>(taskType);
TrangaTask? task = taskManager
.GetTasksMatching(pTask, connectorName: connectorName, internalId: publicationId)?.First();
2023-06-01 23:08:43 +02:00
if (task is null)
return -1f;
return task.progress;
}
catch (ArgumentException)
{
return -1f;
}
});
app.MapPost("/Tasks/Start", (string taskType, string? connectorName, string? internalId) =>
2023-05-21 21:12:32 +02:00
{
try
{
TrangaTask.Task pTask = Enum.Parse<TrangaTask.Task>(taskType);
TrangaTask? task = taskManager
.GetTasksMatching(pTask, connectorName: connectorName, internalId: internalId)?.FirstOrDefault();
if (task is null)
return;
taskManager.ExecuteTaskNow(task);
}
catch (ArgumentException)
{
2023-05-21 21:12:32 +02:00
return;
}
2023-05-21 21:12:32 +02:00
});
app.MapGet("/Tasks/GetRunningTasks",
() => taskManager.GetAllTasks().Where(task => task.state is TrangaTask.ExecutionState.Running));
app.MapGet("/Queue/GetList",
() => taskManager.GetAllTasks().Where(task => task.state is TrangaTask.ExecutionState.Enqueued));
app.MapPost("/Queue/Enqueue", (string taskType, string? connectorName, string? publicationId) =>
{
try
{
TrangaTask.Task pTask = Enum.Parse<TrangaTask.Task>(taskType);
TrangaTask? task = taskManager
.GetTasksMatching(pTask, connectorName: connectorName, internalId: publicationId)?.First();
if (task is null)
return;
taskManager.AddTaskToQueue(task);
}
catch (ArgumentException)
{
2023-05-21 21:12:32 +02:00
return;
}
2023-05-21 21:12:32 +02:00
});
app.MapDelete("/Queue/Dequeue", (string taskType, string? connectorName, string? publicationId) =>
2023-05-21 21:12:32 +02:00
{
try
{
TrangaTask.Task pTask = Enum.Parse<TrangaTask.Task>(taskType);
TrangaTask? task = taskManager
.GetTasksMatching(pTask, connectorName: connectorName, internalId: publicationId)?.First();
if (task is null)
return;
taskManager.RemoveTaskFromQueue(task);
}
catch (ArgumentException)
{
2023-05-21 21:12:32 +02:00
return;
}
2023-05-21 21:12:32 +02:00
});
app.MapGet("/Settings/Get", () => taskManager.settings);
2023-05-21 21:12:32 +02:00
app.MapPost("/Settings/Update",
2023-06-03 21:26:29 +02:00
(string? downloadLocation, string? komgaUrl, string? komgaAuth, string? kavitaUrl, string? kavitaUsername, string? kavitaPassword) =>
taskManager.UpdateSettings(downloadLocation, komgaUrl, komgaAuth, kavitaUrl, kavitaUsername, kavitaPassword));
2023-05-21 21:12:32 +02:00
app.Run();