Quick Apps (2.0) is a composer for building DIAL applications from reusable tools and integrations. It lets you declaratively compose new DIAL applications by wiring DIAL-native tools, REST APIs, and MCP servers with any LLM registered in DIAL Core acting as the orchestrator. Publishing a Quick App produces a DIAL application record managed by Core.
- Compose applications by wiring tools and an LLM orchestrator via JSON-schema–validated manifests.
- Advanced flow controls: fallbacks, parallel tool execution, loops and retries.
- Native DIAL tools plus external REST and MCP integrations.
- Any LLM available in DIAL Core (Azure OpenAI, Anthropic, Vertex AI, etc.).
Some features are released as Preview before becoming Stable:
| Stage | Meaning |
|---|---|
| Preview | Available for use but may change in breaking ways without a major version bump. Feedback is welcome. |
| Stable | Covered by semantic versioning — breaking changes require a major version bump. |
Features in Preview are marked with a [Preview] tag in documentation.
- Configuration Reference - Full configuration model, environment variables, and examples
- Agent Skills
[Preview]- How to create and manage reusable agent skills - Technical Documentation - Internal architecture and design documents
- Local development and run instructions, utilities and tests remain in this repository. For detailed setup commands ( venv, poetry, make targets) see the project docs and Makefile.
- To run Quick Apps as a standalone service you need to provide DIAL Core endpoint and relevant environment variables.
All configuration-specific details (configuration model, environment variables, orchestrator, contexts, tool_sets, tool fallback, attachments, authorization types, parameter/display configurations and examples) were moved to a dedicated file:
- Configuration — full configuration reference and examples.
Incoming request headers whose names start with X- (case-insensitive) are automatically forwarded to all outbound
calls made during that chat completion. No configuration is required.
- Orchestrator (Azure OpenAI): forwarded headers are sent on each chat completion request.
- MCP tools: forwarded headers are merged into the HTTP/SSE headers used when connecting to MCP servers.
- DIAL deployment tools: forwarded headers are sent as
extra_headerswhen calling DIAL chat completions. - REST API tools: forwarded headers are merged into the outgoing HTTP request headers.
Use this for tracing (e.g. X-Request-Id, X-Correlation-Id), multi-tenancy (X-Tenant-Id), or any custom header
your gateways or downstream services expect.
| Variable | Default | Required | Description |
|---|---|---|---|
| DIAL Core | |||
DIAL_URL |
— | Yes | URL of the DIAL Core API |
DIAL_API_VERSION |
2025-01-01-preview |
No | API version for DIAL Core API |
| Logging | |||
LOG_FORMAT |
See below ¹ | No | Custom logging format string |
LOG_LEVEL |
INFO |
No | Root logger level (all loggers except quickapp) |
QUICKAPP_LOG_LEVEL |
INFO |
No | Log level for quickapp loggers |
LOG_MULTILINE_LOG_ENABLED |
false |
No | Enable multiline log mode |
| Agent | |||
DEFAULT_AGENT_MAX_ITERATIONS |
15 |
No | Maximum number of orchestrator iterations (-1 for infinite) |
CHAT_MESSAGE_LOG_LEN |
-1 (unlimited) |
No | Character limit for message content previews in logs |
SHOW_USAGE_STATISTICS |
false |
No | Include usage statistics in chat completion stream |
SHOW_EXECUTION_TIME_STAGE |
false |
No | Show execution time stage in the UI |
| Python Interpreter | |||
PY_INTERPRETER_LOCAL_RUN |
false |
No | Run PyInterpreter locally instead of via DIAL Core API |
PY_INTERPRETER_URL |
(falls back to DIAL_URL) | No | URL of the PyInterpreter service |
PY_INTERPRETER_API_KEY |
— | No | API key for local-run PyInterpreter |
PY_INTERPRETER_DEFAULT_SESSION_ID |
— | No | Default session ID for the PyInterpreter |
PY_INTERPRETER_CLIENT_TIMEOUT |
60.0 |
No | Timeout (seconds) for PyInterpreter client requests |
PY_INTERPRETER_CLIENT_MAX_RETRIES |
3 |
No | Max retries for PyInterpreter client requests |
| Templates | |||
PREDEFINED_EXTRA_PATHS |
— | No | JSON list of directories layered on top of built-in predefined content (later entries override earlier ones) |
CONFIG_PROMPT_MAPPING |
(built-in mapping) | No | JSON mapping of predefined system prompts to DIAL Core deployments |
| Observability | |||
OTEL_SERVICE_NAME |
quickapps |
No | Service name for OpenTelemetry tracing and metrics |
| Scripts & Tests | |||
REMOTE_DIAL_URL |
— | No | URL of the remote DIAL Core, used only by generate_dial_config script and e2e/integration tests |
REMOTE_DIAL_API_KEY |
— | No | API key of the remote DIAL Core, used only by generate_dial_config script and e2e/integration tests |
Caution
These variables still work but will be removed in a future major version.
| Variable | Replacement | Description |
|---|---|---|
PREDEFINED_BASE_PATH |
PREDEFINED_EXTRA_PATHS |
If set alone, treated as a single extra layer on top of the built-in content |
¹Notes:
- Variables listed above are a superset used across development and deployment modes. Some variables (e.g.
REMOTE_DIAL_*) are only used when running the full local stack via docker-compose or during testing. - For a standalone Quick Apps deployment the essential variable is only
DIAL_URL - For PyInterpreter tool setup see: DIAL Core, PyInterpreter.
Warning
The config/predefined/instructions/ directory convention (formerly documented as "Agent instructions") has been
removed. Instructions are replaced by Agent Skills [Preview], which offer richer
metadata,
on-demand retrieval, and layered overrides. See the
migration guide for details.
-
Install Make
- macOS: usually preinstalled.
- Windows: see https://gnuwin32.sourceforge.net/packages/make.htm or use Chocolatey.
- Ensure
makeis in PATH (which make).
-
Install Python 3.13
- macOS (Homebrew):
brew install python@3.13 - Official downloads: https://www.python.org/downloads/
- Ensure
python3.13(orpython3) is in PATH (python3.13 --version).
- macOS (Homebrew):
-
Recommended way - system-wide, independent of any particular python venv:
- MacOS - recommended way to install poetry is to use pipx
- Windows - recommended way to install poetry is to use official installer
- Make sure that
poetryis in the PATH and works properly (runpoetry --version). - Alternative - venv-specific (using
pip): make sure the correct python venv is activatedmake install_poetry
-
Clone the repository
-
Create and activate virtual environment
make init_venv source .venv/bin/activate -
Install dev dependencies
make install_dev
-
Create
.envfile in the root of the project. Copy.env.templatefile data to the.envand fill the values. The full information about ENV variables can be found in Configuration.cp .env.template .env
-
Generate DIAL configuration files:
make generate_dial_config
This command will generate two files in
docker_compose_files/core/configuration/generated/:models.json- contains the models configuration for DIAL.
-
Option A — Full local stack (docker-compose)
-
Use this if you want to bring up DIAL Core, chat UI, redis, themes and adapters locally for end-to-end development and testing.
-
This docker-compose setup launches multiple services and uses internal hostnames (for example core, redis, themes).
-
Setup expects the Quick Apps service to run on your host machine at
host.docker.internal:5000python3 ./src/quickapp/app.py
-
Then start the local stack:
docker compose up -d
-
Notes:
- If you want to run Quick Apps in Docker instead of on the host, update
application-schemas.json and change the Quick
Apps host from
host.docker.internal:5000toquick-apps:5000. - When running via docker-compose the compose files set service hostnames (for example DIAL URL inside containers is http://core:8080). Those container-internal hostnames are not valid from your host machine — use the exposed ports (for example http://localhost:8090) when calling services from the host.
- Some environment variables in the repo (e.g. adapter or chat-specific variables) are only relevant for the full stack docker-compose setup and may be ignored when you deploy Quick Apps standalone.
- If you want to run Quick Apps in Docker instead of on the host, update
application-schemas.json and change the Quick
Apps host from
-
-
Option B — Quick Apps standalone (connect to an existing DIAL Core)
- Use this when you already have a DIAL Core instance available (local, staging, or cloud). You do NOT need to run core, chat, redis, themes, or adapter containers to deploy Quick Apps.
- Steps:
- Create and fill your .env (or set environment variables) with the fields required by Quick Apps. At minimum
ensure:
- DIAL_URL points to your DIAL Core API endpoint (example: https://core.example.com or http://core:8080 depending on your environment).
- If required by your DIAL Core instance, set DIAL_API_KEY or other auth variables.
- PREDEFINED_EXTRA_PATHS if you need to add or override predefined templates/toolsets.
- Run the Quick Apps 2 backend. One of:
python3 ./src/quickapp/app.pydocker build -t quickapp:latest -f Dockerfile . && docker run --rm -it quickapp:latest
- Register the application in DIAL Core
- Add the Quick App schema generated by
make dump_app_schemato the Core configuration so Core knows the Quick App application schema. For Helm create/update a ConfigMap or mount the generated file under the path referenced by PREDEFINED_EXTRA_PATHS so Core can load it. - Ensure the chat UI has the Quick Apps feature enabled. Verify the chat service (or your ai-dial-chat
deployment) includes
quick-appsin its ENABLED_FEATURES flags so the UI will surface Quick Apps.
- Add the Quick App schema generated by
- Create and fill your .env (or set environment variables) with the fields required by Quick Apps. At minimum
ensure:
- Notes:
- Quick Apps will act as a client of DIAL Core; it must be able to reach the DIAL Core API (DIAL_URL) and, if required, present credentials (DIAL_API_KEY).
- Registering on the DIAL Core side can be done by adding the application JSON to Core configuration or via your Core management UI — ensure the application record points to the Quick Apps service as appropriate.
-
Format the code:
make format # Format all source files + regenerate app schema make format FILES="src/quickapp/agent/orchestrator.py" # Format specific files (skips schema dump)
-
Run linters:
make lint # Run all linters (always checks all source files) -
Run individual tools (accept
FILES="..."to target specific files):make black # Run black formatter make isort # Run isort formatter make flake8 # Run flake8 linter make mypy # Run type checking
-
Run tests:
make test # Run all unit tests make test ARGS="-k test_name -x" # Run specific tests / fail fast make test_cov # Run unit tests with coverage report
-
Run arbitrary Python scripts:
make run_python SCRIPT=src/scripts/dump_app_schema.py
-
To automatically apply black and isort on commit, enable PreCommit:
make install_pre_commit_hooks
This command will set up the git hook scripts.
Refer to Testing Guide for detailed instructions on setting up and running tests.
For more information about DIAL and its components, visit the DIAL documentation. Join the DIAL community on Discord for support and collaboration.