Example Starlette REST API application

Related tags

RESTful APIrecords
Overview

Records

The idea of this project is to show how Starlette, Marshmallow, and SQLAlchemy can be combined to create a RESTful HTTP API application that is modular, lightweight, and capable of dealing with many simultaneous requests.

Architecture

Uses a 3-tier architecture, illustrated below.

Setting up

Requires Python 3.9+, git, and poetry.

Building

$ git clone https://github.com/rbw/records.git
$ cd records
$ poetry update

Starting Postgres

The application requires an SQLAlchemy-supported relational database. This example uses pg.ARRAY in AlbumModel, making it compatible with Postgres only.

A docker-compose file for running a Postgres server is available in the project root.

$ docker-compose up

Starting Records

$ poetry shell
$ python -m records

Usage

Get all albums

$ curl http://localhost:5000/albums

Create an album

$ curl -X POST --data '{"title": "test", "release_date": "2035-01-20", "stores": ["APPLE", "YOUTUBE"], "tracks": ["TEST000000001", "TEST000000002"], "upc": "00000000000005"}' http://localhost:5000/albums

Show an album

$ curl http://localhost:5000/albums/00000000000005

Todo

  • Add Tracks API [GET/POST/DELETE => /tracks,/tracks:trackid:]
  • Implement add-tracks-to-album [POST => /albums/:albumid:/tracks]
  • Implement del-track-from-album [DELETE => /albums/:albumid:/tracks/:trackid:]
  • Implement query filtering
  • Add CLI
  • Project docs
  • Code docs
  • Automated tests

Funding

Consider leaving a donation if you like this software.

Author

Robert Wikman <[email protected]>

Owner
Robert Wikman
Robert Wikman
Embrace the APIs of the future. Hug aims to make developing APIs as simple as possible, but no simpler.

Read Latest Documentation - Browse GitHub Code Repository hug aims to make developing Python driven APIs as simple as possible, but no simpler. As a r

Hug API Framework 6.7k Dec 27, 2022
Built on Django Rest Framework, to provide with command execution on linux terminal

Built on Django Rest Framework, to provide with command execution on linux terminal

1 Oct 31, 2021
One package to access multiple different data sources through their respective API platforms.

BESTLab Platform One package to access multiple different data sources through their respective API platforms. Usage HOBO Platform See hobo_example.py

Wei 1 Nov 16, 2021
Django Ninja is a web framework for building APIs with Django and Python 3.6+ type hints.

๐Ÿ’จ Fast, Async-ready, Openapi, type hints based framework for building APIs

Vitaliy Kucheryaviy 3.8k Jan 04, 2023
Automated generation of real Swagger/OpenAPI 2.0 schemas from Django REST Framework code.

drf-yasg - Yet another Swagger generator Generate real Swagger/OpenAPI 2.0 specifications from a Django Rest Framework API. Compatible with Django Res

Cristi Vรฎjdea 3k Jan 06, 2023
Swagger Documentation Generator for Django REST Framework: deprecated

Django REST Swagger: deprecated (2019-06-04) This project is no longer being maintained. Please consider drf-yasg as an alternative/successor. I haven

Marc Gibbons 2.6k Dec 23, 2022
Django app for handling the server headers required for Cross-Origin Resource Sharing (CORS)

django-cors-headers A Django App that adds Cross-Origin Resource Sharing (CORS) headers to responses. This allows in-browser requests to your Django a

Adam Johnson 4.8k Jan 05, 2023
Estudo e desenvolvimento de uma API REST

Estudo e desenvolvimento de uma API REST ๐Ÿง‘โ€๐Ÿ’ป Tecnologias Esse projeto utilizarรก as seguintes tecnologias: Git Python Flask DBeaver Vscode SQLite ๐ŸŽฏ

Deusimar 7 May 30, 2022
Browsable web APIs for Flask.

Flask API Browsable web APIs for Flask. Status: This project is in maintenance mode. The original author (Tom Christie) has shifted his focus to API S

Flask API 1.3k Dec 27, 2022
Example Starlette REST API application

The idea of this project is to show how Starlette, Marshmallow, and SQLAlchemy can be combined to create a RESTful HTTP API application that is modular, lightweight, and capable of dealing with many

Robert Wikman 0 Jan 07, 2022
The Web API toolkit. ๐Ÿ› 

๐Ÿ›  The Web API toolkit. ๐Ÿ›  Community: https://discuss.apistar.org ๐Ÿค” ๐Ÿ’ญ ๐Ÿค“ ๐Ÿ’ฌ ๐Ÿ˜Ž Documentation: https://docs.apistar.com ๐Ÿ“˜ Requirements: Python 3.6+

Encode 5.6k Dec 27, 2022
a web-remote minecraft server wrapper with some unique features

Canceled here, continued as Semoxy MCWeb - a Minecraft Server Web Interface MCWeb is a web-remote Minecraft Server Wrapper for controlling your Minecr

Anton Vogelsang 1 Jul 12, 2021
A minimalistic manga reader for desktop built with React and Django

smanga A minimalistic manga reader/server for serving local manga images on desktop browser. Provides a two-page view layout just as reading a physica

Padam Upreti 13 Sep 24, 2022
Recursive Serialization for Django REST framework

djangorestframework-recursive Overview Recursive Serialization for Django REST framework This package provides a RecursiveField that enables you to se

336 Dec 28, 2022
A light REST library for Django.

django-nap Read The Docs: https://django-nap.readthedocs.io/en/latest/ Change log: https://django-nap.readthedocs.io/en/latest/changelog.html An API l

Curtis Maloney 223 Dec 07, 2022
Generate Views, Serializers, and Urls for your Django Rest Framework application

DRF Generators Writing APIs can be boring and repetitive work. Don't write another CRUDdy view in Django Rest Framework. With DRF Generators, one simp

Tobin Brown 332 Dec 17, 2022
Simplified REST API to get stickers from Snap

Snap Sticker kit REST API Simplified REST API to get stickers from Snap ๐Ÿ’ป Instructions Search stickers Request: url = "https://sticker-kit-horizon733

Dishant Gandhi 1 Jan 05, 2022
Dropdown population implementation for Django REST Framework

drf-dropdown Dropdown population implementation for Django REST Framework Usage Add DropdownView to API URL # urls.py import dropdown urlpatterns = [

Preeti Yuankrathok 4 Dec 06, 2022
Integrate GraphQL into your Django project.

Graphene-Django A Django integration for Graphene. ๐Ÿ’ฌ Join the community on Slack Documentation Visit the documentation to get started! Quickstart For

GraphQL Python 4k Dec 31, 2022
Flask RestAPI Project - Transimage Rest API For Python

[ ์ด๋ฏธ์ง€ ๋ณ€ํ™˜ ํ”Œ๋ผ์Šคํฌ Rest API ver01 ] 0. Flask Rest API - in SunnyWeb : ์ด๋ฏธ์ง€ ๋ณ€ํ™˜ ์›น์˜ Flask

OliverKim 1 Jan 12, 2022