Metadata-Version: 2.4
Name: commonmeta-py
Version: 0.210
Summary: Library for conversions to/from the Commonmeta scholarly metadata format
Project-URL: Homepage, https://python.commonmeta.org
Project-URL: Repository, https://github.com/front-matter/commonmeta-py
Project-URL: Documentation, https://python.commonmeta.org
Author-email: Martin Fenner <martin@front-matter.de>
License: MIT
License-File: LICENSE
Keywords: bibtex,commonmeta,crossref,csl,datacite,inveniordm,metadata,openalex,schemaorg,science
Requires-Python: <4.0,>=3.9
Requires-Dist: base32-lib~=1.0
Requires-Dist: beautifulsoup4<5,>=4.11
Requires-Dist: bibtexparser~=1.4
Requires-Dist: citeproc-py-styles<1,>=0.1.2
Requires-Dist: citeproc-py<1,>=0.6
Requires-Dist: click<9,>=8.1.7
Requires-Dist: datacite<2,>=1.1.1
Requires-Dist: dateparser<2,>=1.1.7
Requires-Dist: edtf<6,>=5.0.0
Requires-Dist: furl<3,>=2.1.3
Requires-Dist: isbnlib>=3.10.14
Requires-Dist: jsonschema~=4.21
Requires-Dist: lxml>=4.8
Requires-Dist: marshmallow-utils>=0.10.0
Requires-Dist: nameparser<2,>=1.1.1
Requires-Dist: nh3<0.3,>=0.2.14
Requires-Dist: orjson<4,>=3.9.14
Requires-Dist: orjsonl<2,>=1.0.0
Requires-Dist: psycopg[binary]<4,>=3.2
Requires-Dist: pycountry>=22.3.5
Requires-Dist: pyjwt<3,>=2.8.0
Requires-Dist: python-dateutil<3,>=2.8.2
Requires-Dist: pyyaml>=5.4
Requires-Dist: requests-toolbelt>=1.0.0
Requires-Dist: requests>=2.31.0
Requires-Dist: requests>=2.32.3
Requires-Dist: types-beautifulsoup4<5,>=4.11
Requires-Dist: types-dateparser~=1.1
Requires-Dist: types-pyyaml>=5.4
Requires-Dist: types-xmltodict<0.20,>=0.13
Requires-Dist: xmlschema>=4.0.1
Requires-Dist: xmltodict<0.20,>=0.12
Requires-Dist: xsdata[cli]<26,>=25.7
Description-Content-Type: text/markdown

[![DOI](https://zenodo.org/badge/570526578.svg)](https://zenodo.org/doi/10.5281/zenodo.8340374)
[![Build](https://github.com/front-matter/commonmeta-py/actions/workflows/build.yml/badge.svg)](https://github.com/front-matter/commonmeta-py/actions/workflows/build.yml)
[![PyPI version](https://img.shields.io/pypi/v/commonmeta-py.svg)](https://pypi.org/project/commonmeta-py/)
[![Coverage](https://sonarcloud.io/api/project_badges/measure?project=front-matter_commonmeta-py&metric=coverage)](https://sonarcloud.io/summary/new_code?id=front-matter_commonmeta-py)
[![Maintainability Rating](https://sonarcloud.io/api/project_badges/measure?project=front-matter_commonmeta-py&metric=sqale_rating)](https://sonarcloud.io/summary/new_code?id=front-matter_commonmeta-py)
[![docs](https://img.shields.io/badge/docs-passing-blue)](https://python.commonmeta.org)
![GitHub](https://img.shields.io/github/license/front-matter/commonmeta-py?logo=MIT)

# commonmeta-py

commonmeta-py is a Python library to implement Commonmeta, the common Metadata Model for Scholarly Metadata. Use commonmeta-py to convert scholarly metadata, in a variety of formats, listed below. Commonmeta-py is work in progress, the first release on PyPi (version 0.5.0) was on February 16, 2023. Up until version 0.5.1, the library was called talbot. Commonmeta-py is modelled after the [commonmeta-ruby ruby gem](https://github.com/front-matter/commonmeta-ruby).

commonmeta-py uses semantic versioning. Currently, its major version number is still at 0, meaning the API is not yet stable, and breaking changes are expected in the internal API and commonmeta JSON format.

## Installation

Stable version

    uv add commonmeta-py

## Supported Metadata Formats

Commometa-py reads and/or writes these metadata formats:

| Format                                                                                           | Name          | Content Type                           | Read    | Write   |
| ------------------------------------------------------------------------------------------------ | ------------- | -------------------------------------- | ------- | ------- |
| Commonmeta  | commonmeta    | application/vnd.commonmeta+json        | yes     | yes     |
| [CrossRef XML](https://www.crossref.org/schema/documentation/unixref1.1/unixref1.1.html) | crossref_xml      | application/vnd.crossref.unixref+xml   | yes | yes |
| [Crossref](https://api.crossref.org)                                                             | crossref | application/vnd.crossref+json          | yes     | n/a     |
| [DataCite](https://api.datacite.org/)                                                            | datacite | application/vnd.datacite.datacite+json | yes     | yes |
| [Schema.org (in JSON-LD)](http://schema.org/)                                                    | schema_org    | application/vnd.schemaorg.ld+json      | yes     | yes     |
| [RDF XML](http://www.w3.org/TR/rdf-syntax-grammar/)                                              | rdf_xml       | application/rdf+xml                    | no      | later   |
| [RDF Turtle](http://www.w3.org/TeamSubmission/turtle/)                                           | turtle        | text/turtle                            | no      | later   |
| [CSL-JSON](https://citationstyles.org/)                                                     | csl      | application/vnd.citationstyles.csl+json | yes | yes     |
| [Formatted text citation](https://citationstyles.org/)                                           | citation      | text/x-bibliography                    | n/a     | yes     |
| [Codemeta](https://codemeta.github.io/)                                                          | codemeta      | application/vnd.codemeta.ld+json       | yes | later |
| [Citation File Format (CFF)](https://citation-file-format.github.io/)                            | cff           | application/vnd.cff+yaml               | yes | later |
| [JATS](https://jats.nlm.nih.gov/)                                                                | jats          | application/vnd.jats+xml               | later   | later   |
| [CSV](ttps://en.wikipedia.org/wiki/Comma-separated_values)                                       | csv           | text/csv                               | no      | later   |
| [BibTex](http://en.wikipedia.org/wiki/BibTeX)                                                    | bibtex        | application/x-bibtex                   | later | yes     |
| [RIS](http://en.wikipedia.org/wiki/RIS_(file_format))                                            | ris           | application/x-research-info-systems    | yes   | yes     |
| [InvenioRDM](https://inveniordm.docs.cern.ch/reference/metadata/)                                | inveniordm    | application/vnd.inveniordm.v1+json     | yes   | yes     |
| [JSON Feed](https://www.jsonfeed.org/)                                                           | jsonfeed     | application/feed+json    | yes | later     |
| [OpenAlex](https://www.openalex.org/)                                                           | openalex     |    | yes | no     |

_commonmeta_: the Commonmeta format is the native format for the library and used internally.
_Planned_: we plan to implement this format for the v1.0 public release.
_Later_: we plan to implement this format in a later release.

## Documentation

Documentation (work in progress) for using the library is available at the [commonmeta-py Documentation](https://python.commonmeta.org/) website and includes several interactive Jupyter Notebooks .

This repository includes a Nixpacks configuration to build and serve the Quarto documentation site in the `docs/` folder.

- Config file: [nixpacks.toml](nixpacks.toml)
- Quarto project: [docs/_quarto.yml](docs/_quarto.yml)
- Build output: [docs/_site](docs/_site)

### Coolify setup

- App type: Nixpacks
- Repository/branch: this repo, `main`
- Build: auto-detected via Nixpacks
- Port: Coolify provides `PORT`. The start command respects `${PORT}` and falls back to `3000` for local runs.
- Healthcheck: HTTP path `/`, interval 10s, timeout 5s, retries 3

## Meta

Please note that this project is released with a [Contributor Code of Conduct](https://github.com/front-matter/commonmeta-py/blob/main/CODE_OF_CONDUCT.md). By participating in this project you agree to abide by its terms.

License: [MIT](https://github.com/front-matter/commonmeta-py/blob/main/LICENSE)
