Skip to main content

A FastAPI project generator

Project description

Jackson Easy API

Easy API is a simple library for building APIs using FastAPI and SQLAlchemy. It provides an easy-to-use framework to help you create and manage APIs with minimal effort.

Installation

To install Easy API, run the following command:

pip install jackson_easy_api

After installation, run the start command to initialize your project and generate the manage.py file in the root of your project:

start

Available Commands

Commands:
  createproject <name>   Create a new project with the given name
  createapp <name>       Create a new app within your project
  makemigrations         Generate a new migration with a message
  migrate                Apply migrations to the database
  test <app_name>        Run tests for the specified app (or all apps if no app_name is provided)
  format <app_name>      Format a specified app using isort and blue
  --help, -h             Show this help message

Example Usage

  1. Create a new project:
python manage.py createproject my_project
  1. Create a new app within the project:
python manage.py createapp my_app

Important: After creating a new app, you must add the app name to the apps list in settings.py. This ensures the app's routes are included in the FastAPI application.

Here's an example of how to modify settings.py:

import importlib
from typing import List
from fastapi import FastAPI

class Settings:
    app_title: str = "API School"
    app_version: str = "1.0.0"
    apps: List[str] = ["my_app"]  # Add your app here

    @staticmethod
    def create_app() -> FastAPI:
        application: FastAPI = FastAPI(
            title=settings.app_title,
            version=settings.app_version,
        )

        # Loop through the apps and include their routes
        for app_name in settings.apps:
            app_module = importlib.import_module(f"{app_name}.routes")
            application.include_router(app_module.router, prefix=f"{app_name}", tags=[app_name])

        return application

settings = Settings()

This configuration will ensure that the routes for your app (my_app in this case) are included in the FastAPI application with a URL prefix of /my_app.

  1. Make migrations for your app:
python manage.py makemigrations
  1. Apply migrations to the database:
python manage.py migrate
  1. Run tests for a specific app:
python manage.py test my_app

Documentation

For detailed documentation and usage examples, please visit the GitHub repository.

License

This project is licensed under the MIT License - see the LICENSE file for details.

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

jackson_easy_api-0.3.307.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jackson_easy_api-0.3.307-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file jackson_easy_api-0.3.307.tar.gz.

File metadata

  • Download URL: jackson_easy_api-0.3.307.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.11.10 Linux/6.5.0-1025-azure

File hashes

Hashes for jackson_easy_api-0.3.307.tar.gz
Algorithm Hash digest
SHA256 0da635b77daef3552c618ad43f180de7d0182043c96691eae8a8eb2ae92ac5d8
MD5 1f6062204c330d966cbd765f2b9c0732
BLAKE2b-256 7381823d5a95cb4dfb8c92fbf494238296e5ca9728e4bfd0fb11f1684a495018

See more details on using hashes here.

File details

Details for the file jackson_easy_api-0.3.307-py3-none-any.whl.

File metadata

  • Download URL: jackson_easy_api-0.3.307-py3-none-any.whl
  • Upload date:
  • Size: 8.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.11.10 Linux/6.5.0-1025-azure

File hashes

Hashes for jackson_easy_api-0.3.307-py3-none-any.whl
Algorithm Hash digest
SHA256 010fe2417facccd180e13a2953924b598731bc0da0e089d72a2ce7a698605082
MD5 d5b248bc3fdbe7c6a3ba8721185a0756
BLAKE2b-256 4a135b7a6886349b97a324e129f64ad331c5a9bc7283a4d836913fa6672f9254

See more details on using hashes here.

Supported by

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