mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2026-03-02 22:46:56 -05:00
[Enhancement]: Better Ebook handling and conversion #1784
Labels
No labels
authentication
awaiting release
backlog
bug
chapter editor
config-issue
ebooks
encoding/embedding
enhancement
help wanted
listening sessions & progress
planned
possible plugin
progress sync
sorting/filtering/searching
unable to reproduce
upload
users & permissions
waiting
No milestone
No project
No assignees
1 participant
Notifications
Due date
No due date set.
Dependencies
No dependencies set.
Reference
starred/audiobookshelf#1784
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @FlyinPancake on GitHub (Dec 29, 2023).
Describe the feature/enhancement
Hi!
I really like this project, and would like to ditch calibre-web from my stack.
abs works splendidly for audiobooks, and it could be wonderful for ebooks as well!
For my use-case, custom metadata providers are a must. My friend and I are developing one, that would be compatible with abs, we would like to implement it as a REST API which exposes the metadata required for abs. We would like to collaborate on an OpenApi spec for this REST API, which then could be used as a custom provider. As we are coming up with this spec, I will link it here. This should be really simple, as this would be a generalized provider, that could be specified by the user.
I love abs's send to ereader ability, but as Kindle dropped support for
mobiit is tedious to manually convert and upload each ebook as epub. For this problem ebook-converter could be integrated simirarly to tone. The second issue is filesize for email attachments, as right now abs tries to send even 40mb PDFs as attachments, that inevitably fail. Kindle supports.zipfiles for this reason, and this functionality could be incorporated as well.I know that this is a community-run project, and I am ready to be a part of development efforts (despite my laughable JS skills). advplyr made a great tool for us data hoarders to admire and manage our piles of data and I am greatful for its existance <3
This feature request is a big one and serves more like a wishlist than actual requests.
Thanks for coming to my TED talk
@advplyr commented on GitHub (Jan 2, 2024):
Hey, I would be interested in hearing more about the custom metadata provider you are working on. Are you aggregating metadata from different sources or putting together your own metadata? Are you hosting this publicly so it could be integrated as a metadata provider for everyone in Abs?
Ebook converter is outside the scope of Abs right now but maybe sometime in the future or as a plugin. Just as an aside, Tone is going to be removed in an upcoming version so the only external dependencies we will have to deal with is ffmpeg/ffprobe.
We can definitely support zipping large ebooks before sending to kindle. We would also need to check if the zipped file still exceeds 50MB
@FlyinPancake commented on GitHub (Jan 2, 2024):
Hi!
We are currently working on our API, and then will we start tackling the integration with ABS. The provider is currently hosted in a private repo, as the source vert much forbids scraping. We developed a scraper + cache setup to not get IP banned. I plan on open souring the cache and API part, but keeping the scraper private to not get taken down.
That way anyone who wants a custom metadata source, can implement a single rust trait and have the rest taken care of.
We are still iterating on the API spec, as of now we are closest to audible, but we'd love to get your input on what would be best for this. Our current solution is a single EP that returns the matches for a query. Currently a match object looks like this:
Of course, returning a list of narrators and authors would be nice if it is easy to implement in ABS. We will add series to the object too, it's just not yet implemented.
To sum it up
As for public hosting, I am not comfortable hosting it, since it clearly violates the EULA for the provider, however the eventual OSS base could be hosted as a sidecar for ABS, hence our goal for a backend-agnostic custom metadata provider + API
The book converter function would be really handy for me, if there is a plugin system, I'd be happy to help, but as I said before, I am not the go-to guy for frontend and JS.
Just a note, that the filesize should be configurable, as many email providers limit the attachment size
@FlyinPancake commented on GitHub (Jan 2, 2024):
Here is the current OpenAPI schema:
@FlyinPancake commented on GitHub (Jan 2, 2024):
We began work on adding CMP to the UI in my fork over in my fork
@Dewyer commented on GitHub (Jan 3, 2024):
I opened a pull request, with some code, it implements the basic version for the UI for managing the providers, and a very basic implementation.
@ghuh commented on GitHub (Oct 12, 2025):
The zip conversion would be awesome! I just setup ABS yesterday and really like it for audiobooks, but I keep hitting the 25MB email attachment limit (gmail) for sending ebooks to Kindle which is making this not particularly useable for eBooks.