Skip to main content

A very small module to add Linked Data API functionality to a Python Flask installation

Project description

pyLDAPI-250.png

Welcome to pyLDAPI

The Python Linked Data API (pyLDAPI) is:

A very small module to add Linked Data API functionality to a Python Flask installation.

PyPI version

What is it?

This module contains a small Python module which is intended to be added (imported) into a Python Flask installation to add a small library of Renderer classes which can be used to handle requests and return responses in a manner consistent with Linked Data principles of operation.

The intention is to make it easy to “Linked Data-enable” web APIs.

An API using this module will get:

  • an alt profile for each endpoint that uses a Renderer class to return responses that the API delivers
    • this is a profile, or view of the resource that lists all other available profiles

  • a Register of Registers
    • a start-up function that auto-generates a Register of Registers is run when the API is launched.

  • a basic, over-writeable template for Registers’ HTML & RDF

  • all of the functionality defined by the W3C’s Content Negotiation by Profile specification
    • to allow for requests of content that conform to data specifications and profiles

The main parts of pyLDAPI are as follows:

Block diagram of pyLDAPI's main parts

Web requests arrive at a Web Server, such as Apache or nginx, which then forwards (some of) them on to Flask, a Python web framework. Flask calls Python functions for web requests defined in a request/function mapping and may call pyLDAPI elements. Flask need not call pyLDAPI for all requests, just as Apache/nginx need not forward all web request to flask. pyLDAPI may then draw on any Python data source, such as database APIs, and uses the rdflib Python module to formulate RDF responses.

Definitions

Alt Profile

The model view that lists all other views. This API uses the definition of Alternate Profiles Data Model as an OWL ontology presented at https://www.w3.org/TR/dx-prof-conneg/#altr-owl.

Linked Data Principles

The principles of making things available over the internet in both human and machine-readable forms. Codified by the World Wide Web Consortium. See https://www.w3.org/standards/semanticweb/data.

Model View

A set of properties of a Linked Data object codified according to a standard or profile of a standard.

Object

Any individual thing delivered according to Linked Data principles.

Register

A simple listing of URIs of objects, delivered according to Linked Data principles.

Register of Registers

A register that lists all other registers which this API provides.

pyLDAPI in action

Block diagram of the GNAF implementation

Parts of the GNAF implementation

Block diagram of the ASGS implementation

Parts of the ASGS implementation

Documentation

Detailed documentation can be found at https://pyldapi.readthedocs.io/

Licence

This is licensed under GNU General Public License (GPL) v3.0. See the LICENSE deed for more details.

Contact

Dr Nicholas Car (lead)

Ashley Sommer (senior developer)

Informatics Software Engineer

Changelog

3.11

  • tokens applied to Representations in Alternate View profile, not Profiles

3.0

  • Content Negotiation specification by Profile supported

  • replaced all references to “format” with “Media Type” and “view” with “profile”

  • renamed class View to Profile

  • added unit tests for all profile functions

  • added unit tests for main ConnegP functions

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

pyldapi-3.11.tar.gz (17.7 kB view details)

Uploaded Source

Built Distribution

pyldapi-3.11-py3-none-any.whl (29.0 kB view details)

Uploaded Python 3

File details

Details for the file pyldapi-3.11.tar.gz.

File metadata

  • Download URL: pyldapi-3.11.tar.gz
  • Upload date:
  • Size: 17.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.3

File hashes

Hashes for pyldapi-3.11.tar.gz
Algorithm Hash digest
SHA256 7b8bc8a5e5d3006ef0c5efd6d1ce1b03d50b9eff364029b5f374629e28f1f781
MD5 fe8d83ee3d874f7349c6383750c466fe
BLAKE2b-256 b9444cce1b5725d13fc85de01d71c0df7e74d3ea35afbb98a2ddf4bb592888ee

See more details on using hashes here.

File details

Details for the file pyldapi-3.11-py3-none-any.whl.

File metadata

  • Download URL: pyldapi-3.11-py3-none-any.whl
  • Upload date:
  • Size: 29.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.3

File hashes

Hashes for pyldapi-3.11-py3-none-any.whl
Algorithm Hash digest
SHA256 9baebb94da0bae181ad37d71bbf9f4b5522303e613d1748e33206567741de96c
MD5 214a7e0328ad6a5439dc70c10f6ab044
BLAKE2b-256 8b8a7511d956967ac247082818b8ac040b91a80be35b8434e56e006fdbc9c175

See more details on using hashes here.

Supported by

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