Register Guidelines E-Books Search Today's Posts Mark Forums Read

Go Back   MobileRead Forums > E-Book Software > Calibre > Plugins

Notices

Reply
 
Thread Tools Search this Thread
Old 08-31-2025, 05:51 PM   #16
ARR8
Member
ARR8 began at the beginning.
 
Posts: 18
Karma: 20
Join Date: Aug 2025
Device: PocketBook Verse Pro
That definitely strikes me as a policy that makes sense for a forum, but, when applied to a forum-qua-software-distribution-site, it's just a hoop I have to jump through to be able to edit my own code... and for what? It's not like I'm getting anything out of sharing the code I wrote for myself besides some minor sense of satisfaction out of contributing back to the Calibre community in a small way.

I am sure I am not the only one to run into this and other potential plugin devs have silently given up, thus depriving the user base of their work.

Beware Trivial Inconveniences
ARR8 is offline   Reply With Quote
Old 08-31-2025, 07:36 PM   #17
ARR8
Member
ARR8 began at the beginning.
 
Posts: 18
Karma: 20
Join Date: Aug 2025
Device: PocketBook Verse Pro
Quote:
Originally Posted by BetterRed View Post
To edit your own posts you need to get your post count up to 10 or more, post some replies in some of the threads in the Lounge.

BR
I now have >10 posts and still cannot edit. I have attached it here. To any moderator reading this, please replace the attachment in the first post with this one. Thanks.

Last edited by BetterRed; 08-31-2025 at 09:38 PM. Reason: Remove attachment - moved to first post
ARR8 is offline   Reply With Quote
Old 08-31-2025, 09:41 PM   #18
BetterRed
null operator (he/him)
BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.BetterRed ought to be getting tired of karma fortunes by now.
 
Posts: 22,003
Karma: 30277294
Join Date: Mar 2012
Location: Sydney Australia
Device: none
Quote:
Originally Posted by ARR8 View Post
I now have >10 posts and still cannot edit. I have attached it here. To any moderator reading this, please replace the attachment in the first post with this one. Thanks.
Done - try editing #1 again, could be a delay, otherwise complain in the Feedback forum, one of Admins will have to sort it out.

BR

Last edited by BetterRed; 08-31-2025 at 09:43 PM.
BetterRed is offline   Reply With Quote
Old 09-01-2025, 04:48 AM   #19
dewd
Connoisseur
dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.dewd ought to be getting tired of karma fortunes by now.
 
Posts: 57
Karma: 1231814
Join Date: Nov 2017
Device: Kobo Libra Colour, Kindle Voyage(s)
The updated plugin version works for me, thank you.
dewd is offline   Reply With Quote
Old 10-09-2025, 04:03 AM   #20
LaylaReads
Junior Member
LaylaReads began at the beginning.
 
Posts: 1
Karma: 10
Join Date: Jan 2025
Device: MKindle
This is one of my favorite plugins, thanks for building it @ARR8. It was working like a dream until Monday of this week (10/6/25). It stopped fetching all metadata and I tried everything I could think of to reset it. I took a look at the logs today, and this is what I see. I'm still learning to code so I am having trouble reading it all, but the bottom has a 403 forbidden error, which I do understand I'm wondering if Storygraph cracked down on their security? Is this happening to anyone else? Is there anything else in the error log that shows something I need to change? I gotta get my fav back

Found 0 results Downloading from StoryGraph took 1.0549993515014648 Using query URL: https://app.thestorygraph.com/browse...0Scott%20Lynch Failed to make identify query: 'https://app.thestorygraph.com/browse?search_term=Lies%20of%20Locke%20Lamora%20Sc ott%20Lynch' Traceback (most recent call last): File "calibre_plugins.dummy2.__init__", line 338, in identify File "mechanize\_mechanize.py", line 257, in open File "mechanize\_mechanize.py", line 313, in _mech_open mechanize._response.get_seek_wrapper_class..httper ror_seek_wrapper: HTTP Error 403: Forbidden
LaylaReads is offline   Reply With Quote
Old 10-10-2025, 12:08 AM   #21
ARR8
Member
ARR8 began at the beginning.
 
Posts: 18
Karma: 20
Join Date: Aug 2025
Device: PocketBook Verse Pro
Thanks for the kind words. Yes, it looks like Storygraph reenabled Cloudflare's automated request prevention, which unfortunately will entirely prevent the plugin from working. The last time they enabled it, they said to me that it was a temporary measure because they were getting DDoSed. I don't know if they're enabling it temporarily again or have switched to using it in a more permanent posture. If the latter, we'll have to wait for them to release the API, which I would rewrite the plugin to use. Either way, looks like a wait-and-see situation.
ARR8 is offline   Reply With Quote
Old 10-10-2025, 07:41 AM   #22
JSWolf
Resident Curmudgeon
JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.
 
JSWolf's Avatar
 
Posts: 80,650
Karma: 150249619
Join Date: Nov 2006
Location: Roslindale, Massachusetts
Device: Kobo Libra 2, Kobo Aura H2O, PRS-650, PRS-T1, nook STR, PW3
Quote:
Originally Posted by ARR8 View Post
Thanks for the kind words. Yes, it looks like Storygraph reenabled Cloudflare's automated request prevention, which unfortunately will entirely prevent the plugin from working. The last time they enabled it, they said to me that it was a temporary measure because they were getting DDoSed. I don't know if they're enabling it temporarily again or have switched to using it in a more permanent posture. If the latter, we'll have to wait for them to release the API, which I would rewrite the plugin to use. Either way, looks like a wait-and-see situation.
Have a look at the Kobo Metadata plugin. It has a way to get around Cloudflare on Kobo. Maybe you can incorporate this for StoryGraph.
JSWolf is offline   Reply With Quote
Old 10-12-2025, 01:10 PM   #23
ARR8
Member
ARR8 began at the beginning.
 
Posts: 18
Karma: 20
Join Date: Aug 2025
Device: PocketBook Verse Pro
Good suggestion, thank you. I've tried refactoring the plugin to use the same module. Unfortunately, it doesn't work. My guess is that the module can handle the protection level used by Kobo but the StoryGraph is using a higher one beyond its capabilities. On the plus side, that indicates to me that this is more likely to be a temporary measure. I'll keep this version and periodically check to see if they lower their protection level to one more like Kobo's, though, and will upload if so.
ARR8 is offline   Reply With Quote
Old 10-19-2025, 09:20 PM   #24
ARR8
Member
ARR8 began at the beginning.
 
Posts: 18
Karma: 20
Join Date: Aug 2025
Device: PocketBook Verse Pro
Looks like that day is today. Uploaded a new version using the cloudscraper module.
ARR8 is offline   Reply With Quote
Old 10-20-2025, 05:34 PM   #25
JSWolf
Resident Curmudgeon
JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.
 
JSWolf's Avatar
 
Posts: 80,650
Karma: 150249619
Join Date: Nov 2006
Location: Roslindale, Massachusetts
Device: Kobo Libra 2, Kobo Aura H2O, PRS-650, PRS-T1, nook STR, PW3
Quote:
Originally Posted by ARR8 View Post
Looks like that day is today. Uploaded a new version using the cloudscraper module.
In the first post of the plugin thread, there should to be a spoiler that has a what's new for each released version.

The 2.0.0 version is not working.
Code:
****************************** StoryGraph (2, 0, 0) ****************************** 
Found 0 results 
Downloading from StoryGraph took 0.09256124496459961 
Using query URL: https://app.thestorygraph.com/browse?search_term=9780593653265
Failed to make identify query: 'https://app.thestorygraph.com/browse?search_term=9780593653265'
Traceback (most recent call last):
  File "calibre_plugins.storygraph.storygraph", line 300, in identify
  File "calibre_plugins.storygraph.storygraph", line 226, in _get_webpage
  File "calibre_plugins.storygraph.storygraph", line 211, in session
  File "C:\Users\jswol\AppData\Roaming\calibre\plugins\Kobo Metadata.zip\cloudscraper\__init__.py", line 319, in create_scraper
  File "C:\Users\jswol\AppData\Roaming\calibre\plugins\Kobo Metadata.zip\cloudscraper\__init__.py", line 152, in __init__
TypeError: Session.__init__() got an unexpected keyword argument 'auto_refresh_on_403'

Last edited by JSWolf; 10-20-2025 at 05:43 PM.
JSWolf is offline   Reply With Quote
Old 10-20-2025, 05:54 PM   #26
PeterT
Grand Sorcerer
PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.PeterT ought to be getting tired of karma fortunes by now.
 
Posts: 13,682
Karma: 79983758
Join Date: Nov 2007
Location: Toronto
Device: Libra H2O, Libra Colour
@jswolf ; Out of curiousity, what happens if you either disable or uninistall the Kobo Metadata plugin? Both of them contain a copy of the cloudscape module....
PeterT is offline   Reply With Quote
Old 10-20-2025, 06:30 PM   #27
ARR8
Member
ARR8 began at the beginning.
 
Posts: 18
Karma: 20
Join Date: Aug 2025
Device: PocketBook Verse Pro
Yes, this is interesting. Tl;dr: I'll upload a fix. Some technical details follow.

The log suggests that the outdated version of the cloudscraper module integrated with Kobo Metadata is interfering with the one I've packaged. I don't get the error when testing locally without Kobo Metadata installed and in fact can reproduce it if I do install Kobo Metadata.

Calibre does implement a sort of isolated namespacing for plugin imports, but both plugins concerned bypass it because it breaks packaged modules' importing their own dependencies (this was by far the trickiest part of the 2.0 update). That's the immediate source of the issue.

It looks like the way Calibre loads plugins is deterministic and alphabetical. If I rename my plugin to come before Kobo, it loads the newer version and works perfectly. However, the option I've specified, auto_refresh_on_403, is necessary when using the newer version with Calibre and Kobo Metadata not specifying it means that it hangs instead of returning on failure.

The quickest fix for this is for me to rename my copy of the module, which will fix the immediate issue, and which I will do shortly. However, both the Kobo plugin and mine include second-order dependencies which would be nontrivial to rename and apparently have become a time bomb if either of us update one to an incompatible version, though they seem to be working together fine for now.

The long-term fix would have to be on the Calibre side. Bypassing its namespacing is the only way to make the modules work, short of running a script to rewrite all imports, but that doesn't have to be the case. I can understand that this isn't high-priority, though.

There's a medium-term fix where all plugin developers using this import method make an effort to keep library versions in sync, but I don't regard that as a serious option.
ARR8 is offline   Reply With Quote
Old 10-21-2025, 05:33 AM   #28
JSWolf
Resident Curmudgeon
JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.JSWolf ought to be getting tired of karma fortunes by now.
 
JSWolf's Avatar
 
Posts: 80,650
Karma: 150249619
Join Date: Nov 2006
Location: Roslindale, Massachusetts
Device: Kobo Libra 2, Kobo Aura H2O, PRS-650, PRS-T1, nook STR, PW3
Still not working with and without Kobo Metadata running.

Code:
****************************** StoryGraph (2, 0, 1) ****************************** 
Found 0 results 
Downloading from StoryGraph took 0.05278897285461426 
Using query URL: https://app.thestorygraph.com/browse?search_term=9780593653265
Failed to make identify query: 'https://app.thestorygraph.com/browse?search_term=9780593653265'
Traceback (most recent call last):
  File "C:\Users\jswol\AppData\Roaming\calibre\plugins\StoryGraph.zip\cloudscraperv3\user_agent\__init__.py", line 77, in loadUserAgent
FileNotFoundError: [Errno 2] No such file or directory: 'C:\\Users\\jswol\\AppData\\Roaming\\calibre\\plugins\\StoryGraph.zip\\cloudscraperv3\\user_agent\\browsers.json'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "calibre_plugins.storygraph.storygraph", line 300, in identify
  File "calibre_plugins.storygraph.storygraph", line 226, in _get_webpage
  File "calibre_plugins.storygraph.storygraph", line 211, in session
  File "C:\Users\jswol\AppData\Roaming\calibre\plugins\StoryGraph.zip\cloudscraperv3\__init__.py", line 686, in create_scraper
  File "C:\Users\jswol\AppData\Roaming\calibre\plugins\StoryGraph.zip\cloudscraperv3\__init__.py", line 155, in __init__
  File "C:\Users\jswol\AppData\Roaming\calibre\plugins\StoryGraph.zip\cloudscraperv3\user_agent\__init__.py", line 20, in __init__
  File "C:\Users\jswol\AppData\Roaming\calibre\plugins\StoryGraph.zip\cloudscraperv3\user_agent\__init__.py", line 89, in loadUserAgent
AttributeError: module 'sys' has no attribute '_MEIPASS'
JSWolf is offline   Reply With Quote
Reply

Tags
calibre, metadata, mood, pace, storygraph

Thread Tools Search this Thread
Search this Thread:

Advanced Search

Forum Jump

Similar Threads
Thread Thread Starter Forum Replies Last Post
[Metadata Source Plugin] Show multiple results for single source? memory_dump Plugins 7 10-09-2025 01:50 AM
[Metadata Source Plugin] Kobo Metadata NotSimone Plugins 181 08-15-2025 11:44 PM
How do I know which Metadata Source Plugin was called from fetch-ebook-metadata? eryMpexI Library Management 6 04-22-2023 08:58 AM
Read a book's metadata in a Metadata source plugin? J-H Development 2 03-30-2021 09:08 AM
[Metadata Source Plugin] Empty Plugin? (Fake Identifier) mneimeyer Plugins 3 11-11-2019 08:07 PM


All times are GMT -4. The time now is 02:55 AM.


MobileRead.com is a privately owned, operated and funded community.