rasa-pro 3.14.0.dev20250825__py3-none-any.whl → 3.14.0.dev20250901__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/builder/README.md +120 -0
- rasa/builder/__init__.py +0 -0
- rasa/builder/auth.py +176 -0
- rasa/builder/config.py +91 -0
- rasa/builder/copilot/__init__.py +0 -0
- rasa/builder/copilot/constants.py +28 -0
- rasa/builder/copilot/copilot.py +376 -0
- rasa/builder/copilot/copilot_response_handler.py +522 -0
- rasa/builder/copilot/copilot_templated_message_provider.py +58 -0
- rasa/builder/copilot/exceptions.py +32 -0
- rasa/builder/copilot/models.py +464 -0
- rasa/builder/copilot/prompts/__init__.py +0 -0
- rasa/builder/copilot/prompts/copilot_system_prompt.jinja2 +771 -0
- rasa/builder/copilot/signing.py +305 -0
- rasa/builder/copilot/telemetry.py +200 -0
- rasa/builder/copilot/templated_messages/__init__.py +0 -0
- rasa/builder/copilot/templated_messages/copilot_internal_messages_templates.yml +16 -0
- rasa/builder/copilot/templated_messages/copilot_templated_responses.yml +38 -0
- rasa/builder/document_retrieval/__init__.py +0 -0
- rasa/builder/document_retrieval/constants.py +15 -0
- rasa/builder/document_retrieval/inkeep-rag-response-schema.json +64 -0
- rasa/builder/document_retrieval/inkeep_document_retrieval.py +238 -0
- rasa/builder/document_retrieval/models.py +62 -0
- rasa/builder/download.py +147 -0
- rasa/builder/exceptions.py +91 -0
- rasa/builder/guardrails/__init__.py +1 -0
- rasa/builder/guardrails/constants.py +9 -0
- rasa/builder/guardrails/exceptions.py +4 -0
- rasa/builder/guardrails/lakera.py +206 -0
- rasa/builder/guardrails/models.py +231 -0
- rasa/builder/guardrails/store.py +238 -0
- rasa/builder/guardrails/utils.py +328 -0
- rasa/builder/job_manager.py +87 -0
- rasa/builder/jobs.py +270 -0
- rasa/builder/llm_service.py +246 -0
- rasa/builder/logging_utils.py +265 -0
- rasa/builder/main.py +258 -0
- rasa/builder/models.py +216 -0
- rasa/builder/project_generator.py +462 -0
- rasa/builder/project_info.py +72 -0
- rasa/builder/scrape_rasa_docs.py +97 -0
- rasa/builder/service.py +1335 -0
- rasa/builder/shared/tracker_context.py +212 -0
- rasa/builder/skill_to_bot_prompt.jinja2 +164 -0
- rasa/builder/training_service.py +124 -0
- rasa/builder/validation_service.py +97 -0
- rasa/cli/project_templates/basic/actions/__init__ +0 -0
- rasa/cli/project_templates/basic/actions/action_human_handoff.py +40 -0
- rasa/cli/project_templates/basic/config.yml +27 -0
- rasa/cli/project_templates/basic/credentials.yml +33 -0
- rasa/cli/project_templates/basic/data/data.md +9 -0
- rasa/cli/project_templates/basic/data/general/feedback.yml +21 -0
- rasa/cli/project_templates/basic/data/general/goodbye.yml +6 -0
- rasa/cli/project_templates/basic/data/general/hello.yml +6 -0
- rasa/cli/project_templates/basic/data/general/help.yml +6 -0
- rasa/cli/project_templates/basic/data/general/human_handoff.yml +16 -0
- rasa/cli/project_templates/basic/data/general/show_faqs.yml +6 -0
- rasa/cli/project_templates/basic/data/system/patterns/pattern_cannot_handle.yml +7 -0
- rasa/cli/project_templates/basic/data/system/patterns/pattern_completed.yml +7 -0
- rasa/cli/project_templates/basic/data/system/patterns/pattern_correction.yml +7 -0
- rasa/cli/project_templates/basic/data/system/patterns/pattern_search.yml +8 -0
- rasa/cli/project_templates/basic/data/system/patterns/pattern_session_start.yml +8 -0
- rasa/cli/project_templates/basic/docs/docs.md +5 -0
- rasa/cli/project_templates/basic/docs/template.txt +28 -0
- rasa/cli/project_templates/basic/domain/domain.md +9 -0
- rasa/cli/project_templates/basic/domain/general/feedback.yml +25 -0
- rasa/cli/project_templates/basic/domain/general/goodbye.yml +9 -0
- rasa/cli/project_templates/basic/domain/general/hello.yml +7 -0
- rasa/cli/project_templates/basic/domain/general/help.yml +21 -0
- rasa/cli/project_templates/basic/domain/general/human_handoff.yml +32 -0
- rasa/cli/project_templates/basic/domain/general/show_faqs.yml +14 -0
- rasa/cli/project_templates/basic/domain/system/patterns/pattern_cannot_handle.yml +5 -0
- rasa/cli/project_templates/basic/domain/system/patterns/pattern_session_start.yml +19 -0
- rasa/cli/project_templates/basic/endpoints.yml +63 -0
- rasa/cli/project_templates/basic/prompts/rephraser_demo_personality_prompt.jinja2 +38 -0
- rasa/cli/project_templates/finance/actions/__init__.py +46 -0
- rasa/cli/project_templates/finance/actions/accounts/__init__.py +0 -0
- rasa/cli/project_templates/finance/actions/accounts/action_ask_account.py +47 -0
- rasa/cli/project_templates/finance/actions/accounts/action_check_balance.py +40 -0
- rasa/cli/project_templates/finance/actions/action_session_start.py +74 -0
- rasa/cli/project_templates/finance/actions/cards/__init__.py +0 -0
- rasa/cli/project_templates/finance/actions/cards/action_ask_card.py +48 -0
- rasa/cli/project_templates/finance/actions/cards/action_check_card_existence.py +36 -0
- rasa/cli/project_templates/finance/actions/cards/action_update_card_status.py +54 -0
- rasa/cli/project_templates/finance/actions/database.py +277 -0
- rasa/cli/project_templates/finance/actions/transfers/__init__.py +0 -0
- rasa/cli/project_templates/finance/actions/transfers/action_add_payee.py +52 -0
- rasa/cli/project_templates/finance/actions/transfers/action_ask_account_from.py +51 -0
- rasa/cli/project_templates/finance/actions/transfers/action_check_payee_existence.py +40 -0
- rasa/cli/project_templates/finance/actions/transfers/action_check_sufficient_funds.py +40 -0
- rasa/cli/project_templates/finance/actions/transfers/action_list_payees.py +46 -0
- rasa/cli/project_templates/finance/actions/transfers/action_process_immediate_payment.py +18 -0
- rasa/cli/project_templates/finance/actions/transfers/action_remove_payee.py +49 -0
- rasa/cli/project_templates/finance/actions/transfers/action_schedule_payment.py +19 -0
- rasa/cli/project_templates/finance/actions/transfers/action_validate_payment_date.py +36 -0
- rasa/cli/project_templates/finance/config.yml +21 -0
- rasa/cli/project_templates/finance/credentials.yml +32 -0
- rasa/cli/project_templates/finance/csvs/accounts.csv +8 -0
- rasa/cli/project_templates/finance/csvs/advisors.csv +7 -0
- rasa/cli/project_templates/finance/csvs/appointments.csv +211 -0
- rasa/cli/project_templates/finance/csvs/branches.csv +10 -0
- rasa/cli/project_templates/finance/csvs/cards.csv +11 -0
- rasa/cli/project_templates/finance/csvs/payees.csv +11 -0
- rasa/cli/project_templates/finance/csvs/transactions.csv +71 -0
- rasa/cli/project_templates/finance/csvs/users.csv +4 -0
- rasa/cli/project_templates/finance/data/accounts/check_balance.yml +10 -0
- rasa/cli/project_templates/finance/data/cards/block_card.yml +66 -0
- rasa/cli/project_templates/finance/data/cards/select_card.yml +12 -0
- rasa/cli/project_templates/finance/data/general/bot_identity.yml +6 -0
- rasa/cli/project_templates/finance/data/general/feedback.yml +20 -0
- rasa/cli/project_templates/finance/data/general/goodbye.yml +6 -0
- rasa/cli/project_templates/finance/data/general/hello.yml +7 -0
- rasa/cli/project_templates/finance/data/general/help.yml +9 -0
- rasa/cli/project_templates/finance/data/general/human_handoff.yml +16 -0
- rasa/cli/project_templates/finance/data/general/welcome.yml +9 -0
- rasa/cli/project_templates/finance/data/system/patterns/pattern_chitchat.yml +5 -0
- rasa/cli/project_templates/finance/data/system/patterns/pattern_completed.yml +7 -0
- rasa/cli/project_templates/finance/data/system/patterns/pattern_correction.yml +7 -0
- rasa/cli/project_templates/finance/data/system/patterns/pattern_search.yml +8 -0
- rasa/cli/project_templates/finance/data/system/patterns/pattern_session_start.yml +8 -0
- rasa/cli/project_templates/finance/data/system/source/accounts.json +51 -0
- rasa/cli/project_templates/finance/data/system/source/advisors.json +44 -0
- rasa/cli/project_templates/finance/data/system/source/appointments.json +1474 -0
- rasa/cli/project_templates/finance/data/system/source/branches.json +47 -0
- rasa/cli/project_templates/finance/data/system/source/cards.json +72 -0
- rasa/cli/project_templates/finance/data/system/source/payees.json +74 -0
- rasa/cli/project_templates/finance/data/system/source/transactions.json +492 -0
- rasa/cli/project_templates/finance/data/system/source/users.json +29 -0
- rasa/cli/project_templates/finance/data/transfers/add_payee.yml +29 -0
- rasa/cli/project_templates/finance/data/transfers/list_payees.yml +5 -0
- rasa/cli/project_templates/finance/data/transfers/remove_payee.yml +21 -0
- rasa/cli/project_templates/finance/data/transfers/transfer_money.yml +67 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/consequences_of_blocking_card.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/reasons_to_block_card.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/recovering_from_card_fraud.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/tips_for_card_security.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/what_to_do_if_card_is_lost.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/account_balance_security.txt +7 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/common_balance_inquiries.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/methods_to_check_balance.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/understanding_balance_updates.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/what_to_do_if_balance_is_incorrect.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/benefits_of_authorised_payees.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/common_issues_with_payees.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/general_payee_information.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/payee_management_tips.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/understanding_payee_types.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/common_transfer_errors.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/fees_for_transfers.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/general_transfer_information.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/security_tips_for_transfers.txt +8 -0
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/transfer_processing_times.txt +8 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part1.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part10.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part11.txt +48 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part12.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part13.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part14.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part15.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part16.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part17.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part18.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part19.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part2.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part20.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part21.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part22.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part23.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part24.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part25.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part26.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part27.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part28.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part29.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part3.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part30.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part31.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part32.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part33.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part34.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part35.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part36.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part37.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part38.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part39.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part4.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part40.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part41.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part42.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part43.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part44.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part45.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part46.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part47.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part48.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part49.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part5.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part50.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part51.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part52.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part53.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part54.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part55.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part56.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part57.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part58.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part59.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part6.txt +47 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part60.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part61.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part7.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part8.txt +50 -0
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part9.txt +47 -0
- rasa/cli/project_templates/finance/domain/accounts/check_balance.yml +11 -0
- rasa/cli/project_templates/finance/domain/cards/block_card.yml +101 -0
- rasa/cli/project_templates/finance/domain/cards/select_card.yml +12 -0
- rasa/cli/project_templates/finance/domain/general/assistant_details.yml +12 -0
- rasa/cli/project_templates/finance/domain/general/bot_identity.yml +5 -0
- rasa/cli/project_templates/finance/domain/general/cannot_handle.yml +5 -0
- rasa/cli/project_templates/finance/domain/general/defaults.yml +24 -0
- rasa/cli/project_templates/finance/domain/general/feedback.yml +28 -0
- rasa/cli/project_templates/finance/domain/general/goodbye.yml +7 -0
- rasa/cli/project_templates/finance/domain/general/help.yml +5 -0
- rasa/cli/project_templates/finance/domain/general/human_handoff.yml +30 -0
- rasa/cli/project_templates/finance/domain/general/utils.yml +13 -0
- rasa/cli/project_templates/finance/domain/general/welcome.yml +8 -0
- rasa/cli/project_templates/finance/domain/transfers/add_payee.yml +47 -0
- rasa/cli/project_templates/finance/domain/transfers/list_payees.yml +4 -0
- rasa/cli/project_templates/finance/domain/transfers/remove_payee.yml +16 -0
- rasa/cli/project_templates/finance/domain/transfers/transfer_money.yml +79 -0
- rasa/cli/project_templates/finance/endpoints.yml +63 -0
- rasa/cli/project_templates/finance/prompts/rephraser_demo_personality_prompt.jinja2 +19 -0
- rasa/cli/project_templates/telco/actions/__init__.py +0 -0
- rasa/cli/project_templates/telco/actions/billing/__init__.py +0 -0
- rasa/cli/project_templates/telco/actions/billing/actions_billing.py +204 -0
- rasa/cli/project_templates/telco/actions/general/__init__.py +0 -0
- rasa/cli/project_templates/telco/actions/general/action_human_handoff.py +49 -0
- rasa/cli/project_templates/telco/actions/network/__init__.py +0 -0
- rasa/cli/project_templates/telco/actions/network/actions_get_data_from_db.py +48 -0
- rasa/cli/project_templates/telco/actions/network/actions_run_diagnostics.py +28 -0
- rasa/cli/project_templates/telco/actions/network/actions_session_start.py +18 -0
- rasa/cli/project_templates/telco/config.yml +27 -0
- rasa/cli/project_templates/telco/credentials.yml +33 -0
- rasa/cli/project_templates/telco/csvs/billing.csv +19 -0
- rasa/cli/project_templates/telco/csvs/customers.csv +5 -0
- rasa/cli/project_templates/telco/data/billing/flow_understand_bill.yml +45 -0
- rasa/cli/project_templates/telco/data/general/bot_challenge.yml +6 -0
- rasa/cli/project_templates/telco/data/general/feedback.yml +20 -0
- rasa/cli/project_templates/telco/data/general/goodbye.yml +6 -0
- rasa/cli/project_templates/telco/data/general/hello.yml +6 -0
- rasa/cli/project_templates/telco/data/general/human_handoff.yml +16 -0
- rasa/cli/project_templates/telco/data/general/patterns.yml +30 -0
- rasa/cli/project_templates/telco/data/network/flow_reboot_router.yml +8 -0
- rasa/cli/project_templates/telco/data/network/flow_reset_router.yml +7 -0
- rasa/cli/project_templates/telco/data/network/flow_solve_internet_issue.yml +73 -0
- rasa/cli/project_templates/telco/docs/docs.md +5 -0
- rasa/cli/project_templates/telco/docs/network/reset_vs_rboot_router.txt +1 -0
- rasa/cli/project_templates/telco/docs/network/restart_router.txt +6 -0
- rasa/cli/project_templates/telco/docs/network/run_speed_test.txt +6 -0
- rasa/cli/project_templates/telco/domain/billing/domain_undertand_bill.yml +102 -0
- rasa/cli/project_templates/telco/domain/general/bot_challenge.yml +4 -0
- rasa/cli/project_templates/telco/domain/general/feedback.yml +25 -0
- rasa/cli/project_templates/telco/domain/general/goodbye.yml +7 -0
- rasa/cli/project_templates/telco/domain/general/hello.yml +5 -0
- rasa/cli/project_templates/telco/domain/general/human_handoff.yml +29 -0
- rasa/cli/project_templates/telco/domain/general/patterns.yml +33 -0
- rasa/cli/project_templates/telco/domain/network/domain_reboot_router.yml +21 -0
- rasa/cli/project_templates/telco/domain/network/domain_reset_router.yml +12 -0
- rasa/cli/project_templates/telco/domain/network/domain_run_speed_test.yml +25 -0
- rasa/cli/project_templates/telco/domain/network/domain_solve_internet_issue.yml +75 -0
- rasa/cli/project_templates/telco/domain/shared.yml +129 -0
- rasa/cli/project_templates/telco/endpoints.yml +63 -0
- rasa/cli/project_templates/telco/prompts/rephraser_demo_personality_prompt.jinja2 +40 -0
- rasa/cli/project_templates/tutorial/config.yml +2 -1
- rasa/cli/scaffold.py +46 -2
- rasa/core/actions/action.py +0 -1
- rasa/core/channels/inspector/dist/assets/{arc-1ddec37b.js → arc-18042c22.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{blockDiagram-38ab4fdb-18af387c.js → blockDiagram-38ab4fdb-fdd6bcfa.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{c4Diagram-3d4e48cf-250127a3.js → c4Diagram-3d4e48cf-f5ae6786.js} +1 -1
- rasa/core/channels/inspector/dist/assets/channel-b9b536fc.js +1 -0
- rasa/core/channels/inspector/dist/assets/{classDiagram-70f12bd4-c3388b34.js → classDiagram-70f12bd4-81efba3e.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{classDiagram-v2-f2320105-9c893a82.js → classDiagram-v2-f2320105-3b6b6a92.js} +1 -1
- rasa/core/channels/inspector/dist/assets/clone-78d2ddcf.js +1 -0
- rasa/core/channels/inspector/dist/assets/{createText-2e5e7dd3-c111213b.js → createText-2e5e7dd3-31422447.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{edges-e0da2a9e-812a729d.js → edges-e0da2a9e-518a90db.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{erDiagram-9861fffd-fd5051bc.js → erDiagram-9861fffd-a6d3c25a.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{flowDb-956e92f1-3287ac02.js → flowDb-956e92f1-e048c2be.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{flowDiagram-66a62f08-692fb0b2.js → flowDiagram-66a62f08-c7474c91.js} +1 -1
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-96b9c2cf-8b09c060.js +1 -0
- rasa/core/channels/inspector/dist/assets/{flowchart-elk-definition-4a651766-008376f1.js → flowchart-elk-definition-4a651766-cb4d8723.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{ganttDiagram-c361ad54-df330a69.js → ganttDiagram-c361ad54-346636a2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{gitGraphDiagram-72cf32ee-e03676fb.js → gitGraphDiagram-72cf32ee-7c508874.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{graph-46fad2ba.js → graph-14702d8a.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{index-3862675e-a484ac55.js → index-3862675e-f18b534b.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{index-a003633f.js → index-4d4bdf3a.js} +231 -231
- rasa/core/channels/inspector/dist/assets/{infoDiagram-f8f76790-3f9e6ec2.js → infoDiagram-f8f76790-64154b83.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{journeyDiagram-49397b02-79f72383.js → journeyDiagram-49397b02-833a5f95.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{layout-aad098e5.js → layout-5a3b2123.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{line-219ab7ae.js → line-2272a8c7.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{linear-2cddbe62.js → linear-35bcf273.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{mindmap-definition-fc14e90a-1d41ed99.js → mindmap-definition-fc14e90a-92dcb0e9.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{pieDiagram-8a3498a8-cc496ee8.js → pieDiagram-8a3498a8-94dbc900.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{quadrantDiagram-120e2f19-84d32884.js → quadrantDiagram-120e2f19-8b7a9c33.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{requirementDiagram-deff3bca-c0deb984.js → requirementDiagram-deff3bca-6f7eab81.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{sankeyDiagram-04a897e0-b9d7fd62.js → sankeyDiagram-04a897e0-f43e581d.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{sequenceDiagram-704730f1-7d517565.js → sequenceDiagram-704730f1-0bcbefc3.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{stateDiagram-587899a1-98ef9b27.js → stateDiagram-587899a1-b8a74083.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{stateDiagram-v2-d93cdb3a-cee70748.js → stateDiagram-v2-d93cdb3a-2070218f.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-6aaf32cf-3f9d1c96.js → styles-6aaf32cf-f1d54e34.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-9a916d00-67471923.js → styles-9a916d00-980de489.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-c10674c1-bd093fb7.js → styles-c10674c1-3c03abde.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{svgDrawCommon-08f97a94-675794e8.js → svgDrawCommon-08f97a94-46ba068f.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{timeline-definition-85554ec2-0ac67617.js → timeline-definition-85554ec2-901f5e3d.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{xychartDiagram-e933f94c-c018dc37.js → xychartDiagram-e933f94c-acbc628a.js} +1 -1
- rasa/core/channels/inspector/dist/index.html +2 -2
- rasa/core/channels/inspector/index.html +1 -1
- rasa/core/channels/inspector/src/App.tsx +10 -11
- rasa/core/channels/inspector/src/components/DialogueInformation.tsx +12 -3
- rasa/core/channels/studio_chat.py +25 -7
- rasa/core/policies/enterprise_search_policy.py +4 -7
- rasa/core/policies/flows/flow_executor.py +8 -1
- rasa/dialogue_understanding/generator/flow_retrieval.py +10 -9
- rasa/engine/storage/local_model_storage.py +45 -2
- rasa/model_manager/model_api.py +1 -2
- rasa/model_manager/runner_service.py +1 -1
- rasa/model_manager/trainer_service.py +12 -9
- rasa/model_manager/utils.py +1 -29
- rasa/shared/core/domain.py +62 -15
- rasa/shared/core/flows/flow_step.py +7 -1
- rasa/shared/core/flows/steps/call.py +8 -1
- rasa/shared/core/flows/yaml_flows_io.py +16 -8
- rasa/shared/core/slots.py +4 -0
- rasa/shared/importers/importer.py +6 -0
- rasa/shared/importers/utils.py +77 -1
- rasa/studio/upload.py +12 -46
- rasa/telemetry.py +97 -23
- rasa/utils/io.py +27 -9
- rasa/utils/json_utils.py +6 -1
- rasa/utils/log_utils.py +5 -1
- rasa/utils/openapi.py +144 -0
- rasa/validator.py +7 -3
- rasa/version.py +1 -1
- {rasa_pro-3.14.0.dev20250825.dist-info → rasa_pro-3.14.0.dev20250901.dist-info}/METADATA +9 -10
- {rasa_pro-3.14.0.dev20250825.dist-info → rasa_pro-3.14.0.dev20250901.dist-info}/RECORD +347 -73
- rasa/core/channels/inspector/dist/assets/channel-59f6d54b.js +0 -1
- rasa/core/channels/inspector/dist/assets/clone-26177ddb.js +0 -1
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-96b9c2cf-29c03f5a.js +0 -1
- {rasa_pro-3.14.0.dev20250825.dist-info → rasa_pro-3.14.0.dev20250901.dist-info}/NOTICE +0 -0
- {rasa_pro-3.14.0.dev20250825.dist-info → rasa_pro-3.14.0.dev20250901.dist-info}/WHEEL +0 -0
- {rasa_pro-3.14.0.dev20250825.dist-info → rasa_pro-3.14.0.dev20250901.dist-info}/entry_points.txt +0 -0
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
import base64
|
|
2
|
+
import hashlib
|
|
3
|
+
import hmac
|
|
4
|
+
import json
|
|
5
|
+
from typing import Any, List, Optional, Tuple
|
|
6
|
+
|
|
7
|
+
import structlog
|
|
8
|
+
|
|
9
|
+
from rasa.builder import config
|
|
10
|
+
from rasa.builder.copilot.constants import ROLE_COPILOT, ROLE_USER, SIGNATURE_VERSION_V1
|
|
11
|
+
from rasa.builder.copilot.copilot_response_handler import CopilotResponseHandler
|
|
12
|
+
from rasa.builder.copilot.exceptions import (
|
|
13
|
+
InvalidCopilotChatHistorySignature,
|
|
14
|
+
MissingCopilotChatHistorySignature,
|
|
15
|
+
)
|
|
16
|
+
from rasa.builder.copilot.models import (
|
|
17
|
+
CopilotChatMessage,
|
|
18
|
+
CopilotRequest,
|
|
19
|
+
GeneratedContent,
|
|
20
|
+
ResponseCategory,
|
|
21
|
+
ResponseCompleteness,
|
|
22
|
+
ServerSentEvent,
|
|
23
|
+
SigningContext,
|
|
24
|
+
TextContent,
|
|
25
|
+
)
|
|
26
|
+
|
|
27
|
+
structlogger = structlog.get_logger()
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
def _b64url_no_pad(bytes_to_convert: bytes) -> str:
|
|
31
|
+
"""Convert bytes to a base64 URL-safe string without padding.
|
|
32
|
+
|
|
33
|
+
Args:
|
|
34
|
+
bytes_to_convert: Bytes to convert.
|
|
35
|
+
|
|
36
|
+
Returns:
|
|
37
|
+
str: Base64 URL-safe encoded string without padding.
|
|
38
|
+
"""
|
|
39
|
+
return base64.urlsafe_b64encode(bytes_to_convert).rstrip(b"=").decode("ascii")
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
def _canonicalize_messages(messages: List[CopilotChatMessage]) -> bytes:
|
|
43
|
+
"""Canonicalize messages to a deterministic JSON format suitable for signing.
|
|
44
|
+
|
|
45
|
+
Args:
|
|
46
|
+
messages: List of CopilotChatMessage objects to normalize.
|
|
47
|
+
|
|
48
|
+
Returns:
|
|
49
|
+
bytes: Canonicalized JSON string of messages.
|
|
50
|
+
"""
|
|
51
|
+
canonical: List[dict] = []
|
|
52
|
+
|
|
53
|
+
for message in messages:
|
|
54
|
+
# Preserve internal roles exactly as sent by the client (e.g. "user",
|
|
55
|
+
# "copilot", or any future internal roles) and keep structured content blocks.
|
|
56
|
+
message_dict = message.model_dump(
|
|
57
|
+
include={"role", "content"}, exclude_none=True
|
|
58
|
+
)
|
|
59
|
+
|
|
60
|
+
role = message_dict.get("role", "")
|
|
61
|
+
content = message_dict.get("content", [])
|
|
62
|
+
|
|
63
|
+
canonical.append({"role": role, "content": content})
|
|
64
|
+
|
|
65
|
+
# Dump to JSON with consistent formatting
|
|
66
|
+
return json.dumps(
|
|
67
|
+
canonical,
|
|
68
|
+
ensure_ascii=False,
|
|
69
|
+
separators=(",", ":"),
|
|
70
|
+
sort_keys=True,
|
|
71
|
+
).encode("utf-8")
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
def compute_history_signature(
|
|
75
|
+
messages: List[CopilotChatMessage],
|
|
76
|
+
session_id: str,
|
|
77
|
+
secret: str,
|
|
78
|
+
version: str = SIGNATURE_VERSION_V1,
|
|
79
|
+
) -> str:
|
|
80
|
+
"""Compute a signature for the chat history messages.
|
|
81
|
+
|
|
82
|
+
Args:
|
|
83
|
+
messages: List of CopilotChatMessage objects representing the chat history.
|
|
84
|
+
session_id: Unique identifier for the session.
|
|
85
|
+
secret: Secret key used for signing.
|
|
86
|
+
version: Version of the signature format (default is SIGNATURE_VERSION_V1).
|
|
87
|
+
|
|
88
|
+
Returns:
|
|
89
|
+
str: Base64 URL-safe encoded signature.
|
|
90
|
+
"""
|
|
91
|
+
canonical = _canonicalize_messages(messages)
|
|
92
|
+
mac_input = (
|
|
93
|
+
version.encode("utf-8")
|
|
94
|
+
+ b"\x00"
|
|
95
|
+
+ session_id.encode("utf-8")
|
|
96
|
+
+ b"\x00"
|
|
97
|
+
+ canonical
|
|
98
|
+
)
|
|
99
|
+
digest = hmac.new(
|
|
100
|
+
key=secret.encode("utf-8"), msg=mac_input, digestmod=hashlib.sha256
|
|
101
|
+
).digest()
|
|
102
|
+
signature = _b64url_no_pad(digest)
|
|
103
|
+
return signature
|
|
104
|
+
|
|
105
|
+
|
|
106
|
+
def verify_history_signature(
|
|
107
|
+
history_signature: str,
|
|
108
|
+
messages: List[CopilotChatMessage],
|
|
109
|
+
session_id: str,
|
|
110
|
+
secret: str,
|
|
111
|
+
version: Optional[str],
|
|
112
|
+
) -> bool:
|
|
113
|
+
"""Verify the history signature against the provided messages and session ID.
|
|
114
|
+
|
|
115
|
+
Args:
|
|
116
|
+
history_signature: Base64 URL-safe encoded signature to verify.
|
|
117
|
+
messages: List of CopilotChatMessage objects representing the chat history.
|
|
118
|
+
session_id: Unique identifier for the session.
|
|
119
|
+
secret: Secret key used for signing.
|
|
120
|
+
version: Version of the signature format (default is SIGNATURE_VERSION_V1).
|
|
121
|
+
|
|
122
|
+
Returns:
|
|
123
|
+
bool: True if the signature is valid, False otherwise.
|
|
124
|
+
"""
|
|
125
|
+
version = version or SIGNATURE_VERSION_V1
|
|
126
|
+
expected_signature = compute_history_signature(
|
|
127
|
+
messages=messages, session_id=session_id, secret=secret, version=version
|
|
128
|
+
)
|
|
129
|
+
return hmac.compare_digest(expected_signature, history_signature)
|
|
130
|
+
|
|
131
|
+
|
|
132
|
+
def _signing_context() -> Optional[SigningContext]:
|
|
133
|
+
"""Get the signing context for history signatures.
|
|
134
|
+
|
|
135
|
+
Returns:
|
|
136
|
+
SigningContext if a secret is present, otherwise None.
|
|
137
|
+
"""
|
|
138
|
+
if not (secret := config.COPILOT_HISTORY_SIGNING_SECRET):
|
|
139
|
+
return None
|
|
140
|
+
|
|
141
|
+
return SigningContext(
|
|
142
|
+
secret=secret,
|
|
143
|
+
default_version=SIGNATURE_VERSION_V1,
|
|
144
|
+
)
|
|
145
|
+
|
|
146
|
+
|
|
147
|
+
async def verify_signature(req: CopilotRequest) -> bool:
|
|
148
|
+
"""Verify the history signature for a request.
|
|
149
|
+
|
|
150
|
+
Args:
|
|
151
|
+
req: Request object containing copilot chat history and session ID.
|
|
152
|
+
|
|
153
|
+
Returns:
|
|
154
|
+
True if verification passes.
|
|
155
|
+
|
|
156
|
+
Raises:
|
|
157
|
+
InvalidCopilotChatHistorySignature: when the provided signature doesn't match.
|
|
158
|
+
MissingCopilotChatHistorySignature: when a required signature is missing.
|
|
159
|
+
"""
|
|
160
|
+
context = _signing_context()
|
|
161
|
+
|
|
162
|
+
# If no server-side secret, signature verification is not enforced
|
|
163
|
+
if context is None:
|
|
164
|
+
return True
|
|
165
|
+
|
|
166
|
+
# If the client didn't opt in by providing the signature version, skip verification
|
|
167
|
+
if not (signature_version := getattr(req, "signature_version", None)):
|
|
168
|
+
return True
|
|
169
|
+
|
|
170
|
+
# Allow missing signature on first user turn
|
|
171
|
+
user_message_count = sum(
|
|
172
|
+
1 for m in req.copilot_chat_history if getattr(m, "role", None) == ROLE_USER
|
|
173
|
+
)
|
|
174
|
+
allow_missing = user_message_count <= 1
|
|
175
|
+
version = signature_version or context.default_version
|
|
176
|
+
|
|
177
|
+
history_signature = getattr(req, "history_signature", None)
|
|
178
|
+
if history_signature and context.secret:
|
|
179
|
+
# We generate the signature against the conversation history,
|
|
180
|
+
# excluding the user message if it's the last one in the list
|
|
181
|
+
messages = req.copilot_chat_history
|
|
182
|
+
if user_message_count and req.copilot_chat_history[-1].role == ROLE_USER:
|
|
183
|
+
messages = req.copilot_chat_history[:-1]
|
|
184
|
+
|
|
185
|
+
is_valid = verify_history_signature(
|
|
186
|
+
history_signature=history_signature,
|
|
187
|
+
messages=messages,
|
|
188
|
+
session_id=req.session_id,
|
|
189
|
+
secret=context.secret,
|
|
190
|
+
version=version,
|
|
191
|
+
)
|
|
192
|
+
if not is_valid:
|
|
193
|
+
structlogger.error(
|
|
194
|
+
"copilot.signing.invalid_history_signature",
|
|
195
|
+
version=version,
|
|
196
|
+
session_id=req.session_id,
|
|
197
|
+
)
|
|
198
|
+
raise InvalidCopilotChatHistorySignature("invalid_history_signature")
|
|
199
|
+
return True
|
|
200
|
+
|
|
201
|
+
# Client opted in and this is not the first turn → signature is required
|
|
202
|
+
if not allow_missing:
|
|
203
|
+
structlogger.error(
|
|
204
|
+
"copilot.signing.missing_history_signature",
|
|
205
|
+
version=version,
|
|
206
|
+
session_id=req.session_id,
|
|
207
|
+
)
|
|
208
|
+
raise MissingCopilotChatHistorySignature("missing_history_signature")
|
|
209
|
+
|
|
210
|
+
# Soft mode for first turn without signature
|
|
211
|
+
return True
|
|
212
|
+
|
|
213
|
+
|
|
214
|
+
async def create_signature_envelope_for_text(
|
|
215
|
+
req: CopilotRequest,
|
|
216
|
+
text: str,
|
|
217
|
+
category: ResponseCategory,
|
|
218
|
+
) -> Optional[ServerSentEvent]:
|
|
219
|
+
"""Create a signature SSE envelope for the assistant message.
|
|
220
|
+
|
|
221
|
+
Args:
|
|
222
|
+
req: Request object containing copilot chat history and session ID.
|
|
223
|
+
text: Text content of the assistant message.
|
|
224
|
+
category: Response category of the assistant message.
|
|
225
|
+
|
|
226
|
+
Returns:
|
|
227
|
+
Optional[ServerSentEvent]: SSE envelope with signature data or None if
|
|
228
|
+
signing is not applicable.
|
|
229
|
+
"""
|
|
230
|
+
context = _signing_context()
|
|
231
|
+
|
|
232
|
+
# If no server-side secret, signature verification is not enforced
|
|
233
|
+
if context is None:
|
|
234
|
+
return None
|
|
235
|
+
|
|
236
|
+
if not getattr(req, "signature_version", None):
|
|
237
|
+
return None
|
|
238
|
+
|
|
239
|
+
assistant_message = CopilotChatMessage(
|
|
240
|
+
role=ROLE_COPILOT,
|
|
241
|
+
content=[TextContent(type="text", text=text)],
|
|
242
|
+
response_category=category,
|
|
243
|
+
)
|
|
244
|
+
next_history = [*req.copilot_chat_history, assistant_message]
|
|
245
|
+
version = getattr(req, "signature_version", None) or context.default_version
|
|
246
|
+
signature = compute_history_signature(
|
|
247
|
+
messages=next_history,
|
|
248
|
+
session_id=req.session_id,
|
|
249
|
+
secret=context.secret,
|
|
250
|
+
version=version,
|
|
251
|
+
)
|
|
252
|
+
|
|
253
|
+
return ServerSentEvent(
|
|
254
|
+
event="copilot_response",
|
|
255
|
+
data={
|
|
256
|
+
"response_category": "signature",
|
|
257
|
+
"completeness": ResponseCompleteness.COMPLETE.value,
|
|
258
|
+
"version": version,
|
|
259
|
+
"signature": signature,
|
|
260
|
+
"assistant_message": assistant_message.model_dump(),
|
|
261
|
+
},
|
|
262
|
+
)
|
|
263
|
+
|
|
264
|
+
|
|
265
|
+
async def create_signature_envelope_for_handler(
|
|
266
|
+
req: CopilotRequest, handler: CopilotResponseHandler
|
|
267
|
+
) -> Optional[ServerSentEvent]:
|
|
268
|
+
"""Create a signature SSE envelope from the accumulated handler output.
|
|
269
|
+
|
|
270
|
+
Args:
|
|
271
|
+
req: Request object containing copilot chat history and session ID.
|
|
272
|
+
handler: The response handler containing generated responses.
|
|
273
|
+
|
|
274
|
+
Returns:
|
|
275
|
+
Optional[ServerSentEvent]: SSE envelope with signature data or None if
|
|
276
|
+
signing is not applicable.
|
|
277
|
+
"""
|
|
278
|
+
text, category = extract_full_text_and_category(handler)
|
|
279
|
+
return await create_signature_envelope_for_text(req, text, category)
|
|
280
|
+
|
|
281
|
+
|
|
282
|
+
def extract_full_text_and_category(handler: Any) -> Tuple[str, ResponseCategory]:
|
|
283
|
+
"""Extract full text and response category from the handler's generated responses.
|
|
284
|
+
|
|
285
|
+
Args:
|
|
286
|
+
handler: The response handler containing generated responses.
|
|
287
|
+
|
|
288
|
+
Returns:
|
|
289
|
+
Tuple[str, ResponseCategory]: Concatenated text and the last response category.
|
|
290
|
+
"""
|
|
291
|
+
text_parts: List[str] = []
|
|
292
|
+
last_category: Optional[ResponseCategory] = None
|
|
293
|
+
|
|
294
|
+
for response in getattr(handler, "generated_responses", []) or []:
|
|
295
|
+
content = getattr(response, "content", None)
|
|
296
|
+
if isinstance(response, GeneratedContent) and content:
|
|
297
|
+
text_parts.append(content)
|
|
298
|
+
category = getattr(response, "response_category", None)
|
|
299
|
+
if category and category not in {
|
|
300
|
+
ResponseCategory.REFERENCE,
|
|
301
|
+
ResponseCategory.REFERENCE_ENTRY,
|
|
302
|
+
}:
|
|
303
|
+
last_category = category
|
|
304
|
+
|
|
305
|
+
return "".join(text_parts), (last_category or ResponseCategory.COPILOT)
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
import datetime as dt
|
|
2
|
+
import os
|
|
3
|
+
import uuid
|
|
4
|
+
from typing import Iterable, Optional, Sequence
|
|
5
|
+
|
|
6
|
+
import structlog
|
|
7
|
+
|
|
8
|
+
from rasa import telemetry
|
|
9
|
+
from rasa.builder.copilot.constants import COPILOT_SEGMENT_WRITE_KEY_ENV_VAR
|
|
10
|
+
from rasa.builder.copilot.copilot_response_handler import CopilotResponseHandler
|
|
11
|
+
from rasa.builder.document_retrieval.models import Document
|
|
12
|
+
from rasa.telemetry import (
|
|
13
|
+
SEGMENT_TRACK_ENDPOINT,
|
|
14
|
+
segment_request_payload,
|
|
15
|
+
send_segment_request,
|
|
16
|
+
with_default_context_fields,
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
structlogger = structlog.get_logger()
|
|
20
|
+
|
|
21
|
+
COPILOT_USER_MESSAGE_EVENT = "copilot_user_message"
|
|
22
|
+
COPILOT_BOT_MESSAGE_EVENT = "copilot_bot_message"
|
|
23
|
+
|
|
24
|
+
COPILOT_SEGMENT_WRITE_KEY = os.getenv(COPILOT_SEGMENT_WRITE_KEY_ENV_VAR)
|
|
25
|
+
if _SEGMENT_ON := bool(COPILOT_SEGMENT_WRITE_KEY):
|
|
26
|
+
structlogger.info("builder.telemetry.enabled")
|
|
27
|
+
else:
|
|
28
|
+
structlogger.warning("builder.telemetry.disabled")
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
def _track(event: str, user_id: str, properties: dict) -> None:
|
|
32
|
+
"""Track an event with Segment.
|
|
33
|
+
|
|
34
|
+
Args:
|
|
35
|
+
event: The name of the event to track.
|
|
36
|
+
user_id: The ID of the user associated with the event.
|
|
37
|
+
properties: Additional properties to include with the event.
|
|
38
|
+
|
|
39
|
+
Raises:
|
|
40
|
+
Exception: If tracking fails, an exception is logged.
|
|
41
|
+
"""
|
|
42
|
+
if not _SEGMENT_ON or not telemetry.is_telemetry_enabled():
|
|
43
|
+
structlogger.debug("builder.telemetry._track.disabled")
|
|
44
|
+
return
|
|
45
|
+
structlogger.debug("builder.telemetry._track.enabled")
|
|
46
|
+
|
|
47
|
+
try:
|
|
48
|
+
payload = segment_request_payload(
|
|
49
|
+
user_id, event, properties, context=with_default_context_fields()
|
|
50
|
+
)
|
|
51
|
+
structlogger.debug("builder.telemetry._track.sending", payload=payload)
|
|
52
|
+
|
|
53
|
+
send_segment_request(SEGMENT_TRACK_ENDPOINT, payload, COPILOT_SEGMENT_WRITE_KEY)
|
|
54
|
+
except Exception as e: # skipcq:PYL-W0703
|
|
55
|
+
structlogger.warning("builder.telemetry.track_failed", error=str(e))
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
class CopilotTelemetry:
|
|
59
|
+
def __init__(
|
|
60
|
+
self,
|
|
61
|
+
*,
|
|
62
|
+
project_id: str,
|
|
63
|
+
user_id: str,
|
|
64
|
+
) -> None:
|
|
65
|
+
"""Initialize Telemetry instance."""
|
|
66
|
+
self._project_id = project_id
|
|
67
|
+
self._user_id = user_id
|
|
68
|
+
# TODO Load prompt version
|
|
69
|
+
self._prompt_version = "1"
|
|
70
|
+
|
|
71
|
+
def log_user_turn(self, text: str) -> None:
|
|
72
|
+
"""Track a user message in the conversation.
|
|
73
|
+
|
|
74
|
+
Args:
|
|
75
|
+
text: The text of the user message.
|
|
76
|
+
"""
|
|
77
|
+
structlogger.debug("builder.telemetry.log_user_turn", text=text)
|
|
78
|
+
_track(
|
|
79
|
+
COPILOT_USER_MESSAGE_EVENT,
|
|
80
|
+
self._user_id,
|
|
81
|
+
{
|
|
82
|
+
"project_id": self._project_id,
|
|
83
|
+
"message_id": uuid.uuid4().hex,
|
|
84
|
+
"text": text,
|
|
85
|
+
"timestamp": dt.datetime.utcnow().isoformat(),
|
|
86
|
+
},
|
|
87
|
+
)
|
|
88
|
+
|
|
89
|
+
def log_copilot_turn(
|
|
90
|
+
self,
|
|
91
|
+
*,
|
|
92
|
+
text: str,
|
|
93
|
+
source_urls: Sequence[str],
|
|
94
|
+
flags: Iterable[str],
|
|
95
|
+
latency_ms: int,
|
|
96
|
+
model: str,
|
|
97
|
+
input_tokens: Optional[int] = None,
|
|
98
|
+
output_tokens: Optional[int] = None,
|
|
99
|
+
total_tokens: Optional[int] = None,
|
|
100
|
+
system_prompt: Optional[str] = None,
|
|
101
|
+
) -> None:
|
|
102
|
+
"""Track a copilot message in the conversation.
|
|
103
|
+
|
|
104
|
+
Args:
|
|
105
|
+
text: The text of the copilot message.
|
|
106
|
+
source_urls: URLs of the sources used to generate the response.
|
|
107
|
+
flags: Flags indicating special conditions or features.
|
|
108
|
+
latency_ms: End-to-end Copilot latency to produce this response.
|
|
109
|
+
model: The model used to generate the response.
|
|
110
|
+
input_tokens: Number of input tokens used (optional).
|
|
111
|
+
output_tokens: Number of output tokens generated (optional).
|
|
112
|
+
total_tokens: Total number of tokens used (input + output) (optional).
|
|
113
|
+
"""
|
|
114
|
+
structlogger.debug("builder.telemetry.log_copilot_turn", text=text)
|
|
115
|
+
_track(
|
|
116
|
+
COPILOT_BOT_MESSAGE_EVENT,
|
|
117
|
+
self._user_id,
|
|
118
|
+
{
|
|
119
|
+
"project_id": self._project_id,
|
|
120
|
+
"message_id": uuid.uuid4().hex,
|
|
121
|
+
"text": text,
|
|
122
|
+
"prompt_version": self._prompt_version,
|
|
123
|
+
"source_urls": list(source_urls),
|
|
124
|
+
"flags": list(flags),
|
|
125
|
+
"latency_ms": latency_ms,
|
|
126
|
+
"model": model,
|
|
127
|
+
"input_tokens": input_tokens,
|
|
128
|
+
"output_tokens": output_tokens,
|
|
129
|
+
"total_tokens": total_tokens,
|
|
130
|
+
"system_prompt": system_prompt,
|
|
131
|
+
"timestamp": dt.datetime.utcnow().isoformat(),
|
|
132
|
+
},
|
|
133
|
+
)
|
|
134
|
+
|
|
135
|
+
@staticmethod
|
|
136
|
+
def _extract_flags(handler: CopilotResponseHandler) -> list[str]:
|
|
137
|
+
"""Extract flags from the response handler.
|
|
138
|
+
|
|
139
|
+
Args:
|
|
140
|
+
handler: The response handler containing generated responses.
|
|
141
|
+
|
|
142
|
+
Returns:
|
|
143
|
+
A list of flags indicating special conditions or features.
|
|
144
|
+
"""
|
|
145
|
+
flags = {r.response_category.value for r in handler.generated_responses}
|
|
146
|
+
return sorted(flags)
|
|
147
|
+
|
|
148
|
+
@staticmethod
|
|
149
|
+
def _full_text(handler: CopilotResponseHandler) -> str:
|
|
150
|
+
"""Extract full text from the response handler.
|
|
151
|
+
|
|
152
|
+
Args:
|
|
153
|
+
handler: The response handler containing generated responses.
|
|
154
|
+
|
|
155
|
+
Returns:
|
|
156
|
+
The concatenated content of all generated responses.
|
|
157
|
+
"""
|
|
158
|
+
return "".join(
|
|
159
|
+
response.content
|
|
160
|
+
for response in handler.generated_responses
|
|
161
|
+
if getattr(response, "content", None)
|
|
162
|
+
)
|
|
163
|
+
|
|
164
|
+
def log_copilot_from_handler(
|
|
165
|
+
self,
|
|
166
|
+
*,
|
|
167
|
+
handler: CopilotResponseHandler,
|
|
168
|
+
used_documents: list[Document],
|
|
169
|
+
latency_ms: int,
|
|
170
|
+
model: str,
|
|
171
|
+
prompt_tokens: int,
|
|
172
|
+
completion_tokens: int,
|
|
173
|
+
total_tokens: int,
|
|
174
|
+
system_prompt: str,
|
|
175
|
+
) -> None:
|
|
176
|
+
"""Log a copilot message from the response handler.
|
|
177
|
+
|
|
178
|
+
Args:
|
|
179
|
+
handler: The response handler containing generated responses.
|
|
180
|
+
used_documents: List of documents used as supporting evidence.
|
|
181
|
+
latency_ms: End-to-end Copilot latency to produce this response.
|
|
182
|
+
model: The model used to generate the response.
|
|
183
|
+
prompt_tokens: Number of input tokens used.
|
|
184
|
+
completion_tokens: Number of output tokens generated.
|
|
185
|
+
total_tokens: Total number of tokens used (input + output).
|
|
186
|
+
system_prompt: The system prompt used.
|
|
187
|
+
"""
|
|
188
|
+
structlogger.debug("builder.telemetry.log_copilot_from_handler")
|
|
189
|
+
text = self._full_text(handler)
|
|
190
|
+
self.log_copilot_turn(
|
|
191
|
+
text=text,
|
|
192
|
+
source_urls=[d.url for d in used_documents if d.url],
|
|
193
|
+
flags=self._extract_flags(handler),
|
|
194
|
+
latency_ms=latency_ms,
|
|
195
|
+
model=model,
|
|
196
|
+
input_tokens=prompt_tokens,
|
|
197
|
+
output_tokens=completion_tokens,
|
|
198
|
+
total_tokens=total_tokens,
|
|
199
|
+
system_prompt=system_prompt,
|
|
200
|
+
)
|
|
File without changes
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
# Templates for role ROLE_RASA_INTERNAL
|
|
2
|
+
# Note: Only 'training_error_log_analysis' and 'e2e_testing_error_log_analysis' are
|
|
3
|
+
# valid response categories for rasa internal messages for now.
|
|
4
|
+
# Future contexts can be added here + in ResponseCategory enumeration.
|
|
5
|
+
|
|
6
|
+
templates:
|
|
7
|
+
# Templated utterance when training fails.
|
|
8
|
+
training_error_log_analysis: |
|
|
9
|
+
The assistant training failed. Your task is to analyze provided error logs
|
|
10
|
+
and help me fix the issue.
|
|
11
|
+
|
|
12
|
+
# Templated utterance when e2e testing fails.
|
|
13
|
+
e2e_testing_error_log_analysis: |
|
|
14
|
+
The e2e testing failed. Your task is to analyze provided error from the E2E
|
|
15
|
+
test logs and help me fix the issue. Help me understand if the issue is within
|
|
16
|
+
the the E2E test or the assistant.
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
responses:
|
|
2
|
+
roleplay_response: |
|
|
3
|
+
Looks like we’ve slipped into chatting as if I were your bot. I’m here to help you
|
|
4
|
+
build and improve your Rasa agent, not to roleplay as it. If you'd like to test your
|
|
5
|
+
agent, add your message in the chat preview on the right. If you’re not sure what to
|
|
6
|
+
test, I can help you create a new skill or suggest a few example conversations to
|
|
7
|
+
try.
|
|
8
|
+
|
|
9
|
+
out_of_scope_response: |
|
|
10
|
+
I’m here to help you build and improve your Rasa chatbot. I can explain concepts,
|
|
11
|
+
walk you through changes, or debug things with you.
|
|
12
|
+
|
|
13
|
+
Do you want me to show you what your assistant can do right now, or help you add
|
|
14
|
+
something new?
|
|
15
|
+
|
|
16
|
+
error_fallback_response: |
|
|
17
|
+
Your project ran into an error, but I'm not sure what caused it. Take a look at the
|
|
18
|
+
logs for the full details.
|
|
19
|
+
|
|
20
|
+
guardrail_policy_violation_response: |
|
|
21
|
+
I’m here to help you with Rasa agent development in a safe and respectful
|
|
22
|
+
environment. I cannot assist with harmful content, inappropriate material, or
|
|
23
|
+
attempts to manipulate my responses. Continued attempts to use the system in this
|
|
24
|
+
way may result in project termination and account blocking.
|
|
25
|
+
|
|
26
|
+
copilot_redacted_message: "[Copilot response redacted for guardrails check.]"
|
|
27
|
+
|
|
28
|
+
knowledge_base_access_requested_response: |
|
|
29
|
+
At the moment I can't read your knowledge base directly, but you can browse the
|
|
30
|
+
available entries in the `/docs` folder in your code editor.
|
|
31
|
+
|
|
32
|
+
guardrail_blocked_user_response: |
|
|
33
|
+
Your Copilot access has been temporarily blocked due to repeated policy violations.
|
|
34
|
+
If you believe this is an error or would like to request a review, please reach out to support@rasa.com.
|
|
35
|
+
|
|
36
|
+
guardrail_blocked_project_response: |
|
|
37
|
+
Your Copilot access has been temporarily blocked due to repeated policy violations.
|
|
38
|
+
If you believe this is an error or would like to request a review, please reach out to support@rasa.com.
|
|
File without changes
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import importlib_resources
|
|
2
|
+
|
|
3
|
+
from rasa.constants import PACKAGE_NAME
|
|
4
|
+
|
|
5
|
+
INKEEP_API_KEY_ENV_VAR = "INKEEP_API_KEY"
|
|
6
|
+
|
|
7
|
+
INKEEP_RAG_RESPONSE_SCHEMA_PATH = str(
|
|
8
|
+
importlib_resources.files(PACKAGE_NAME)
|
|
9
|
+
.joinpath("builder")
|
|
10
|
+
.joinpath("document_retrieval")
|
|
11
|
+
.joinpath("inkeep-rag-response-schema.json")
|
|
12
|
+
)
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
INKEEP_DOCUMENT_RETRIEVAL_MODEL = "inkeep-rag"
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
3
|
+
"type": "object",
|
|
4
|
+
"properties": {
|
|
5
|
+
"content": {
|
|
6
|
+
"type": "array",
|
|
7
|
+
"items": {
|
|
8
|
+
"type": "object",
|
|
9
|
+
"properties": {
|
|
10
|
+
"type": {
|
|
11
|
+
"type": "string"
|
|
12
|
+
},
|
|
13
|
+
"source": {
|
|
14
|
+
"type": "object",
|
|
15
|
+
"properties": {
|
|
16
|
+
"content": {
|
|
17
|
+
"type": "array",
|
|
18
|
+
"items": {
|
|
19
|
+
"type": "object",
|
|
20
|
+
"properties": {
|
|
21
|
+
"type": {
|
|
22
|
+
"type": "string"
|
|
23
|
+
},
|
|
24
|
+
"media_type": {
|
|
25
|
+
"type": "string"
|
|
26
|
+
},
|
|
27
|
+
"text": {
|
|
28
|
+
"type": "string"
|
|
29
|
+
},
|
|
30
|
+
"data": {
|
|
31
|
+
"type": "string"
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
"type": {
|
|
37
|
+
"type": "string"
|
|
38
|
+
},
|
|
39
|
+
"media_type": {
|
|
40
|
+
"type": "string"
|
|
41
|
+
},
|
|
42
|
+
"data": {
|
|
43
|
+
"type": "string"
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
"title": {
|
|
48
|
+
"type": "string"
|
|
49
|
+
},
|
|
50
|
+
"context": {
|
|
51
|
+
"type": "string"
|
|
52
|
+
},
|
|
53
|
+
"record_type": {
|
|
54
|
+
"type": "string"
|
|
55
|
+
},
|
|
56
|
+
"url": {
|
|
57
|
+
"type": "string"
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
"required": ["content"]
|
|
64
|
+
}
|