Skip to content

evokateur/image4isbn

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

59 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

image4isbn

A set of tools to find cover images for ISBNs, with the ability to retrieve items and update images in a Square catalog.

Tools

Commands are composable into pipelines connected by a stream of JSONL data. Schema is append-only. Fields are added as items move through the pipeline. Nothing is removed or mutated.

square-fetch-items

Fetches items from a Square catalog, emitting JSONL

Appends: id, isbn, and attributes specified in SQUARE_OTHER_ATTRIBUTE_NAMES)

square-fetch-items | jq .
{
  "id": "Q6O257AKWZXONAM33IDHVJDS",
  "isbn": "9780140434088",
  "title": "The Moonstone",
  "author": "Wilkie Collins"
}
{
  "id": "BVOI6U7ULAOQ6NSCGSOZUHOP",
  "isbn": "9780816628773",
  "title": "The Practice of Everyday Life, Vol. 2: Living and Cooking",
  "author": "Michel de Certeau"
}
{
  "id": "KITW7KPCX5QGP5Q2ET34FXZA",
  "isbn": "9780517414248",
  "title": "Mary Queen of Scots",
  "author": "Antonia Fraser"
}

find-covers

Makes API calls to find cover images for each item.

Reads: isbn; Appends: images, failed_api_calls

square-fetch-items | find-covers --source open_library | jq .
{
  "id": "Q6O257AKWZXONAM33IDHVJDS",
  "isbn": "9780140434088",
  "title": "The Moonstone",
  "author": "Wilkie Collins",
  "images": [
    {
      "source": "open_library",
      "url": "https://covers.openlibrary.org/b/isbn/9780140434088-L.jpg",
      "api_call": {
        "url": "https://covers.openlibrary.org/b/isbn/9780140434088-L.jpg",
        "called_at": "2026-05-21T21:02:52Z",
        "status": 200
      }
    }
  ],
  "failed_api_calls": []
}
{
  "id": "BVOI6U7ULAOQ6NSCGSOZUHOP",
  "isbn": "9780816628773",
  "title": "The Practice of Everyday Life, Vol. 2: Living and Cooking",
  "author": "Michel de Certeau",
  "images": [
    {
      "source": "open_library",
      "url": "https://covers.openlibrary.org/b/isbn/9780816628773-L.jpg",
      "api_call": {
        "url": "https://covers.openlibrary.org/b/isbn/9780816628773-L.jpg",
        "called_at": "2026-05-21T21:02:53Z",
        "status": 200
      }
    }
  ],
  "failed_api_calls": []
}
{
  "id": "KITW7KPCX5QGP5Q2ET34FXZA",
  "isbn": "9780517414248",
  "title": "Mary Queen of Scots",
  "author": "Antonia Fraser",
  "images": [],
  "failed_api_calls": [
    {
      "url": "https://covers.openlibrary.org/b/isbn/9780517414248-L.jpg",
      "called_at": "2026-05-21T21:03:00Z",
      "status": 200,
      "result": "placeholder"
    }
  ]
}

summarize

Generates an HTML report showing how many covers were found, a sample of the matched images, and a list of ISBNs for which no cover image was found.

square-fetch-items | find-covers --source open_library | summarize > report.html && open report.html
sample-cover-image-report

download-covers

Downloads each image to a directory as <isbn>.jpg.

Reads: images[].url; Appends: images[].local_path

square-fetch-items | find-covers --source open_library | download-covers
{
  "id": "Q6O257AKWZXONAM33IDHVJDS",
  "isbn": "9780140434088",
  "title": "The Moonstone",
  "author": "Wilkie Collins",
  "images": [
    {
      "source": "open_library",
      "url": "https://covers.openlibrary.org/b/isbn/9780140434088-L.jpg",
      "api_call": {
        "url": "https://covers.openlibrary.org/b/isbn/9780140434088-L.jpg",
        "called_at": "2026-05-21T21:24:40Z",
        "status": 200
      },
      "local_path": "docs/covers/9780140434088.jpg"
    }
  ],
  "failed_api_calls": []
}
{
  "id": "BVOI6U7ULAOQ6NSCGSOZUHOP",
  "isbn": "9780816628773",
  "title": "The Practice of Everyday Life, Vol. 2: Living and Cooking",
  "author": "Michel de Certeau",
  "images": [
    {
      "source": "open_library",
      "url": "https://covers.openlibrary.org/b/isbn/9780816628773-L.jpg",
      "api_call": {
        "url": "https://covers.openlibrary.org/b/isbn/9780816628773-L.jpg",
        "called_at": "2026-05-21T21:24:40Z",
        "status": 200
      },
      "local_path": "docs/covers/9780816628773.jpg"
    }
  ],
  "failed_api_calls": []
}
{
  "id": "KITW7KPCX5QGP5Q2ET34FXZA",
  "isbn": "9780517414248",
  "title": "Mary Queen of Scots",
  "author": "Antonia Fraser",
  "images": [],
  "failed_api_calls": [
    {
      "url": "https://covers.openlibrary.org/b/isbn/9780517414248-L.jpg",
      "called_at": "2026-05-21T21:24:41Z",
      "status": 200,
      "result": "placeholder"
    }
  ]
}

square-attach-images

Uploads each item's cover image to Square, attaching it to the matching catalog item.

Reads: id, images[].local_path; Appends: images[].attached.square_image_id

square-fetch-items | find-covers --source open_library | download-covers | square-attach-images | jq .
# stderr
Total items:            3
No item_id:             0
No cover:               1
Already attached:       0
Images attached:        2
{
  "id": "Q6O257AKWZXONAM33IDHVJDS",
  "isbn": "9780140434088",
  "title": "The Moonstone",
  "author": "Wilkie Collins",
  "images": [
    {
      "source": "open_library",
      "url": "https://covers.openlibrary.org/b/isbn/9780140434088-L.jpg",
      "local_path": "covers/9780140434088.jpg",
      "attached": {
        "square_image_id": "WF5PEFDHAEGJ64TRY2K2KI3C"
      }
    }
  ],
  "failed_api_calls": []
}
{
  "id": "BVOI6U7ULAOQ6NSCGSOZUHOP",
  "isbn": "9780816628773",
  "title": "The Practice of Everyday Life, Vol. 2: Living and Cooking",
  "author": "Michel de Certeau",
  "images": [
    {
      "source": "open_library",
      "url": "https://covers.openlibrary.org/b/isbn/9780816628773-L.jpg",
      "local_path": "covers/9780816628773.jpg",
      "attached": {
        "square_image_id": "2TFHAT3L4EBJSWKTF4QROXM7"
      }
    }
  ],
  "failed_api_calls": []
}
{
  "id": "KITW7KPCX5QGP5Q2ET34FXZA",
  "isbn": "9780517414248",
  "title": "Mary Queen of Scots",
  "author": "Antonia Fraser",
  "images": [],
  "failed_api_calls": [
    {
      "url": "https://covers.openlibrary.org/b/isbn/9780517414248-L.jpg",
      "status": 200,
      "result": "placeholder"
    }
  ]
}

to-items

Emits items with the isbn from each line in the input stream as JSONL

Appends: isbn

echo "9780802190734" | to-items | jq .
{
  "isbn": "9780802190734"
}

Since there's an ISBN, it can be piped into find-covers

echo "9780802190734" | to-items | find-covers --source open_library | jq .
{
  "isbn": "9780802190734",
  "images": [
    {
      "source": "open_library",
      "url": "https://covers.openlibrary.org/b/isbn/9780802190734-L.jpg",
      "api_call": {
        "url": "https://covers.openlibrary.org/b/isbn/9780802190734-L.jpg",
        "called_at": "2026-05-18T15:36:08Z",
        "status": 200
      }
    }
  ],
  "failed_api_calls": []
}

I really like pipes.

uv run scripts/fetch_random_isbns.py --count 5 | to-items | \
find-covers --source open_library | summarize > report.html && open report.html
Capture d'écran 2026-05-18 à 08 56 54

Configuration

Copy .env.example to .env and fill in the values.

cp .env.example .env
Variable Description
SQUARE_ACCESS_TOKEN Square access token
SQUARE_ENVIRONMENT sandbox for testing, production for the real catalog
SQUARE_ISBN_ATTRIBUTE_NAME Name of the Square custom attribute for ISBNs (default: isbn)
SQUARE_OTHER_ATTRIBUTE_NAMES Names of other custom attributes to carry along the pipeline, comma-separated (e.g. title, author)
COVERS_DIR Directory for downloaded cover images (default: covers)
GOOGLE_BOOKS_API_KEY For using --source google

Installation

make install

About

Tool to find cover images for ISBNs

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors