summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorElena ``of Valhalla'' Grandi <valhalla@trueelena.org>2021-09-16 14:16:25 +0200
committerElena ``of Valhalla'' Grandi <valhalla@trueelena.org>2021-09-16 14:16:25 +0200
commitf3a4612901b9e2ce6ad5ad501edfcc887b717587 (patch)
treef2bfe93f9c4861767c91b1e7c61842c4f1e63b11 /scripts
parent87c153d34a0f4e131f8bff5cc814703cbc704cbb (diff)
Script to import book data from openlibrary
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/openlibrary2lesana105
1 files changed, 105 insertions, 0 deletions
diff --git a/scripts/openlibrary2lesana b/scripts/openlibrary2lesana
new file mode 100755
index 0000000..4ea94ea
--- /dev/null
+++ b/scripts/openlibrary2lesana
@@ -0,0 +1,105 @@
+#!/usr/bin/env python3
+
+import argparse
+import logging
+import os
+import sys
+
+import requests
+import dateutil.parser
+
+import lesana
+import lesana.command
+
+
+OPENAPI_BASE = "https://openlibrary.org"
+OPENAPI_ISBN_URL = OPENAPI_BASE + '/isbn/{isbn}.json'
+
+
+logger = logging.getLogger(__name__)
+
+
+class OL2L(lesana.command.Command):
+ """
+ Manage collections
+ """
+
+ arguments = [
+ (
+ ['--collection', '-c'],
+ dict(
+ help='Name of the lesana collection, default is .',
+ default='.',
+ ),
+ ),
+ (
+ ['--template', '-t'],
+ {
+ "help": "Template, "
+ + "default is templates/from_openlibrary.yaml",
+ "default": 'templates/from_openlibrary.yaml',
+ },
+ ),
+ (
+ ['isbn'],
+ {
+ 'help': "ISBN of the book we want to search"
+ },
+ ),
+ ]
+
+ def _load_args(self):
+ self.parser = argparse.ArgumentParser()
+ for arg in self.arguments:
+ self.parser.add_argument(*arg[0], **arg[1])
+ self.args = self.parser.parse_args()
+
+ def main(self):
+ self._load_args()
+ self.collection = self.collection_class(
+ directory=self.args.collection
+ )
+
+ logging.info("Looking for %s on OpenLibrary", self.args.isbn)
+ res = requests.get(OPENAPI_ISBN_URL.format(isbn=self.args.isbn))
+
+ if res.status_code != 200:
+ logger.error("No such isbn found on openlibrary")
+ sys.exit(1)
+
+ edition = res.json()
+
+ langs = []
+ for l in edition["languages"]:
+ langs.append(l["key"].split("/")[-1])
+
+ pub_date = dateutil.parser.parse(edition["publish_date"])
+
+ authors = []
+ for aid in edition["authors"]:
+ logging.info("Retrieving %s from OpenLibrary", aid)
+ res = requests.get(OPENAPI_BASE + aid["key"] + ".json")
+ authors.append(res.json())
+
+ data = {
+ "edition": edition,
+ "langs": langs,
+ "pub_date": pub_date,
+ "authors": authors,
+ }
+
+ entry = self.collection.entry_from_rendered_template(
+ self.args.template,
+ data
+ )
+ filepath = os.path.join(self.collection.itemdir, entry.fname)
+ if self.edit_file_in_external_editor(filepath):
+ self.collection.update_cache([entry.fname])
+ if self.collection.settings["git"]:
+ self.collection.git_add_files([filepath])
+ saved_entry = self.collection.entry_from_eid(entry.eid)
+ print(saved_entry)
+
+
+if __name__ == '__main__':
+ OL2L().main()