Skip to main content

Generate attrs models content using DRF from sqlalchemy models.

Project description

exdrf-gen-al2at

exdrf-gen-al2at is an exdrf-gen plugin that generates attrs-based Python modules from an ExDataset built from your SQLAlchemy declarative models. Output is driven by Jinja2 templates under al2at_templates/ and the composite tree in exdrf_gen.fs_support (TopDir, CategDir, ResFile, …).

Python 3.12.2+ is required.

What it generates

Layout under the output directory:

  • Root __init__.py, api.py
  • Per category: {category}/__init__.py, {category}/api.py
  • Per resource: {category}/{resource}.py from c/m.py.j2

Templates receive out_module, db_module, type_to_attrs, and standard dataset/resource context from exdrf-gen (see the exdrf-gen README for fs_support and preserve markers).

Dependencies

Declared in pyproject.toml for this package:

  • attrs

You also need (same environment as your SQLAlchemy models):

  • exdrf-gen — shared CLI, Jinja environment, fs_support
  • exdrf-alGetDataset and dataset_from_sqlalchemy for the DATASET argument
  • click — used by the CLI

Install the plugin package in editable or release form alongside those dependencies.

Command-line usage

The command is registered on the shared exdrf_gen Click group. With exdrf-gen installed:

exdrf-gen al2at DATASET OUT-PATH OUT-MODULE DB-MODULE

Same entry point via python -m exdrf_gen (loads plugins, then the CLI):

python -m exdrf_gen al2at DATASET OUT-PATH OUT-MODULE DB-MODULE

Arguments:

  • DATASETmodule.path:Symbol pointing to your SQLAlchemy declarative Base (or equivalent). Resolved by exdrf_al.click_support.GetDataset.
  • OUT-PATH — output directory (created as needed). Override with env var EXDRF_AL2AT_PATH.
  • OUT-MODULE — Python package name for generated imports.
  • DB-MODULE — module where SQLAlchemy model classes live (passed into templates).

Global options on the root group include --debug.

Python API

from exdrf_gen_al2at.creator import generate_attrs_from_alchemy
from exdrf_gen.jinja_support import jinja_env

generate_attrs_from_alchemy(
    d_set=dataset,
    out_path="/path/to/out",
    out_module="my_app.generated",
    db_module="my_app.db.models",
    env=jinja_env,
)

Plugin registration

This package registers:

[project.entry-points.'exdrf.plugins']
exdrf_gen = 'exdrf_gen_al2at'

Importing exdrf_gen_al2at calls install_plugin with the template directory so jinja_env can resolve al2at_templates.

See also

  • exdrf-genREADME.md (plugins, Jinja, fs_support)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

exdrf_gen_al2at-0.1.11-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file exdrf_gen_al2at-0.1.11-py3-none-any.whl.

File metadata

File hashes

Hashes for exdrf_gen_al2at-0.1.11-py3-none-any.whl
Algorithm Hash digest
SHA256 b5c704cc511b7e993b0c66c9b4f24bd99f5d875ae9468ef3e9604d16db61b44d
MD5 d97542ee63e0afe74b1744e5a259dcde
BLAKE2b-256 8771ac3e4ab092af84f54237224cb8e291b3ad8452fd84c03cfef1b5a0ceef35

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