• fonix232@fedia.io
    link
    fedilink
    arrow-up
    1
    ·
    2 days ago

    OPDS doesn’t do progress sync, at all… you’re running something else there if that works for you.

        • Fmstrat@lemmy.world
          link
          fedilink
          English
          arrow-up
          1
          ·
          2 days ago

          PSE is a protocol, how information is used on each side of that protocol is at the developers discretion.

          pse:lastRead="10"
          pse:lastReadDate="2010-01-10T10:01:11Z"
          
          • fonix232@fedia.io
            link
            fedilink
            arrow-up
            1
            ·
            2 days ago

            which is fucking useless for actual progress sync of books because it doesn’t handle concurrency (multiple readers reading the same content, potentially offline), and more importantly, modern ebook formats have no concept of “page” in transit. Oh, you read page 10? Awesome! Now do tell, is it page 10 on a 5" 800x480 eink display with 48px font size and giant margins/lineheights/word paddings, or is it page 10 on a 13" display of 2480x1860 resolution with 11px font size and barely any margins? Since you’ll get wildly different results in both cases, and OPDS doesn’t really allow for adapting this simple integer to a precise position.

            No, for that you require a proper locator scheme, something OPDS doesn’t provide and cannot enforce.

            Page based progress is fine for fixed format publications - comics, PDF/DOCX files, etc., but that approach breaks irreparably the moment you switch to dynamically formatted content. In case of EPUV/MOBI/the various Kindle formats, you want to determine the reader’s position based on the first and last paragraph/sentence visible on the reader and correlate that to a position within the actual files of the book, which is actually dynamic, as it can be resolved regardless if it’s XML formatted EPUB or if you dumbed the book down to a simple TXT file.

            So no, OPDS’s PSE is at best a stopgap solution for syncing progress.

            • Fmstrat@lemmy.world
              link
              fedilink
              English
              arrow-up
              1
              ·
              1 day ago

              doesn’t handle concurrency

              Kavita is multiuser, each with their own progress sync. https://wiki.kavitareader.com/getting-started/

              Now do tell, is it page 10 on a 5" 800x480 eink display with 48px font size and giant margins/lineheights/word paddings, or is it page 10 on a 13" display of 2480x1860 resolution with 11px font size and barely any margins

              Again, it’s a protocol and developer discression can be used. Page 10 could be word 10, or word 1000/avg 10 words = 10. PSE can be used to store progress, without needing to request the page because the eBook is local. It could be any API format.

              • fonix232@fedia.io
                link
                fedilink
                arrow-up
                1
                ·
                22 hours ago

                by concurrency I meant multiple devices of the same user, not multiple users. I don’t know why you’d even consider that I think other users’ progress should be exposed on a single call?

                and yet again, that progress doesn’t mean anything when you base it on a number. locator patterns that find the SECTION you’re in based on first-last word (or rather, sentence, for actual precision) are the way to go. you can try hacking this simplified protocol as much as you want, it will never work as well as a dedicated one.