rasa-pro 3.14.0.dev20250922__py3-none-any.whl → 3.14.0rc2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of rasa-pro might be problematic. Click here for more details.
- rasa/__main__.py +15 -3
- rasa/agents/__init__.py +0 -0
- rasa/agents/agent_factory.py +122 -0
- rasa/agents/agent_manager.py +211 -0
- rasa/agents/constants.py +43 -0
- rasa/agents/core/__init__.py +0 -0
- rasa/agents/core/agent_protocol.py +107 -0
- rasa/agents/core/types.py +81 -0
- rasa/agents/exceptions.py +38 -0
- rasa/agents/protocol/__init__.py +5 -0
- rasa/agents/protocol/a2a/__init__.py +0 -0
- rasa/agents/protocol/a2a/a2a_agent.py +879 -0
- rasa/agents/protocol/mcp/__init__.py +0 -0
- rasa/agents/protocol/mcp/mcp_base_agent.py +726 -0
- rasa/agents/protocol/mcp/mcp_open_agent.py +327 -0
- rasa/agents/protocol/mcp/mcp_task_agent.py +522 -0
- rasa/agents/schemas/__init__.py +13 -0
- rasa/agents/schemas/agent_input.py +38 -0
- rasa/agents/schemas/agent_output.py +26 -0
- rasa/agents/schemas/agent_tool_result.py +65 -0
- rasa/agents/schemas/agent_tool_schema.py +186 -0
- rasa/agents/templates/__init__.py +0 -0
- rasa/agents/templates/mcp_open_agent_prompt_template.jinja2 +20 -0
- rasa/agents/templates/mcp_task_agent_prompt_template.jinja2 +22 -0
- rasa/agents/utils.py +206 -0
- rasa/agents/validation.py +485 -0
- rasa/api.py +24 -9
- rasa/builder/config.py +6 -2
- rasa/builder/copilot/constants.py +4 -1
- rasa/builder/copilot/copilot.py +155 -79
- rasa/builder/copilot/models.py +304 -108
- rasa/builder/copilot/prompts/copilot_training_error_handler_prompt.jinja2 +53 -0
- rasa/builder/guardrails/{lakera.py → clients.py} +55 -5
- rasa/builder/guardrails/constants.py +3 -0
- rasa/builder/guardrails/models.py +45 -10
- rasa/builder/guardrails/policy_checker.py +324 -0
- rasa/builder/guardrails/utils.py +42 -276
- rasa/builder/jobs.py +182 -12
- rasa/builder/llm_service.py +32 -5
- rasa/builder/models.py +13 -3
- rasa/builder/project_generator.py +6 -1
- rasa/builder/service.py +31 -15
- rasa/builder/training_service.py +18 -24
- rasa/builder/validation_service.py +1 -1
- rasa/cli/arguments/default_arguments.py +12 -0
- rasa/cli/arguments/run.py +2 -0
- rasa/cli/arguments/train.py +2 -0
- rasa/cli/data.py +10 -8
- rasa/cli/dialogue_understanding_test.py +10 -7
- rasa/cli/e2e_test.py +9 -6
- rasa/cli/evaluate.py +4 -2
- rasa/cli/export.py +5 -2
- rasa/cli/inspect.py +8 -4
- rasa/cli/interactive.py +5 -4
- rasa/cli/llm_fine_tuning.py +11 -6
- rasa/cli/project_templates/finance/domain/general/help.yml +0 -0
- rasa/cli/project_templates/tutorial/credentials.yml +10 -0
- rasa/cli/run.py +12 -10
- rasa/cli/scaffold.py +4 -4
- rasa/cli/shell.py +9 -5
- rasa/cli/studio/studio.py +1 -1
- rasa/cli/test.py +34 -14
- rasa/cli/train.py +41 -28
- rasa/cli/utils.py +1 -393
- rasa/cli/validation/__init__.py +0 -0
- rasa/cli/validation/bot_config.py +223 -0
- rasa/cli/validation/config_path_validation.py +257 -0
- rasa/cli/x.py +8 -4
- rasa/constants.py +7 -1
- rasa/core/actions/action.py +51 -10
- rasa/core/actions/grpc_custom_action_executor.py +1 -1
- rasa/core/agent.py +19 -2
- rasa/core/available_agents.py +229 -0
- rasa/core/brokers/kafka.py +5 -1
- rasa/core/channels/__init__.py +82 -35
- rasa/core/channels/development_inspector.py +3 -3
- rasa/core/channels/inspector/README.md +25 -13
- rasa/core/channels/inspector/dist/assets/{arc-35222594.js → arc-6177260a.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{blockDiagram-38ab4fdb-a0efbfd3.js → blockDiagram-38ab4fdb-b054f038.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{c4Diagram-3d4e48cf-0584c0f2.js → c4Diagram-3d4e48cf-f25427d5.js} +1 -1
- rasa/core/channels/inspector/dist/assets/channel-bf9cbb34.js +1 -0
- rasa/core/channels/inspector/dist/assets/{classDiagram-70f12bd4-39f40dbe.js → classDiagram-70f12bd4-c7a2af53.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{classDiagram-v2-f2320105-1ad755f3.js → classDiagram-v2-f2320105-58db65c0.js} +1 -1
- rasa/core/channels/inspector/dist/assets/clone-8f9083bb.js +1 -0
- rasa/core/channels/inspector/dist/assets/{createText-2e5e7dd3-b0f4f0fe.js → createText-2e5e7dd3-088372e2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{edges-e0da2a9e-9039bff9.js → edges-e0da2a9e-58676240.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{erDiagram-9861fffd-65c9b127.js → erDiagram-9861fffd-0c14d7c6.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{flowDb-956e92f1-4f08b38e.js → flowDb-956e92f1-ea63f85c.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{flowDiagram-66a62f08-e95c362a.js → flowDiagram-66a62f08-a2af48cd.js} +1 -1
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-96b9c2cf-9ecd5b59.js +1 -0
- rasa/core/channels/inspector/dist/assets/{flowchart-elk-definition-4a651766-703c3015.js → flowchart-elk-definition-4a651766-6937abe7.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{ganttDiagram-c361ad54-699328ea.js → ganttDiagram-c361ad54-7473f357.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{gitGraphDiagram-72cf32ee-04cf4b05.js → gitGraphDiagram-72cf32ee-d0c9405e.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{graph-ee94449e.js → graph-0a6f8466.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{index-3862675e-940162b4.js → index-3862675e-7610671a.js} +1 -1
- rasa/core/channels/inspector/dist/assets/index-74e01d94.js +1354 -0
- rasa/core/channels/inspector/dist/assets/{infoDiagram-f8f76790-c79c2866.js → infoDiagram-f8f76790-be397dc7.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{journeyDiagram-49397b02-84489d30.js → journeyDiagram-49397b02-4cefbf62.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{layout-a9aa9858.js → layout-e7fbc2bf.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{line-eb73cf26.js → line-a8aa457c.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{linear-b3399f9a.js → linear-3351e0d2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{mindmap-definition-fc14e90a-b095bf1a.js → mindmap-definition-fc14e90a-b8cbf605.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{pieDiagram-8a3498a8-07644b66.js → pieDiagram-8a3498a8-f327f774.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{quadrantDiagram-120e2f19-573a3f9c.js → quadrantDiagram-120e2f19-2854c591.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{requirementDiagram-deff3bca-d457e1e1.js → requirementDiagram-deff3bca-964985d5.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{sankeyDiagram-04a897e0-9d26e1a2.js → sankeyDiagram-04a897e0-edeb4f33.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{sequenceDiagram-704730f1-3a9cde10.js → sequenceDiagram-704730f1-fcf70125.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{stateDiagram-587899a1-4f3e8cec.js → stateDiagram-587899a1-0e770395.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{stateDiagram-v2-d93cdb3a-e617e5bf.js → stateDiagram-v2-d93cdb3a-af8dcd22.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-6aaf32cf-eab30d2f.js → styles-6aaf32cf-36a9e70d.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-9a916d00-09994be2.js → styles-9a916d00-884a8b5b.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-c10674c1-b7110364.js → styles-c10674c1-dc097813.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{svgDrawCommon-08f97a94-3ebc92ad.js → svgDrawCommon-08f97a94-5a2c7eed.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{timeline-definition-85554ec2-7d13d2f2.js → timeline-definition-85554ec2-e89c4f6e.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{xychartDiagram-e933f94c-488385e1.js → xychartDiagram-e933f94c-afb6fe56.js} +1 -1
- rasa/core/channels/inspector/dist/index.html +1 -1
- rasa/core/channels/inspector/package.json +18 -18
- rasa/core/channels/inspector/src/App.tsx +29 -4
- rasa/core/channels/inspector/src/components/DialogueAgentStack.tsx +108 -0
- rasa/core/channels/inspector/src/components/{DialogueStack.tsx → DialogueHistoryStack.tsx} +4 -2
- rasa/core/channels/inspector/src/helpers/audio/audiostream.ts +7 -4
- rasa/core/channels/inspector/src/helpers/formatters.test.ts +4 -0
- rasa/core/channels/inspector/src/helpers/formatters.ts +24 -3
- rasa/core/channels/inspector/src/helpers/utils.test.ts +127 -0
- rasa/core/channels/inspector/src/helpers/utils.ts +66 -1
- rasa/core/channels/inspector/src/theme/base/styles.ts +19 -1
- rasa/core/channels/inspector/src/types.ts +21 -0
- rasa/core/channels/inspector/yarn.lock +336 -189
- rasa/core/channels/studio_chat.py +6 -6
- rasa/core/channels/telegram.py +4 -9
- rasa/core/channels/voice_stream/genesys.py +1 -1
- rasa/core/channels/voice_stream/tts/deepgram.py +140 -0
- rasa/core/channels/voice_stream/twilio_media_streams.py +5 -1
- rasa/core/channels/voice_stream/voice_channel.py +3 -0
- rasa/core/concurrent_lock_store.py +38 -21
- rasa/core/config/__init__.py +0 -0
- rasa/core/{available_endpoints.py → config/available_endpoints.py} +51 -16
- rasa/core/config/configuration.py +260 -0
- rasa/core/config/credentials.py +19 -0
- rasa/core/config/message_procesing_config.py +34 -0
- rasa/core/constants.py +10 -0
- rasa/core/iam_credentials_providers/aws_iam_credentials_providers.py +69 -4
- rasa/core/iam_credentials_providers/credentials_provider_protocol.py +2 -1
- rasa/core/lock_store.py +4 -0
- rasa/core/policies/enterprise_search_policy.py +5 -3
- rasa/core/policies/flow_policy.py +4 -4
- rasa/core/policies/flows/agent_executor.py +632 -0
- rasa/core/policies/flows/flow_executor.py +136 -75
- rasa/core/policies/flows/mcp_tool_executor.py +298 -0
- rasa/core/policies/intentless_policy.py +1 -1
- rasa/core/policies/ted_policy.py +20 -12
- rasa/core/policies/unexpected_intent_policy.py +6 -0
- rasa/core/processor.py +68 -44
- rasa/core/redis_connection_factory.py +7 -2
- rasa/core/run.py +37 -8
- rasa/core/test.py +4 -0
- rasa/core/tracker_stores/redis_tracker_store.py +4 -0
- rasa/core/tracker_stores/sql_tracker_store.py +3 -1
- rasa/core/tracker_stores/tracker_store.py +3 -7
- rasa/core/train.py +1 -1
- rasa/core/training/interactive.py +20 -18
- rasa/core/training/story_conflict.py +5 -5
- rasa/core/utils.py +22 -23
- rasa/dialogue_understanding/commands/__init__.py +8 -0
- rasa/dialogue_understanding/commands/cancel_flow_command.py +19 -5
- rasa/dialogue_understanding/commands/chit_chat_answer_command.py +21 -2
- rasa/dialogue_understanding/commands/clarify_command.py +20 -2
- rasa/dialogue_understanding/commands/continue_agent_command.py +91 -0
- rasa/dialogue_understanding/commands/knowledge_answer_command.py +21 -2
- rasa/dialogue_understanding/commands/restart_agent_command.py +162 -0
- rasa/dialogue_understanding/commands/start_flow_command.py +68 -7
- rasa/dialogue_understanding/commands/utils.py +124 -2
- rasa/dialogue_understanding/generator/command_parser.py +4 -0
- rasa/dialogue_understanding/generator/llm_based_command_generator.py +50 -12
- rasa/dialogue_understanding/generator/llm_command_generator.py +1 -1
- rasa/dialogue_understanding/generator/multi_step/multi_step_llm_command_generator.py +1 -1
- rasa/dialogue_understanding/generator/prompt_templates/agent_command_prompt_v2_claude_3_5_sonnet_20240620_template.jinja2 +66 -0
- rasa/dialogue_understanding/generator/prompt_templates/agent_command_prompt_v2_gpt_4o_2024_11_20_template.jinja2 +66 -0
- rasa/dialogue_understanding/generator/prompt_templates/agent_command_prompt_v3_claude_3_5_sonnet_20240620_template.jinja2 +89 -0
- rasa/dialogue_understanding/generator/prompt_templates/agent_command_prompt_v3_gpt_4o_2024_11_20_template.jinja2 +88 -0
- rasa/dialogue_understanding/generator/single_step/compact_llm_command_generator.py +42 -7
- rasa/dialogue_understanding/generator/single_step/search_ready_llm_command_generator.py +40 -3
- rasa/dialogue_understanding/generator/single_step/single_step_based_llm_command_generator.py +20 -3
- rasa/dialogue_understanding/patterns/cancel.py +27 -6
- rasa/dialogue_understanding/patterns/clarify.py +3 -14
- rasa/dialogue_understanding/patterns/continue_interrupted.py +239 -6
- rasa/dialogue_understanding/patterns/default_flows_for_patterns.yml +46 -8
- rasa/dialogue_understanding/processor/command_processor.py +136 -15
- rasa/dialogue_understanding/stack/dialogue_stack.py +98 -2
- rasa/dialogue_understanding/stack/frames/flow_stack_frame.py +57 -0
- rasa/dialogue_understanding/stack/utils.py +57 -3
- rasa/dialogue_understanding/utils.py +24 -4
- rasa/dialogue_understanding_test/du_test_runner.py +8 -3
- rasa/e2e_test/e2e_test_runner.py +13 -3
- rasa/engine/caching.py +2 -2
- rasa/engine/constants.py +1 -1
- rasa/engine/recipes/default_components.py +138 -49
- rasa/engine/recipes/default_recipe.py +108 -11
- rasa/engine/runner/dask.py +8 -5
- rasa/engine/validation.py +19 -6
- rasa/graph_components/validators/default_recipe_validator.py +86 -28
- rasa/hooks.py +5 -5
- rasa/llm_fine_tuning/utils.py +2 -2
- rasa/model_training.py +60 -47
- rasa/nlu/classifiers/diet_classifier.py +198 -98
- rasa/nlu/classifiers/logistic_regression_classifier.py +1 -4
- rasa/nlu/classifiers/mitie_intent_classifier.py +3 -0
- rasa/nlu/classifiers/sklearn_intent_classifier.py +1 -3
- rasa/nlu/extractors/crf_entity_extractor.py +9 -10
- rasa/nlu/extractors/mitie_entity_extractor.py +3 -0
- rasa/nlu/extractors/spacy_entity_extractor.py +3 -0
- rasa/nlu/featurizers/dense_featurizer/convert_featurizer.py +4 -0
- rasa/nlu/featurizers/dense_featurizer/lm_featurizer.py +5 -0
- rasa/nlu/featurizers/dense_featurizer/mitie_featurizer.py +2 -0
- rasa/nlu/featurizers/dense_featurizer/spacy_featurizer.py +3 -0
- rasa/nlu/featurizers/sparse_featurizer/count_vectors_featurizer.py +4 -2
- rasa/nlu/featurizers/sparse_featurizer/lexical_syntactic_featurizer.py +4 -0
- rasa/nlu/selectors/response_selector.py +10 -2
- rasa/nlu/tokenizers/jieba_tokenizer.py +3 -4
- rasa/nlu/tokenizers/mitie_tokenizer.py +3 -2
- rasa/nlu/tokenizers/spacy_tokenizer.py +3 -2
- rasa/nlu/utils/mitie_utils.py +3 -0
- rasa/nlu/utils/spacy_utils.py +3 -2
- rasa/plugin.py +8 -8
- rasa/privacy/privacy_manager.py +12 -3
- rasa/server.py +15 -3
- rasa/shared/agents/__init__.py +0 -0
- rasa/shared/agents/auth/__init__.py +0 -0
- rasa/shared/agents/auth/agent_auth_factory.py +105 -0
- rasa/shared/agents/auth/agent_auth_manager.py +92 -0
- rasa/shared/agents/auth/auth_strategy/__init__.py +19 -0
- rasa/shared/agents/auth/auth_strategy/agent_auth_strategy.py +52 -0
- rasa/shared/agents/auth/auth_strategy/api_key_auth_strategy.py +42 -0
- rasa/shared/agents/auth/auth_strategy/bearer_token_auth_strategy.py +28 -0
- rasa/shared/agents/auth/auth_strategy/oauth2_auth_strategy.py +167 -0
- rasa/shared/agents/auth/constants.py +12 -0
- rasa/shared/agents/auth/types.py +12 -0
- rasa/shared/agents/utils.py +35 -0
- rasa/shared/constants.py +8 -0
- rasa/shared/core/constants.py +16 -1
- rasa/shared/core/domain.py +0 -7
- rasa/shared/core/events.py +327 -0
- rasa/shared/core/flows/constants.py +5 -0
- rasa/shared/core/flows/flows_list.py +21 -5
- rasa/shared/core/flows/flows_yaml_schema.json +119 -184
- rasa/shared/core/flows/steps/call.py +49 -5
- rasa/shared/core/flows/steps/collect.py +98 -13
- rasa/shared/core/flows/validation.py +372 -8
- rasa/shared/core/flows/yaml_flows_io.py +3 -2
- rasa/shared/core/slots.py +2 -2
- rasa/shared/core/trackers.py +5 -2
- rasa/shared/exceptions.py +16 -0
- rasa/shared/importers/rasa.py +1 -1
- rasa/shared/importers/utils.py +9 -3
- rasa/shared/providers/llm/_base_litellm_client.py +41 -9
- rasa/shared/providers/llm/litellm_router_llm_client.py +8 -4
- rasa/shared/providers/llm/llm_client.py +7 -3
- rasa/shared/providers/llm/llm_response.py +66 -0
- rasa/shared/providers/llm/self_hosted_llm_client.py +8 -4
- rasa/shared/utils/common.py +24 -0
- rasa/shared/utils/health_check/health_check.py +7 -3
- rasa/shared/utils/llm.py +39 -16
- rasa/shared/utils/mcp/__init__.py +0 -0
- rasa/shared/utils/mcp/server_connection.py +247 -0
- rasa/shared/utils/mcp/utils.py +20 -0
- rasa/shared/utils/schemas/events.py +42 -0
- rasa/shared/utils/yaml.py +3 -1
- rasa/studio/pull/pull.py +3 -2
- rasa/studio/train.py +8 -7
- rasa/studio/upload.py +3 -6
- rasa/telemetry.py +69 -5
- rasa/tracing/config.py +45 -12
- rasa/tracing/constants.py +14 -0
- rasa/tracing/instrumentation/attribute_extractors.py +142 -9
- rasa/tracing/instrumentation/instrumentation.py +626 -21
- rasa/tracing/instrumentation/intentless_policy_instrumentation.py +4 -4
- rasa/tracing/instrumentation/metrics.py +32 -0
- rasa/tracing/metric_instrument_provider.py +68 -0
- rasa/utils/common.py +92 -1
- rasa/utils/endpoints.py +11 -2
- rasa/utils/log_utils.py +96 -5
- rasa/utils/ml_utils.py +1 -1
- rasa/utils/tensorflow/__init__.py +7 -0
- rasa/utils/tensorflow/callback.py +136 -101
- rasa/utils/tensorflow/crf.py +1 -1
- rasa/utils/tensorflow/data_generator.py +21 -8
- rasa/utils/tensorflow/layers.py +21 -11
- rasa/utils/tensorflow/metrics.py +7 -3
- rasa/utils/tensorflow/models.py +56 -8
- rasa/utils/tensorflow/rasa_layers.py +8 -6
- rasa/utils/tensorflow/transformer.py +2 -3
- rasa/utils/train_utils.py +54 -24
- rasa/validator.py +5 -5
- rasa/version.py +1 -1
- {rasa_pro-3.14.0.dev20250922.dist-info → rasa_pro-3.14.0rc2.dist-info}/METADATA +47 -41
- {rasa_pro-3.14.0.dev20250922.dist-info → rasa_pro-3.14.0rc2.dist-info}/RECORD +299 -238
- rasa/builder/scrape_rasa_docs.py +0 -97
- rasa/core/channels/inspector/dist/assets/channel-8e08bed9.js +0 -1
- rasa/core/channels/inspector/dist/assets/clone-78c82dea.js +0 -1
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-96b9c2cf-2b08f601.js +0 -1
- rasa/core/channels/inspector/dist/assets/index-c941dcb3.js +0 -1336
- {rasa_pro-3.14.0.dev20250922.dist-info → rasa_pro-3.14.0rc2.dist-info}/NOTICE +0 -0
- {rasa_pro-3.14.0.dev20250922.dist-info → rasa_pro-3.14.0rc2.dist-info}/WHEEL +0 -0
- {rasa_pro-3.14.0.dev20250922.dist-info → rasa_pro-3.14.0rc2.dist-info}/entry_points.txt +0 -0
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
## Task Description
|
|
2
|
+
Your task is to analyze the current conversation context and generate a list of actions to start new business processes that we call flows, to extract slots, or respond to off-topic and knowledge requests.
|
|
3
|
+
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
## Available Flows and Slots
|
|
7
|
+
Use the following structured data:
|
|
8
|
+
```json
|
|
9
|
+
{"flows":[{% for flow in available_flows %}{"name":"{{ flow.name }}","description":{{ flow.description | to_json_escaped_string }}{% if flow.agent_info %},"sub-agents":[{% for agent in flow.agent_info %}{"name":"{{ agent.name }}","description":{{ agent.description | to_json_escaped_string }}}{% if not loop.last %},{% endif %}{% endfor %}]{% endif %}{% if flow.slots %},"slots":[{% for slot in flow.slots %}{"name":"{{ slot.name }}"{% if slot.description %},"description":{{ slot.description | to_json_escaped_string }}{% endif %}{% if slot.allowed_values %},"allowed_values":{{ slot.allowed_values }}{% endif %}}{% if not loop.last %},{% endif %}{% endfor %}]{% endif %}}{% if not loop.last %},{% endif %}{% endfor %}]}
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## Available Actions:
|
|
15
|
+
* `start flow flow_name`: Start a flow. For example, `start flow transfer_money` or `start flow list_contacts`.
|
|
16
|
+
* `set slot slot_name slot_value`: Set a slot for the active flow. For example, `set slot transfer_money_recipient Freddy`. Can be used to correct and change previously set values. ONLY use slots that are explicitly defined in the flow's slot list.
|
|
17
|
+
* `disambiguate flows flow_name1 flow_name2 ... flow_name_n`: When a message could refer to multiple flows, list the possible flows as options to clarify. Example: `disambiguate flows list_contacts add_contact remove_contact`.
|
|
18
|
+
* `search and reply`: Provide a response from the knowledge base to address the user’s inquiry when no flows fit, including domain knowledge, FAQs, and all off-topic or social messages.
|
|
19
|
+
* `cancel flow`: Cancel the current flow if the user requests it.
|
|
20
|
+
* `repeat message`: Repeat the last bot message.{% if active_agent %}
|
|
21
|
+
* `continue agent`: Continue the currently active agent {{ active_agent.name }}. This has HIGHEST PRIORITY when an agent is active and the user is responding to agent questions.{% endif %}{% if completed_agents %}
|
|
22
|
+
* `restart agent agent_name`: Restart the agent with the given name, in case the user wants to change some answer to a previous question asked by the agent. For example, `restart agent car_research_agent` if the user changed his mind about the car he wants to buy. ONLY use agents that are listed in the `completed_agents` section.{% endif %}
|
|
23
|
+
|
|
24
|
+
---
|
|
25
|
+
|
|
26
|
+
## General Instructions
|
|
27
|
+
### Start Flow
|
|
28
|
+
* Only start a flow if the user's message is clear and fully addressed by that flow's description and purpose.
|
|
29
|
+
* Pay close attention to exact wording and scope in the flow description — do not assume or “stretch” the intended use of a flow.
|
|
30
|
+
### Set Slot
|
|
31
|
+
* Do not fill slots with abstract values or placeholders.
|
|
32
|
+
* For categorical slots try to match the user message with allowed slot values. Use "other" if you cannot match it.
|
|
33
|
+
* Set the boolean slots based on the user response. Map positive responses to `True`, and negative to `False`.
|
|
34
|
+
* Extract text slot values exactly as provided by the user. Avoid assumptions, format changes, or partial extractions.
|
|
35
|
+
* ONLY use `set slot` with slots that are explicitly defined in the current flow's slot list. Do NOT create or assume slots that don't exist.
|
|
36
|
+
### Disambiguate Flows
|
|
37
|
+
* Use `disambiguate flows` when the user's message matches multiple flows and you cannot decide which flow is most appropriate.
|
|
38
|
+
* If the user message is short and not precise enough to start a flow or `search and reply`, disambiguate.
|
|
39
|
+
* If a single flow is a strong/plausible fit, prefer starting that flow directly.
|
|
40
|
+
* If a user's message unambiguously and distinctly matches multiple flows, start all relevant flows at once (rather than disambiguating).
|
|
41
|
+
### Search and Reply
|
|
42
|
+
* Only start `search and reply` if the user intent is clear.
|
|
43
|
+
* Flow Priority: If you are unsure between starting a flow or `search and reply`, always prioritize starting a flow.
|
|
44
|
+
### Cancel Flow
|
|
45
|
+
* Do not cancel any flow unless the user explicitly requests it.
|
|
46
|
+
* Multiple flows can be started without cancelling the previous, if the user wants to pursue multiple processes.{% if active_agent or completed_agents %}
|
|
47
|
+
### Agents{% if active_agent %}
|
|
48
|
+
* When an agent is active, ALWAYS prioritize `continue agent` over `search and reply` unless the user is clearly asking something unrelated to the agent's task.{% endif %}{% if completed_agents %}
|
|
49
|
+
* ONLY use `restart agent` with agents that are listed in the `completed_agents` section. Do NOT restart non-existent agents.{% endif %}
|
|
50
|
+
* If you're unsure about agent names, refer to the structured data provided in the `Current State` section.
|
|
51
|
+
{% endif %}### General Tips
|
|
52
|
+
* Only use information provided by the user.
|
|
53
|
+
* Strictly adhere to the provided action format.
|
|
54
|
+
* ONLY use the exact actions listed above. Do NOT invent new actions like "respond <message>" or any other variations.
|
|
55
|
+
* Focus on the last message and take it one step at a time.
|
|
56
|
+
* Use the previous conversation steps only to aid understanding.
|
|
57
|
+
|
|
58
|
+
---
|
|
59
|
+
|
|
60
|
+
## Decision Rule Table
|
|
61
|
+
| Condition | Action |
|
|
62
|
+
|---------------------------------------------------------------|--------------------|{% if active_agent %}
|
|
63
|
+
| Agent is active and the user is responding to agent questions | continue agent |{% endif %}
|
|
64
|
+
| Flow perfectly matches user's message | start flow |
|
|
65
|
+
| Multiple flows are equally strong, relevant matches | disambiguate flows |
|
|
66
|
+
| User's message is unclear or imprecise | disambiguate flows |
|
|
67
|
+
| No flow fits at all, but knowledge base may help | search and reply |
|
|
68
|
+
|
|
69
|
+
---
|
|
70
|
+
|
|
71
|
+
## Current State
|
|
72
|
+
{% if current_flow != None %}Use the following structured data:
|
|
73
|
+
```json
|
|
74
|
+
{"active_flow":{"name":"{{ current_flow }}","current_step":{"requested_slot":"{{ current_slot }}","requested_slot_description":{{ current_slot_description | to_json_escaped_string }}},"slots":[{% for slot in flow_slots %}{"name":"{{ slot.name }}","value":"{{ slot.value }}","type":"{{ slot.type }}"{% if slot.description %},"description":{{ slot.description | to_json_escaped_string }}{% endif %}{% if slot.allowed_values %},"allowed_values":"{{ slot.allowed_values }}"{% endif %}}{% if not loop.last %},{% endif %}{% endfor %}]}{% if active_agent %},"active_agent":{"name":"{{ active_agent.name }}","description":{{ active_agent.description | to_json_escaped_string }}}{% endif %}{% if completed_agents %},"completed_agents":[{% for agent in completed_agents %}{"name":"{{ agent.name }}","description":{{ agent.description | to_json_escaped_string }}}{% if not loop.last %},{% endif %}{% endfor %}]{% endif %}}
|
|
75
|
+
```{% else %}
|
|
76
|
+
You are currently not inside any flow.{% endif %}
|
|
77
|
+
|
|
78
|
+
---
|
|
79
|
+
|
|
80
|
+
## Conversation History
|
|
81
|
+
{{ current_conversation }}
|
|
82
|
+
|
|
83
|
+
---
|
|
84
|
+
|
|
85
|
+
## Task
|
|
86
|
+
Create an action list with one action per line in response to the user's last message: """{{ user_message }}""".
|
|
87
|
+
|
|
88
|
+
Your action list:
|
|
@@ -2,6 +2,7 @@ from typing import Any, Dict, Literal, Optional, Text
|
|
|
2
2
|
|
|
3
3
|
import structlog
|
|
4
4
|
|
|
5
|
+
from rasa.core.available_agents import AvailableAgents
|
|
5
6
|
from rasa.dialogue_understanding.commands.command_syntax_manager import (
|
|
6
7
|
CommandSyntaxVersion,
|
|
7
8
|
)
|
|
@@ -45,6 +46,7 @@ DEFAULT_LLM_CONFIG = {
|
|
|
45
46
|
TIMEOUT_CONFIG_KEY: 7,
|
|
46
47
|
}
|
|
47
48
|
|
|
49
|
+
# Non-agent default prompt mapping (used by default)
|
|
48
50
|
MODEL_PROMPT_MAPPER = {
|
|
49
51
|
f"{OPENAI_PROVIDER}/{MODEL_NAME_GPT_4O_2024_11_20}": (
|
|
50
52
|
"command_prompt_v2_gpt_4o_2024_11_20_template.jinja2"
|
|
@@ -60,16 +62,38 @@ MODEL_PROMPT_MAPPER = {
|
|
|
60
62
|
),
|
|
61
63
|
}
|
|
62
64
|
|
|
63
|
-
#
|
|
65
|
+
# Agentic prompt mapping (used only when agents are configured)
|
|
66
|
+
AGENT_MODEL_PROMPT_MAPPER = {
|
|
67
|
+
f"{OPENAI_PROVIDER}/{MODEL_NAME_GPT_4O_2024_11_20}": (
|
|
68
|
+
"agent_command_prompt_v2_gpt_4o_2024_11_20_template.jinja2"
|
|
69
|
+
),
|
|
70
|
+
f"{AZURE_OPENAI_PROVIDER}/{MODEL_NAME_GPT_4O_2024_11_20}": (
|
|
71
|
+
"agent_command_prompt_v2_gpt_4o_2024_11_20_template.jinja2"
|
|
72
|
+
),
|
|
73
|
+
f"{AWS_BEDROCK_PROVIDER}/anthropic.{MODEL_NAME_CLAUDE_3_5_SONNET_20240620}-v1:0": (
|
|
74
|
+
"agent_command_prompt_v2_claude_3_5_sonnet_20240620_template.jinja2"
|
|
75
|
+
),
|
|
76
|
+
f"{ANTHROPIC_PROVIDER}/{MODEL_NAME_CLAUDE_3_5_SONNET_20240620}": (
|
|
77
|
+
"agent_command_prompt_v2_claude_3_5_sonnet_20240620_template.jinja2"
|
|
78
|
+
),
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
# Defaults for non-agent prompts
|
|
64
82
|
DEFAULT_COMMAND_PROMPT_TEMPLATE_FILE_NAME = (
|
|
65
83
|
"command_prompt_v2_gpt_4o_2024_11_20_template.jinja2"
|
|
66
84
|
)
|
|
67
|
-
# When the configured model is not found in the model prompt mapper, then we use the
|
|
68
|
-
# fallback prompt template
|
|
69
85
|
FALLBACK_COMMAND_PROMPT_TEMPLATE_FILE_NAME = (
|
|
70
86
|
"command_prompt_v2_gpt_4o_2024_11_20_template.jinja2"
|
|
71
87
|
)
|
|
72
88
|
|
|
89
|
+
# Defaults for agentic prompts
|
|
90
|
+
AGENT_DEFAULT_COMMAND_PROMPT_TEMPLATE_FILE_NAME = (
|
|
91
|
+
"agent_command_prompt_v2_gpt_4o_2024_11_20_template.jinja2"
|
|
92
|
+
)
|
|
93
|
+
AGENT_FALLBACK_COMMAND_PROMPT_TEMPLATE_FILE_NAME = (
|
|
94
|
+
"agent_command_prompt_v2_gpt_4o_2024_11_20_template.jinja2"
|
|
95
|
+
)
|
|
96
|
+
|
|
73
97
|
|
|
74
98
|
@DefaultV1Recipe.register(
|
|
75
99
|
[
|
|
@@ -99,17 +123,29 @@ class CompactLLMCommandGenerator(SingleStepBasedLLMCommandGenerator):
|
|
|
99
123
|
@staticmethod
|
|
100
124
|
def get_default_prompt_template_file_name() -> str:
|
|
101
125
|
"""Get the default prompt template file name for the command generator."""
|
|
102
|
-
return
|
|
126
|
+
return (
|
|
127
|
+
AGENT_DEFAULT_COMMAND_PROMPT_TEMPLATE_FILE_NAME
|
|
128
|
+
if AvailableAgents.has_agents()
|
|
129
|
+
else DEFAULT_COMMAND_PROMPT_TEMPLATE_FILE_NAME
|
|
130
|
+
)
|
|
103
131
|
|
|
104
132
|
@staticmethod
|
|
105
133
|
def get_fallback_prompt_template_file_name() -> str:
|
|
106
134
|
"""Get the fallback prompt template file name for the command generator."""
|
|
107
|
-
return
|
|
135
|
+
return (
|
|
136
|
+
AGENT_FALLBACK_COMMAND_PROMPT_TEMPLATE_FILE_NAME
|
|
137
|
+
if AvailableAgents.has_agents()
|
|
138
|
+
else FALLBACK_COMMAND_PROMPT_TEMPLATE_FILE_NAME
|
|
139
|
+
)
|
|
108
140
|
|
|
109
141
|
@staticmethod
|
|
110
142
|
def get_model_prompt_mapper() -> Dict[str, str]:
|
|
111
143
|
"""Get the model prompt mapper for the command generator."""
|
|
112
|
-
return
|
|
144
|
+
return (
|
|
145
|
+
AGENT_MODEL_PROMPT_MAPPER
|
|
146
|
+
if AvailableAgents.has_agents()
|
|
147
|
+
else MODEL_PROMPT_MAPPER
|
|
148
|
+
)
|
|
113
149
|
|
|
114
150
|
@staticmethod
|
|
115
151
|
def get_default_llm_config() -> Dict[str, Any]:
|
|
@@ -132,7 +168,6 @@ class CompactLLMCommandGenerator(SingleStepBasedLLMCommandGenerator):
|
|
|
132
168
|
if prompt_template is not None:
|
|
133
169
|
return prompt_template
|
|
134
170
|
|
|
135
|
-
# Get the default prompt template based on the model name.
|
|
136
171
|
default_command_prompt_template = get_default_prompt_template_based_on_model(
|
|
137
172
|
llm_config=config.get(LLM_CONFIG_KEY, {}) or {},
|
|
138
173
|
model_prompt_mapping=cls.get_model_prompt_mapper(),
|
|
@@ -2,6 +2,7 @@ from typing import Any, Dict, Literal, Optional, Text
|
|
|
2
2
|
|
|
3
3
|
import structlog
|
|
4
4
|
|
|
5
|
+
from rasa.core.available_agents import AvailableAgents
|
|
5
6
|
from rasa.dialogue_understanding.commands.command_syntax_manager import (
|
|
6
7
|
CommandSyntaxVersion,
|
|
7
8
|
)
|
|
@@ -44,6 +45,7 @@ DEFAULT_LLM_CONFIG = {
|
|
|
44
45
|
TIMEOUT_CONFIG_KEY: 7,
|
|
45
46
|
}
|
|
46
47
|
|
|
48
|
+
# Non-agent defaults
|
|
47
49
|
DEFAULT_COMMAND_PROMPT_TEMPLATE_FILE_NAME = (
|
|
48
50
|
"command_prompt_v3_gpt_4o_2024_11_20_template.jinja2"
|
|
49
51
|
)
|
|
@@ -66,6 +68,29 @@ MODEL_PROMPT_MAPPER = {
|
|
|
66
68
|
),
|
|
67
69
|
}
|
|
68
70
|
|
|
71
|
+
# Agentic mapping and defaults (used only when agents exist)
|
|
72
|
+
AGENT_DEFAULT_COMMAND_PROMPT_TEMPLATE_FILE_NAME = (
|
|
73
|
+
"agent_command_prompt_v3_gpt_4o_2024_11_20_template.jinja2"
|
|
74
|
+
)
|
|
75
|
+
AGENT_FALLBACK_COMMAND_PROMPT_TEMPLATE_FILE_NAME = (
|
|
76
|
+
"agent_command_prompt_v3_gpt_4o_2024_11_20_template.jinja2"
|
|
77
|
+
)
|
|
78
|
+
AGENT_MODEL_PROMPT_MAPPER = {
|
|
79
|
+
f"{OPENAI_PROVIDER}/{MODEL_NAME_GPT_4O_2024_11_20}": (
|
|
80
|
+
"agent_command_prompt_v3_gpt_4o_2024_11_20_template.jinja2"
|
|
81
|
+
),
|
|
82
|
+
f"{AZURE_OPENAI_PROVIDER}/{MODEL_NAME_GPT_4O_2024_11_20}": (
|
|
83
|
+
"agent_command_prompt_v3_gpt_4o_2024_11_20_template.jinja2"
|
|
84
|
+
),
|
|
85
|
+
f"{AWS_BEDROCK_PROVIDER}/anthropic."
|
|
86
|
+
f"{MODEL_NAME_CLAUDE_3_5_SONNET_20240620}-v1:0": (
|
|
87
|
+
"agent_command_prompt_v3_claude_3_5_sonnet_20240620_template.jinja2"
|
|
88
|
+
),
|
|
89
|
+
f"{ANTHROPIC_PROVIDER}/{MODEL_NAME_CLAUDE_3_5_SONNET_20240620}": (
|
|
90
|
+
"agent_command_prompt_v3_claude_3_5_sonnet_20240620_template.jinja2"
|
|
91
|
+
),
|
|
92
|
+
}
|
|
93
|
+
|
|
69
94
|
|
|
70
95
|
@DefaultV1Recipe.register(
|
|
71
96
|
[
|
|
@@ -100,17 +125,29 @@ class SearchReadyLLMCommandGenerator(SingleStepBasedLLMCommandGenerator):
|
|
|
100
125
|
@staticmethod
|
|
101
126
|
def get_default_prompt_template_file_name() -> str:
|
|
102
127
|
"""Get the default prompt template file name for the command generator."""
|
|
103
|
-
return
|
|
128
|
+
return (
|
|
129
|
+
AGENT_DEFAULT_COMMAND_PROMPT_TEMPLATE_FILE_NAME
|
|
130
|
+
if AvailableAgents.has_agents()
|
|
131
|
+
else DEFAULT_COMMAND_PROMPT_TEMPLATE_FILE_NAME
|
|
132
|
+
)
|
|
104
133
|
|
|
105
134
|
@staticmethod
|
|
106
135
|
def get_fallback_prompt_template_file_name() -> str:
|
|
107
136
|
"""Get the fallback prompt template file name for the command generator."""
|
|
108
|
-
return
|
|
137
|
+
return (
|
|
138
|
+
AGENT_FALLBACK_COMMAND_PROMPT_TEMPLATE_FILE_NAME
|
|
139
|
+
if AvailableAgents.has_agents()
|
|
140
|
+
else FALLBACK_COMMAND_PROMPT_TEMPLATE_FILE_NAME
|
|
141
|
+
)
|
|
109
142
|
|
|
110
143
|
@staticmethod
|
|
111
144
|
def get_model_prompt_mapper() -> Dict[str, str]:
|
|
112
145
|
"""Get the model prompt mapper for the command generator."""
|
|
113
|
-
return
|
|
146
|
+
return (
|
|
147
|
+
AGENT_MODEL_PROMPT_MAPPER
|
|
148
|
+
if AvailableAgents.has_agents()
|
|
149
|
+
else MODEL_PROMPT_MAPPER
|
|
150
|
+
)
|
|
114
151
|
|
|
115
152
|
@staticmethod
|
|
116
153
|
def get_component_command_syntax_version() -> CommandSyntaxVersion:
|
rasa/dialogue_understanding/generator/single_step/single_step_based_llm_command_generator.py
CHANGED
|
@@ -5,6 +5,11 @@ from typing import Any, Dict, List, Literal, Optional, Text
|
|
|
5
5
|
import structlog
|
|
6
6
|
|
|
7
7
|
import rasa.shared.utils.io
|
|
8
|
+
from rasa.agents.utils import (
|
|
9
|
+
get_active_agent_info,
|
|
10
|
+
get_completed_agents_info,
|
|
11
|
+
)
|
|
12
|
+
from rasa.core.available_agents import AvailableAgents
|
|
8
13
|
from rasa.dialogue_understanding.commands import (
|
|
9
14
|
CannotHandleCommand,
|
|
10
15
|
Command,
|
|
@@ -232,6 +237,8 @@ class SingleStepBasedLLMCommandGenerator(LLMBasedCommandGenerator, ABC):
|
|
|
232
237
|
log_module=self.__class__.__name__,
|
|
233
238
|
log_event="llm_command_generator.predict_commands.finished",
|
|
234
239
|
commands=commands,
|
|
240
|
+
event_info="Commands predictd by the Command Generator",
|
|
241
|
+
highlight=True,
|
|
235
242
|
)
|
|
236
243
|
|
|
237
244
|
domain = kwargs.get("domain")
|
|
@@ -396,13 +403,18 @@ class SingleStepBasedLLMCommandGenerator(LLMBasedCommandGenerator, ABC):
|
|
|
396
403
|
current_slot_allowed_values = allowed_values_for_slot(
|
|
397
404
|
tracker.slots.get(current_slot)
|
|
398
405
|
)
|
|
399
|
-
|
|
406
|
+
has_agents = AvailableAgents.has_agents()
|
|
407
|
+
current_conversation = tracker_as_readable_transcript(
|
|
408
|
+
tracker, highlight_agent_turns=has_agents
|
|
409
|
+
)
|
|
400
410
|
latest_user_message = sanitize_message_for_prompt(message.get(TEXT))
|
|
401
411
|
current_conversation += f"\nUSER: {latest_user_message}"
|
|
402
412
|
|
|
403
|
-
inputs = {
|
|
413
|
+
inputs: Dict[str, Any] = {
|
|
404
414
|
"available_flows": self.prepare_flows_for_template(
|
|
405
|
-
startable_flows,
|
|
415
|
+
startable_flows,
|
|
416
|
+
tracker,
|
|
417
|
+
add_agent_info=has_agents,
|
|
406
418
|
),
|
|
407
419
|
"current_conversation": current_conversation,
|
|
408
420
|
"flow_slots": flow_slots,
|
|
@@ -413,6 +425,11 @@ class SingleStepBasedLLMCommandGenerator(LLMBasedCommandGenerator, ABC):
|
|
|
413
425
|
"current_slot_allowed_values": current_slot_allowed_values,
|
|
414
426
|
"user_message": latest_user_message,
|
|
415
427
|
}
|
|
428
|
+
if has_agents:
|
|
429
|
+
inputs["active_agent"] = (
|
|
430
|
+
get_active_agent_info(tracker, top_flow.id) if top_flow else None
|
|
431
|
+
)
|
|
432
|
+
inputs["completed_agents"] = get_completed_agents_info(tracker)
|
|
416
433
|
|
|
417
434
|
return self.compile_template(self.prompt_template).render(**inputs)
|
|
418
435
|
|
|
@@ -8,10 +8,12 @@ import structlog
|
|
|
8
8
|
from rasa.core.actions import action
|
|
9
9
|
from rasa.core.channels.channel import OutputChannel
|
|
10
10
|
from rasa.core.nlg.generator import NaturalLanguageGenerator
|
|
11
|
+
from rasa.dialogue_understanding.stack.dialogue_stack import DialogueStack
|
|
11
12
|
from rasa.dialogue_understanding.stack.frames import (
|
|
12
13
|
BaseFlowStackFrame,
|
|
13
14
|
PatternFlowStackFrame,
|
|
14
15
|
)
|
|
16
|
+
from rasa.dialogue_understanding.stack.frames.flow_stack_frame import AgentStackFrame
|
|
15
17
|
from rasa.shared.constants import RASA_DEFAULT_FLOW_PATTERN_PREFIX
|
|
16
18
|
from rasa.shared.core.constants import ACTION_CANCEL_FLOW
|
|
17
19
|
from rasa.shared.core.domain import Domain
|
|
@@ -30,7 +32,8 @@ class CancelPatternFlowStackFrame(PatternFlowStackFrame):
|
|
|
30
32
|
"""A pattern flow stack frame which cancels a flow.
|
|
31
33
|
|
|
32
34
|
The frame contains the information about the stack frames that should
|
|
33
|
-
be canceled.
|
|
35
|
+
be canceled.
|
|
36
|
+
"""
|
|
34
37
|
|
|
35
38
|
flow_id: str = FLOW_PATTERN_CANCEL
|
|
36
39
|
"""The ID of the flow."""
|
|
@@ -93,19 +96,37 @@ class ActionCancelFlow(action.Action):
|
|
|
93
96
|
structlogger.warning("action.cancel_flow.no_cancel_frame")
|
|
94
97
|
return []
|
|
95
98
|
|
|
99
|
+
agent_frame_ids_to_cancel = []
|
|
96
100
|
for canceled_frame_id in top.canceled_frames:
|
|
97
101
|
for frame in stack.frames:
|
|
98
102
|
if frame.frame_id == canceled_frame_id and isinstance(
|
|
99
103
|
frame, BaseFlowStackFrame
|
|
100
104
|
):
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
+
if isinstance(frame, AgentStackFrame):
|
|
106
|
+
# When an AgentStackFrame needs to be canceled, we can
|
|
107
|
+
# remove it directly from the stack. No extra logic is
|
|
108
|
+
# required in the flow executor, since
|
|
109
|
+
# the AgentCanceled event has already been created by
|
|
110
|
+
# ActionCancelInterruptedFlows or CancelFlowCommand, and the
|
|
111
|
+
# steps following the agentic call step should not be executed.
|
|
112
|
+
agent_frame_ids_to_cancel.append(frame.frame_id)
|
|
113
|
+
break
|
|
114
|
+
else:
|
|
115
|
+
# Setting the stack frame to the end step so it is
|
|
116
|
+
# properly wrapped up by the flow policy
|
|
117
|
+
frame.step_id = ContinueFlowStep.continue_step_for_id(END_STEP)
|
|
118
|
+
break
|
|
105
119
|
else:
|
|
106
120
|
structlogger.warning(
|
|
107
121
|
"action.cancel_flow.frame_not_found",
|
|
108
122
|
frame_id=canceled_frame_id,
|
|
109
123
|
)
|
|
110
124
|
|
|
111
|
-
|
|
125
|
+
# Create a copy of the stack without the agentic frames that should
|
|
126
|
+
# be canceled
|
|
127
|
+
new_stack = DialogueStack.empty()
|
|
128
|
+
for frame in stack.frames:
|
|
129
|
+
if frame.frame_id not in agent_frame_ids_to_cancel:
|
|
130
|
+
new_stack.push(frame)
|
|
131
|
+
|
|
132
|
+
return tracker.create_stack_updated_events(new_stack)
|
|
@@ -61,19 +61,6 @@ class ActionClarifyFlows(action.Action):
|
|
|
61
61
|
"""Return the flow name."""
|
|
62
62
|
return ACTION_CLARIFY_FLOWS
|
|
63
63
|
|
|
64
|
-
@staticmethod
|
|
65
|
-
def assemble_options_string(names: List[str]) -> str:
|
|
66
|
-
"""Concatenate options to a human-readable string."""
|
|
67
|
-
clarification_message = ""
|
|
68
|
-
for i, name in enumerate(names):
|
|
69
|
-
if i == 0:
|
|
70
|
-
clarification_message += name
|
|
71
|
-
elif i == len(names) - 1:
|
|
72
|
-
clarification_message += f" or {name}"
|
|
73
|
-
else:
|
|
74
|
-
clarification_message += f", {name}"
|
|
75
|
-
return clarification_message
|
|
76
|
-
|
|
77
64
|
async def run(
|
|
78
65
|
self,
|
|
79
66
|
output_channel: "OutputChannel",
|
|
@@ -83,6 +70,8 @@ class ActionClarifyFlows(action.Action):
|
|
|
83
70
|
metadata: Optional[Dict[str, Any]] = None,
|
|
84
71
|
) -> List[Event]:
|
|
85
72
|
"""Correct the slots."""
|
|
73
|
+
from rasa.dialogue_understanding.utils import assemble_options_string
|
|
74
|
+
|
|
86
75
|
stack = tracker.stack
|
|
87
76
|
if not (top := stack.top()):
|
|
88
77
|
structlogger.warning("action.clarify_flows.no_active_flow")
|
|
@@ -92,7 +81,7 @@ class ActionClarifyFlows(action.Action):
|
|
|
92
81
|
structlogger.warning("action.clarify_flows.no_clarification_frame")
|
|
93
82
|
return []
|
|
94
83
|
|
|
95
|
-
options_string =
|
|
84
|
+
options_string = assemble_options_string(top.names, conjunction="or")
|
|
96
85
|
top.clarification_options = options_string
|
|
97
86
|
# since we modified the stack frame, we need to update the stack
|
|
98
87
|
return tracker.create_stack_updated_events(stack)
|