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)
  --help, -h             Show this help message

Example Usage

  1. Create a new project:
start createproject my_project
  1. Create a new app within the project:
start 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:
start makemigrations
  1. Apply migrations to the database:
start migrate
  1. Run tests for a specific app:
start 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.257.tar.gz (6.9 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.257-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: jackson_easy_api-0.3.257.tar.gz
  • Upload date:
  • Size: 6.9 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.257.tar.gz
Algorithm Hash digest
SHA256 dec2613a3f5f5c6bb6c67d885a90281ff217b3ccbad95a76e84f7efd1534b596
MD5 a91c76a71f5c3c44b0665b08468ac240
BLAKE2b-256 c9a99a0f6f936d9950b0fc072f2518ff5056bd385992eb09a60411e2b562df33

See more details on using hashes here.

File details

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

File metadata

  • Download URL: jackson_easy_api-0.3.257-py3-none-any.whl
  • Upload date:
  • Size: 8.5 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.257-py3-none-any.whl
Algorithm Hash digest
SHA256 247c703e379fcf236ef35415a802f19527b9c8b14857e10788b08b2cd4f96bf7
MD5 c99a8aac762390f8284c32b0db966c74
BLAKE2b-256 3a6c76a2b104baf00eb0ad1d7ee83b73991fa8bc43f26c01bbfc4a42d372d7fd

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