Agently Docs

Agently documentation for building AI applications with stable outputs, observable actions, and durable workflows.

View the Project on GitHub AgentEra/Agently

Settings

Agently settings are a hierarchical key-value store. Three scopes:

Scope Set with Visible to
Global Agently.set_settings(...) every agent and request created after the call
Agent agent.set_settings(...) requests built from that agent
Request / runtime start(..., max_retries=...) and similar method-level args one call only

Lower-scope keys override higher-scope keys; keys you don’t override inherit through.

Setting paths

The first argument to set_settings(...) is a dotted path. Common paths:

Path Meaning
OpenAICompatible shorthand alias resolved to plugins.ModelRequester.OpenAICompatible
AnthropicCompatible shorthand for the Claude requester
plugins.ModelRequester.<Name> full path; same as the shorthand
debug enable streaming console logs of the model request
runtime.show_model_logs enable console logs for model requests and response parsing; True is equivalent to "simple"
runtime.show_action_logs enable console logs for Action Runtime planning and execution; True is equivalent to "simple"
runtime.show_tool_logs compatibility alias for runtime.show_action_logs in existing tool-loop examples
runtime.show_trigger_flow_logs enable console logs for TriggerFlow execution / signal events; True is equivalent to "simple"
runtime.show_runtime_logs enable console logs for request, session, chunk, runtime.print, and other generic observation events; True is equivalent to "simple"
runtime.show_deprecation_warnings emit deprecated API warnings; defaults to True, set to False / "off" to silence deprecation warnings globally
runtime.session_id bind a request to an explicit session id

You can also pass a single dict and Agently merges by key:

Agently.set_settings("OpenAICompatible", {
    "base_url": "https://api.openai.com/v1",
    "model": "${ENV.OPENAI_MODEL}",
})

Reading settings back

agent_settings = agent.settings.get("plugins.ModelRequester.OpenAICompatible", {})
print(agent_settings.get("model"))

settings.get(path, default) walks the dotted path; missing keys return the default.

Env placeholders

Anywhere in a settings value, ${ENV.<NAME>} is replaced with the matching environment variable when the settings are read. The pattern is parsed by agently/utils/Settings.py.

Agently.set_settings("OpenAICompatible", {
    "api_key": "${ENV.OPENAI_API_KEY}",
})

Loading from files

For non-trivial projects, keep settings in YAML / TOML / JSON instead of inline Python:

from agently import Agently

Agently.load_settings("yaml_file", "settings.yaml", auto_load_env=True)

auto_load_env=True loads any .env in the working directory before resolving ${ENV.*} placeholders. Top-level aliases use the same mappings as set_settings(...), so a file can use either OpenAICompatible: or the full plugins.ModelRequester.OpenAICompatible: path.

If you need a standalone Settings object, use Settings().load(...):

from agently.utils import Settings

settings = Settings()
settings.load("yaml_file", "settings.yaml", auto_load_env=True)

A typical layout for a project that uses files is in Project Framework.

Debug toggle

Agently.set_settings("debug", True)

Prints the streaming model request log to the console. Useful for verifying that prompt slots, output schema, and retries are doing what you expect.

Runtime logs can also be enabled per family:

Agently.set_settings("runtime.show_model_logs", True)
Agently.set_settings("runtime.show_action_logs", True)
Agently.set_settings("runtime.show_trigger_flow_logs", True)
Agently.set_settings("runtime.show_runtime_logs", "detail")

Each switch accepts False / "off", True / "simple", or "detail". "simple" prints summaries and warning/error/critical events; "detail" prints the full observation event stream for that family. Action loop events render as ActionLoop; concrete action.* events render with the action name and action_type. runtime.show_tool_logs remains accepted for existing code and enables the same Action Runtime log family when runtime.show_action_logs is not set. Start events render as Started, normal completion renders as Completed, and only failure events or explicit failure payloads render as Failed.

Production deployments that intentionally keep legacy compatibility calls can silence deprecation warnings globally:

Agently.set_settings("runtime.show_deprecation_warnings", False)

This only affects Agently deprecation warnings. Operational runtime warnings, errors, and risky-scope warnings such as flow_data remain controlled by their own APIs and settings.

See also