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

Only Sync if Newer #7

Closed
elmodor opened this issue May 12, 2023 · 6 comments
Closed

Only Sync if Newer #7

elmodor opened this issue May 12, 2023 · 6 comments
Assignees
Labels
bug Something isn't working

Comments

@elmodor
Copy link
Contributor

elmodor commented May 12, 2023

Feature Request

It would be really cool if the plugin would only sync if the data from koreader is newer than the data currently stored in calibre.

Usecase

I have two devices where I read on.
If I read a book to 50% on device A, sync it the percent read is set to 50.
Then connect device B where the book is still at 20% because it was not opened/synced by koreader, sync it to calibre the percent read is changed to 20.
This should not happen and the sync should be aborted because the data in calibre is newer.

Similar Implementations

I took a look at how Kobo Utils does this:
They have a setting store_if_more_recent and check the current_last_read vs the new_last_read status (in their jobs.py file). This can only be done if the last_read is stored in a column.

Possible Implementation

I assume the last read date is equal to the date_sidecar_modified field which is already implemented in the latest beta.
A new setting could be introduced similar to Kobo Utils: Sync only if more recent
If this settings is checked, and the date_sidecar_modified is stored in a column, it can be checked if the date_sidecar_modified from the devices koreader is newer than the stored date_sidecar_modified. If it is older, sync_to_calibre (action.py) should not call update_metadata for that current book.

@elmodor
Copy link
Contributor Author

elmodor commented May 12, 2023

I was able to implement the settings part (a checkbox in the config menu) but I got stuck when I wanted to use the date_sidecar_modified.

How is this supposed to work with a wireless connected device?

                parsed_contents['calculated']['date_sidecar_modified'] = datetime.fromtimestamp(
                    os.path.getmtime(path)).replace(tzinfo=local_tz
                    )

os.path.getmtime will call a path on my PC not on the wireless connected device. The path is something like Book.sdr/metadate.epub.lua which does not exist.

I think the only way to get this data is if koreader writes a timestamp/last read state into the metadata file.

@elmodor
Copy link
Contributor Author

elmodor commented May 17, 2023

Also see #2 (comment)

@harmtemolder
Copy link
Owner

How does this relate to #8? Do we need this issue to work on an improvement for wirelessly connected devices? Or may it be closed?

@elmodor
Copy link
Contributor Author

elmodor commented May 25, 2023

While I added the ability to "sync only if more recent" in #8 it does not work for (at least) wireless connected devices because the mtime can not be obtained of the sidecar file.

That is why I added the "fallback" for this option in case no newdate_modified is obtainable (e.g. for wireless devices) where it does not compare the mtime and instead compares the read_percent if available. Only syncs if read_percent is larger than the stored one.

To properly obtain the last modified date for all cases (wireless, and I guess SD card too?) either koreader needs to store this info inside the sidecar as well or we have to get access to the history.lua file as mentioned in #2

@kyxap kyxap self-assigned this Jul 27, 2024
@kyxap kyxap added bug Something isn't working waiting for author answer Tag to use if there any information required for author labels Jul 27, 2024
@kyxap
Copy link
Collaborator

kyxap commented Jul 27, 2024

@elmodor hey, can you reproduce this issue with latest release? if so please let me know

@kyxap
Copy link
Collaborator

kyxap commented Aug 2, 2024

going to close since no response from the author, let me know if you still have this issue

@kyxap kyxap closed this as completed Aug 2, 2024
@kyxap kyxap removed the waiting for author answer Tag to use if there any information required for author label Aug 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants