Multi purpose API Generator based on an Ontology Framework.
Project description
OntologyToAPI
This project is an ontology-driven API generator designed for backend development by transforming structured domain knowledge into fully functional APIs. The tool accepts ontologies specified in Turtle (.ttl), Resource Description Framework (.rdf) and Web Ontology Language (.owl).
Ontological Framework:
- The following classes, relationships and data properties serve as a semantic blueprint for both metadata and business models.
The ontological framework is composed of two main modules:
- Metadata Ontology Module: This module defines the essential classes and properties required to describe the metadata and its sources (e.g. Query to be executed on the CommunicationTechnology).
- BusinessModel Ontology Module: This module captures the specific business logic and rules governing some operation, it requires an ExternalCode concretization, and it can require any metadata or parameter (To be sent in the API request).
- ExternalCode Ontology Module: This module has all the technical details to connect to an external code, it also adds the possibility to dynamically require python packages.
- Communications Ontology Module: This module describes the communication technologies that can be used to fetch the data of some metadata in multiple forms (e. g).
From now on you must be ready to go and create your own ontological specification importing the Ontology Modules and extending it. You can do this by using the Protégé ontology editor (https://protege.stanford.edu/). Or if you prefer you can use any text editor to create your ontology files in the supported formats (.ttl, .rdf, .owl).
Step 1: Installing the Package
# Now inside the environment install the python package
pip install ontologytoapi
Step 2: Running
- If you want to see a quick ontology sample in .ttl please access the following link: https://github.com/JCGCosta/OntologyToAPI/tree/master/samples
- With you metadata and business models ontologies implemented you can generate your API by having the following python file as an entry point:
import uvicorn
from OntologyToAPI.core import APIGenerator
if __name__ == "__main__":
APIGen = APIGenerator(showLogs=True)
APIGen.load_ontologies(paths=[
"Your/Metadata/Ontology/.ttl.owl.rdf"
])
APIGen.load_ontologies(paths=[
"Your/BusinessModel/Ontology/.ttl.owl.rdf"
])
APIGen.serialize_ontologies()
api_app = APIGen.generate_api_routes()
uvicorn.run(api_app, host="127.0.0.1", port=5000)
Change Log
0.0.7 (27/10/2025)
FIRST RELEASE
- Fixing pathing issues
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ontologytoapi-0.0.7.tar.gz.
File metadata
- Download URL: ontologytoapi-0.0.7.tar.gz
- Upload date:
- Size: 9.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ab652cb8463a0f016048c30283400d68ac6f2d8174eb5bc7114c2ca2fdd315d4
|
|
| MD5 |
ce18c52423291795e57780e18dc5d77d
|
|
| BLAKE2b-256 |
4a010098a2f27562de8234a6a94685dd445488a62f11c88be17707ed5deceb2a
|
File details
Details for the file ontologytoapi-0.0.7-py3-none-any.whl.
File metadata
- Download URL: ontologytoapi-0.0.7-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
11ffd0d7d801f39441449d7e7324ddb58a6582eabc0cb3aa41c3417b534c5036
|
|
| MD5 |
2ed7a2ecb6cea847601cc1a191aa4734
|
|
| BLAKE2b-256 |
b5619053e5766ff53cb11ff549094ae4f5ddc5f3c904f1bee770ebfcf6da4a88
|