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

There seems to be no protection against fetching again an again the same version of the catalog #1007

Closed
kelson42 opened this issue Oct 15, 2024 · 6 comments · Fixed by #1034 or #1063
Assignees
Milestone

Comments

@kelson42
Copy link
Contributor

kelson42 commented Oct 15, 2024

If I click twice on "fetch catalog" it takes many seconds each time to complete. Which tends to let me think there is no check if the version of the online catalogue is the same as the copy we have locally. If the version would be checked and proven to be the same (via Etag), then Kiwix should not redownload everything and it should be over in 0.1s.

See https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/If-None-Match

@kelson42
Copy link
Contributor Author

@BPerlakiH Can you please confirm/explain how it works?

@BPerlakiH
Copy link
Collaborator

@kelson42 I can see in the traffic that the catalog is refetched on each button press:
https://library.kiwix.org/catalog/v2/entries?count=-1
It seems to have the correct headers though:

Cache-Control: max-age=0, must-revalidate
ETag: "1726580544242481858.2213904/z"

The amount of time it takes is divided though. From what I can see the request (on a good wifi) takes only 900ms, whereas parsing and (maybe inserting the data) takes longer, around 2 more seconds.

The libkiwix library is also attempting to download the favicons, which I think is not really needed as it just simply not working, so we download those "on demand", when displaying the list of categories. It is also creating a lot of log outputs:

Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/da7fb796-e4ee-641f-41ff-6d7da49a28cb/?size=48
Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/4f489a41-d2dd-8066-7136-d21277420e45/?size=48
Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/f73302be-60bc-b740-53ba-50b1624eb4b9/?size=48
Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/e2c51a75-6700-cb90-69bd-f22a9de13482/?size=48
Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/646f6c7f-60da-6a29-ebf6-47384265edce/?size=48
Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/c9470bd8-571d-4815-76d3-fb4086036613/?size=48
Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/9f6dcc7e-a1dc-4868-4a8f-30d01a38ba29/?size=48
Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/2460effe-5812-9c25-1cfa-1ea824d9a843/?size=48
Cannot download favicon from https://library.kiwix.org/catalog/v2/illustration/fca187d6-425a-2e11-7867-eb61e2a7916e/?size=48
....

over 3200 lines of those.

@kelson42
Copy link
Contributor Author

kelson42 commented Oct 17, 2024

@kelson42 I can see in the traffic that the catalog is refetched on each button press:

Thx for confirming the bug. Please read documentation I have given and fix both HTTP request and response handling.

@kelson42
Copy link
Contributor Author

The libkiwix library is also attempting to download the favicons, which I think is not really needed

If you believe the libkiwix does not work properly, please open an issue there.

@kelson42 kelson42 modified the milestones: 3.6.0, 3.7.0 Oct 18, 2024
@kelson42 kelson42 modified the milestones: 3.8.0, 3.7.0 Nov 19, 2024
@BPerlakiH BPerlakiH linked a pull request Nov 24, 2024 that will close this issue
@BPerlakiH BPerlakiH modified the milestones: 3.7.0, 3.6.0 Nov 24, 2024
@BPerlakiH
Copy link
Collaborator

There's a side effect bug of this solution.
When the user has downloaded the library, that is parsed and saved to the DB.
So far so good, but the zim file categories to languages dictionary is saved only in the memory, and therefore on subsequent launches the user might be stuck with a single category:
Image

For this reason, I am re-opening this issue.

@kelson42
Copy link
Contributor Author

kelson42 commented Jan 2, 2025

@BPerlakiH Related to #1023 which should be kept in mind... but here its looks like that the refershing of the category list is just branched at the wrong place.

@BPerlakiH BPerlakiH modified the milestones: 3.6.0, 3.7.1 Jan 2, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
2 participants