Skip to main content

Python wrapper for CaltechDATA API.

Project description

CaltechDATA API Python Library

DOI

The caltechdata_api Python library provides a convenient interface for interacting with the CaltechDATA API. It allows users to write files, create DataCite 4 standard JSON records, edit existing records, and retrieve metadata from the CaltechDATA repository.

Features

Writing and Editing Records

  • caltechdata_write: Writes files and a DataCite 4 standard JSON record to the CaltechDATA repository.
  • caltechdata_edit: Edits existing records in CaltechDATA.

Metadata Operations

  • get_metadata: Retrieves metadata from CaltechDATA records.

Requirements

  • Python 3.6+

Installation

Install the library via pip:

pip install caltechdata_api

Examples

There are some example python scripts in the GitHub repository.

Create a record:

python write.py example.json -fnames logo.gif
# Output: pbkn6-m9y63 (unique identifier)

The response will be the unique identifier for the record. You can put this at the end of a url to visit the record (e.g. https://data.caltechlibrary.dev/records/pbkn6-m9y63)

Edit a record

Make changes to the example.json file to see a change)

python edit.py example.json -id pbkn6-m9y63
10.33569/pbkn6-m9y63

The response is the DOI for the record, which includes the unique identifier for the record in the default configuration.

Using Custom DOIs

Some groups have worked with the library to create custom DOIs. These can be passed in the metadata like:

python write.py example_custom.json -fnames logo.gif
m6zxz-p4j22

And then you can edit with

python edit.py example_custom.json -id m6zxz-p4j22
10.5281/inveniordm.1234

This returns the custom DOI of the record if it is successful.

Setup and Authentication

  1. Acquire a personal access token from your CaltechDATA account (found under "Applications" at the top right of your screen).
  2. Copy the token to a file named token.bash.
  3. Load the token in the command line using source token.bash.

Note on Testing

Only test your application on the test repository (data.caltechlibrary.dev). Testing the API on the public repository will generate junk records that are annoying to delete.

Using the Command Line Interface

If you would like to interact with the CaltechDATA API using the Command line Interface (CLI), please see the detailed documentation.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

caltechdata_api-1.10.6.tar.gz (44.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

caltechdata_api-1.10.6-py3-none-any.whl (47.0 kB view details)

Uploaded Python 3

File details

Details for the file caltechdata_api-1.10.6.tar.gz.

File metadata

  • Download URL: caltechdata_api-1.10.6.tar.gz
  • Upload date:
  • Size: 44.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for caltechdata_api-1.10.6.tar.gz
Algorithm Hash digest
SHA256 8de178c3af047b1baf96f8accb75f904a011bf0bb0405a38c11245d56426757b
MD5 e8f6f78ef52dbfb4fe48f390882f2e01
BLAKE2b-256 d5fbfc399e2c63f994220b441ab6c173fcb7841f55af3fc6df118dc737f30917

See more details on using hashes here.

File details

Details for the file caltechdata_api-1.10.6-py3-none-any.whl.

File metadata

File hashes

Hashes for caltechdata_api-1.10.6-py3-none-any.whl
Algorithm Hash digest
SHA256 7548b344a55c768e8102fca840de07b7365e3b79b928b8af8f039cc35cce9b9b
MD5 5c7ba2217546e375093a8f5b447e8839
BLAKE2b-256 e46fc684bf496926cb43dcce590c6b488abd911a54695114756e7c2042f3a1fa

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page