Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Server v2 #167

Draft
wants to merge 153 commits into
base: cuttingedge
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
153 commits
Select commit Hold shift + click to select a range
7e54577
Added initial documentation for API Calls
estradalab Apr 6, 2024
dd965d8
Revert "Added initial documentation for API Calls"
db-2001 Apr 6, 2024
7628510
Documentation for API Calls
db-2001 Apr 6, 2024
6f5fb7e
API rewrite to parse JSON body for POST and DELETE
db-2001 Apr 7, 2024
dbc1b94
Merge branch 'cuttingedge' into json-api
db-2001 Apr 18, 2024
33b8ede
Use new requestParams variable for AprilFoolsMode setting
db-2001 Apr 18, 2024
2768ab3
Merge remote-tracking branch 'upstream/cuttingedge' into json-api
db-2001 Apr 18, 2024
01bab62
Log request if unknown
db-2001 Apr 18, 2024
a8aa7d3
Okay, actually write request variables to log.
db-2001 Apr 18, 2024
7e5fa6c
API v2
C9Glax Apr 19, 2024
f5cecb9
Github Reference Link Style
C9Glax Apr 19, 2024
0313d81
Return JobIds instead of full jobs.
C9Glax Apr 19, 2024
238395a
Return JobIds instead of full jobs.
C9Glax Apr 19, 2024
595051b
Merge remote-tracking branch 'origin/Server-V2' into Server-V2
C9Glax Apr 19, 2024
d22b49c
Change Method Header for Handlers to return the response to HandleReq…
C9Glax Apr 19, 2024
bd14722
Merge remote-tracking branch 'refs/remotes/db-2001/json-api' into Ser…
C9Glax Apr 19, 2024
2828fec
Merge
C9Glax Apr 19, 2024
f79743e
actually use v2 API
C9Glax Apr 19, 2024
fa25980
Hard cutover https://github.com/C9Glax/tranga/pull/167#issuecomment-2…
C9Glax Apr 20, 2024
630e507
#74 API Documentation
C9Glax Apr 20, 2024
011af9c
#114 API Documentation
C9Glax Apr 20, 2024
5e64709
Spelling
C9Glax Apr 20, 2024
c41f04d
All Valid Request Paths return "Not Implemented".
C9Glax Apr 20, 2024
a610eff
Merge branch 'refs/heads/cuttingedge' into Server-V2
C9Glax Apr 20, 2024
e96dd07
Link API Documentation in README.md
C9Glax Apr 20, 2024
9a02859
Docker Image build
C9Glax Apr 20, 2024
8b9769b
Merge branch 'refs/heads/master' into Server-V2
C9Glax Apr 20, 2024
b3fb53f
Corrected link
C9Glax Apr 20, 2024
4cb7c94
Implemented /v2/Connector/<ConnectorName>/GetManga
C9Glax Apr 21, 2024
4104169
Fix path excluding symbols that are used in requests
C9Glax Apr 21, 2024
6d48a10
Implemented GET
C9Glax Apr 21, 2024
49cfff8
Changed the Creation Job API to a single Endpoint /v2/Job/Create/<Type>
C9Glax Apr 21, 2024
b6ffb97
Merge branch 'refs/heads/cuttingedge' into Server-V2
C9Glax Apr 22, 2024
3adb103
Fix API-Path prematurely triggering match.
C9Glax Apr 22, 2024
cce4901
Implement all /v2/Settings
C9Glax Apr 22, 2024
6448293
Implemented GET /v2/LogFile
C9Glax Apr 22, 2024
03e90ec
No longer require connector name to create job
C9Glax Apr 22, 2024
c323132
nullable
C9Glax Apr 22, 2024
ea866e0
Added Endpoint /v2/Manga lists all known Manga
C9Glax Apr 22, 2024
e360037
Add "(?:/?)" to the end of all Regex RequestPaths
C9Glax Apr 22, 2024
8c66bbc
Use publicationCache to store and update Manga
C9Glax Apr 22, 2024
bce7718
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Apr 22, 2024
cee7870
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Apr 22, 2024
a56555e
Add LibraryConnector.Test to see if requests can be made to endpoint.
C9Glax Apr 22, 2024
0ced3a7
Implement /v2/LibraryConnector/*
C9Glax Apr 22, 2024
2651a0c
Implemented /v2/NotificationConnector/*
C9Glax Apr 22, 2024
3d08b1f
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Apr 25, 2024
28a0efe
Add Endpoint /v2/Manga/internalId/Chapters/Latest
C9Glax Apr 25, 2024
80dc8fb
Resolves #176 Return 409 conflict if job already exists.
C9Glax Apr 25, 2024
061da1b
Add field customFolder and startChapter to CreateJob Endpoint
C9Glax Apr 25, 2024
8887cea
Add Endpoint POST /v2/Manga/internalId/ignoreChaptersBelow #167
C9Glax Apr 25, 2024
2e1f633
Add Endpoint POST /v2/Manga/internalId/moveFolder #167
C9Glax Apr 25, 2024
5b22246
Add Endpoint GET /v2/Job returns list of jobs specified by jobid
C9Glax Apr 25, 2024
0735e2c
Change GET /v2/Manga to /v2/Mangas
C9Glax Apr 25, 2024
49a9b7c
Corrected Job->Manga in return
C9Glax Apr 25, 2024
7f95ab9
Add Endpoint GET /v2/Manga to request multiple Manga from internalIds…
C9Glax Apr 25, 2024
7ed3846
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Apr 25, 2024
4021237
Add Endpoint GET /v2/Manga/Search GlobalSearch
C9Glax Apr 25, 2024
017f31c
Clean
C9Glax Apr 26, 2024
2cfc7ac
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Apr 27, 2024
27a5598
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax May 26, 2024
5c30913
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax May 26, 2024
beb4553
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax May 26, 2024
8ccb6c0
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax May 26, 2024
6ae3918
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Jun 1, 2024
4f14903
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Jun 1, 2024
790e77b
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Jun 1, 2024
ee6de66
Merge branch 'refs/heads/C9Glax-tranga-issue-187' into Server-V2
C9Glax Jun 15, 2024
fd20b9f
NTFY use Username and Password
C9Glax Jun 15, 2024
fab30dc
Documentation
C9Glax Jun 15, 2024
8607bd2
#187 NTFY JsonConverter
C9Glax Jun 15, 2024
f3e0959
Merge pull request #198 from C9Glax/master
C9Glax Jun 29, 2024
5bc2a89
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Jun 29, 2024
d221532
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Jun 29, 2024
d73bf70
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Jul 11, 2024
6b9ddca
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Jul 31, 2024
cf242f8
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Aug 10, 2024
9dd5217
Update MangaHere bad ManhuaPlus to v2 architecture
C9Glax Aug 10, 2024
8145abb
Fix workign Directory in TrangaArgsMain
C9Glax Aug 10, 2024
b18f8e4
Fix GET /v2/Job/Types
C9Glax Aug 10, 2024
2f36701
Reduce Logspam
C9Glax Aug 10, 2024
1ee9b64
Fix Permissions for manga-directory
C9Glax Aug 10, 2024
6520aeb
Cleanup MangaCache
C9Glax Aug 10, 2024
960d3f7
Fix Cover location
C9Glax Aug 10, 2024
fc884ad
Fix HandleRequest trying to send more than one response
C9Glax Aug 10, 2024
032ee95
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Aug 26, 2024
3c3f7bb
Merge recent changes to TrangaSettings backend
C9Glax Aug 26, 2024
e95eb04
#229 Resize cover Images if requested
C9Glax Aug 26, 2024
054c887
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Aug 26, 2024
06cdbbd
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Aug 26, 2024
75eea8c
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Aug 26, 2024
217700d
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 9, 2024
190fa8c
Fix #239 multiple enumeration on Export
C9Glax Sep 9, 2024
3b9d4a6
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 11, 2024
77bb309
Fix #248 double closing OutputStream in response
C9Glax Sep 16, 2024
99df9a9
Fix #248
C9Glax Sep 16, 2024
c6cfd9e
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 16, 2024
73ad881
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 16, 2024
18edcef
Resolve #247
C9Glax Sep 16, 2024
c36204c
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 16, 2024
96e2845
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 16, 2024
be68ddc
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 16, 2024
7b6724a
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 18, 2024
a92eba2
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 21, 2024
32ecdcd
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 23, 2024
48ab44c
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 27, 2024
26a07f4
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 27, 2024
1c5f105
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 27, 2024
4871bc8
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Sep 28, 2024
d80fcd9
Manga website url nullable
C9Glax Sep 30, 2024
225db8b
Change return type of api request to get Connectors to get connector-…
C9Glax Oct 17, 2024
6a4d454
Extend Types.md documentation
C9Glax Oct 17, 2024
d4af068
Add BaseUris: string[] field to MangaConnector, to match Connector to…
C9Glax Oct 17, 2024
575fb73
typo
C9Glax Oct 17, 2024
2c9bd25
Fix order of RequestPaths
C9Glax Oct 18, 2024
8670863
Add Job and ProgressToken Types to docs
C9Glax Oct 18, 2024
00c4f05
Update documentation
C9Glax Oct 18, 2024
1a63136
Use Sixlabors.Imagesharp for resizing coverimages.
C9Glax Oct 18, 2024
70993a6
Add ReleaseStatus to docs/types.md
C9Glax Oct 18, 2024
27f823c
GET V2Manga with internalIds return distinct array.
C9Glax Oct 19, 2024
a88b85e
Add numbers to JobTypes (and type documentation)
C9Glax Oct 19, 2024
26b2910
Add GET /v2/Jobs/Standby
C9Glax Oct 19, 2024
240af81
Add doc types chapter
C9Glax Oct 20, 2024
f9a30f2
Types documentation add quotation marks
C9Glax Oct 20, 2024
f57667b
add documentation types settings
C9Glax Oct 20, 2024
582b3af
Add docs types LibraryConnector
C9Glax Oct 20, 2024
93696fb
docs Types documentation NotificationConnector
C9Glax Oct 20, 2024
9d47445
Assign numbers to ProgressToken.State
C9Glax Oct 20, 2024
96b5921
GET LibraryTypes Create and Test set url to lowercase
C9Glax Oct 23, 2024
2db85e5
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Oct 27, 2024
fb7ed21
Update Types doc with last merge for Chapters
C9Glax Oct 27, 2024
febce6b
Downloaded Image processing:
C9Glax Oct 27, 2024
585d7e3
Fix order of startup: Load Manga first, the jobs
C9Glax Oct 27, 2024
07c6081
#236
C9Glax Oct 27, 2024
3e581e2
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Oct 30, 2024
1cb8899
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Oct 31, 2024
f7daacf
Use Robidoux algorithm for resizing covers
C9Glax Oct 31, 2024
b7bc04a
Add zstd compression to all API Traffic
C9Glax Oct 31, 2024
3f37eef
Include modified date in image responses for cachecontrol
C9Glax Oct 31, 2024
c7dc5e7
Add "Expires" Header to image responses
C9Glax Oct 31, 2024
5018800
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Nov 2, 2024
bc44a53
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Nov 2, 2024
483dcc4
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Nov 2, 2024
1bd9145
Asuratoon Server-V2
C9Glax Nov 11, 2024
29f3f1a
Merge branch 'refs/heads/cuttingedge-merge-ServerV2' into Server-V2
C9Glax Nov 28, 2024
b5b45d0
Merge branch 'cuttingedge-merge-ServerV2' into Server-V2
C9Glax Dec 4, 2024
44ff158
Merge branch 'cuttingedge-merge-ServerV2' into Server-V2
C9Glax Dec 4, 2024
7daebcb
Merge branch 'cuttingedge-merge-ServerV2' into Server-V2
C9Glax Dec 12, 2024
4040b58
Merge branch 'cuttingedge-merge-ServerV2' into Server-V2
C9Glax Dec 12, 2024
afcc2ca
merge
C9Glax Dec 12, 2024
9d6a8ed
Merge branch 'cuttingedge-merge-ServerV2' into Server-V2
C9Glax Dec 13, 2024
57df419
Merge branch 'cuttingedge-merge-ServerV2' into Server-V2
C9Glax Dec 14, 2024
bf9fe51
Merge branch 'cuttingedge-merge-ServerV2' into Server-V2
C9Glax Dec 14, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@ riderModule.iml
cover.jpg
cover.png
/.vscode
/.vs/
Tranga/Properties/launchSettings.json
/Manga
/settings
*.DotSettings.user
7 changes: 5 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<br />
<div align="center">

<h3 align="center">Tranga</h3>
<h3 align="center">Tranga v2</h3>

<p align="center">
Automatic Manga and Metadata downloader
Expand Down Expand Up @@ -62,7 +62,8 @@ Notifications can be sent to your devices using [Gotify](https://gotify.net/), [
### What this does and doesn't do

Tranga (this git-repo) will open a port (standard 6531) and listen for requests to add Jobs to Monitor and/or download specific Manga.
The configuration is all done through HTTP-Requests.
The configuration is all done through HTTP-Requests. [Documentation](docs/API_Calls_v2.md)

_**For a web-frontend use [tranga-website](https://github.com/C9Glax/tranga-website).**_

This project downloads the images for a Manga from the specified Scanlation-Website and packages them with some metadata - from that same website - in a .cbz-archive (per chapter).
Expand Down Expand Up @@ -90,6 +91,8 @@ That is why I wanted to create my own project, in a language I understand, and t
- [PuppeteerSharp](https://www.puppeteersharp.com/)
- [Html Agility Pack (HAP)](https://html-agility-pack.net/)
- [Soenneker.Utils.String.NeedlemanWunsch](https://github.com/soenneker/soenneker.utils.string.needlemanwunsch)
- [Sixlabors.ImageSharp](https://docs-v2.sixlabors.com/articles/imagesharp/index.html#license)
- [zstd-wrapper](https://github.com/oleg-st/ZstdSharp) [zstd](https://github.com/facebook/zstd)
- 💙 Blåhaj 🦈

<p align="right">(<a href="#readme-top">back to top</a>)</p>
Expand Down
77 changes: 68 additions & 9 deletions Tranga/GlobalBase.cs
Original file line number Diff line number Diff line change
@@ -1,8 +1,11 @@
using System.Globalization;
using System.Runtime.InteropServices;
using System.Text;
using System.Text.RegularExpressions;
using Logging;
using Newtonsoft.Json;
using Tranga.LibraryConnectors;
using Tranga.MangaConnectors;
using Tranga.NotificationConnectors;

namespace Tranga;
Expand All @@ -14,6 +17,7 @@ public abstract class GlobalBase
protected HashSet<NotificationConnector> notificationConnectors { get; init; }
protected HashSet<LibraryConnector> libraryConnectors { get; init; }
private Dictionary<string, Manga> cachedPublications { get; init; }
protected HashSet<MangaConnector> _connectors;
public static readonly NumberFormatInfo numberFormatDecimalPoint = new (){ NumberDecimalSeparator = "." };
protected static readonly Regex baseUrlRex = new(@"https?:\/\/[0-9A-z\.-]+(:[0-9]+)?");

Expand All @@ -23,6 +27,7 @@ protected GlobalBase(GlobalBase clone)
this.notificationConnectors = clone.notificationConnectors;
this.libraryConnectors = clone.libraryConnectors;
this.cachedPublications = clone.cachedPublications;
this._connectors = clone._connectors;
}

protected GlobalBase(Logger? logger)
Expand All @@ -31,29 +36,83 @@ protected GlobalBase(Logger? logger)
this.notificationConnectors = TrangaSettings.LoadNotificationConnectors(this);
this.libraryConnectors = TrangaSettings.LoadLibraryConnectors(this);
this.cachedPublications = new();
this._connectors = new();
}

protected Manga? GetCachedManga(string internalId)
{
return cachedPublications.TryGetValue(internalId, out Manga manga) switch
{
true => manga,
_ => null
};
}

protected IEnumerable<Manga> GetAllCachedManga() => cachedPublications.Values;

protected void AddMangaToCache(Manga manga)
{
if (!this.cachedPublications.TryAdd(manga.internalId, manga))
if (!cachedPublications.TryAdd(manga.internalId, manga))
{
Log($"Overwriting Manga {manga.internalId}");
this.cachedPublications[manga.internalId] = manga;
cachedPublications[manga.internalId] = manga;
}
ExportManga();
}

protected void RemoveMangaFromCache(Manga manga) => RemoveMangaFromCache(manga.internalId);

protected Manga? GetCachedManga(string internalId)
protected void RemoveMangaFromCache(string internalId)
{
return cachedPublications.TryGetValue(internalId, out Manga manga) switch
cachedPublications.Remove(internalId);
ExportManga();
}

internal void ImportManga()
{
string folder = TrangaSettings.mangaCacheFolderPath;
Directory.CreateDirectory(folder);

foreach (FileInfo fileInfo in new DirectoryInfo(folder).GetFiles())
{
true => manga,
_ => null
};
string content = File.ReadAllText(fileInfo.FullName);
try
{
Manga m = JsonConvert.DeserializeObject<Manga>(content, new MangaConnectorJsonConverter(this, _connectors));
this.cachedPublications.TryAdd(m.internalId, m);
}
catch (JsonException e)
{
Log($"Error parsing Manga {fileInfo.Name}:\n{e.Message}");
}
}

}

protected IEnumerable<Manga> GetAllCachedManga()
private static bool ExportRunning = false;
private void ExportManga()
{
return cachedPublications.Values;
while (ExportRunning)
Thread.Sleep(1);
ExportRunning = true;
string folder = TrangaSettings.mangaCacheFolderPath;
Directory.CreateDirectory(folder);
Manga[] copy = new Manga[cachedPublications.Values.Count];
cachedPublications.Values.CopyTo(copy, 0);
foreach (Manga manga in copy)
{
string content = JsonConvert.SerializeObject(manga, Formatting.Indented);
string filePath = Path.Combine(folder, $"{manga.internalId}.json");
File.WriteAllText(filePath, content, Encoding.UTF8);
}

foreach (FileInfo fileInfo in new DirectoryInfo(folder).GetFiles())
{
if(!cachedPublications.Keys.Any(key => fileInfo.Name.Substring(0, fileInfo.Name.LastIndexOf('.')).Equals(key)))
fileInfo.Delete();
}

ExportRunning = false;
}

protected void Log(string message)
Expand Down
12 changes: 8 additions & 4 deletions Tranga/Jobs/DownloadChapter.cs
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,12 @@ public class DownloadChapter : Job
{
public Chapter chapter { get; init; }

public DownloadChapter(GlobalBase clone, MangaConnector connector, Chapter chapter, DateTime lastExecution, string? parentJobId = null) : base(clone, JobType.DownloadChapterJob, connector, lastExecution, parentJobId: parentJobId)
public DownloadChapter(GlobalBase clone, Chapter chapter, DateTime lastExecution, string? parentJobId = null) : base(clone, JobType.DownloadChapterJob, lastExecution, parentJobId: parentJobId)
{
this.chapter = chapter;
}

public DownloadChapter(GlobalBase clone, MangaConnector connector, Chapter chapter, string? parentJobId = null) : base(clone, JobType.DownloadChapterJob, connector, parentJobId: parentJobId)
public DownloadChapter(GlobalBase clone, Chapter chapter, string? parentJobId = null) : base(clone, JobType.DownloadChapterJob, parentJobId: parentJobId)
{
this.chapter = chapter;
}
Expand Down Expand Up @@ -44,11 +44,15 @@ protected override IEnumerable<Job> ExecuteReturnSubTasksInternal(JobBoss jobBos
return Array.Empty<Job>();
}

protected override MangaConnector GetMangaConnector()
{
return chapter.parentManga.mangaConnector;
}

public override bool Equals(object? obj)
{
if (obj is not DownloadChapter otherJob)
return false;
return otherJob.mangaConnector == this.mangaConnector &&
otherJob.chapter.Equals(this.chapter);
return otherJob.chapter.Equals(this.chapter);
}
}
42 changes: 27 additions & 15 deletions Tranga/Jobs/DownloadNewChapters.cs
Original file line number Diff line number Diff line change
@@ -1,29 +1,29 @@
using Tranga.MangaConnectors;
using Newtonsoft.Json;
using Tranga.MangaConnectors;

namespace Tranga.Jobs;

public class DownloadNewChapters : Job
{
public Manga manga { get; set; }
public string mangaInternalId { get; set; }
[JsonIgnore] private Manga? manga => GetCachedManga(mangaInternalId);
public string translatedLanguage { get; init; }

public DownloadNewChapters(GlobalBase clone, MangaConnector connector, Manga manga, DateTime lastExecution,
bool recurring = false, TimeSpan? recurrence = null, string? parentJobId = null, string translatedLanguage = "en") : base(clone, JobType.DownloadNewChaptersJob, connector, lastExecution, recurring,
recurrence, parentJobId)
public DownloadNewChapters(GlobalBase clone, string mangaInternalId, DateTime lastExecution, bool recurring = false, TimeSpan? recurrence = null, string? parentJobId = null, string translatedLanguage = "en") : base(clone, JobType.DownloadNewChaptersJob, lastExecution, recurring, recurrence, parentJobId)
{
this.manga = manga;
this.mangaInternalId = mangaInternalId;
this.translatedLanguage = translatedLanguage;
}

public DownloadNewChapters(GlobalBase clone, MangaConnector connector, Manga manga, bool recurring = false, TimeSpan? recurrence = null, string? parentJobId = null, string translatedLanguage = "en") : base (clone, JobType.DownloadNewChaptersJob, connector, recurring, recurrence, parentJobId)
public DownloadNewChapters(GlobalBase clone, MangaConnector connector, string mangaInternalId, bool recurring = false, TimeSpan? recurrence = null, string? parentJobId = null, string translatedLanguage = "en") : base (clone, JobType.DownloadNewChaptersJob, recurring, recurrence, parentJobId)
{
this.manga = manga;
this.mangaInternalId = mangaInternalId;
this.translatedLanguage = translatedLanguage;
}

protected override string GetId()
{
return $"{GetType()}-{manga.internalId}";
return $"{GetType()}-{mangaInternalId}";
}

public override string ToString()
Expand All @@ -33,27 +33,39 @@ public override string ToString()

protected override IEnumerable<Job> ExecuteReturnSubTasksInternal(JobBoss jobBoss)
{
manga.SaveSeriesInfoJson();
Chapter[] chapters = mangaConnector.GetNewChapters(manga, this.translatedLanguage);
if (manga is null)
{
Log($"Manga {mangaInternalId} is missing! Can not execute job.");
return Array.Empty<Job>();
}
manga.Value.SaveSeriesInfoJson();
Chapter[] chapters = manga.Value.mangaConnector.GetNewChapters(manga.Value, this.translatedLanguage);
this.progressToken.increments = chapters.Length;
List<Job> jobs = new();
mangaConnector.CopyCoverFromCacheToDownloadLocation(manga);
manga.Value.mangaConnector.CopyCoverFromCacheToDownloadLocation(manga.Value);
foreach (Chapter chapter in chapters)
{
DownloadChapter downloadChapterJob = new(this, this.mangaConnector, chapter, parentJobId: this.id);
DownloadChapter downloadChapterJob = new(this, chapter, parentJobId: this.id);
jobs.Add(downloadChapterJob);
}
UpdateMetadata updateMetadataJob = new(this, this.mangaConnector, this.manga, parentJobId: this.id);
UpdateMetadata updateMetadataJob = new(this, mangaInternalId, parentJobId: this.id);
jobs.Add(updateMetadataJob);
progressToken.Complete();
return jobs;
}

protected override MangaConnector GetMangaConnector()
{
if (manga is null)
throw new Exception($"Missing Manga {mangaInternalId}");
return manga.Value.mangaConnector;
}

public override bool Equals(object? obj)
{
if (obj is not DownloadNewChapters otherJob)
return false;
return otherJob.mangaConnector == this.mangaConnector &&
otherJob.manga.publicationId == this.manga.publicationId;
otherJob.manga?.publicationId == this.manga?.publicationId;
}
}
13 changes: 7 additions & 6 deletions Tranga/Jobs/Job.cs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ namespace Tranga.Jobs;

public abstract class Job : GlobalBase
{
public MangaConnector mangaConnector { get; init; }
public ProgressToken progressToken { get; private set; }
public bool recurring { get; init; }
public TimeSpan? recurrenceTime { get; set; }
Expand All @@ -13,14 +12,15 @@ public abstract class Job : GlobalBase
public string id => GetId();
internal IEnumerable<Job>? subJobs { get; private set; }
public string? parentJobId { get; init; }
public enum JobType : byte { DownloadChapterJob, DownloadNewChaptersJob, UpdateMetaDataJob }
public enum JobType : byte { DownloadChapterJob = 0, DownloadNewChaptersJob = 1, UpdateMetaDataJob = 2, MonitorManga = 3 }

public MangaConnector mangaConnector => GetMangaConnector();

public JobType jobType;

internal Job(GlobalBase clone, JobType jobType, MangaConnector connector, bool recurring = false, TimeSpan? recurrenceTime = null, string? parentJobId = null) : base(clone)
internal Job(GlobalBase clone, JobType jobType, bool recurring = false, TimeSpan? recurrenceTime = null, string? parentJobId = null) : base(clone)
{
this.jobType = jobType;
this.mangaConnector = connector;
this.progressToken = new ProgressToken(0);
this.recurring = recurring;
if (recurring && recurrenceTime is null)
Expand All @@ -31,11 +31,10 @@ internal Job(GlobalBase clone, JobType jobType, MangaConnector connector, bool r
this.parentJobId = parentJobId;
}

internal Job(GlobalBase clone, JobType jobType, MangaConnector connector, DateTime lastExecution, bool recurring = false,
internal Job(GlobalBase clone, JobType jobType, DateTime lastExecution, bool recurring = false,
TimeSpan? recurrenceTime = null, string? parentJobId = null) : base(clone)
{
this.jobType = jobType;
this.mangaConnector = connector;
this.progressToken = new ProgressToken(0);
this.recurring = recurring;
if (recurring && recurrenceTime is null)
Expand Down Expand Up @@ -95,4 +94,6 @@ public IEnumerable<Job> ExecuteReturnSubTasks(JobBoss jobBoss)
}

protected abstract IEnumerable<Job> ExecuteReturnSubTasksInternal(JobBoss jobBoss);

protected abstract MangaConnector GetMangaConnector();
}
31 changes: 22 additions & 9 deletions Tranga/Jobs/JobBoss.cs
Original file line number Diff line number Diff line change
Expand Up @@ -70,11 +70,9 @@ public void RemoveJobs(IEnumerable<Job?> jobsToRemove)
RemoveJob(job);
}

public IEnumerable<Job> GetJobsLike(string? connectorName = null, string? internalId = null, float? chapterNumber = null)
public IEnumerable<Job> GetJobsLike(string? internalId = null, float? chapterNumber = null)
{
IEnumerable<Job> ret = this.jobs;
if (connectorName is not null)
ret = ret.Where(job => job.mangaConnector.name == connectorName);

if (internalId is not null && chapterNumber is not null)
ret = ret.Where(jjob =>
Expand All @@ -89,18 +87,18 @@ public IEnumerable<Job> GetJobsLike(string? connectorName = null, string? intern
{
if (jjob is not DownloadNewChapters job)
return false;
return job.manga.internalId == internalId;
return job.mangaInternalId == internalId;
});
return ret;
}

public IEnumerable<Job> GetJobsLike(MangaConnector? mangaConnector = null, Manga? publication = null,
public IEnumerable<Job> GetJobsLike(Manga? publication = null,
Chapter? chapter = null)
{
if (chapter is not null)
return GetJobsLike(mangaConnector?.name, chapter.Value.parentManga.internalId, chapter.Value.chapterNumber);
return GetJobsLike(chapter.Value.parentManga.internalId, chapter.Value.chapterNumber);
else
return GetJobsLike(mangaConnector?.name, publication?.internalId);
return GetJobsLike(publication?.internalId);
}

public Job? GetJobById(string jobId)
Expand Down Expand Up @@ -150,6 +148,9 @@ private void LoadJobsList(HashSet<MangaConnector> connectors)
File.SetUnixFileMode(TrangaSettings.jobsFolderPath, UserRead | UserWrite | UserExecute | GroupRead | OtherRead);
if (!Directory.Exists(TrangaSettings.jobsFolderPath)) //No jobs to load
return;

//Load Manga-Files
ImportManga();

//Load json-job-files
foreach (FileInfo file in Directory.GetFiles(TrangaSettings.jobsFolderPath, "*.json").Select(f => new FileInfo(f)))
Expand Down Expand Up @@ -185,12 +186,24 @@ private void LoadJobsList(HashSet<MangaConnector> connectors)
parentJob.AddSubJob(job);
Log($"Parent Job {parentJob}");
}
if (job is DownloadNewChapters dncJob)
AddMangaToCache(dncJob.manga);
}

string[] jobMangaInternalIds = this.jobs.Where(job => job is DownloadNewChapters)
.Select(dnc => ((DownloadNewChapters)dnc).mangaInternalId).ToArray();
jobMangaInternalIds = jobMangaInternalIds.Concat(
this.jobs.Where(job => job is UpdateMetadata)
.Select(dnc => ((UpdateMetadata)dnc).mangaInternalId)).ToArray();
string[] internalIds = GetAllCachedManga().Select(m => m.internalId).ToArray();

string[] extraneousIds = internalIds.Except(jobMangaInternalIds).ToArray();
foreach (string internalId in extraneousIds)
RemoveMangaFromCache(internalId);

string[] coverFiles = Directory.GetFiles(TrangaSettings.coverImageCache);
foreach(string fileName in coverFiles.Where(fileName => !GetAllCachedManga().Any(manga => manga.coverFileNameInCache == fileName)))
File.Delete(fileName);
string[] mangaFiles = Directory.GetFiles(TrangaSettings.mangaCacheFolderPath);
foreach(string fileName in mangaFiles.Where(fileName => !GetAllCachedManga().Any(manga => fileName.Split('.')[0] == manga.internalId)))
File.Delete(fileName);
}

Expand Down
Loading
Loading