Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/miguelgrinberg/microblog-api
A modern (as of 2023) Flask API back end.
https://github.com/miguelgrinberg/microblog-api
api flask openapi
Last synced: about 4 hours ago
JSON representation
A modern (as of 2023) Flask API back end.
- Host: GitHub
- URL: https://github.com/miguelgrinberg/microblog-api
- Owner: miguelgrinberg
- License: mit
- Created: 2021-11-25T14:56:14.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-04-27T23:30:52.000Z (9 months ago)
- Last Synced: 2024-05-22T11:31:24.598Z (8 months ago)
- Topics: api, flask, openapi
- Language: Python
- Homepage:
- Size: 120 KB
- Stars: 353
- Watchers: 15
- Forks: 96
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - miguelgrinberg/microblog-api - A modern (as of 2024) Flask API back end. (Python)
README
# microblog-api
[![Build status](https://github.com/miguelgrinberg/microblog-api/workflows/build/badge.svg)](https://github.com/miguelgrinberg/microblog-api/actions) [![codecov](https://codecov.io/gh/miguelgrinberg/microblog-api/branch/main/graph/badge.svg)](https://codecov.io/gh/miguelgrinberg/microblog-api)
A modern (as of 2024) Flask API back end.
## Deploy to Heroku
Click the button below to deploy the application directly to your Heroku
account.[![Deploy](https://www.herokucdn.com/deploy/button.svg)](https://heroku.com/deploy?template=https://github.com/miguelgrinberg/microblog-api/tree/heroku)
## Deploy on your Computer
### Setup
Follow these steps if you want to run this application on your computer, either
in a Docker container or as a standalone Python application.```bash
git clone https://github.com/miguelgrinberg/microblog-api
cd microblog-api
cp .env.example .env
```Open the new `.env` file and enter values for the configuration variables.
### Run with Docker
To start:
```bash
docker-compose up -d
```The application runs on port 5000 on your Docker host. You can access the API
documentation on the `/docs` URL (i.e. `http://localhost:5000/docs` if you are
running Docker locally).To populate the database with some randomly generated data:
```bash
docker-compose run --rm microblog-api bash -c "flask fake users 10 && flask fake posts 100"
```To stop the application:
```bash
docker-compose down
```### Run locally
Set up a Python 3 virtualenv and install the dependencies on it:
```bash
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt
```Create the database and populate it with some randomly generated data:
```bash
alembic upgrade head
flask fake users 10
flask fake posts 100
```Run the application with the Flask development web server:
```bash
flask run
```The application runs on `localhost:5000`. You can access the API documentation
at `http://localhost:5000/docs`.## Troubleshooting
On macOS Monterey and newer, Apple decided to use port 5000 for its AirPlay
service, which means that the Microblog API server will not be able to run on
this port. There are two possible ways to solve this problem:1. Disable the AirPlay Receiver service. To do this, open the System
Preferences, go to "Sharing" and uncheck "AirPlay Receiver".
2. Move Microblog API to another port:
- If you are running Microblog API with Docker, add a
`MICROBLOG_API_PORT=4000` line to your *.env* file. Change the 4000 to your
desired port number.
- If you are running Microblog API with Python, start the server with the
command `flask run --port=4000`.