Skip to main content

A Type-Safe UI/CLI Generator powered by Pydantic.

Project description

Typerform

A Type-Safe UI/CLI Generator powered by Pydantic and Prompt-Toolkit.

PyPI version Python CI License Typed

Typerform transforms your Pydantic models into professional, interactive CLI wizards. Stop writing boilerplate input loops and manual validation—let your schemas drive the user experience.

Features

Feature Description
Zero Boilerplate Just one line of code to generate an entire multi-step wizard.
Type-Safe Inherits all constraints (min_length, ge, EmailStr) from Pydantic.
Backtracking Full backtracking support—type :b or :back to edit previous fields.
Conditional Logic Dynamically skip fields based on previous answers using 'when' metadata.
Secure by Default Automatic masking for SecretStr fields (API keys, passwords).
Enterprise Ready Pluggable prompt engines for 100% automated testing in CI/CD.
Smart Autocomplete Fuzzy search and real-time suggestions for Enums and Literals.
Hydration Pre-fill forms from Environment variables or configuration files.

Installation

pip install pytypeform

Quick Start

from typing import Literal
from pydantic import BaseModel, Field
from typeform import form

class SetupConfig(BaseModel):
    project_name: str = Field(description="Project Name", min_length=3)
    environment: Literal["dev", "staging", "prod"] = Field(default="dev")
    enable_telemetry: bool = Field(default=True, description="Enable Telemetry")

# Generate the wizard!
config = form(SetupConfig, title="Project Setup")

print(config.model_dump())

Advanced Usage

Backtracking and Navigation

Typerform maintains a navigation stack. At any prompt, you can use special commands:

  • :back or :b - Move to the previous field.
  • :? - Show extended help text (if provided in json_schema_extra).

Conditional Logic

Hide or show fields dynamically based on the current state of the form:

class CloudConfig(BaseModel):
    provider: Literal["aws", "gcp"]
    # Only asked if provider is 'aws'
    aws_region: str = Field(
        "us-east-1", 
        json_schema_extra={"when": "provider == 'aws'"}
    )

Collection Wizard (Lists)

Typerform handles List[T] by entering a collection loop:

class Team(BaseModel):
    members: list[str] = Field(description="Team Members")

# User will be prompted to add multiple items sequentially.

Hydration (Auto-filling)

Speed up workflows by pre-filling fields from the environment:

import os
config = form(MyModel, hydrate_from=[os.environ])

Contributing

Contributions are welcome! Whether it's bug reports, feature requests, or new prompt engines.

git clone https://github.com/STHITAPRAJNAS/typeform.git
cd typeform
pip install -e ".[dev]"
pytest                        # run test suite
ruff check src/typeform      # lint
mypy src/typeform            # type-check

License

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

Copyright (c) 2026 Sthitaprajna Sahoo and contributors.

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

pytypeform-0.2.3.tar.gz (12.0 kB view details)

Uploaded Source

Built Distribution

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

pytypeform-0.2.3-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file pytypeform-0.2.3.tar.gz.

File metadata

  • Download URL: pytypeform-0.2.3.tar.gz
  • Upload date:
  • Size: 12.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pytypeform-0.2.3.tar.gz
Algorithm Hash digest
SHA256 c22a82a747cef12b5c5b992577a529cf2f27b0daafd4c244c9f6d666a028b770
MD5 d9d3dba997d077f6c63ae86d6ef9ddee
BLAKE2b-256 c54ca60b4fa1029924044cf459e471b46fed6f65dd3969a5b05b42e40561eb10

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytypeform-0.2.3.tar.gz:

Publisher: release.yml on STHITAPRAJNAS/typeform

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pytypeform-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: pytypeform-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 10.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pytypeform-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 da8ba4a49ceb4c7f5b40ae61c9078c8ede1404a773e6b024158c03fd39fdc7bc
MD5 15d08bf8753bd68ffc6b1610be5f886e
BLAKE2b-256 5b7c09ea0632978e0bbe7d806a47c195299baa3e24f6738243632664f50d0852

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytypeform-0.2.3-py3-none-any.whl:

Publisher: release.yml on STHITAPRAJNAS/typeform

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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