-
Notifications
You must be signed in to change notification settings - Fork 17
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
base: cuttingedge
Are you sure you want to change the base?
Server v2 #167
Conversation
This reverts commit 7e54577.
Solved Merge conflicts with cuttingedge branch
/v2/Jobs /v2/Jobs/Running /v2/Jobs/Waiting /v2/Jobs/Monitoring
/v2/Jobs /v2/Jobs/Running /v2/Jobs/Waiting /v2/Jobs/Monitoring
…uest so we don't forget to send a response.
Yeah this makes sense, let's make a branch of the current working code, like a V01.XX.XX and generate a docker image for that so people can force their server to run that code. |
And you can just merge my current json API branch into this Server V2 branch if you want a head start. Once that's done we can close my branch and Implement json API as part of V2 and not have any in V1 |
You want a hard cut-over? The way I wrote the current requests, we could still have both parts running, and be future-proof (v3,4,5...) too. |
I think something as big as an API changing structure would be enough to do a hard cut-over, it's your call in the end but I think V2 being the version with the big API change makes sense to me and then we just leave the old version alone, maybe patch it every now and then if we need to but otherwise leave it alone. |
Also do you want to take the lead on the server side of V2 then? That'll let me focus on doing the frontend V2 implementing all these manga pop-up and search/add pop-up changes that everybody's been wanting. I can also then implement any other changes as a result of the server V2. What do you think? |
Sounds like plan! |
# Conflicts: # Tranga/Tranga.csproj
# Conflicts: # Tranga/Jobs/DownloadNewChapters.cs # Tranga/Jobs/JobBoss.cs # Tranga/Jobs/UpdateMetadata.cs
Hi 👋 Since I have some free time, is there a list of stuff that needs to be done to push forward either tranga or tranga-website? (Not promising anything but I'll try) |
Hey @ale-ben, thanks for the offer! Happy Holidays! I think on the front end, the current pure JavaScript + CSS needs to be migrated over to the react + Typescript format. |
Thanks for the reply @db-2001! What still needs to be done? |
Btw, if u want to add me on discord here's the link https://discord.gg/jS94ybbn |
Hi @ale-ben ! |
Ok, thanks for the update! Since v2 branch is pg-v2 I'll close #308 |
I might have lied, it is postgres-server-v2 (a merge between both attempts) ;) |
Ok, it took a while due various compilation problems but finally I got the API working! The main problem now is that frontend refuses to communicate with the API. It keeps getting stuck here: Frontend tries to call Am I missing something or is this endpoint not implemented yet? |
@ale-ben |
I'm kind of stuck, I pulled the latest changes from I am trying to run the project but I keep getting this error:
I tried everything that comes to mind (except for moving my head back a couple of commits):
What am I missing? |
You are missing my untested changes to Give my regards to Dave, he tried his best but could not fathom my incompetence :) I am gonna very busy for the coming 2 months at least, so apart from fixing bugs on the current branch, I am not gonna really be able to make a lot of progress... So if you wanna go wild, now is the time 👍🏼 |
Ok, thanks for the info, I'll see what I can do. I will open a PR if I accomplish something. |
Go right ahead! |
@C9Glax Do you have any Idea? |
Just a quick hunch: What probably is the best idea (threading, database updates, yadada), is to have a separate copy of the Jobs, that we then sync with the database after every check? That way changes to the Job-Objects can be made independent of the pgsql context and still be up-to-date enough for other applications? |
The solution appears to be quite simpler than what either of us expected (I feel like Dave knew though...)! My formatter is quite aggressive and I haven't figured out how to tune it yet, sorry if some files are reformatted... I opened a draft PR to track the changes between my branch and the official repo, you can follow my progresses here: #317 |
Unfortunately, with every solution comes a new problem... I just noticed that creating identifiers using random numbers has a huge downside, if you search multiple times for the same manga (using the same connector), pg will have multiple entries (one for each search) for the same manga. I would suggest going back to using non-random based IDs like V1 used to do (for example Manga-[MangaConnectorId]-[ConnectorId]). |
Nice! |
Yes, the primary Key should consist of |
Nice, I was hoping for hashing IDs! Formatter is fixed btw |
Also, sorry for the continuous pings... |
That's the idea 👍🏼 Don't worry about the pings, this is better than working on stuff for a few hours and then disagreeing on how to do something. |
@db-2001
While going over your PR (related issue) I thought about some off the issues we have with the API.
#113 (comment)
Resolves #74
Resolves #114
Could be their own Requests.
By returning a list of JobIds and crosschecking locally which jobs exist, this should be a lot easier on data.
Generally the API transmits a lot more data than it needs to, so streamlining requests (stripping data, splitting single requests into multiple smaller ones) we can react a lot better to changes.
So extending your effort, I propose that we also get going on a Version 2 of the API.
The old API would still be accessible (for now), but we could gradually shift requests to the new one.
I have started writing out the API-Documentation.
If you have any more requests you would like to see, then write them in this PR.