Skip to main content

Add your description here

Project description

Fast-Craftsmanship CLI Tool

Fast-Craftsmanship is a CLI tool designed to streamline the management and scaffolding of FastAPI projects. It follows best practices to help you create a clean, consistent, and scalable project structure, whether you are starting a new project or adding features to an existing one.

📚 Documentation: https://fguedes90.github.io/fast-craftsmanship/

Features

  • Project Initialization: Quickly scaffold a new FastAPI project with a pre-defined structure.
  • DDD Structure Generation: Generate files for domain, service, API, repository, and tests following Domain-Driven Design principles.
  • Database Migrations: Easily create, apply, and rollback database migrations.
  • Code Verification: Run type checking, linting, tests, and formatting checks using a single command.
  • Extensibility: Easily extend the CLI with custom templates and commands.

Installation

From PyPI

If the package is available on PyPI:

pip install fast-craftsmanship

From Source

Clone the repository and install in editable mode:

git clone <repository-URL>
cd fcship
pip install -e ".[dev]"

Usage

After installation, use the CLI by invoking craftsmanship followed by the desired command.

Basic Commands

  • Project Initialization

    craftsmanship project init <project_name>
    
  • Domain Generation

    craftsmanship domain create <domain_name>
    
  • Service Layer Generation

    craftsmanship service create <service_name>
    
  • API Endpoint Generation

    craftsmanship api create <api_name>
    
  • Repository Implementation

    craftsmanship repo create <repository_name>
    
  • Test File Generation

    craftsmanship test create <unit|integration> <test_name>
    
  • Database Migrations

    craftsmanship db migration <migration_name>
    craftsmanship db migrate
    craftsmanship db rollback
    
  • Code Verification

    craftsmanship verify <all|type|lint|test|format>
    

Additional

  • Version Information
    craftsmanship --version
    

Project Structure

When a new project is initialized, the following structure is created:

├── api/              # API endpoints and schemas
├── domain/           # Domain entities and interfaces
├── service/          # Service layer implementation
├── infrastructure/   # Database and external services
└── tests/            # Test suites (unit and integration)

Development

Setup

# Clone the repository
git clone <repository-URL>
cd fast-craftsmanship

# Install in development mode
make dev-install

Available Commands

Run make help to see all available commands:

clean                Clean up build artifacts
check-all            Run linting and tests
dev-install          Install the package with development dependencies
docs                 Generate documentation (placeholder - add your documentation command)
format               Format code with ruff
help                 Show this help
install              Install the package
lint                 Lint code with ruff
release              Create a new release (placeholder - add your release commands)
test                 Run all tests
test-cov             Run tests with coverage report

Releasing New Versions

This project uses GitHub Actions for CI/CD with semantic versioning:

  1. To create a new release, go to the GitHub Actions tab and run the "Bump Version" workflow
  2. Choose the version type (patch, minor, or major)
  3. The workflow will:
    • Update the version in pyproject.toml
    • Commit and push the changes
    • Create a tag for the new version
    • Trigger the release workflow

Documentation

Full documentation is available at https://fguedes90.github.io/fast-craftsmanship/.

Our documentation includes:

  • Detailed command references
  • Tutorials and guides
  • Architecture explanations
  • Development workflows
  • Best practices for functional programming

To run the documentation locally:

# Install the docs dependencies
pip install -e ".[docs]"

# Serve the documentation
mkdocs serve

Contributing

Contributions are welcome! To contribute:

  1. Fork the repository.
  2. Create a new branch: git checkout -b feature/my-feature
  3. Commit your changes.
  4. Push your branch: git push origin feature/my-feature
  5. Open a pull request describing your feature.

License

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

Support

If you encounter issues or have suggestions, please open an issue in the repository.


Happy coding with Fast-Craftsmanship! 🚀

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

fast_craftsmanship-0.2.6.tar.gz (81.3 kB view details)

Uploaded Source

Built Distribution

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

fast_craftsmanship-0.2.6-py3-none-any.whl (100.6 kB view details)

Uploaded Python 3

File details

Details for the file fast_craftsmanship-0.2.6.tar.gz.

File metadata

  • Download URL: fast_craftsmanship-0.2.6.tar.gz
  • Upload date:
  • Size: 81.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fast_craftsmanship-0.2.6.tar.gz
Algorithm Hash digest
SHA256 469d4b9d19cfb3eed67c39dfa83583fa51e78dc71554d3d830d192d2fc60e70a
MD5 dc4b7bf3c19d1f142bedc222c2347997
BLAKE2b-256 695c250c324d30fec132e176c574a10b93faa43148faa1c2ce7d30b96ca0eddc

See more details on using hashes here.

File details

Details for the file fast_craftsmanship-0.2.6-py3-none-any.whl.

File metadata

File hashes

Hashes for fast_craftsmanship-0.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 bd8a7374e38d2c248cf5e6145399b894f5c26e37a1e1f67f441d7ac8aaa4214c
MD5 064580bd0ccc7db6a8509b0a2748b07d
BLAKE2b-256 6922648c1c3559e8255e22a709ce096cc15d248f20dfa72c1d870754be2047b7

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