rasa-pro 3.14.0a16__py3-none-any.whl β 3.14.0a18__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/copilot/prompts/copilot_system_prompt.jinja2 +156 -105
- rasa/builder/copilot/telemetry.py +35 -19
- rasa/builder/jobs.py +15 -5
- rasa/builder/main.py +5 -14
- rasa/builder/models.py +7 -7
- rasa/builder/project_generator.py +130 -23
- rasa/builder/service.py +34 -18
- rasa/builder/template_cache.py +9 -184
- rasa/cli/project_templates/basic/README.md +23 -0
- rasa/cli/project_templates/basic/actions/actions.md +10 -0
- rasa/cli/project_templates/basic/config.yml +4 -4
- rasa/cli/project_templates/basic/data/data.md +5 -6
- rasa/cli/project_templates/basic/domain/domain.md +7 -5
- rasa/cli/project_templates/basic/domain/general/show_faqs.yml +1 -1
- rasa/cli/project_templates/basic/endpoints.yml +1 -1
- rasa/cli/project_templates/finance/README.md +26 -0
- rasa/cli/project_templates/finance/actions/__init__.py +0 -46
- rasa/cli/project_templates/finance/actions/accounts/check_balance.py +18 -0
- rasa/cli/project_templates/finance/actions/actions.md +15 -0
- rasa/cli/project_templates/finance/actions/{transfers/action_process_immediate_payment.py β cards/check_that_card_exists.py} +6 -3
- rasa/cli/project_templates/finance/actions/cards/list_cards.py +22 -0
- rasa/cli/project_templates/finance/actions/contacts/__init__.py +0 -0
- rasa/cli/project_templates/finance/actions/contacts/add_contact.py +30 -0
- rasa/cli/project_templates/finance/actions/contacts/list_contacts.py +22 -0
- rasa/cli/project_templates/finance/actions/contacts/remove_contact.py +35 -0
- rasa/cli/project_templates/finance/actions/db.py +117 -0
- rasa/cli/project_templates/finance/actions/transfers/check_transfer_funds.py +27 -0
- rasa/cli/project_templates/finance/actions/transfers/check_transfer_limit.py +36 -0
- rasa/cli/project_templates/finance/actions/transfers/execute_recurrent_payment.py +20 -0
- rasa/cli/project_templates/finance/actions/transfers/execute_transfer.py +45 -0
- rasa/cli/project_templates/finance/actions/transfers/list_transactions.py +32 -0
- rasa/cli/project_templates/finance/config.yml +6 -0
- rasa/cli/project_templates/finance/credentials.yml +7 -6
- rasa/cli/project_templates/finance/data/accounts/check_balance.yml +3 -4
- rasa/cli/project_templates/finance/data/accounts/download_statements.yml +26 -0
- rasa/cli/project_templates/finance/data/bills/bill_pay_reminder.yml +25 -0
- rasa/cli/project_templates/finance/data/cards/activate_card.yml +35 -0
- rasa/cli/project_templates/finance/data/cards/block_card.yml +37 -58
- rasa/cli/project_templates/finance/data/cards/list_cards.yml +14 -0
- rasa/cli/project_templates/finance/data/cards/replace_card.yml +16 -0
- rasa/cli/project_templates/finance/data/cards/replace_eligible_card.yml +29 -0
- rasa/cli/project_templates/finance/data/contacts/add_contact.yml +33 -0
- rasa/cli/project_templates/finance/data/contacts/list_contacts.yml +14 -0
- rasa/cli/project_templates/finance/data/contacts/remove_contact.yml +31 -0
- rasa/cli/project_templates/finance/data/data.md +14 -0
- rasa/cli/project_templates/finance/data/general/agent_details.yml +6 -0
- rasa/cli/project_templates/finance/data/general/hello.yml +1 -2
- rasa/cli/project_templates/finance/data/general/help.yml +2 -2
- rasa/cli/project_templates/finance/data/general/human_handoff.yml +1 -1
- rasa/cli/project_templates/finance/data/transfers/check_transfer_limit.yml +18 -0
- rasa/cli/project_templates/finance/data/transfers/list_transactions.yml +46 -0
- rasa/cli/project_templates/finance/data/transfers/move_money_between_accounts.yml +51 -0
- rasa/cli/project_templates/finance/data/transfers/transfer_money.yml +29 -62
- rasa/cli/project_templates/finance/data/transfers/transfer_money_to_a_third_party.yml +175 -0
- rasa/cli/project_templates/finance/db/cards.json +18 -0
- rasa/cli/project_templates/finance/db/contacts.json +10 -0
- rasa/cli/project_templates/finance/db/my_account.json +6 -0
- rasa/cli/project_templates/finance/db/transactions.json +22 -0
- rasa/cli/project_templates/finance/docs/docs.md +8 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/account_features/budgeting_analytics.txt +22 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/account_features/multi_currency_accounts.txt +19 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/account_features/premium_benefits.txt +19 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/card_management/contactless_limits.txt +16 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/card_management/freeze_unfreeze_card.txt +16 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/card_management/lost_stolen_card.txt +19 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/money_transfers/instant_payments.txt +19 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/money_transfers/international_transfers.txt +19 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/security_fraud/fraud_protection.txt +22 -0
- rasa/cli/project_templates/finance/docs/fenlo_banking_faq/security_fraud/secure_payments.txt +22 -0
- rasa/cli/project_templates/finance/domain/_system/patterns/pattern_session_start.yml +11 -0
- rasa/cli/project_templates/finance/domain/accounts/check_balance.yml +9 -5
- rasa/cli/project_templates/finance/domain/accounts/download_statements.yml +40 -0
- rasa/cli/project_templates/finance/domain/bills/bill_pay_reminder.yml +49 -0
- rasa/cli/project_templates/finance/domain/cards/activate_card.yml +24 -0
- rasa/cli/project_templates/finance/domain/cards/block_card.yml +33 -90
- rasa/cli/project_templates/finance/domain/cards/list_cards.yml +16 -0
- rasa/cli/project_templates/finance/domain/cards/replace_card.yml +43 -0
- rasa/cli/project_templates/finance/domain/cards/shared.yml +15 -0
- rasa/cli/project_templates/finance/domain/contacts/add_contact.yml +37 -0
- rasa/cli/project_templates/finance/domain/contacts/list_contacts.yml +16 -0
- rasa/cli/project_templates/finance/domain/contacts/remove_contact.yml +32 -0
- rasa/cli/project_templates/finance/domain/domain.md +18 -0
- rasa/cli/project_templates/finance/domain/general/_shared.yml +53 -0
- rasa/cli/project_templates/finance/domain/general/agent_details.yml +31 -0
- rasa/cli/project_templates/finance/domain/general/cannot_handle.yml +5 -2
- rasa/cli/project_templates/finance/domain/general/feedback.yml +0 -3
- rasa/cli/project_templates/finance/domain/general/human_handoff.yml +7 -3
- rasa/cli/project_templates/finance/domain/general/welcome.yml +5 -2
- rasa/cli/project_templates/finance/domain/transfers/check_transfer_limit.yml +32 -0
- rasa/cli/project_templates/finance/domain/transfers/list_transactions.yml +44 -0
- rasa/cli/project_templates/finance/domain/transfers/shared.yml +17 -0
- rasa/cli/project_templates/finance/domain/transfers/transfer_money.yml +203 -61
- rasa/cli/project_templates/finance/endpoints.yml +4 -3
- rasa/cli/project_templates/finance/prompts/rephraser_demo_personality_prompt.jinja2 +31 -12
- rasa/cli/project_templates/telco/README.md +25 -0
- rasa/cli/project_templates/telco/actions/actions.md +12 -0
- rasa/cli/project_templates/telco/config.yml +4 -4
- rasa/cli/project_templates/telco/data/data.md +11 -0
- rasa/cli/project_templates/telco/docs/docs.md +3 -0
- rasa/cli/project_templates/telco/domain/domain.md +13 -0
- rasa/cli/project_templates/telco/endpoints.yml +1 -1
- rasa/cli/project_templates/telco/prompts/rephraser_demo_personality_prompt.jinja2 +1 -1
- rasa/core/brokers/broker.py +1 -1
- rasa/core/brokers/kafka.py +52 -8
- rasa/core/channels/inspector/dist/assets/{arc-460861ce.js β arc-35222594.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{blockDiagram-38ab4fdb-16c993e0.js β blockDiagram-38ab4fdb-a0efbfd3.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{c4Diagram-3d4e48cf-488337d7.js β c4Diagram-3d4e48cf-0584c0f2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/channel-8e08bed9.js +1 -0
- rasa/core/channels/inspector/dist/assets/{classDiagram-70f12bd4-b08e53a8.js β classDiagram-70f12bd4-39f40dbe.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{classDiagram-v2-f2320105-b73f5a83.js β classDiagram-v2-f2320105-1ad755f3.js} +1 -1
- rasa/core/channels/inspector/dist/assets/clone-78c82dea.js +1 -0
- rasa/core/channels/inspector/dist/assets/{createText-2e5e7dd3-0210a219.js β createText-2e5e7dd3-b0f4f0fe.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{edges-e0da2a9e-28df7099.js β edges-e0da2a9e-9039bff9.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{erDiagram-9861fffd-9fbf4a58.js β erDiagram-9861fffd-65c9b127.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{flowDb-956e92f1-fa691f62.js β flowDb-956e92f1-4f08b38e.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{flowDiagram-66a62f08-ca907b67.js β flowDiagram-66a62f08-e95c362a.js} +1 -1
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-96b9c2cf-2b08f601.js +1 -0
- rasa/core/channels/inspector/dist/assets/{flowchart-elk-definition-4a651766-c10945f2.js β flowchart-elk-definition-4a651766-703c3015.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{ganttDiagram-c361ad54-9d49a75a.js β ganttDiagram-c361ad54-699328ea.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{gitGraphDiagram-72cf32ee-9aa698ac.js β gitGraphDiagram-72cf32ee-04cf4b05.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{graph-3ab38d50.js β graph-ee94449e.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{index-3862675e-6edac98f.js β index-3862675e-940162b4.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{index-61128091.js β index-c941dcb3.js} +3 -3
- rasa/core/channels/inspector/dist/assets/{infoDiagram-f8f76790-21baff85.js β infoDiagram-f8f76790-c79c2866.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{journeyDiagram-49397b02-4a6c7e98.js β journeyDiagram-49397b02-84489d30.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{layout-4beae36e.js β layout-a9aa9858.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{line-633b638e.js β line-eb73cf26.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{linear-22d77d65.js β linear-b3399f9a.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{mindmap-definition-fc14e90a-f219ef43.js β mindmap-definition-fc14e90a-b095bf1a.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{pieDiagram-8a3498a8-c7e1cafb.js β pieDiagram-8a3498a8-07644b66.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{quadrantDiagram-120e2f19-045e49b4.js β quadrantDiagram-120e2f19-573a3f9c.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{requirementDiagram-deff3bca-22485cb9.js β requirementDiagram-deff3bca-d457e1e1.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{sankeyDiagram-04a897e0-281c3da2.js β sankeyDiagram-04a897e0-9d26e1a2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{sequenceDiagram-704730f1-a3dd10e0.js β sequenceDiagram-704730f1-3a9cde10.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{stateDiagram-587899a1-61bd6eb2.js β stateDiagram-587899a1-4f3e8cec.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{stateDiagram-v2-d93cdb3a-deead491.js β stateDiagram-v2-d93cdb3a-e617e5bf.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-6aaf32cf-1b10e104.js β styles-6aaf32cf-eab30d2f.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-9a916d00-b1e18e58.js β styles-9a916d00-09994be2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-c10674c1-956c3492.js β styles-c10674c1-b7110364.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{svgDrawCommon-08f97a94-e13f753d.js β svgDrawCommon-08f97a94-3ebc92ad.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{timeline-definition-85554ec2-e568acd2.js β timeline-definition-85554ec2-7d13d2f2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{xychartDiagram-e933f94c-8b7e27fc.js β xychartDiagram-e933f94c-488385e1.js} +1 -1
- rasa/core/channels/inspector/dist/index.html +1 -1
- rasa/core/channels/inspector/src/helpers/audio/audiostream.ts +14 -0
- rasa/core/channels/studio_chat.py +7 -0
- rasa/core/channels/voice_stream/asr/asr_event.py +1 -1
- rasa/core/channels/voice_stream/asr/azure.py +6 -3
- rasa/core/channels/voice_stream/asr/deepgram.py +1 -1
- rasa/core/channels/voice_stream/audiocodes.py +3 -0
- rasa/core/channels/voice_stream/browser_audio.py +53 -3
- rasa/core/channels/voice_stream/genesys.py +2 -1
- rasa/core/channels/voice_stream/jambonz.py +9 -1
- rasa/core/channels/voice_stream/twilio_media_streams.py +16 -0
- rasa/core/channels/voice_stream/voice_channel.py +61 -0
- rasa/core/concurrent_lock_store.py +66 -16
- rasa/core/iam_credentials_providers/aws_iam_credentials_providers.py +76 -1
- rasa/core/iam_credentials_providers/credentials_provider_protocol.py +1 -1
- rasa/core/lock_store.py +41 -7
- rasa/model_manager/warm_rasa_process.py +13 -1
- rasa/shared/nlu/training_data/schemas/responses.yml +3 -0
- rasa/version.py +1 -1
- {rasa_pro-3.14.0a16.dist-info β rasa_pro-3.14.0a18.dist-info}/METADATA +5 -3
- {rasa_pro-3.14.0a16.dist-info β rasa_pro-3.14.0a18.dist-info}/RECORD +166 -228
- rasa/cli/project_templates/finance/actions/accounts/action_ask_account.py +0 -47
- rasa/cli/project_templates/finance/actions/accounts/action_check_balance.py +0 -40
- rasa/cli/project_templates/finance/actions/action_session_start.py +0 -74
- rasa/cli/project_templates/finance/actions/cards/action_ask_card.py +0 -48
- rasa/cli/project_templates/finance/actions/cards/action_check_card_existence.py +0 -36
- rasa/cli/project_templates/finance/actions/cards/action_update_card_status.py +0 -54
- rasa/cli/project_templates/finance/actions/database.py +0 -277
- rasa/cli/project_templates/finance/actions/transfers/action_add_payee.py +0 -52
- rasa/cli/project_templates/finance/actions/transfers/action_ask_account_from.py +0 -51
- rasa/cli/project_templates/finance/actions/transfers/action_check_payee_existence.py +0 -40
- rasa/cli/project_templates/finance/actions/transfers/action_check_sufficient_funds.py +0 -40
- rasa/cli/project_templates/finance/actions/transfers/action_list_payees.py +0 -46
- rasa/cli/project_templates/finance/actions/transfers/action_remove_payee.py +0 -49
- rasa/cli/project_templates/finance/actions/transfers/action_schedule_payment.py +0 -19
- rasa/cli/project_templates/finance/actions/transfers/action_validate_payment_date.py +0 -36
- rasa/cli/project_templates/finance/csvs/accounts.csv +0 -8
- rasa/cli/project_templates/finance/csvs/advisors.csv +0 -7
- rasa/cli/project_templates/finance/csvs/appointments.csv +0 -211
- rasa/cli/project_templates/finance/csvs/branches.csv +0 -10
- rasa/cli/project_templates/finance/csvs/cards.csv +0 -11
- rasa/cli/project_templates/finance/csvs/payees.csv +0 -11
- rasa/cli/project_templates/finance/csvs/transactions.csv +0 -71
- rasa/cli/project_templates/finance/csvs/users.csv +0 -4
- rasa/cli/project_templates/finance/data/cards/select_card.yml +0 -12
- rasa/cli/project_templates/finance/data/general/bot_identity.yml +0 -6
- rasa/cli/project_templates/finance/data/system/patterns/pattern_chitchat.yml +0 -5
- rasa/cli/project_templates/finance/data/system/source/accounts.json +0 -51
- rasa/cli/project_templates/finance/data/system/source/advisors.json +0 -44
- rasa/cli/project_templates/finance/data/system/source/appointments.json +0 -1474
- rasa/cli/project_templates/finance/data/system/source/branches.json +0 -47
- rasa/cli/project_templates/finance/data/system/source/cards.json +0 -72
- rasa/cli/project_templates/finance/data/system/source/payees.json +0 -74
- rasa/cli/project_templates/finance/data/system/source/transactions.json +0 -492
- rasa/cli/project_templates/finance/data/system/source/users.json +0 -29
- rasa/cli/project_templates/finance/data/transfers/add_payee.yml +0 -29
- rasa/cli/project_templates/finance/data/transfers/list_payees.yml +0 -5
- rasa/cli/project_templates/finance/data/transfers/remove_payee.yml +0 -21
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/consequences_of_blocking_card.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/reasons_to_block_card.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/recovering_from_card_fraud.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/tips_for_card_security.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/block_card/what_to_do_if_card_is_lost.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/account_balance_security.txt +0 -7
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/common_balance_inquiries.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/methods_to_check_balance.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/understanding_balance_updates.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/check_balance/what_to_do_if_balance_is_incorrect.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/benefits_of_authorised_payees.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/common_issues_with_payees.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/general_payee_information.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/payee_management_tips.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/manage_payees/understanding_payee_types.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/common_transfer_errors.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/fees_for_transfers.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/general_transfer_information.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/security_tips_for_transfers.txt +0 -8
- rasa/cli/project_templates/finance/docs/bank_of_rasa_faq/transfer_money/transfer_processing_times.txt +0 -8
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part1.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part10.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part11.txt +0 -48
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part12.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part13.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part14.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part15.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part16.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part17.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part18.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part19.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part2.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part20.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part21.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part22.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part23.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part24.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part25.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part26.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part27.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part28.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part29.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part3.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part30.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part31.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part32.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part33.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part34.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part35.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part36.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part37.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part38.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part39.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part4.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part40.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part41.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part42.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part43.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part44.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part45.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part46.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part47.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part48.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part49.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part5.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part50.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part51.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part52.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part53.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part54.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part55.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part56.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part57.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part58.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part59.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part6.txt +0 -47
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part60.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part61.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part7.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part8.txt +0 -50
- rasa/cli/project_templates/finance/docs/huggingface_alpaca_dataset/questions_part9.txt +0 -47
- rasa/cli/project_templates/finance/domain/cards/select_card.yml +0 -12
- rasa/cli/project_templates/finance/domain/general/assistant_details.yml +0 -12
- rasa/cli/project_templates/finance/domain/general/bot_identity.yml +0 -5
- rasa/cli/project_templates/finance/domain/general/defaults.yml +0 -24
- rasa/cli/project_templates/finance/domain/general/goodbye.yml +0 -7
- rasa/cli/project_templates/finance/domain/general/help.yml +0 -5
- rasa/cli/project_templates/finance/domain/general/utils.yml +0 -13
- rasa/cli/project_templates/finance/domain/transfers/add_payee.yml +0 -47
- rasa/cli/project_templates/finance/domain/transfers/list_payees.yml +0 -4
- rasa/cli/project_templates/finance/domain/transfers/remove_payee.yml +0 -16
- rasa/core/channels/inspector/dist/assets/channel-b560a3d4.js +0 -1
- rasa/core/channels/inspector/dist/assets/clone-67015557.js +0 -1
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-96b9c2cf-4a070961.js +0 -1
- {rasa_pro-3.14.0a16.dist-info β rasa_pro-3.14.0a18.dist-info}/NOTICE +0 -0
- {rasa_pro-3.14.0a16.dist-info β rasa_pro-3.14.0a18.dist-info}/WHEEL +0 -0
- {rasa_pro-3.14.0a16.dist-info β rasa_pro-3.14.0a18.dist-info}/entry_points.txt +0 -0
|
@@ -5,23 +5,25 @@ import os
|
|
|
5
5
|
import shutil
|
|
6
6
|
from pathlib import Path
|
|
7
7
|
from textwrap import dedent
|
|
8
|
-
from typing import Any, Dict, List, Optional
|
|
8
|
+
from typing import Any, Dict, Generator, List, Optional
|
|
9
9
|
|
|
10
10
|
import structlog
|
|
11
11
|
|
|
12
12
|
from rasa.builder import config
|
|
13
13
|
from rasa.builder.exceptions import ProjectGenerationError, ValidationError
|
|
14
14
|
from rasa.builder.llm_service import get_skill_generation_messages, llm_service
|
|
15
|
+
from rasa.builder.logging_utils import capture_exception_with_context
|
|
15
16
|
from rasa.builder.models import BotFiles
|
|
16
17
|
from rasa.builder.project_info import ProjectInfo, ensure_first_used, load_project_info
|
|
17
18
|
from rasa.builder.template_cache import copy_cache_for_template_if_available
|
|
18
19
|
from rasa.builder.training_service import TrainingInput
|
|
19
20
|
from rasa.builder.validation_service import validate_project
|
|
20
21
|
from rasa.cli.scaffold import ProjectTemplateName, create_initial_project
|
|
22
|
+
from rasa.shared.constants import DEFAULT_MODELS_PATH
|
|
21
23
|
from rasa.shared.core.flows import yaml_flows_io
|
|
22
24
|
from rasa.shared.importers.importer import TrainingDataImporter
|
|
23
25
|
from rasa.shared.utils.yaml import dump_obj_as_yaml_to_string
|
|
24
|
-
from rasa.utils.io import subpath
|
|
26
|
+
from rasa.utils.io import InvalidPathException, subpath
|
|
25
27
|
|
|
26
28
|
structlogger = structlog.get_logger()
|
|
27
29
|
|
|
@@ -60,7 +62,7 @@ class ProjectGenerator:
|
|
|
60
62
|
create_initial_project(self.project_folder.as_posix(), template)
|
|
61
63
|
# If a local cache for this template exists, copy it into the project.
|
|
62
64
|
# We no longer download here to avoid blocking project creation.
|
|
63
|
-
copy_cache_for_template_if_available(template, self.project_folder)
|
|
65
|
+
await copy_cache_for_template_if_available(template, self.project_folder)
|
|
64
66
|
# needs to happen after caching, as we download/copy .rasa and that would
|
|
65
67
|
# overwrite the project info file in .rasa
|
|
66
68
|
ensure_first_used(self.project_folder)
|
|
@@ -233,25 +235,9 @@ class ProjectGenerator:
|
|
|
233
235
|
"""
|
|
234
236
|
bot_files: BotFiles = {}
|
|
235
237
|
|
|
236
|
-
for file in self.
|
|
237
|
-
# Skip directories
|
|
238
|
-
if not file.is_file():
|
|
239
|
-
continue
|
|
240
|
-
|
|
238
|
+
for file in self.bot_file_paths():
|
|
241
239
|
relative_path = file.relative_to(self.project_folder)
|
|
242
240
|
|
|
243
|
-
# Skip hidden files and directories (any path component starting with '.')
|
|
244
|
-
# as well as `__pycache__` folders
|
|
245
|
-
if any(part.startswith(".") for part in relative_path.parts):
|
|
246
|
-
continue
|
|
247
|
-
|
|
248
|
-
if "__pycache__" in relative_path.parts:
|
|
249
|
-
continue
|
|
250
|
-
|
|
251
|
-
# exclude the project_folder / models folder
|
|
252
|
-
if relative_path.parts[0] == "models":
|
|
253
|
-
continue
|
|
254
|
-
|
|
255
241
|
# Exclude the docs directory if specified
|
|
256
242
|
if exclude_docs_directory and relative_path.parts[0] == "docs":
|
|
257
243
|
continue
|
|
@@ -263,7 +249,6 @@ class ProjectGenerator:
|
|
|
263
249
|
]
|
|
264
250
|
if file.suffix.lstrip(".").lower() not in allowed_file_extensions:
|
|
265
251
|
continue
|
|
266
|
-
|
|
267
252
|
# Read file content and store with relative path as key
|
|
268
253
|
try:
|
|
269
254
|
bot_files[relative_path.as_posix()] = file.read_text(encoding="utf-8")
|
|
@@ -274,9 +259,40 @@ class ProjectGenerator:
|
|
|
274
259
|
file_path=file.as_posix(),
|
|
275
260
|
)
|
|
276
261
|
bot_files[relative_path.as_posix()] = None
|
|
277
|
-
|
|
278
262
|
return bot_files
|
|
279
263
|
|
|
264
|
+
def is_restricted_path(self, path: Path) -> bool:
|
|
265
|
+
"""Check if the path is restricted.
|
|
266
|
+
|
|
267
|
+
These paths are excluded from deletion and editing by the user.
|
|
268
|
+
"""
|
|
269
|
+
relative_path = path.relative_to(self.project_folder)
|
|
270
|
+
|
|
271
|
+
# Skip hidden files and directories (any path component starting with '.')
|
|
272
|
+
# as well as `__pycache__` folders
|
|
273
|
+
if any(part.startswith(".") for part in relative_path.parts):
|
|
274
|
+
return True
|
|
275
|
+
|
|
276
|
+
if "__pycache__" in relative_path.parts:
|
|
277
|
+
return True
|
|
278
|
+
|
|
279
|
+
# exclude the project_folder / models folder
|
|
280
|
+
if relative_path.parts[0] == DEFAULT_MODELS_PATH:
|
|
281
|
+
return True
|
|
282
|
+
|
|
283
|
+
return False
|
|
284
|
+
|
|
285
|
+
def bot_file_paths(
|
|
286
|
+
self,
|
|
287
|
+
) -> Generator[Path, None, None]:
|
|
288
|
+
"""Get the paths of all bot files."""
|
|
289
|
+
for file in self.project_folder.glob("**/*"):
|
|
290
|
+
# Skip directories
|
|
291
|
+
if not file.is_file() or self.is_restricted_path(file):
|
|
292
|
+
continue
|
|
293
|
+
|
|
294
|
+
yield file
|
|
295
|
+
|
|
280
296
|
def _get_bot_data_for_llm(self) -> Dict[str, Any]:
|
|
281
297
|
"""Get the current bot data for the LLM."""
|
|
282
298
|
file_importer = self._create_importer()
|
|
@@ -321,7 +337,7 @@ class ProjectGenerator:
|
|
|
321
337
|
def update_bot_files(self, files: Dict[str, Optional[str]]) -> None:
|
|
322
338
|
"""Update bot files with new content by writing to disk."""
|
|
323
339
|
for filename, content in files.items():
|
|
324
|
-
file_path = Path(subpath(self.project_folder, filename))
|
|
340
|
+
file_path = Path(subpath(str(self.project_folder), filename))
|
|
325
341
|
# Disallow updates inside .rasa project metadata directory
|
|
326
342
|
if any(
|
|
327
343
|
part.startswith(".")
|
|
@@ -332,6 +348,95 @@ class ProjectGenerator:
|
|
|
332
348
|
file_path.parent.mkdir(parents=True, exist_ok=True)
|
|
333
349
|
file_path.write_text(content, encoding="utf-8")
|
|
334
350
|
|
|
351
|
+
def ensure_all_files_are_writable(self, files: Dict[str, Optional[str]]) -> None:
|
|
352
|
+
"""Ensure all files are writable."""
|
|
353
|
+
for filename, content in files.items():
|
|
354
|
+
file_path = Path(subpath(str(self.project_folder), filename))
|
|
355
|
+
if self.is_restricted_path(file_path):
|
|
356
|
+
raise InvalidPathException(
|
|
357
|
+
f"This file or folder is restricted from editing: {file_path}"
|
|
358
|
+
)
|
|
359
|
+
|
|
360
|
+
def replace_all_bot_files(self, files: Dict[str, Optional[str]]) -> None:
|
|
361
|
+
"""Replace all bot files with new content, deleting files not in the request.
|
|
362
|
+
|
|
363
|
+
Files/folders starting with .rasa/ or models/ are excluded from deletion.
|
|
364
|
+
|
|
365
|
+
Args:
|
|
366
|
+
files: Dictionary mapping file names to their content
|
|
367
|
+
"""
|
|
368
|
+
self.ensure_all_files_are_writable(files)
|
|
369
|
+
# Collect all existing files - any files not in the new `files` dict will be
|
|
370
|
+
# deleted from this set
|
|
371
|
+
existing_files = set(path.as_posix() for path in self.bot_file_paths())
|
|
372
|
+
|
|
373
|
+
# Write all new files
|
|
374
|
+
for filename, content in files.items():
|
|
375
|
+
if content is None:
|
|
376
|
+
continue
|
|
377
|
+
|
|
378
|
+
file_path = Path(subpath(str(self.project_folder), filename))
|
|
379
|
+
file_path.parent.mkdir(parents=True, exist_ok=True)
|
|
380
|
+
|
|
381
|
+
try:
|
|
382
|
+
file_path.write_text(content, encoding="utf-8")
|
|
383
|
+
except Exception as e:
|
|
384
|
+
# Log write failure and avoid deleting an existing file by mistake
|
|
385
|
+
capture_exception_with_context(
|
|
386
|
+
e,
|
|
387
|
+
"project_generator.replace_all_bot_files.write_error",
|
|
388
|
+
extra={"file_path": file_path},
|
|
389
|
+
)
|
|
390
|
+
if file_path.as_posix() in existing_files:
|
|
391
|
+
# Keep the original file if it already existed
|
|
392
|
+
existing_files.discard(file_path.as_posix())
|
|
393
|
+
continue
|
|
394
|
+
|
|
395
|
+
# Remove from deletion set since this file is in the new set of files
|
|
396
|
+
existing_files.discard(file_path.as_posix())
|
|
397
|
+
|
|
398
|
+
# Delete files that weren't in the request
|
|
399
|
+
for file_to_delete in existing_files:
|
|
400
|
+
file_path = Path(file_to_delete)
|
|
401
|
+
try:
|
|
402
|
+
file_path.unlink()
|
|
403
|
+
except Exception as e:
|
|
404
|
+
capture_exception_with_context(
|
|
405
|
+
e,
|
|
406
|
+
"project_generator.replace_all_bot_files.delete_error",
|
|
407
|
+
extra={"file_path": file_path},
|
|
408
|
+
)
|
|
409
|
+
|
|
410
|
+
# Clean up empty directories (except excluded ones)
|
|
411
|
+
self._cleanup_empty_directories()
|
|
412
|
+
|
|
413
|
+
def _cleanup_empty_directories(self) -> None:
|
|
414
|
+
"""Remove empty directories from the project folder.
|
|
415
|
+
|
|
416
|
+
Excludes hidden files and directories, and models/ from cleanup.
|
|
417
|
+
"""
|
|
418
|
+
# Walk directories in reverse order (deepest first)
|
|
419
|
+
for dirpath, dirnames, filenames in os.walk(self.project_folder, topdown=False):
|
|
420
|
+
# Skip if this is the project root
|
|
421
|
+
if dirpath == str(self.project_folder):
|
|
422
|
+
continue
|
|
423
|
+
|
|
424
|
+
if self.is_restricted_path(Path(dirpath)):
|
|
425
|
+
continue
|
|
426
|
+
|
|
427
|
+
relative_path = Path(dirpath).relative_to(self.project_folder)
|
|
428
|
+
|
|
429
|
+
try:
|
|
430
|
+
# Only remove if directory is empty
|
|
431
|
+
if not os.listdir(dirpath):
|
|
432
|
+
os.rmdir(dirpath)
|
|
433
|
+
except Exception as e:
|
|
434
|
+
capture_exception_with_context(
|
|
435
|
+
e,
|
|
436
|
+
"project_generator.cleanup_empty_directories.error",
|
|
437
|
+
extra={"directory": relative_path.as_posix()},
|
|
438
|
+
)
|
|
439
|
+
|
|
335
440
|
def cleanup(self) -> None:
|
|
336
441
|
"""Cleanup the project folder."""
|
|
337
442
|
# remove all the files and folders in the project folder resulting
|
|
@@ -339,6 +444,8 @@ class ProjectGenerator:
|
|
|
339
444
|
for filename in os.listdir(self.project_folder):
|
|
340
445
|
file_path = os.path.join(self.project_folder, filename)
|
|
341
446
|
try:
|
|
447
|
+
if filename == "lost+found":
|
|
448
|
+
continue
|
|
342
449
|
if os.path.isfile(file_path) or os.path.islink(file_path):
|
|
343
450
|
os.unlink(file_path)
|
|
344
451
|
elif os.path.isdir(file_path):
|
rasa/builder/service.py
CHANGED
|
@@ -54,8 +54,8 @@ from rasa.builder.guardrails.utils import (
|
|
|
54
54
|
from rasa.builder.job_manager import job_manager
|
|
55
55
|
from rasa.builder.jobs import (
|
|
56
56
|
run_prompt_to_bot_job,
|
|
57
|
+
run_replace_all_files_job,
|
|
57
58
|
run_template_to_bot_job,
|
|
58
|
-
run_update_files_job,
|
|
59
59
|
)
|
|
60
60
|
from rasa.builder.llm_service import llm_service
|
|
61
61
|
from rasa.builder.logging_utils import (
|
|
@@ -512,26 +512,31 @@ async def get_bot_files(request: Request) -> HTTPResponse:
|
|
|
512
512
|
)
|
|
513
513
|
|
|
514
514
|
|
|
515
|
-
@bp.route("/files", methods=["
|
|
516
|
-
@openapi.summary("
|
|
515
|
+
@bp.route("/files", methods=["POST"])
|
|
516
|
+
@openapi.summary("Replace all bot files")
|
|
517
517
|
@openapi.description(
|
|
518
|
-
"
|
|
519
|
-
"
|
|
520
|
-
"
|
|
518
|
+
"Replaces all bot configuration files with the provided files, deletes any "
|
|
519
|
+
"files not included in the request (excluding .rasa/ and models/ directories), "
|
|
520
|
+
"and retrains the model. Returns immediately with a job ID. Connect to "
|
|
521
|
+
"`/job-events/<job_id>` for real-time SSE progress tracking."
|
|
521
522
|
"\n\n"
|
|
523
|
+
"**File Management:**\n"
|
|
524
|
+
"- All files in the request are written to the project folder\n"
|
|
525
|
+
"- Files not included in the request are deleted from the project\n"
|
|
526
|
+
"- Files/folders starting with `.rasa/` or `models/` are excluded from deletion\n\n"
|
|
522
527
|
"**SSE Event Flow:** (available via /job-events/<job_id>)\n"
|
|
523
528
|
"1. `received` - Request received by server\n"
|
|
524
529
|
"2. `validating` - Validating bot configuration files\n"
|
|
525
530
|
"3. `validation_success` - File validation completed successfully\n"
|
|
526
531
|
"4. `training` - Training the bot model with updated files\n"
|
|
527
532
|
"5. `train_success` - Model training completed\n"
|
|
528
|
-
"6. `done` - Bot files
|
|
533
|
+
"6. `done` - Bot files replacement completed\n\n"
|
|
529
534
|
"**Error Events (can occur at any time):**\n"
|
|
530
535
|
"- `validation_error` - Bot configuration files are invalid\n"
|
|
531
536
|
"- `train_error` - Files updated but training failed\n"
|
|
532
537
|
"- `error` - Unexpected error occurred\n\n"
|
|
533
538
|
"**Usage:**\n"
|
|
534
|
-
"1. Send
|
|
539
|
+
"1. Send POST request with Content-Type: application/json\n"
|
|
535
540
|
"2. The response will be a JSON object `{job_id: ...}`\n"
|
|
536
541
|
"3. Connect to `/job-events/<job_id>` for a server-sent event stream of progress."
|
|
537
542
|
)
|
|
@@ -539,9 +544,11 @@ async def get_bot_files(request: Request) -> HTTPResponse:
|
|
|
539
544
|
@openapi.body(
|
|
540
545
|
{"application/json": {str: Optional[str]}},
|
|
541
546
|
description=(
|
|
542
|
-
"A dictionary mapping file names to their
|
|
543
|
-
"
|
|
544
|
-
"Files
|
|
547
|
+
"A dictionary mapping file names to their complete content. "
|
|
548
|
+
"All files in the project will be replaced with these files. "
|
|
549
|
+
"Files not included in the request will be deleted from the project "
|
|
550
|
+
"(except for .rasa/ and models/ directories). "
|
|
551
|
+
"The file name should be the relative path from the project root."
|
|
545
552
|
),
|
|
546
553
|
required=True,
|
|
547
554
|
example={
|
|
@@ -558,6 +565,10 @@ async def get_bot_files(request: Request) -> HTTPResponse:
|
|
|
558
565
|
" - name: CountVectorsFeaturizer\n"
|
|
559
566
|
"policies:\n - name: MemoizationPolicy\n - name: RulePolicy"
|
|
560
567
|
),
|
|
568
|
+
"data/nlu.yml": (
|
|
569
|
+
"version: '3.1'\n"
|
|
570
|
+
"nlu:\n- intent: greet\n examples: |\n - hello\n - hi"
|
|
571
|
+
),
|
|
561
572
|
},
|
|
562
573
|
)
|
|
563
574
|
@openapi.response(
|
|
@@ -565,7 +576,7 @@ async def get_bot_files(request: Request) -> HTTPResponse:
|
|
|
565
576
|
{"application/json": model_to_schema(JobCreateResponse)},
|
|
566
577
|
description=(
|
|
567
578
|
"Job created. Poll or subscribe to /job-events/<job_id> "
|
|
568
|
-
"for progress and SSE updates."
|
|
579
|
+
"for progress and SSE updates on file replacement and training."
|
|
569
580
|
),
|
|
570
581
|
)
|
|
571
582
|
@openapi.response(
|
|
@@ -607,8 +618,8 @@ async def get_bot_files(request: Request) -> HTTPResponse:
|
|
|
607
618
|
schema=str,
|
|
608
619
|
)
|
|
609
620
|
@protected()
|
|
610
|
-
async def
|
|
611
|
-
"""
|
|
621
|
+
async def replace_all_bot_files(request: Request) -> HTTPResponse:
|
|
622
|
+
"""Replace all bot files with server-sent events for progress tracking."""
|
|
612
623
|
try:
|
|
613
624
|
bot_files = request.json
|
|
614
625
|
except Exception as exc:
|
|
@@ -621,17 +632,17 @@ async def update_bot_files(request: Request) -> HTTPResponse:
|
|
|
621
632
|
|
|
622
633
|
try:
|
|
623
634
|
job = job_manager.create_job()
|
|
624
|
-
request.app.add_task(
|
|
635
|
+
request.app.add_task(run_replace_all_files_job(request.app, job, bot_files))
|
|
625
636
|
return response.json(JobCreateResponse(job_id=job.id).model_dump(), status=200)
|
|
626
637
|
except Exception as exc:
|
|
627
638
|
capture_exception_with_context(
|
|
628
639
|
exc,
|
|
629
|
-
"bot_builder_service.
|
|
630
|
-
tags={"endpoint": "/api/files", "method": "
|
|
640
|
+
"bot_builder_service.replace_all_bot_files.unexpected_error",
|
|
641
|
+
tags={"endpoint": "/api/files", "method": "POST"},
|
|
631
642
|
)
|
|
632
643
|
return response.json(
|
|
633
644
|
ApiErrorResponse(
|
|
634
|
-
error="Failed to
|
|
645
|
+
error="Failed to replace bot files", details={"error": str(exc)}
|
|
635
646
|
).model_dump(),
|
|
636
647
|
status=HTTPStatus.INTERNAL_SERVER_ERROR,
|
|
637
648
|
)
|
|
@@ -1144,6 +1155,11 @@ async def copilot(request: Request) -> None:
|
|
|
1144
1155
|
latency_ms=int((time.perf_counter() - start_timestamp) * 1000),
|
|
1145
1156
|
system_message=generation_context.system_message,
|
|
1146
1157
|
chat_history=generation_context.chat_history,
|
|
1158
|
+
last_user_message=(
|
|
1159
|
+
req.last_message.get_text_content()
|
|
1160
|
+
if (req.last_message and req.last_message.role == ROLE_USER)
|
|
1161
|
+
else None
|
|
1162
|
+
),
|
|
1147
1163
|
**copilot_client.usage_statistics.model_dump(),
|
|
1148
1164
|
)
|
|
1149
1165
|
)
|
rasa/builder/template_cache.py
CHANGED
|
@@ -1,83 +1,26 @@
|
|
|
1
|
-
import asyncio
|
|
2
1
|
import os
|
|
3
|
-
import shutil
|
|
4
|
-
import tarfile
|
|
5
|
-
import tempfile
|
|
6
2
|
from pathlib import Path
|
|
7
|
-
from typing import Generator
|
|
8
3
|
|
|
9
4
|
import aiofiles
|
|
10
|
-
import
|
|
5
|
+
import aiofiles.os
|
|
6
|
+
import aioshutil
|
|
11
7
|
import structlog
|
|
12
|
-
from sanic import Sanic
|
|
13
8
|
|
|
14
|
-
import rasa.version
|
|
15
|
-
from rasa.builder.logging_utils import capture_exception_with_context
|
|
16
9
|
from rasa.cli.scaffold import ProjectTemplateName
|
|
17
10
|
|
|
18
11
|
structlogger = structlog.get_logger()
|
|
19
12
|
|
|
20
|
-
CACHE_BUCKET_URL = "https://trained-templates.s3.us-east-1.amazonaws.com"
|
|
21
13
|
|
|
22
14
|
# Root directory for storing downloaded template caches on disk.
|
|
23
|
-
_CACHE_ROOT_DIR = Path(
|
|
24
|
-
os.getenv(
|
|
25
|
-
"RASA_TEMPLATE_CACHE_DIR",
|
|
26
|
-
Path.home().joinpath(".rasa", "template-cache").as_posix(),
|
|
27
|
-
)
|
|
28
|
-
)
|
|
15
|
+
_CACHE_ROOT_DIR = Path(os.getenv("RASA_TEMPLATE_CACHE_DIR", "/templates"))
|
|
29
16
|
|
|
30
17
|
|
|
31
18
|
def _template_cache_dir(template: ProjectTemplateName) -> Path:
|
|
32
19
|
"""Return the local cache directory for a given template and version."""
|
|
33
|
-
return _CACHE_ROOT_DIR /
|
|
20
|
+
return _CACHE_ROOT_DIR / template.value
|
|
34
21
|
|
|
35
22
|
|
|
36
|
-
def
|
|
37
|
-
return Path(
|
|
38
|
-
os.getenv(
|
|
39
|
-
"RASA_TEMPLATE_CACHE_DIR",
|
|
40
|
-
Path.home().joinpath(".rasa", "template-cache").as_posix(),
|
|
41
|
-
)
|
|
42
|
-
)
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
def _safe_tar_members(
|
|
46
|
-
tar: tarfile.TarFile, destination_directory: Path
|
|
47
|
-
) -> Generator[tarfile.TarInfo, None, None]:
|
|
48
|
-
"""Yield safe members for extraction to prevent path traversal and links.
|
|
49
|
-
|
|
50
|
-
Args:
|
|
51
|
-
tar: Open tar file handle
|
|
52
|
-
destination_directory: Directory to which files will be extracted
|
|
53
|
-
|
|
54
|
-
Yields:
|
|
55
|
-
Members that are safe to extract within destination_directory
|
|
56
|
-
"""
|
|
57
|
-
base_path = destination_directory.resolve()
|
|
58
|
-
|
|
59
|
-
for member in tar.getmembers():
|
|
60
|
-
name = member.name
|
|
61
|
-
# Skip empty names and absolute paths
|
|
62
|
-
if not name or name.startswith("/") or name.startswith("\\"):
|
|
63
|
-
continue
|
|
64
|
-
|
|
65
|
-
# Disallow symlinks and hardlinks
|
|
66
|
-
if member.issym() or member.islnk():
|
|
67
|
-
continue
|
|
68
|
-
|
|
69
|
-
# Compute the final path and ensure it's within base_path
|
|
70
|
-
target_path = (base_path / name).resolve()
|
|
71
|
-
try:
|
|
72
|
-
target_path.relative_to(base_path)
|
|
73
|
-
except ValueError:
|
|
74
|
-
# Member would escape the destination directory
|
|
75
|
-
continue
|
|
76
|
-
|
|
77
|
-
yield member
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
def _copytree(src: Path, dst: Path) -> None:
|
|
23
|
+
async def _copytree(src: Path, dst: Path) -> None:
|
|
81
24
|
"""Copy directory tree from src to dst, merging into dst.
|
|
82
25
|
|
|
83
26
|
Existing files are overwritten. Hidden files and directories are included, as
|
|
@@ -87,132 +30,14 @@ def _copytree(src: Path, dst: Path) -> None:
|
|
|
87
30
|
for root, dirs, files in os.walk(src):
|
|
88
31
|
rel_path = Path(root).relative_to(src)
|
|
89
32
|
target_dir = dst / rel_path
|
|
90
|
-
|
|
33
|
+
await aiofiles.os.makedirs(target_dir, exist_ok=True)
|
|
91
34
|
for filename in files:
|
|
92
35
|
src_file = Path(root) / filename
|
|
93
36
|
dst_file = target_dir / filename
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
async def download_cache_for_template(
|
|
98
|
-
template: ProjectTemplateName, target_dir: str
|
|
99
|
-
) -> None:
|
|
100
|
-
# get a temp path for the cache file download
|
|
101
|
-
temporary_cache_file = tempfile.NamedTemporaryFile(suffix=".tar.gz", delete=False)
|
|
102
|
-
|
|
103
|
-
try:
|
|
104
|
-
url = f"{CACHE_BUCKET_URL}/{rasa.version.__version__}-{template.value}.tar.gz"
|
|
105
|
-
async with aiohttp.ClientSession() as session:
|
|
106
|
-
async with session.get(url) as response:
|
|
107
|
-
response.raise_for_status()
|
|
108
|
-
async with aiofiles.open(temporary_cache_file.name, "wb") as f:
|
|
109
|
-
async for chunk in response.content.iter_chunked(1024 * 1024):
|
|
110
|
-
await f.write(chunk)
|
|
111
|
-
|
|
112
|
-
# extract the cache to the project folder using safe member filtering
|
|
113
|
-
with tarfile.open(temporary_cache_file.name, "r:gz") as tar:
|
|
114
|
-
destination = Path(target_dir)
|
|
115
|
-
destination.mkdir(parents=True, exist_ok=True)
|
|
116
|
-
tar.extractall(
|
|
117
|
-
path=destination,
|
|
118
|
-
members=_safe_tar_members(tar, destination),
|
|
119
|
-
)
|
|
120
|
-
|
|
121
|
-
structlogger.info(
|
|
122
|
-
"project_generator.download_cache_for_template.success",
|
|
123
|
-
template=template,
|
|
124
|
-
event_info=(
|
|
125
|
-
"Downloaded cache for template, extracted to target directory."
|
|
126
|
-
),
|
|
127
|
-
target_dir=target_dir,
|
|
128
|
-
)
|
|
129
|
-
except aiohttp.ClientResponseError as e:
|
|
130
|
-
if e.status == 403:
|
|
131
|
-
structlogger.debug(
|
|
132
|
-
"project_generator.download_cache_for_template.no_cache_found",
|
|
133
|
-
template=template,
|
|
134
|
-
event_info=("No cache found for template, continuing without it."),
|
|
135
|
-
target_dir=target_dir,
|
|
136
|
-
)
|
|
137
|
-
else:
|
|
138
|
-
capture_exception_with_context(
|
|
139
|
-
e,
|
|
140
|
-
"project_generator.download_cache_for_template.response_error",
|
|
141
|
-
extra={
|
|
142
|
-
"template": template.value,
|
|
143
|
-
"status": str(e.status),
|
|
144
|
-
"target_dir": target_dir,
|
|
145
|
-
},
|
|
146
|
-
)
|
|
147
|
-
except Exception as exc:
|
|
148
|
-
capture_exception_with_context(
|
|
149
|
-
exc,
|
|
150
|
-
"project_generator.download_cache_for_template.unexpected_error",
|
|
151
|
-
extra={"template": template.value, "target_dir": target_dir},
|
|
152
|
-
)
|
|
153
|
-
finally:
|
|
154
|
-
# Clean up the temporary file
|
|
155
|
-
try:
|
|
156
|
-
Path(temporary_cache_file.name).unlink(missing_ok=True)
|
|
157
|
-
except Exception as exc:
|
|
158
|
-
structlogger.debug(
|
|
159
|
-
"project_generator.download_cache_for_template.cleanup_error",
|
|
160
|
-
error=str(exc),
|
|
161
|
-
template=template,
|
|
162
|
-
event_info=("Failed to cleanup cache for template, ignoring."),
|
|
163
|
-
)
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
async def background_download_template_caches(
|
|
167
|
-
app: Sanic, loop: asyncio.AbstractEventLoop
|
|
168
|
-
) -> None:
|
|
169
|
-
"""Kick off background downloads of template caches if enabled."""
|
|
170
|
-
try:
|
|
171
|
-
structlogger.info(
|
|
172
|
-
"builder.main.background_cache_download.start",
|
|
173
|
-
event_info=(
|
|
174
|
-
"Starting background download of template caches for this " "version"
|
|
175
|
-
),
|
|
176
|
-
)
|
|
177
|
-
|
|
178
|
-
# Ensure cache root exists
|
|
179
|
-
_cache_root_dir().mkdir(parents=True, exist_ok=True)
|
|
180
|
-
|
|
181
|
-
async def _download(template: ProjectTemplateName) -> None:
|
|
182
|
-
try:
|
|
183
|
-
target_dir = _template_cache_dir(template)
|
|
184
|
-
if target_dir.exists() and any(target_dir.iterdir()):
|
|
185
|
-
structlogger.debug(
|
|
186
|
-
"builder.main.background_cache_download.skipped",
|
|
187
|
-
template=template,
|
|
188
|
-
event_info=(
|
|
189
|
-
"Skipping download of template cache because it "
|
|
190
|
-
"already exists."
|
|
191
|
-
),
|
|
192
|
-
target_dir=target_dir,
|
|
193
|
-
)
|
|
194
|
-
return
|
|
195
|
-
|
|
196
|
-
target_dir.mkdir(parents=True, exist_ok=True)
|
|
197
|
-
await download_cache_for_template(template, target_dir.as_posix())
|
|
198
|
-
except Exception as exc:
|
|
199
|
-
structlogger.debug(
|
|
200
|
-
"builder.main.background_cache_download.error",
|
|
201
|
-
template=template,
|
|
202
|
-
error=str(exc),
|
|
203
|
-
)
|
|
204
|
-
|
|
205
|
-
# schedule downloads concurrently without blocking startup
|
|
206
|
-
for template in ProjectTemplateName:
|
|
207
|
-
loop.create_task(_download(template))
|
|
208
|
-
except Exception as exc:
|
|
209
|
-
structlogger.debug(
|
|
210
|
-
"builder.main.background_cache_download.unexpected_error",
|
|
211
|
-
error=str(exc),
|
|
212
|
-
)
|
|
37
|
+
await aioshutil.copy2(src_file, dst_file)
|
|
213
38
|
|
|
214
39
|
|
|
215
|
-
def copy_cache_for_template_if_available(
|
|
40
|
+
async def copy_cache_for_template_if_available(
|
|
216
41
|
template: ProjectTemplateName, project_folder: Path
|
|
217
42
|
) -> None:
|
|
218
43
|
"""Copy a previously downloaded cache for `template` into `project_folder`.
|
|
@@ -222,7 +47,7 @@ def copy_cache_for_template_if_available(
|
|
|
222
47
|
try:
|
|
223
48
|
cache_dir = _template_cache_dir(template)
|
|
224
49
|
if cache_dir.exists() and any(cache_dir.iterdir()):
|
|
225
|
-
_copytree(cache_dir, project_folder)
|
|
50
|
+
await _copytree(cache_dir, project_folder)
|
|
226
51
|
structlogger.info(
|
|
227
52
|
"project_generator.copy_cache_for_template.success",
|
|
228
53
|
template=template,
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
# Basic Rasa Template
|
|
2
|
+
|
|
3
|
+
A simple, general-purpose conversational agent template that provides essential conversational capabilities.
|
|
4
|
+
|
|
5
|
+
## π What's Included
|
|
6
|
+
|
|
7
|
+
This template provides a foundation for building conversational agents with:
|
|
8
|
+
- **Basic conversational flows**: Greetings, help, feedback, and human handoff
|
|
9
|
+
- **Help system**: Users can ask for assistance and get guided responses
|
|
10
|
+
- **Feedback collection**: Gather user feedback to improve the agent
|
|
11
|
+
- **Human handoff**: Seamlessly transfer conversations to human agents when needed
|
|
12
|
+
|
|
13
|
+
## π Directory Structure
|
|
14
|
+
|
|
15
|
+
```
|
|
16
|
+
βββ actions/ # Custom Python logic for agent actions
|
|
17
|
+
βββ data/ # Conversational flows and training data
|
|
18
|
+
βββ domain/ # Agent configuration (slots, responses, actions)
|
|
19
|
+
βββ docs/ # Knowledge base documents (optional)
|
|
20
|
+
βββ prompts/ # LLM prompts for enhanced responses
|
|
21
|
+
βββ config.yml # Training pipeline configuration
|
|
22
|
+
```
|
|
23
|
+
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
## π `actions/` β The Agent's Toolkit
|
|
2
|
+
|
|
3
|
+
This folder contains Python files that define custom actions your agent can perform. Actions are pieces of code that run when your agent needs to do something beyond just responding with text.
|
|
4
|
+
|
|
5
|
+
**What you'll find:**
|
|
6
|
+
- `action_human_handoff.py`: Handles transferring the conversation to a human agent when needed.
|
|
7
|
+
|
|
8
|
+
**Edit Python files in this folder** to add new custom logic, integrate with APIs, or perform calculations and data processing.
|
|
9
|
+
|
|
10
|
+
Learn more about custom actions in the [Rasa documentation](https://rasa.com/docs/pro/build/custom-actions).
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
# Rasa
|
|
2
|
-
# This file controls your
|
|
1
|
+
# Rasa Agent Configuration
|
|
2
|
+
# This file controls your agent's language, message processing pipeline, and conversation policies.
|
|
3
3
|
# For full documentation, see: https://rasa.com/docs/pro/build/configuring-assistant
|
|
4
4
|
recipe: default.v1
|
|
5
5
|
language: en
|
|
6
6
|
|
|
7
|
-
# The
|
|
8
|
-
# This default value must be replaced with a unique
|
|
7
|
+
# The agent project unique identifier
|
|
8
|
+
# This default value must be replaced with a unique agent name within your deployment
|
|
9
9
|
assistant_id: placeholder_default
|
|
10
10
|
|
|
11
11
|
pipeline:
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
## π `data/` β The
|
|
1
|
+
## π `data/` β The Agent's Business Logic
|
|
2
2
|
|
|
3
|
-
This folder holds files that define your agentβs skills using "flows". Each flow is a step-by-step conversation pattern (like a recipe) for handling a user goal (e.g., checking a balance, updating an address).
|
|
3
|
+
This folder holds files that define your agentβs skills using "flows". [1](https://rasa.com/docs/pro/build/writing-flows) Each flow is a step-by-step conversation pattern (like a recipe) for handling a user goal (e.g., checking a balance, updating an address).
|
|
4
4
|
|
|
5
|
-
**What you
|
|
6
|
-
-
|
|
7
|
-
- Flows are made of steps: collecting info, calling actions, and responding.
|
|
5
|
+
**What you'll find:**
|
|
6
|
+
- **general/**: Basic conversational flows (greetings, help, feedback, human handoff)
|
|
8
7
|
|
|
9
|
-
**Edit
|
|
8
|
+
**Edit YAML files in this folder** to add new skills, change existing flows, or adjust what the agent asks.
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
## π `domain/` β The
|
|
1
|
+
## π `domain/` β The Agent's Brain
|
|
2
2
|
|
|
3
|
-
This folder contains YAML files that define the agent
|
|
4
|
-
- **Slots**: The agent
|
|
5
|
-
- **Responses**: The messages your
|
|
6
|
-
- **Actions**: Custom logic your agent can run (e.g.,
|
|
3
|
+
This folder contains YAML files that define the agent's:
|
|
4
|
+
- **Slots**: The agent's memory (e.g., user's name, session info) [1](https://rasa.com/docs/reference/primitives/slots/).
|
|
5
|
+
- **Responses**: The messages your agent can say to users (e.g., greetings, confirmations) [2](https://rasa.com/docs/reference/primitives/responses).
|
|
6
|
+
- **Actions**: Custom logic your agent can run (e.g., handling feedback, human handoff) [3](https://rasa.com/docs/reference/primitives/custom-actions).
|
|
7
7
|
|
|
8
|
+
**What you'll find:**
|
|
9
|
+
- **general/**: Basic conversational domain elements (greetings, help, feedback)
|
|
8
10
|
|
|
9
11
|
You can organize the domain as one big file or many small ones. Rasa will automatically merge everything during training [1](https://rasa.com/docs/reference/config/domain).
|