rasa-pro 3.12.0.dev1__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.
- README.md +41 -0
- rasa/__init__.py +9 -0
- rasa/__main__.py +177 -0
- rasa/anonymization/__init__.py +2 -0
- rasa/anonymization/anonymisation_rule_yaml_reader.py +91 -0
- rasa/anonymization/anonymization_pipeline.py +286 -0
- rasa/anonymization/anonymization_rule_executor.py +260 -0
- rasa/anonymization/anonymization_rule_orchestrator.py +120 -0
- rasa/anonymization/schemas/config.yml +47 -0
- rasa/anonymization/utils.py +118 -0
- rasa/api.py +160 -0
- rasa/cli/__init__.py +5 -0
- rasa/cli/arguments/__init__.py +0 -0
- rasa/cli/arguments/data.py +106 -0
- rasa/cli/arguments/default_arguments.py +207 -0
- rasa/cli/arguments/evaluate.py +65 -0
- rasa/cli/arguments/export.py +51 -0
- rasa/cli/arguments/interactive.py +74 -0
- rasa/cli/arguments/run.py +219 -0
- rasa/cli/arguments/shell.py +17 -0
- rasa/cli/arguments/test.py +211 -0
- rasa/cli/arguments/train.py +279 -0
- rasa/cli/arguments/visualize.py +34 -0
- rasa/cli/arguments/x.py +30 -0
- rasa/cli/data.py +354 -0
- rasa/cli/dialogue_understanding_test.py +251 -0
- rasa/cli/e2e_test.py +259 -0
- rasa/cli/evaluate.py +222 -0
- rasa/cli/export.py +250 -0
- rasa/cli/inspect.py +75 -0
- rasa/cli/interactive.py +166 -0
- rasa/cli/license.py +65 -0
- rasa/cli/llm_fine_tuning.py +403 -0
- rasa/cli/markers.py +78 -0
- rasa/cli/project_templates/__init__.py +0 -0
- rasa/cli/project_templates/calm/actions/__init__.py +0 -0
- rasa/cli/project_templates/calm/actions/action_template.py +27 -0
- rasa/cli/project_templates/calm/actions/add_contact.py +30 -0
- rasa/cli/project_templates/calm/actions/db.py +57 -0
- rasa/cli/project_templates/calm/actions/list_contacts.py +22 -0
- rasa/cli/project_templates/calm/actions/remove_contact.py +35 -0
- rasa/cli/project_templates/calm/config.yml +10 -0
- rasa/cli/project_templates/calm/credentials.yml +33 -0
- rasa/cli/project_templates/calm/data/flows/add_contact.yml +31 -0
- rasa/cli/project_templates/calm/data/flows/list_contacts.yml +14 -0
- rasa/cli/project_templates/calm/data/flows/remove_contact.yml +29 -0
- rasa/cli/project_templates/calm/db/contacts.json +10 -0
- rasa/cli/project_templates/calm/domain/add_contact.yml +39 -0
- rasa/cli/project_templates/calm/domain/list_contacts.yml +17 -0
- rasa/cli/project_templates/calm/domain/remove_contact.yml +38 -0
- rasa/cli/project_templates/calm/domain/shared.yml +10 -0
- rasa/cli/project_templates/calm/e2e_tests/cancelations/user_cancels_during_a_correction.yml +16 -0
- rasa/cli/project_templates/calm/e2e_tests/cancelations/user_changes_mind_on_a_whim.yml +7 -0
- rasa/cli/project_templates/calm/e2e_tests/corrections/user_corrects_contact_handle.yml +20 -0
- rasa/cli/project_templates/calm/e2e_tests/corrections/user_corrects_contact_name.yml +19 -0
- rasa/cli/project_templates/calm/e2e_tests/happy_paths/user_adds_contact_to_their_list.yml +15 -0
- rasa/cli/project_templates/calm/e2e_tests/happy_paths/user_lists_contacts.yml +5 -0
- rasa/cli/project_templates/calm/e2e_tests/happy_paths/user_removes_contact.yml +11 -0
- rasa/cli/project_templates/calm/e2e_tests/happy_paths/user_removes_contact_from_list.yml +12 -0
- rasa/cli/project_templates/calm/endpoints.yml +58 -0
- rasa/cli/project_templates/default/actions/__init__.py +0 -0
- rasa/cli/project_templates/default/actions/actions.py +27 -0
- rasa/cli/project_templates/default/config.yml +44 -0
- rasa/cli/project_templates/default/credentials.yml +33 -0
- rasa/cli/project_templates/default/data/nlu.yml +91 -0
- rasa/cli/project_templates/default/data/rules.yml +13 -0
- rasa/cli/project_templates/default/data/stories.yml +30 -0
- rasa/cli/project_templates/default/domain.yml +34 -0
- rasa/cli/project_templates/default/endpoints.yml +42 -0
- rasa/cli/project_templates/default/tests/test_stories.yml +91 -0
- rasa/cli/project_templates/tutorial/actions/__init__.py +0 -0
- rasa/cli/project_templates/tutorial/actions/actions.py +22 -0
- rasa/cli/project_templates/tutorial/config.yml +12 -0
- rasa/cli/project_templates/tutorial/credentials.yml +33 -0
- rasa/cli/project_templates/tutorial/data/flows.yml +8 -0
- rasa/cli/project_templates/tutorial/data/patterns.yml +11 -0
- rasa/cli/project_templates/tutorial/domain.yml +35 -0
- rasa/cli/project_templates/tutorial/endpoints.yml +55 -0
- rasa/cli/run.py +143 -0
- rasa/cli/scaffold.py +273 -0
- rasa/cli/shell.py +141 -0
- rasa/cli/studio/__init__.py +0 -0
- rasa/cli/studio/download.py +62 -0
- rasa/cli/studio/studio.py +296 -0
- rasa/cli/studio/train.py +59 -0
- rasa/cli/studio/upload.py +62 -0
- rasa/cli/telemetry.py +102 -0
- rasa/cli/test.py +280 -0
- rasa/cli/train.py +278 -0
- rasa/cli/utils.py +484 -0
- rasa/cli/visualize.py +40 -0
- rasa/cli/x.py +206 -0
- rasa/constants.py +45 -0
- rasa/core/__init__.py +17 -0
- rasa/core/actions/__init__.py +0 -0
- rasa/core/actions/action.py +1318 -0
- rasa/core/actions/action_clean_stack.py +59 -0
- rasa/core/actions/action_exceptions.py +24 -0
- rasa/core/actions/action_hangup.py +29 -0
- rasa/core/actions/action_repeat_bot_messages.py +89 -0
- rasa/core/actions/action_run_slot_rejections.py +210 -0
- rasa/core/actions/action_trigger_chitchat.py +31 -0
- rasa/core/actions/action_trigger_flow.py +109 -0
- rasa/core/actions/action_trigger_search.py +31 -0
- rasa/core/actions/constants.py +5 -0
- rasa/core/actions/custom_action_executor.py +191 -0
- rasa/core/actions/direct_custom_actions_executor.py +109 -0
- rasa/core/actions/e2e_stub_custom_action_executor.py +72 -0
- rasa/core/actions/forms.py +741 -0
- rasa/core/actions/grpc_custom_action_executor.py +251 -0
- rasa/core/actions/http_custom_action_executor.py +145 -0
- rasa/core/actions/loops.py +114 -0
- rasa/core/actions/two_stage_fallback.py +186 -0
- rasa/core/agent.py +559 -0
- rasa/core/auth_retry_tracker_store.py +122 -0
- rasa/core/brokers/__init__.py +0 -0
- rasa/core/brokers/broker.py +126 -0
- rasa/core/brokers/file.py +58 -0
- rasa/core/brokers/kafka.py +324 -0
- rasa/core/brokers/pika.py +388 -0
- rasa/core/brokers/sql.py +86 -0
- rasa/core/channels/__init__.py +61 -0
- rasa/core/channels/botframework.py +338 -0
- rasa/core/channels/callback.py +84 -0
- rasa/core/channels/channel.py +456 -0
- rasa/core/channels/console.py +241 -0
- rasa/core/channels/development_inspector.py +197 -0
- rasa/core/channels/facebook.py +419 -0
- rasa/core/channels/hangouts.py +329 -0
- rasa/core/channels/inspector/.eslintrc.cjs +25 -0
- rasa/core/channels/inspector/.gitignore +23 -0
- rasa/core/channels/inspector/README.md +54 -0
- rasa/core/channels/inspector/assets/favicon.ico +0 -0
- rasa/core/channels/inspector/assets/rasa-chat.js +2 -0
- rasa/core/channels/inspector/custom.d.ts +3 -0
- rasa/core/channels/inspector/dist/assets/arc-861ddd57.js +1 -0
- rasa/core/channels/inspector/dist/assets/array-9f3ba611.js +1 -0
- rasa/core/channels/inspector/dist/assets/c4Diagram-d0fbc5ce-921f02db.js +10 -0
- rasa/core/channels/inspector/dist/assets/classDiagram-936ed81e-b436c4f8.js +2 -0
- rasa/core/channels/inspector/dist/assets/classDiagram-v2-c3cb15f1-511a23cb.js +2 -0
- rasa/core/channels/inspector/dist/assets/createText-62fc7601-ef476ecd.js +7 -0
- rasa/core/channels/inspector/dist/assets/edges-f2ad444c-f1878e0a.js +4 -0
- rasa/core/channels/inspector/dist/assets/erDiagram-9d236eb7-fac75185.js +51 -0
- rasa/core/channels/inspector/dist/assets/flowDb-1972c806-201c5bbc.js +6 -0
- rasa/core/channels/inspector/dist/assets/flowDiagram-7ea5b25a-f904ae41.js +4 -0
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-855bc5b3-b080d6f2.js +1 -0
- rasa/core/channels/inspector/dist/assets/flowchart-elk-definition-abe16c3d-1813da66.js +139 -0
- rasa/core/channels/inspector/dist/assets/ganttDiagram-9b5ea136-872af172.js +266 -0
- rasa/core/channels/inspector/dist/assets/gitGraphDiagram-99d0ae7c-34a0af5a.js +70 -0
- rasa/core/channels/inspector/dist/assets/ibm-plex-mono-v4-latin-regular-128cfa44.ttf +0 -0
- rasa/core/channels/inspector/dist/assets/ibm-plex-mono-v4-latin-regular-21dbcb97.woff +0 -0
- rasa/core/channels/inspector/dist/assets/ibm-plex-mono-v4-latin-regular-222b5e26.svg +329 -0
- rasa/core/channels/inspector/dist/assets/ibm-plex-mono-v4-latin-regular-9ad89b2a.woff2 +0 -0
- rasa/core/channels/inspector/dist/assets/index-2c4b9a3b-42ba3e3d.js +1 -0
- rasa/core/channels/inspector/dist/assets/index-37817b51.js +1317 -0
- rasa/core/channels/inspector/dist/assets/index-3ee28881.css +1 -0
- rasa/core/channels/inspector/dist/assets/infoDiagram-736b4530-6b731386.js +7 -0
- rasa/core/channels/inspector/dist/assets/init-77b53fdd.js +1 -0
- rasa/core/channels/inspector/dist/assets/journeyDiagram-df861f2b-e8579ac6.js +139 -0
- rasa/core/channels/inspector/dist/assets/lato-v14-latin-700-60c05ee4.woff +0 -0
- rasa/core/channels/inspector/dist/assets/lato-v14-latin-700-8335d9b8.svg +438 -0
- rasa/core/channels/inspector/dist/assets/lato-v14-latin-700-9cc39c75.ttf +0 -0
- rasa/core/channels/inspector/dist/assets/lato-v14-latin-700-ead13ccf.woff2 +0 -0
- rasa/core/channels/inspector/dist/assets/lato-v14-latin-regular-16705655.woff2 +0 -0
- rasa/core/channels/inspector/dist/assets/lato-v14-latin-regular-5aeb07f9.woff +0 -0
- rasa/core/channels/inspector/dist/assets/lato-v14-latin-regular-9c459044.ttf +0 -0
- rasa/core/channels/inspector/dist/assets/lato-v14-latin-regular-9e2898a4.svg +435 -0
- rasa/core/channels/inspector/dist/assets/layout-89e6403a.js +1 -0
- rasa/core/channels/inspector/dist/assets/line-dc73d3fc.js +1 -0
- rasa/core/channels/inspector/dist/assets/linear-f5b1d2bc.js +1 -0
- rasa/core/channels/inspector/dist/assets/mindmap-definition-beec6740-82cb74fa.js +109 -0
- rasa/core/channels/inspector/dist/assets/ordinal-ba9b4969.js +1 -0
- rasa/core/channels/inspector/dist/assets/path-53f90ab3.js +1 -0
- rasa/core/channels/inspector/dist/assets/pieDiagram-dbbf0591-bdf5f29b.js +35 -0
- rasa/core/channels/inspector/dist/assets/quadrantDiagram-4d7f4fd6-c7a0cbe4.js +7 -0
- rasa/core/channels/inspector/dist/assets/requirementDiagram-6fc4c22a-7ec5410f.js +52 -0
- rasa/core/channels/inspector/dist/assets/sankeyDiagram-8f13d901-caee5554.js +8 -0
- rasa/core/channels/inspector/dist/assets/sequenceDiagram-b655622a-2935f8db.js +122 -0
- rasa/core/channels/inspector/dist/assets/stateDiagram-59f0c015-8f5d9693.js +1 -0
- rasa/core/channels/inspector/dist/assets/stateDiagram-v2-2b26beab-d565d1de.js +1 -0
- rasa/core/channels/inspector/dist/assets/styles-080da4f6-75ad421d.js +110 -0
- rasa/core/channels/inspector/dist/assets/styles-3dcbcfbf-7e764226.js +159 -0
- rasa/core/channels/inspector/dist/assets/styles-9c745c82-7a4e0e61.js +207 -0
- rasa/core/channels/inspector/dist/assets/svgDrawCommon-4835440b-4019d1bf.js +1 -0
- rasa/core/channels/inspector/dist/assets/timeline-definition-5b62e21b-01ea12df.js +61 -0
- rasa/core/channels/inspector/dist/assets/xychartDiagram-2b33534f-89407137.js +7 -0
- rasa/core/channels/inspector/dist/index.html +42 -0
- rasa/core/channels/inspector/index.html +40 -0
- rasa/core/channels/inspector/jest.config.ts +13 -0
- rasa/core/channels/inspector/package.json +52 -0
- rasa/core/channels/inspector/setupTests.ts +2 -0
- rasa/core/channels/inspector/src/App.tsx +220 -0
- rasa/core/channels/inspector/src/components/Chat.tsx +95 -0
- rasa/core/channels/inspector/src/components/DiagramFlow.tsx +108 -0
- rasa/core/channels/inspector/src/components/DialogueInformation.tsx +187 -0
- rasa/core/channels/inspector/src/components/DialogueStack.tsx +136 -0
- rasa/core/channels/inspector/src/components/ExpandIcon.tsx +16 -0
- rasa/core/channels/inspector/src/components/FullscreenButton.tsx +45 -0
- rasa/core/channels/inspector/src/components/LoadingSpinner.tsx +22 -0
- rasa/core/channels/inspector/src/components/NoActiveFlow.tsx +21 -0
- rasa/core/channels/inspector/src/components/RasaLogo.tsx +32 -0
- rasa/core/channels/inspector/src/components/SaraDiagrams.tsx +39 -0
- rasa/core/channels/inspector/src/components/Slots.tsx +91 -0
- rasa/core/channels/inspector/src/components/Welcome.tsx +54 -0
- rasa/core/channels/inspector/src/helpers/audiostream.ts +191 -0
- rasa/core/channels/inspector/src/helpers/formatters.test.ts +392 -0
- rasa/core/channels/inspector/src/helpers/formatters.ts +306 -0
- rasa/core/channels/inspector/src/helpers/utils.ts +127 -0
- rasa/core/channels/inspector/src/main.tsx +13 -0
- rasa/core/channels/inspector/src/theme/Button/Button.ts +29 -0
- rasa/core/channels/inspector/src/theme/Heading/Heading.ts +31 -0
- rasa/core/channels/inspector/src/theme/Input/Input.ts +27 -0
- rasa/core/channels/inspector/src/theme/Link/Link.ts +10 -0
- rasa/core/channels/inspector/src/theme/Modal/Modal.ts +47 -0
- rasa/core/channels/inspector/src/theme/Table/Table.tsx +38 -0
- rasa/core/channels/inspector/src/theme/Tooltip/Tooltip.ts +12 -0
- rasa/core/channels/inspector/src/theme/base/breakpoints.ts +8 -0
- rasa/core/channels/inspector/src/theme/base/colors.ts +88 -0
- rasa/core/channels/inspector/src/theme/base/fonts/fontFaces.css +29 -0
- rasa/core/channels/inspector/src/theme/base/fonts/ibm-plex-mono-v4-latin/ibm-plex-mono-v4-latin-regular.eot +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/ibm-plex-mono-v4-latin/ibm-plex-mono-v4-latin-regular.svg +329 -0
- rasa/core/channels/inspector/src/theme/base/fonts/ibm-plex-mono-v4-latin/ibm-plex-mono-v4-latin-regular.ttf +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/ibm-plex-mono-v4-latin/ibm-plex-mono-v4-latin-regular.woff +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/ibm-plex-mono-v4-latin/ibm-plex-mono-v4-latin-regular.woff2 +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-700.eot +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-700.svg +438 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-700.ttf +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-700.woff +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-700.woff2 +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-regular.eot +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-regular.svg +435 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-regular.ttf +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-regular.woff +0 -0
- rasa/core/channels/inspector/src/theme/base/fonts/lato-v14-latin/lato-v14-latin-regular.woff2 +0 -0
- rasa/core/channels/inspector/src/theme/base/radii.ts +9 -0
- rasa/core/channels/inspector/src/theme/base/shadows.ts +7 -0
- rasa/core/channels/inspector/src/theme/base/sizes.ts +7 -0
- rasa/core/channels/inspector/src/theme/base/space.ts +15 -0
- rasa/core/channels/inspector/src/theme/base/styles.ts +13 -0
- rasa/core/channels/inspector/src/theme/base/typography.ts +24 -0
- rasa/core/channels/inspector/src/theme/base/zIndices.ts +19 -0
- rasa/core/channels/inspector/src/theme/index.ts +101 -0
- rasa/core/channels/inspector/src/types.ts +84 -0
- rasa/core/channels/inspector/src/vite-env.d.ts +1 -0
- rasa/core/channels/inspector/tests/__mocks__/fileMock.ts +1 -0
- rasa/core/channels/inspector/tests/__mocks__/matchMedia.ts +16 -0
- rasa/core/channels/inspector/tests/__mocks__/styleMock.ts +1 -0
- rasa/core/channels/inspector/tests/renderWithProviders.tsx +14 -0
- rasa/core/channels/inspector/tsconfig.json +26 -0
- rasa/core/channels/inspector/tsconfig.node.json +10 -0
- rasa/core/channels/inspector/vite.config.ts +8 -0
- rasa/core/channels/inspector/yarn.lock +6249 -0
- rasa/core/channels/mattermost.py +229 -0
- rasa/core/channels/rasa_chat.py +126 -0
- rasa/core/channels/rest.py +230 -0
- rasa/core/channels/rocketchat.py +174 -0
- rasa/core/channels/slack.py +620 -0
- rasa/core/channels/socketio.py +302 -0
- rasa/core/channels/telegram.py +298 -0
- rasa/core/channels/twilio.py +169 -0
- rasa/core/channels/vier_cvg.py +374 -0
- rasa/core/channels/voice_ready/__init__.py +0 -0
- rasa/core/channels/voice_ready/audiocodes.py +501 -0
- rasa/core/channels/voice_ready/jambonz.py +121 -0
- rasa/core/channels/voice_ready/jambonz_protocol.py +396 -0
- rasa/core/channels/voice_ready/twilio_voice.py +403 -0
- rasa/core/channels/voice_ready/utils.py +37 -0
- rasa/core/channels/voice_stream/__init__.py +0 -0
- rasa/core/channels/voice_stream/asr/__init__.py +0 -0
- rasa/core/channels/voice_stream/asr/asr_engine.py +89 -0
- rasa/core/channels/voice_stream/asr/asr_event.py +18 -0
- rasa/core/channels/voice_stream/asr/azure.py +130 -0
- rasa/core/channels/voice_stream/asr/deepgram.py +90 -0
- rasa/core/channels/voice_stream/audio_bytes.py +8 -0
- rasa/core/channels/voice_stream/browser_audio.py +107 -0
- rasa/core/channels/voice_stream/call_state.py +23 -0
- rasa/core/channels/voice_stream/tts/__init__.py +0 -0
- rasa/core/channels/voice_stream/tts/azure.py +106 -0
- rasa/core/channels/voice_stream/tts/cartesia.py +118 -0
- rasa/core/channels/voice_stream/tts/tts_cache.py +27 -0
- rasa/core/channels/voice_stream/tts/tts_engine.py +58 -0
- rasa/core/channels/voice_stream/twilio_media_streams.py +173 -0
- rasa/core/channels/voice_stream/util.py +57 -0
- rasa/core/channels/voice_stream/voice_channel.py +427 -0
- rasa/core/channels/webexteams.py +134 -0
- rasa/core/concurrent_lock_store.py +210 -0
- rasa/core/constants.py +112 -0
- rasa/core/evaluation/__init__.py +0 -0
- rasa/core/evaluation/marker.py +267 -0
- rasa/core/evaluation/marker_base.py +923 -0
- rasa/core/evaluation/marker_stats.py +293 -0
- rasa/core/evaluation/marker_tracker_loader.py +103 -0
- rasa/core/exceptions.py +29 -0
- rasa/core/exporter.py +284 -0
- rasa/core/featurizers/__init__.py +0 -0
- rasa/core/featurizers/precomputation.py +410 -0
- rasa/core/featurizers/single_state_featurizer.py +421 -0
- rasa/core/featurizers/tracker_featurizers.py +1262 -0
- rasa/core/http_interpreter.py +89 -0
- rasa/core/information_retrieval/__init__.py +7 -0
- rasa/core/information_retrieval/faiss.py +124 -0
- rasa/core/information_retrieval/information_retrieval.py +137 -0
- rasa/core/information_retrieval/milvus.py +59 -0
- rasa/core/information_retrieval/qdrant.py +96 -0
- rasa/core/jobs.py +63 -0
- rasa/core/lock.py +139 -0
- rasa/core/lock_store.py +343 -0
- rasa/core/migrate.py +403 -0
- rasa/core/nlg/__init__.py +3 -0
- rasa/core/nlg/callback.py +146 -0
- rasa/core/nlg/contextual_response_rephraser.py +320 -0
- rasa/core/nlg/generator.py +230 -0
- rasa/core/nlg/interpolator.py +143 -0
- rasa/core/nlg/response.py +155 -0
- rasa/core/nlg/summarize.py +70 -0
- rasa/core/persistor.py +538 -0
- rasa/core/policies/__init__.py +0 -0
- rasa/core/policies/ensemble.py +329 -0
- rasa/core/policies/enterprise_search_policy.py +905 -0
- rasa/core/policies/enterprise_search_prompt_template.jinja2 +25 -0
- rasa/core/policies/enterprise_search_prompt_with_citation_template.jinja2 +60 -0
- rasa/core/policies/flow_policy.py +205 -0
- rasa/core/policies/flows/__init__.py +0 -0
- rasa/core/policies/flows/flow_exceptions.py +44 -0
- rasa/core/policies/flows/flow_executor.py +754 -0
- rasa/core/policies/flows/flow_step_result.py +43 -0
- rasa/core/policies/intentless_policy.py +1031 -0
- rasa/core/policies/intentless_prompt_template.jinja2 +22 -0
- rasa/core/policies/memoization.py +538 -0
- rasa/core/policies/policy.py +725 -0
- rasa/core/policies/rule_policy.py +1273 -0
- rasa/core/policies/ted_policy.py +2169 -0
- rasa/core/policies/unexpected_intent_policy.py +1022 -0
- rasa/core/processor.py +1465 -0
- rasa/core/run.py +342 -0
- rasa/core/secrets_manager/__init__.py +0 -0
- rasa/core/secrets_manager/constants.py +36 -0
- rasa/core/secrets_manager/endpoints.py +391 -0
- rasa/core/secrets_manager/factory.py +241 -0
- rasa/core/secrets_manager/secret_manager.py +262 -0
- rasa/core/secrets_manager/vault.py +584 -0
- rasa/core/test.py +1335 -0
- rasa/core/tracker_store.py +1703 -0
- rasa/core/train.py +105 -0
- rasa/core/training/__init__.py +89 -0
- rasa/core/training/converters/__init__.py +0 -0
- rasa/core/training/converters/responses_prefix_converter.py +119 -0
- rasa/core/training/interactive.py +1744 -0
- rasa/core/training/story_conflict.py +381 -0
- rasa/core/training/training.py +93 -0
- rasa/core/utils.py +366 -0
- rasa/core/visualize.py +70 -0
- rasa/dialogue_understanding/__init__.py +0 -0
- rasa/dialogue_understanding/coexistence/__init__.py +0 -0
- rasa/dialogue_understanding/coexistence/constants.py +4 -0
- rasa/dialogue_understanding/coexistence/intent_based_router.py +196 -0
- rasa/dialogue_understanding/coexistence/llm_based_router.py +327 -0
- rasa/dialogue_understanding/coexistence/router_template.jinja2 +12 -0
- rasa/dialogue_understanding/commands/__init__.py +61 -0
- rasa/dialogue_understanding/commands/can_not_handle_command.py +70 -0
- rasa/dialogue_understanding/commands/cancel_flow_command.py +125 -0
- rasa/dialogue_understanding/commands/change_flow_command.py +44 -0
- rasa/dialogue_understanding/commands/chit_chat_answer_command.py +57 -0
- rasa/dialogue_understanding/commands/clarify_command.py +86 -0
- rasa/dialogue_understanding/commands/command.py +85 -0
- rasa/dialogue_understanding/commands/correct_slots_command.py +297 -0
- rasa/dialogue_understanding/commands/error_command.py +79 -0
- rasa/dialogue_understanding/commands/free_form_answer_command.py +9 -0
- rasa/dialogue_understanding/commands/handle_code_change_command.py +73 -0
- rasa/dialogue_understanding/commands/human_handoff_command.py +66 -0
- rasa/dialogue_understanding/commands/knowledge_answer_command.py +57 -0
- rasa/dialogue_understanding/commands/noop_command.py +54 -0
- rasa/dialogue_understanding/commands/repeat_bot_messages_command.py +60 -0
- rasa/dialogue_understanding/commands/restart_command.py +58 -0
- rasa/dialogue_understanding/commands/session_end_command.py +61 -0
- rasa/dialogue_understanding/commands/session_start_command.py +59 -0
- rasa/dialogue_understanding/commands/set_slot_command.py +160 -0
- rasa/dialogue_understanding/commands/skip_question_command.py +75 -0
- rasa/dialogue_understanding/commands/start_flow_command.py +107 -0
- rasa/dialogue_understanding/commands/user_silence_command.py +59 -0
- rasa/dialogue_understanding/commands/utils.py +45 -0
- rasa/dialogue_understanding/generator/__init__.py +21 -0
- rasa/dialogue_understanding/generator/command_generator.py +464 -0
- rasa/dialogue_understanding/generator/constants.py +27 -0
- rasa/dialogue_understanding/generator/flow_document_template.jinja2 +4 -0
- rasa/dialogue_understanding/generator/flow_retrieval.py +466 -0
- rasa/dialogue_understanding/generator/llm_based_command_generator.py +500 -0
- rasa/dialogue_understanding/generator/llm_command_generator.py +67 -0
- rasa/dialogue_understanding/generator/multi_step/__init__.py +0 -0
- rasa/dialogue_understanding/generator/multi_step/fill_slots_prompt.jinja2 +62 -0
- rasa/dialogue_understanding/generator/multi_step/handle_flows_prompt.jinja2 +38 -0
- rasa/dialogue_understanding/generator/multi_step/multi_step_llm_command_generator.py +920 -0
- rasa/dialogue_understanding/generator/nlu_command_adapter.py +261 -0
- rasa/dialogue_understanding/generator/single_step/__init__.py +0 -0
- rasa/dialogue_understanding/generator/single_step/command_prompt_template.jinja2 +60 -0
- rasa/dialogue_understanding/generator/single_step/single_step_llm_command_generator.py +486 -0
- rasa/dialogue_understanding/patterns/__init__.py +0 -0
- rasa/dialogue_understanding/patterns/cancel.py +111 -0
- rasa/dialogue_understanding/patterns/cannot_handle.py +43 -0
- rasa/dialogue_understanding/patterns/chitchat.py +37 -0
- rasa/dialogue_understanding/patterns/clarify.py +97 -0
- rasa/dialogue_understanding/patterns/code_change.py +41 -0
- rasa/dialogue_understanding/patterns/collect_information.py +90 -0
- rasa/dialogue_understanding/patterns/completed.py +40 -0
- rasa/dialogue_understanding/patterns/continue_interrupted.py +42 -0
- rasa/dialogue_understanding/patterns/correction.py +278 -0
- rasa/dialogue_understanding/patterns/default_flows_for_patterns.yml +301 -0
- rasa/dialogue_understanding/patterns/human_handoff.py +37 -0
- rasa/dialogue_understanding/patterns/internal_error.py +47 -0
- rasa/dialogue_understanding/patterns/repeat.py +37 -0
- rasa/dialogue_understanding/patterns/restart.py +37 -0
- rasa/dialogue_understanding/patterns/search.py +37 -0
- rasa/dialogue_understanding/patterns/session_start.py +37 -0
- rasa/dialogue_understanding/patterns/skip_question.py +38 -0
- rasa/dialogue_understanding/patterns/user_silence.py +37 -0
- rasa/dialogue_understanding/processor/__init__.py +0 -0
- rasa/dialogue_understanding/processor/command_processor.py +720 -0
- rasa/dialogue_understanding/processor/command_processor_component.py +43 -0
- rasa/dialogue_understanding/stack/__init__.py +0 -0
- rasa/dialogue_understanding/stack/dialogue_stack.py +178 -0
- rasa/dialogue_understanding/stack/frames/__init__.py +19 -0
- rasa/dialogue_understanding/stack/frames/chit_chat_frame.py +27 -0
- rasa/dialogue_understanding/stack/frames/dialogue_stack_frame.py +137 -0
- rasa/dialogue_understanding/stack/frames/flow_stack_frame.py +157 -0
- rasa/dialogue_understanding/stack/frames/pattern_frame.py +10 -0
- rasa/dialogue_understanding/stack/frames/search_frame.py +27 -0
- rasa/dialogue_understanding/stack/utils.py +211 -0
- rasa/dialogue_understanding/utils.py +14 -0
- rasa/dialogue_understanding_test/__init__.py +0 -0
- rasa/dialogue_understanding_test/command_metric_calculation.py +12 -0
- rasa/dialogue_understanding_test/constants.py +17 -0
- rasa/dialogue_understanding_test/du_test_case.py +118 -0
- rasa/dialogue_understanding_test/du_test_result.py +11 -0
- rasa/dialogue_understanding_test/du_test_runner.py +93 -0
- rasa/dialogue_understanding_test/io.py +54 -0
- rasa/dialogue_understanding_test/validation.py +22 -0
- rasa/e2e_test/__init__.py +0 -0
- rasa/e2e_test/aggregate_test_stats_calculator.py +134 -0
- rasa/e2e_test/assertions.py +1345 -0
- rasa/e2e_test/assertions_schema.yml +129 -0
- rasa/e2e_test/constants.py +31 -0
- rasa/e2e_test/e2e_config.py +220 -0
- rasa/e2e_test/e2e_config_schema.yml +26 -0
- rasa/e2e_test/e2e_test_case.py +569 -0
- rasa/e2e_test/e2e_test_converter.py +363 -0
- rasa/e2e_test/e2e_test_converter_prompt.jinja2 +70 -0
- rasa/e2e_test/e2e_test_coverage_report.py +364 -0
- rasa/e2e_test/e2e_test_result.py +54 -0
- rasa/e2e_test/e2e_test_runner.py +1192 -0
- rasa/e2e_test/e2e_test_schema.yml +181 -0
- rasa/e2e_test/pykwalify_extensions.py +39 -0
- rasa/e2e_test/stub_custom_action.py +70 -0
- rasa/e2e_test/utils/__init__.py +0 -0
- rasa/e2e_test/utils/e2e_yaml_utils.py +55 -0
- rasa/e2e_test/utils/io.py +598 -0
- rasa/e2e_test/utils/validation.py +178 -0
- rasa/engine/__init__.py +0 -0
- rasa/engine/caching.py +463 -0
- rasa/engine/constants.py +17 -0
- rasa/engine/exceptions.py +14 -0
- rasa/engine/graph.py +642 -0
- rasa/engine/loader.py +48 -0
- rasa/engine/recipes/__init__.py +0 -0
- rasa/engine/recipes/config_files/default_config.yml +41 -0
- rasa/engine/recipes/default_components.py +97 -0
- rasa/engine/recipes/default_recipe.py +1272 -0
- rasa/engine/recipes/graph_recipe.py +79 -0
- rasa/engine/recipes/recipe.py +93 -0
- rasa/engine/runner/__init__.py +0 -0
- rasa/engine/runner/dask.py +250 -0
- rasa/engine/runner/interface.py +49 -0
- rasa/engine/storage/__init__.py +0 -0
- rasa/engine/storage/local_model_storage.py +244 -0
- rasa/engine/storage/resource.py +110 -0
- rasa/engine/storage/storage.py +199 -0
- rasa/engine/training/__init__.py +0 -0
- rasa/engine/training/components.py +176 -0
- rasa/engine/training/fingerprinting.py +64 -0
- rasa/engine/training/graph_trainer.py +256 -0
- rasa/engine/training/hooks.py +164 -0
- rasa/engine/validation.py +1451 -0
- rasa/env.py +14 -0
- rasa/exceptions.py +69 -0
- rasa/graph_components/__init__.py +0 -0
- rasa/graph_components/converters/__init__.py +0 -0
- rasa/graph_components/converters/nlu_message_converter.py +48 -0
- rasa/graph_components/providers/__init__.py +0 -0
- rasa/graph_components/providers/domain_for_core_training_provider.py +87 -0
- rasa/graph_components/providers/domain_provider.py +71 -0
- rasa/graph_components/providers/flows_provider.py +74 -0
- rasa/graph_components/providers/forms_provider.py +44 -0
- rasa/graph_components/providers/nlu_training_data_provider.py +56 -0
- rasa/graph_components/providers/responses_provider.py +44 -0
- rasa/graph_components/providers/rule_only_provider.py +49 -0
- rasa/graph_components/providers/story_graph_provider.py +96 -0
- rasa/graph_components/providers/training_tracker_provider.py +55 -0
- rasa/graph_components/validators/__init__.py +0 -0
- rasa/graph_components/validators/default_recipe_validator.py +550 -0
- rasa/graph_components/validators/finetuning_validator.py +302 -0
- rasa/hooks.py +111 -0
- rasa/jupyter.py +63 -0
- rasa/llm_fine_tuning/__init__.py +0 -0
- rasa/llm_fine_tuning/annotation_module.py +241 -0
- rasa/llm_fine_tuning/conversations.py +144 -0
- rasa/llm_fine_tuning/llm_data_preparation_module.py +178 -0
- rasa/llm_fine_tuning/paraphrasing/__init__.py +0 -0
- rasa/llm_fine_tuning/paraphrasing/conversation_rephraser.py +281 -0
- rasa/llm_fine_tuning/paraphrasing/default_rephrase_prompt_template.jina2 +44 -0
- rasa/llm_fine_tuning/paraphrasing/rephrase_validator.py +121 -0
- rasa/llm_fine_tuning/paraphrasing/rephrased_user_message.py +10 -0
- rasa/llm_fine_tuning/paraphrasing_module.py +128 -0
- rasa/llm_fine_tuning/storage.py +174 -0
- rasa/llm_fine_tuning/train_test_split_module.py +441 -0
- rasa/markers/__init__.py +0 -0
- rasa/markers/marker.py +269 -0
- rasa/markers/marker_base.py +828 -0
- rasa/markers/upload.py +74 -0
- rasa/markers/validate.py +21 -0
- rasa/model.py +118 -0
- rasa/model_manager/__init__.py +0 -0
- rasa/model_manager/config.py +40 -0
- rasa/model_manager/model_api.py +559 -0
- rasa/model_manager/runner_service.py +286 -0
- rasa/model_manager/socket_bridge.py +146 -0
- rasa/model_manager/studio_jwt_auth.py +86 -0
- rasa/model_manager/trainer_service.py +325 -0
- rasa/model_manager/utils.py +87 -0
- rasa/model_manager/warm_rasa_process.py +187 -0
- rasa/model_service.py +112 -0
- rasa/model_testing.py +457 -0
- rasa/model_training.py +596 -0
- rasa/nlu/__init__.py +7 -0
- rasa/nlu/classifiers/__init__.py +3 -0
- rasa/nlu/classifiers/classifier.py +5 -0
- rasa/nlu/classifiers/diet_classifier.py +1881 -0
- rasa/nlu/classifiers/fallback_classifier.py +192 -0
- rasa/nlu/classifiers/keyword_intent_classifier.py +188 -0
- rasa/nlu/classifiers/logistic_regression_classifier.py +253 -0
- rasa/nlu/classifiers/mitie_intent_classifier.py +156 -0
- rasa/nlu/classifiers/regex_message_handler.py +56 -0
- rasa/nlu/classifiers/sklearn_intent_classifier.py +330 -0
- rasa/nlu/constants.py +77 -0
- rasa/nlu/convert.py +40 -0
- rasa/nlu/emulators/__init__.py +0 -0
- rasa/nlu/emulators/dialogflow.py +55 -0
- rasa/nlu/emulators/emulator.py +49 -0
- rasa/nlu/emulators/luis.py +86 -0
- rasa/nlu/emulators/no_emulator.py +10 -0
- rasa/nlu/emulators/wit.py +56 -0
- rasa/nlu/extractors/__init__.py +0 -0
- rasa/nlu/extractors/crf_entity_extractor.py +715 -0
- rasa/nlu/extractors/duckling_entity_extractor.py +206 -0
- rasa/nlu/extractors/entity_synonyms.py +178 -0
- rasa/nlu/extractors/extractor.py +470 -0
- rasa/nlu/extractors/mitie_entity_extractor.py +293 -0
- rasa/nlu/extractors/regex_entity_extractor.py +220 -0
- rasa/nlu/extractors/spacy_entity_extractor.py +95 -0
- rasa/nlu/featurizers/__init__.py +0 -0
- rasa/nlu/featurizers/dense_featurizer/__init__.py +0 -0
- rasa/nlu/featurizers/dense_featurizer/convert_featurizer.py +445 -0
- rasa/nlu/featurizers/dense_featurizer/dense_featurizer.py +57 -0
- rasa/nlu/featurizers/dense_featurizer/lm_featurizer.py +768 -0
- rasa/nlu/featurizers/dense_featurizer/mitie_featurizer.py +170 -0
- rasa/nlu/featurizers/dense_featurizer/spacy_featurizer.py +132 -0
- rasa/nlu/featurizers/featurizer.py +89 -0
- rasa/nlu/featurizers/sparse_featurizer/__init__.py +0 -0
- rasa/nlu/featurizers/sparse_featurizer/count_vectors_featurizer.py +867 -0
- rasa/nlu/featurizers/sparse_featurizer/lexical_syntactic_featurizer.py +571 -0
- rasa/nlu/featurizers/sparse_featurizer/regex_featurizer.py +271 -0
- rasa/nlu/featurizers/sparse_featurizer/sparse_featurizer.py +9 -0
- rasa/nlu/model.py +24 -0
- rasa/nlu/run.py +27 -0
- rasa/nlu/selectors/__init__.py +0 -0
- rasa/nlu/selectors/response_selector.py +987 -0
- rasa/nlu/test.py +1940 -0
- rasa/nlu/tokenizers/__init__.py +0 -0
- rasa/nlu/tokenizers/jieba_tokenizer.py +148 -0
- rasa/nlu/tokenizers/mitie_tokenizer.py +75 -0
- rasa/nlu/tokenizers/spacy_tokenizer.py +72 -0
- rasa/nlu/tokenizers/tokenizer.py +239 -0
- rasa/nlu/tokenizers/whitespace_tokenizer.py +95 -0
- rasa/nlu/utils/__init__.py +35 -0
- rasa/nlu/utils/bilou_utils.py +462 -0
- rasa/nlu/utils/hugging_face/__init__.py +0 -0
- rasa/nlu/utils/hugging_face/registry.py +108 -0
- rasa/nlu/utils/hugging_face/transformers_pre_post_processors.py +311 -0
- rasa/nlu/utils/mitie_utils.py +113 -0
- rasa/nlu/utils/pattern_utils.py +168 -0
- rasa/nlu/utils/spacy_utils.py +310 -0
- rasa/plugin.py +90 -0
- rasa/server.py +1588 -0
- rasa/shared/__init__.py +0 -0
- rasa/shared/constants.py +311 -0
- rasa/shared/core/__init__.py +0 -0
- rasa/shared/core/command_payload_reader.py +109 -0
- rasa/shared/core/constants.py +180 -0
- rasa/shared/core/conversation.py +46 -0
- rasa/shared/core/domain.py +2172 -0
- rasa/shared/core/events.py +2559 -0
- rasa/shared/core/flows/__init__.py +7 -0
- rasa/shared/core/flows/flow.py +562 -0
- rasa/shared/core/flows/flow_path.py +84 -0
- rasa/shared/core/flows/flow_step.py +146 -0
- rasa/shared/core/flows/flow_step_links.py +319 -0
- rasa/shared/core/flows/flow_step_sequence.py +70 -0
- rasa/shared/core/flows/flows_list.py +258 -0
- rasa/shared/core/flows/flows_yaml_schema.json +303 -0
- rasa/shared/core/flows/nlu_trigger.py +117 -0
- rasa/shared/core/flows/steps/__init__.py +24 -0
- rasa/shared/core/flows/steps/action.py +56 -0
- rasa/shared/core/flows/steps/call.py +64 -0
- rasa/shared/core/flows/steps/collect.py +112 -0
- rasa/shared/core/flows/steps/constants.py +5 -0
- rasa/shared/core/flows/steps/continuation.py +36 -0
- rasa/shared/core/flows/steps/end.py +22 -0
- rasa/shared/core/flows/steps/internal.py +44 -0
- rasa/shared/core/flows/steps/link.py +51 -0
- rasa/shared/core/flows/steps/no_operation.py +48 -0
- rasa/shared/core/flows/steps/set_slots.py +50 -0
- rasa/shared/core/flows/steps/start.py +30 -0
- rasa/shared/core/flows/utils.py +39 -0
- rasa/shared/core/flows/validation.py +735 -0
- rasa/shared/core/flows/yaml_flows_io.py +405 -0
- rasa/shared/core/generator.py +908 -0
- rasa/shared/core/slot_mappings.py +526 -0
- rasa/shared/core/slots.py +654 -0
- rasa/shared/core/trackers.py +1183 -0
- rasa/shared/core/training_data/__init__.py +0 -0
- rasa/shared/core/training_data/loading.py +89 -0
- rasa/shared/core/training_data/story_reader/__init__.py +0 -0
- rasa/shared/core/training_data/story_reader/story_reader.py +129 -0
- rasa/shared/core/training_data/story_reader/story_step_builder.py +168 -0
- rasa/shared/core/training_data/story_reader/yaml_story_reader.py +888 -0
- rasa/shared/core/training_data/story_writer/__init__.py +0 -0
- rasa/shared/core/training_data/story_writer/story_writer.py +76 -0
- rasa/shared/core/training_data/story_writer/yaml_story_writer.py +444 -0
- rasa/shared/core/training_data/structures.py +858 -0
- rasa/shared/core/training_data/visualization.html +146 -0
- rasa/shared/core/training_data/visualization.py +603 -0
- rasa/shared/data.py +249 -0
- rasa/shared/engine/__init__.py +0 -0
- rasa/shared/engine/caching.py +26 -0
- rasa/shared/exceptions.py +167 -0
- rasa/shared/importers/__init__.py +0 -0
- rasa/shared/importers/importer.py +770 -0
- rasa/shared/importers/multi_project.py +215 -0
- rasa/shared/importers/rasa.py +108 -0
- rasa/shared/importers/remote_importer.py +196 -0
- rasa/shared/importers/utils.py +36 -0
- rasa/shared/nlu/__init__.py +0 -0
- rasa/shared/nlu/constants.py +53 -0
- rasa/shared/nlu/interpreter.py +10 -0
- rasa/shared/nlu/training_data/__init__.py +0 -0
- rasa/shared/nlu/training_data/entities_parser.py +208 -0
- rasa/shared/nlu/training_data/features.py +492 -0
- rasa/shared/nlu/training_data/formats/__init__.py +10 -0
- rasa/shared/nlu/training_data/formats/dialogflow.py +163 -0
- rasa/shared/nlu/training_data/formats/luis.py +87 -0
- rasa/shared/nlu/training_data/formats/rasa.py +135 -0
- rasa/shared/nlu/training_data/formats/rasa_yaml.py +618 -0
- rasa/shared/nlu/training_data/formats/readerwriter.py +244 -0
- rasa/shared/nlu/training_data/formats/wit.py +52 -0
- rasa/shared/nlu/training_data/loading.py +137 -0
- rasa/shared/nlu/training_data/lookup_tables_parser.py +30 -0
- rasa/shared/nlu/training_data/message.py +490 -0
- rasa/shared/nlu/training_data/schemas/__init__.py +0 -0
- rasa/shared/nlu/training_data/schemas/data_schema.py +85 -0
- rasa/shared/nlu/training_data/schemas/nlu.yml +53 -0
- rasa/shared/nlu/training_data/schemas/responses.yml +70 -0
- rasa/shared/nlu/training_data/synonyms_parser.py +42 -0
- rasa/shared/nlu/training_data/training_data.py +729 -0
- rasa/shared/nlu/training_data/util.py +223 -0
- rasa/shared/providers/__init__.py +0 -0
- rasa/shared/providers/_configs/__init__.py +0 -0
- rasa/shared/providers/_configs/azure_openai_client_config.py +677 -0
- rasa/shared/providers/_configs/client_config.py +59 -0
- rasa/shared/providers/_configs/default_litellm_client_config.py +132 -0
- rasa/shared/providers/_configs/huggingface_local_embedding_client_config.py +236 -0
- rasa/shared/providers/_configs/litellm_router_client_config.py +222 -0
- rasa/shared/providers/_configs/model_group_config.py +173 -0
- rasa/shared/providers/_configs/openai_client_config.py +177 -0
- rasa/shared/providers/_configs/rasa_llm_client_config.py +75 -0
- rasa/shared/providers/_configs/self_hosted_llm_client_config.py +178 -0
- rasa/shared/providers/_configs/utils.py +117 -0
- rasa/shared/providers/_ssl_verification_utils.py +124 -0
- rasa/shared/providers/_utils.py +79 -0
- rasa/shared/providers/constants.py +7 -0
- rasa/shared/providers/embedding/__init__.py +0 -0
- rasa/shared/providers/embedding/_base_litellm_embedding_client.py +243 -0
- rasa/shared/providers/embedding/_langchain_embedding_client_adapter.py +74 -0
- rasa/shared/providers/embedding/azure_openai_embedding_client.py +335 -0
- rasa/shared/providers/embedding/default_litellm_embedding_client.py +126 -0
- rasa/shared/providers/embedding/embedding_client.py +90 -0
- rasa/shared/providers/embedding/embedding_response.py +41 -0
- rasa/shared/providers/embedding/huggingface_local_embedding_client.py +191 -0
- rasa/shared/providers/embedding/litellm_router_embedding_client.py +138 -0
- rasa/shared/providers/embedding/openai_embedding_client.py +172 -0
- rasa/shared/providers/llm/__init__.py +0 -0
- rasa/shared/providers/llm/_base_litellm_client.py +265 -0
- rasa/shared/providers/llm/azure_openai_llm_client.py +415 -0
- rasa/shared/providers/llm/default_litellm_llm_client.py +110 -0
- rasa/shared/providers/llm/litellm_router_llm_client.py +202 -0
- rasa/shared/providers/llm/llm_client.py +78 -0
- rasa/shared/providers/llm/llm_response.py +50 -0
- rasa/shared/providers/llm/openai_llm_client.py +161 -0
- rasa/shared/providers/llm/rasa_llm_client.py +120 -0
- rasa/shared/providers/llm/self_hosted_llm_client.py +276 -0
- rasa/shared/providers/mappings.py +94 -0
- rasa/shared/providers/router/__init__.py +0 -0
- rasa/shared/providers/router/_base_litellm_router_client.py +185 -0
- rasa/shared/providers/router/router_client.py +75 -0
- rasa/shared/utils/__init__.py +0 -0
- rasa/shared/utils/cli.py +102 -0
- rasa/shared/utils/common.py +324 -0
- rasa/shared/utils/constants.py +4 -0
- rasa/shared/utils/health_check/__init__.py +0 -0
- rasa/shared/utils/health_check/embeddings_health_check_mixin.py +31 -0
- rasa/shared/utils/health_check/health_check.py +258 -0
- rasa/shared/utils/health_check/llm_health_check_mixin.py +31 -0
- rasa/shared/utils/io.py +499 -0
- rasa/shared/utils/llm.py +764 -0
- rasa/shared/utils/pykwalify_extensions.py +27 -0
- rasa/shared/utils/schemas/__init__.py +0 -0
- rasa/shared/utils/schemas/config.yml +2 -0
- rasa/shared/utils/schemas/domain.yml +145 -0
- rasa/shared/utils/schemas/events.py +214 -0
- rasa/shared/utils/schemas/model_config.yml +36 -0
- rasa/shared/utils/schemas/stories.yml +173 -0
- rasa/shared/utils/yaml.py +1068 -0
- rasa/studio/__init__.py +0 -0
- rasa/studio/auth.py +270 -0
- rasa/studio/config.py +136 -0
- rasa/studio/constants.py +19 -0
- rasa/studio/data_handler.py +368 -0
- rasa/studio/download.py +489 -0
- rasa/studio/results_logger.py +137 -0
- rasa/studio/train.py +134 -0
- rasa/studio/upload.py +563 -0
- rasa/telemetry.py +1876 -0
- rasa/tracing/__init__.py +0 -0
- rasa/tracing/config.py +355 -0
- rasa/tracing/constants.py +62 -0
- rasa/tracing/instrumentation/__init__.py +0 -0
- rasa/tracing/instrumentation/attribute_extractors.py +765 -0
- rasa/tracing/instrumentation/instrumentation.py +1306 -0
- rasa/tracing/instrumentation/intentless_policy_instrumentation.py +144 -0
- rasa/tracing/instrumentation/metrics.py +294 -0
- rasa/tracing/metric_instrument_provider.py +205 -0
- rasa/utils/__init__.py +0 -0
- rasa/utils/beta.py +83 -0
- rasa/utils/cli.py +28 -0
- rasa/utils/common.py +639 -0
- rasa/utils/converter.py +53 -0
- rasa/utils/endpoints.py +331 -0
- rasa/utils/io.py +252 -0
- rasa/utils/json_utils.py +60 -0
- rasa/utils/licensing.py +542 -0
- rasa/utils/log_utils.py +181 -0
- rasa/utils/mapper.py +210 -0
- rasa/utils/ml_utils.py +147 -0
- rasa/utils/plotting.py +362 -0
- rasa/utils/sanic_error_handler.py +32 -0
- rasa/utils/singleton.py +23 -0
- rasa/utils/tensorflow/__init__.py +0 -0
- rasa/utils/tensorflow/callback.py +112 -0
- rasa/utils/tensorflow/constants.py +116 -0
- rasa/utils/tensorflow/crf.py +492 -0
- rasa/utils/tensorflow/data_generator.py +440 -0
- rasa/utils/tensorflow/environment.py +161 -0
- rasa/utils/tensorflow/exceptions.py +5 -0
- rasa/utils/tensorflow/feature_array.py +366 -0
- rasa/utils/tensorflow/layers.py +1565 -0
- rasa/utils/tensorflow/layers_utils.py +113 -0
- rasa/utils/tensorflow/metrics.py +281 -0
- rasa/utils/tensorflow/model_data.py +798 -0
- rasa/utils/tensorflow/model_data_utils.py +499 -0
- rasa/utils/tensorflow/models.py +935 -0
- rasa/utils/tensorflow/rasa_layers.py +1094 -0
- rasa/utils/tensorflow/transformer.py +640 -0
- rasa/utils/tensorflow/types.py +6 -0
- rasa/utils/train_utils.py +572 -0
- rasa/utils/url_tools.py +53 -0
- rasa/utils/yaml.py +54 -0
- rasa/validator.py +1644 -0
- rasa/version.py +3 -0
- rasa_pro-3.12.0.dev1.dist-info/METADATA +199 -0
- rasa_pro-3.12.0.dev1.dist-info/NOTICE +5 -0
- rasa_pro-3.12.0.dev1.dist-info/RECORD +790 -0
- rasa_pro-3.12.0.dev1.dist-info/WHEEL +4 -0
- rasa_pro-3.12.0.dev1.dist-info/entry_points.txt +3 -0
|
@@ -0,0 +1,905 @@
|
|
|
1
|
+
import importlib.resources
|
|
2
|
+
import json
|
|
3
|
+
import re
|
|
4
|
+
from typing import TYPE_CHECKING, Any, Dict, List, Optional, Text
|
|
5
|
+
import dotenv
|
|
6
|
+
import structlog
|
|
7
|
+
from jinja2 import Template
|
|
8
|
+
from pydantic import ValidationError
|
|
9
|
+
|
|
10
|
+
import rasa.shared.utils.io
|
|
11
|
+
from rasa.core.constants import (
|
|
12
|
+
POLICY_MAX_HISTORY,
|
|
13
|
+
POLICY_PRIORITY,
|
|
14
|
+
SEARCH_POLICY_PRIORITY,
|
|
15
|
+
UTTER_SOURCE_METADATA_KEY,
|
|
16
|
+
)
|
|
17
|
+
from rasa.core.information_retrieval import (
|
|
18
|
+
InformationRetrieval,
|
|
19
|
+
SearchResult,
|
|
20
|
+
InformationRetrievalException,
|
|
21
|
+
create_from_endpoint_config,
|
|
22
|
+
)
|
|
23
|
+
from rasa.core.information_retrieval.faiss import FAISS_Store
|
|
24
|
+
from rasa.core.policies.policy import Policy, PolicyPrediction
|
|
25
|
+
from rasa.core.utils import AvailableEndpoints
|
|
26
|
+
from rasa.dialogue_understanding.generator.constants import (
|
|
27
|
+
LLM_CONFIG_KEY,
|
|
28
|
+
)
|
|
29
|
+
from rasa.dialogue_understanding.patterns.cannot_handle import (
|
|
30
|
+
CannotHandlePatternFlowStackFrame,
|
|
31
|
+
)
|
|
32
|
+
from rasa.dialogue_understanding.patterns.internal_error import (
|
|
33
|
+
InternalErrorPatternFlowStackFrame,
|
|
34
|
+
)
|
|
35
|
+
from rasa.dialogue_understanding.stack.frames import (
|
|
36
|
+
DialogueStackFrame,
|
|
37
|
+
SearchStackFrame,
|
|
38
|
+
)
|
|
39
|
+
from rasa.dialogue_understanding.stack.frames import PatternFlowStackFrame
|
|
40
|
+
from rasa.engine.graph import ExecutionContext
|
|
41
|
+
from rasa.engine.recipes.default_recipe import DefaultV1Recipe
|
|
42
|
+
from rasa.engine.storage.resource import Resource
|
|
43
|
+
from rasa.engine.storage.storage import ModelStorage
|
|
44
|
+
from rasa.graph_components.providers.forms_provider import Forms
|
|
45
|
+
from rasa.graph_components.providers.responses_provider import Responses
|
|
46
|
+
from rasa.shared.constants import (
|
|
47
|
+
EMBEDDINGS_CONFIG_KEY,
|
|
48
|
+
MODEL_CONFIG_KEY,
|
|
49
|
+
PROMPT_CONFIG_KEY,
|
|
50
|
+
PROVIDER_CONFIG_KEY,
|
|
51
|
+
OPENAI_PROVIDER,
|
|
52
|
+
TIMEOUT_CONFIG_KEY,
|
|
53
|
+
MODEL_NAME_CONFIG_KEY,
|
|
54
|
+
MODEL_GROUP_ID_CONFIG_KEY,
|
|
55
|
+
)
|
|
56
|
+
from rasa.shared.core.constants import (
|
|
57
|
+
ACTION_CANCEL_FLOW,
|
|
58
|
+
ACTION_SEND_TEXT_NAME,
|
|
59
|
+
DEFAULT_SLOT_NAMES,
|
|
60
|
+
)
|
|
61
|
+
from rasa.shared.core.domain import Domain
|
|
62
|
+
from rasa.shared.core.events import Event, UserUttered, BotUttered
|
|
63
|
+
from rasa.shared.core.generator import TrackerWithCachedStates
|
|
64
|
+
from rasa.shared.core.trackers import DialogueStateTracker, EventVerbosity
|
|
65
|
+
from rasa.shared.exceptions import RasaException, FileIOException
|
|
66
|
+
from rasa.shared.nlu.training_data.training_data import TrainingData
|
|
67
|
+
from rasa.shared.providers.embedding._langchain_embedding_client_adapter import (
|
|
68
|
+
_LangchainEmbeddingClientAdapter,
|
|
69
|
+
)
|
|
70
|
+
from rasa.shared.providers.llm.llm_client import LLMClient
|
|
71
|
+
from rasa.shared.utils.cli import print_error_and_exit
|
|
72
|
+
from rasa.shared.utils.health_check.embeddings_health_check_mixin import (
|
|
73
|
+
EmbeddingsHealthCheckMixin,
|
|
74
|
+
)
|
|
75
|
+
from rasa.shared.utils.health_check.llm_health_check_mixin import LLMHealthCheckMixin
|
|
76
|
+
from rasa.shared.utils.io import deep_container_fingerprint
|
|
77
|
+
from rasa.shared.utils.llm import (
|
|
78
|
+
DEFAULT_OPENAI_CHAT_MODEL_NAME,
|
|
79
|
+
DEFAULT_OPENAI_EMBEDDING_MODEL_NAME,
|
|
80
|
+
embedder_factory,
|
|
81
|
+
get_prompt_template,
|
|
82
|
+
llm_factory,
|
|
83
|
+
sanitize_message_for_prompt,
|
|
84
|
+
tracker_as_readable_transcript,
|
|
85
|
+
resolve_model_client_config,
|
|
86
|
+
)
|
|
87
|
+
from rasa.telemetry import (
|
|
88
|
+
track_enterprise_search_policy_predict,
|
|
89
|
+
track_enterprise_search_policy_train_completed,
|
|
90
|
+
track_enterprise_search_policy_train_started,
|
|
91
|
+
)
|
|
92
|
+
|
|
93
|
+
if TYPE_CHECKING:
|
|
94
|
+
from langchain.schema.embeddings import Embeddings
|
|
95
|
+
from rasa.core.featurizers.tracker_featurizers import TrackerFeaturizer
|
|
96
|
+
|
|
97
|
+
from rasa.utils.log_utils import log_llm
|
|
98
|
+
|
|
99
|
+
logger = structlog.get_logger()
|
|
100
|
+
|
|
101
|
+
dotenv.load_dotenv("./.env")
|
|
102
|
+
|
|
103
|
+
SOURCE_PROPERTY = "source"
|
|
104
|
+
VECTOR_STORE_TYPE_PROPERTY = "type"
|
|
105
|
+
VECTOR_STORE_PROPERTY = "vector_store"
|
|
106
|
+
VECTOR_STORE_THRESHOLD_PROPERTY = "threshold"
|
|
107
|
+
TRACE_TOKENS_PROPERTY = "trace_prompt_tokens"
|
|
108
|
+
CITATION_ENABLED_PROPERTY = "citation_enabled"
|
|
109
|
+
USE_LLM_PROPERTY = "use_generative_llm"
|
|
110
|
+
MAX_MESSAGES_IN_QUERY_KEY = "max_messages_in_query"
|
|
111
|
+
|
|
112
|
+
DEFAULT_VECTOR_STORE_TYPE = "faiss"
|
|
113
|
+
DEFAULT_VECTOR_STORE_THRESHOLD = 0.0
|
|
114
|
+
DEFAULT_VECTOR_STORE = {
|
|
115
|
+
VECTOR_STORE_TYPE_PROPERTY: DEFAULT_VECTOR_STORE_TYPE,
|
|
116
|
+
SOURCE_PROPERTY: "./docs",
|
|
117
|
+
VECTOR_STORE_THRESHOLD_PROPERTY: DEFAULT_VECTOR_STORE_THRESHOLD,
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
DEFAULT_LLM_CONFIG = {
|
|
121
|
+
PROVIDER_CONFIG_KEY: OPENAI_PROVIDER,
|
|
122
|
+
MODEL_CONFIG_KEY: DEFAULT_OPENAI_CHAT_MODEL_NAME,
|
|
123
|
+
TIMEOUT_CONFIG_KEY: 10,
|
|
124
|
+
"temperature": 0.0,
|
|
125
|
+
"max_tokens": 256,
|
|
126
|
+
"max_retries": 1,
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
DEFAULT_EMBEDDINGS_CONFIG = {
|
|
130
|
+
PROVIDER_CONFIG_KEY: OPENAI_PROVIDER,
|
|
131
|
+
"model": DEFAULT_OPENAI_EMBEDDING_MODEL_NAME,
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
ENTERPRISE_SEARCH_PROMPT_FILE_NAME = "enterprise_search_policy_prompt.jinja2"
|
|
135
|
+
ENTERPRISE_SEARCH_CONFIG_FILE_NAME = "config.json"
|
|
136
|
+
|
|
137
|
+
SEARCH_RESULTS_METADATA_KEY = "search_results"
|
|
138
|
+
SEARCH_QUERY_METADATA_KEY = "search_query"
|
|
139
|
+
|
|
140
|
+
DEFAULT_ENTERPRISE_SEARCH_PROMPT_TEMPLATE = importlib.resources.read_text(
|
|
141
|
+
"rasa.core.policies", "enterprise_search_prompt_template.jinja2"
|
|
142
|
+
)
|
|
143
|
+
|
|
144
|
+
DEFAULT_ENTERPRISE_SEARCH_PROMPT_WITH_CITATION_TEMPLATE = importlib.resources.read_text(
|
|
145
|
+
"rasa.core.policies", "enterprise_search_prompt_with_citation_template.jinja2"
|
|
146
|
+
)
|
|
147
|
+
|
|
148
|
+
|
|
149
|
+
class VectorStoreConnectionError(RasaException):
|
|
150
|
+
"""Exception raised for errors in connecting to the vector store."""
|
|
151
|
+
|
|
152
|
+
|
|
153
|
+
class VectorStoreConfigurationError(RasaException):
|
|
154
|
+
"""Exception raised for errors in vector store configuration."""
|
|
155
|
+
|
|
156
|
+
|
|
157
|
+
@DefaultV1Recipe.register(
|
|
158
|
+
DefaultV1Recipe.ComponentType.POLICY_WITH_END_TO_END_SUPPORT, is_trainable=True
|
|
159
|
+
)
|
|
160
|
+
class EnterpriseSearchPolicy(LLMHealthCheckMixin, EmbeddingsHealthCheckMixin, Policy):
|
|
161
|
+
"""Policy which uses a vector store and LLMs to respond to user messages.
|
|
162
|
+
|
|
163
|
+
The policy uses a vector store and LLMs to respond to user messages. The
|
|
164
|
+
vector store is used to retrieve the most relevant responses to the user
|
|
165
|
+
message. The LLMs are used to rank the responses and select the best
|
|
166
|
+
response. The policy can be used to respond to user messages without
|
|
167
|
+
training data.
|
|
168
|
+
|
|
169
|
+
Example Configuration:
|
|
170
|
+
|
|
171
|
+
policies:
|
|
172
|
+
# - ...
|
|
173
|
+
- name: EnterpriseSearchPolicy
|
|
174
|
+
vector_store:
|
|
175
|
+
type: "milvus"
|
|
176
|
+
<vector_store_config>
|
|
177
|
+
# - ...
|
|
178
|
+
"""
|
|
179
|
+
|
|
180
|
+
@staticmethod
|
|
181
|
+
def does_support_stack_frame(frame: DialogueStackFrame) -> bool:
|
|
182
|
+
"""Checks if the policy supports the given stack frame."""
|
|
183
|
+
return isinstance(frame, SearchStackFrame)
|
|
184
|
+
|
|
185
|
+
@staticmethod
|
|
186
|
+
def get_default_config() -> Dict[str, Any]:
|
|
187
|
+
"""Returns the default config of the policy."""
|
|
188
|
+
return {
|
|
189
|
+
POLICY_PRIORITY: SEARCH_POLICY_PRIORITY,
|
|
190
|
+
VECTOR_STORE_PROPERTY: DEFAULT_VECTOR_STORE,
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
def __init__(
|
|
194
|
+
self,
|
|
195
|
+
config: Dict[Text, Any],
|
|
196
|
+
model_storage: ModelStorage,
|
|
197
|
+
resource: Resource,
|
|
198
|
+
execution_context: ExecutionContext,
|
|
199
|
+
vector_store: Optional[InformationRetrieval] = None,
|
|
200
|
+
featurizer: Optional["TrackerFeaturizer"] = None,
|
|
201
|
+
prompt_template: Optional[Text] = None,
|
|
202
|
+
) -> None:
|
|
203
|
+
"""Constructs a new Policy object."""
|
|
204
|
+
super().__init__(config, model_storage, resource, execution_context, featurizer)
|
|
205
|
+
|
|
206
|
+
# Resolve LLM config
|
|
207
|
+
self.config[LLM_CONFIG_KEY] = resolve_model_client_config(
|
|
208
|
+
self.config.get(LLM_CONFIG_KEY), EnterpriseSearchPolicy.__name__
|
|
209
|
+
)
|
|
210
|
+
# Resolve embeddings config
|
|
211
|
+
self.config[EMBEDDINGS_CONFIG_KEY] = resolve_model_client_config(
|
|
212
|
+
self.config.get(EMBEDDINGS_CONFIG_KEY), EnterpriseSearchPolicy.__name__
|
|
213
|
+
)
|
|
214
|
+
|
|
215
|
+
# Vector store object and configuration
|
|
216
|
+
self.vector_store = vector_store
|
|
217
|
+
self.vector_store_config = self.config.get(
|
|
218
|
+
VECTOR_STORE_PROPERTY, DEFAULT_VECTOR_STORE
|
|
219
|
+
)
|
|
220
|
+
|
|
221
|
+
# Embeddings configuration for encoding the search query
|
|
222
|
+
self.embeddings_config = (
|
|
223
|
+
self.config[EMBEDDINGS_CONFIG_KEY] or DEFAULT_EMBEDDINGS_CONFIG
|
|
224
|
+
)
|
|
225
|
+
|
|
226
|
+
# LLM Configuration for response generation
|
|
227
|
+
self.llm_config = self.config[LLM_CONFIG_KEY] or DEFAULT_LLM_CONFIG
|
|
228
|
+
|
|
229
|
+
# Maximum number of turns to include in the prompt
|
|
230
|
+
self.max_history = self.config.get(POLICY_MAX_HISTORY)
|
|
231
|
+
|
|
232
|
+
# Maximum number of messages to include in the search query
|
|
233
|
+
self.max_messages_in_query = self.config.get(MAX_MESSAGES_IN_QUERY_KEY, 2)
|
|
234
|
+
|
|
235
|
+
# boolean to enable/disable tracing of prompt tokens
|
|
236
|
+
self.trace_prompt_tokens = self.config.get(TRACE_TOKENS_PROPERTY, False)
|
|
237
|
+
|
|
238
|
+
# boolean to enable/disable the use of LLM for response generation
|
|
239
|
+
self.use_llm = self.config.get(USE_LLM_PROPERTY, True)
|
|
240
|
+
|
|
241
|
+
# boolean to enable/disable citation generation
|
|
242
|
+
self.citation_enabled = self.config.get(CITATION_ENABLED_PROPERTY, False)
|
|
243
|
+
|
|
244
|
+
self.prompt_template = prompt_template or get_prompt_template(
|
|
245
|
+
self.config.get(PROMPT_CONFIG_KEY),
|
|
246
|
+
DEFAULT_ENTERPRISE_SEARCH_PROMPT_TEMPLATE,
|
|
247
|
+
)
|
|
248
|
+
self.citation_prompt_template = get_prompt_template(
|
|
249
|
+
self.config.get(PROMPT_CONFIG_KEY),
|
|
250
|
+
DEFAULT_ENTERPRISE_SEARCH_PROMPT_WITH_CITATION_TEMPLATE,
|
|
251
|
+
)
|
|
252
|
+
# If citation is enabled, use the citation prompt template
|
|
253
|
+
if self.citation_enabled:
|
|
254
|
+
self.prompt_template = self.citation_prompt_template
|
|
255
|
+
|
|
256
|
+
@classmethod
|
|
257
|
+
def _create_plain_embedder(cls, config: Dict[Text, Any]) -> "Embeddings":
|
|
258
|
+
"""Creates an embedder based on the given configuration.
|
|
259
|
+
|
|
260
|
+
Returns:
|
|
261
|
+
The embedder.
|
|
262
|
+
"""
|
|
263
|
+
# Copy the config so original config is not modified
|
|
264
|
+
config = config.copy()
|
|
265
|
+
# Resolve config and instantiate the embedding client
|
|
266
|
+
config[EMBEDDINGS_CONFIG_KEY] = resolve_model_client_config(
|
|
267
|
+
config.get(EMBEDDINGS_CONFIG_KEY), EnterpriseSearchPolicy.__name__
|
|
268
|
+
)
|
|
269
|
+
client = embedder_factory(
|
|
270
|
+
config.get(EMBEDDINGS_CONFIG_KEY), DEFAULT_EMBEDDINGS_CONFIG
|
|
271
|
+
)
|
|
272
|
+
# Wrap the embedding client in the adapter
|
|
273
|
+
return _LangchainEmbeddingClientAdapter(client)
|
|
274
|
+
|
|
275
|
+
def train( # type: ignore[override]
|
|
276
|
+
self,
|
|
277
|
+
training_trackers: List[TrackerWithCachedStates],
|
|
278
|
+
domain: Domain,
|
|
279
|
+
responses: Responses,
|
|
280
|
+
forms: Forms,
|
|
281
|
+
training_data: TrainingData,
|
|
282
|
+
**kwargs: Any,
|
|
283
|
+
) -> Resource:
|
|
284
|
+
"""Trains a policy.
|
|
285
|
+
|
|
286
|
+
Args:
|
|
287
|
+
training_trackers: The story and rules trackers from the training data.
|
|
288
|
+
domain: The model's domain.
|
|
289
|
+
responses: The model's responses.
|
|
290
|
+
forms: The model's forms.
|
|
291
|
+
training_data: The model's training data.
|
|
292
|
+
**kwargs: Depending on the specified `needs` section and the resulting
|
|
293
|
+
graph structure the policy can use different input to train itself.
|
|
294
|
+
|
|
295
|
+
Returns:
|
|
296
|
+
A policy must return its resource locator so that potential children nodes
|
|
297
|
+
can load the policy from the resource.
|
|
298
|
+
"""
|
|
299
|
+
# Perform health checks for both LLM and embeddings client configs
|
|
300
|
+
self._perform_health_checks(self.config, "enterprise_search_policy.train")
|
|
301
|
+
|
|
302
|
+
store_type = self.vector_store_config.get(VECTOR_STORE_TYPE_PROPERTY)
|
|
303
|
+
|
|
304
|
+
# telemetry call to track training start
|
|
305
|
+
track_enterprise_search_policy_train_started()
|
|
306
|
+
|
|
307
|
+
# validate embedding configuration
|
|
308
|
+
try:
|
|
309
|
+
embeddings = self._create_plain_embedder(self.config)
|
|
310
|
+
except (ValidationError, Exception) as e:
|
|
311
|
+
logger.error(
|
|
312
|
+
"enterprise_search_policy.train.embedder_instantiation_failed",
|
|
313
|
+
message="Unable to instantiate the embedding client.",
|
|
314
|
+
error=e,
|
|
315
|
+
)
|
|
316
|
+
print_error_and_exit(
|
|
317
|
+
"Unable to create embedder. Please make sure you specified the "
|
|
318
|
+
f"required environment variables. Error: {e}"
|
|
319
|
+
)
|
|
320
|
+
|
|
321
|
+
if store_type == DEFAULT_VECTOR_STORE_TYPE:
|
|
322
|
+
logger.info("enterprise_search_policy.train.faiss")
|
|
323
|
+
with self._model_storage.write_to(self._resource) as path:
|
|
324
|
+
self.vector_store = FAISS_Store(
|
|
325
|
+
docs_folder=self.vector_store_config.get(SOURCE_PROPERTY),
|
|
326
|
+
embeddings=embeddings,
|
|
327
|
+
index_path=path,
|
|
328
|
+
create_index=True,
|
|
329
|
+
)
|
|
330
|
+
else:
|
|
331
|
+
logger.info("enterprise_search_policy.train.custom", store_type=store_type)
|
|
332
|
+
|
|
333
|
+
# telemetry call to track training completion
|
|
334
|
+
track_enterprise_search_policy_train_completed(
|
|
335
|
+
vector_store_type=store_type,
|
|
336
|
+
embeddings_type=self.embeddings_config.get(PROVIDER_CONFIG_KEY),
|
|
337
|
+
embeddings_model=self.embeddings_config.get(MODEL_CONFIG_KEY)
|
|
338
|
+
or self.embeddings_config.get(MODEL_NAME_CONFIG_KEY),
|
|
339
|
+
embeddings_model_group_id=self.embeddings_config.get(
|
|
340
|
+
MODEL_GROUP_ID_CONFIG_KEY
|
|
341
|
+
),
|
|
342
|
+
llm_type=self.llm_config.get(PROVIDER_CONFIG_KEY),
|
|
343
|
+
llm_model=self.llm_config.get(MODEL_CONFIG_KEY)
|
|
344
|
+
or self.llm_config.get(MODEL_NAME_CONFIG_KEY),
|
|
345
|
+
llm_model_group_id=self.llm_config.get(MODEL_GROUP_ID_CONFIG_KEY),
|
|
346
|
+
citation_enabled=self.citation_enabled,
|
|
347
|
+
)
|
|
348
|
+
self.persist()
|
|
349
|
+
return self._resource
|
|
350
|
+
|
|
351
|
+
def persist(self) -> None:
|
|
352
|
+
"""Persists the policy to storage."""
|
|
353
|
+
with self._model_storage.write_to(self._resource) as path:
|
|
354
|
+
rasa.shared.utils.io.write_text_file(
|
|
355
|
+
self.prompt_template, path / ENTERPRISE_SEARCH_PROMPT_FILE_NAME
|
|
356
|
+
)
|
|
357
|
+
rasa.shared.utils.io.dump_obj_as_json_to_file(
|
|
358
|
+
path / ENTERPRISE_SEARCH_CONFIG_FILE_NAME, self.config
|
|
359
|
+
)
|
|
360
|
+
|
|
361
|
+
def _prepare_slots_for_template(
|
|
362
|
+
self, tracker: DialogueStateTracker
|
|
363
|
+
) -> List[Dict[str, str]]:
|
|
364
|
+
"""Prepares the slots for the template.
|
|
365
|
+
|
|
366
|
+
Args:
|
|
367
|
+
tracker: The tracker containing the conversation history up to now.
|
|
368
|
+
|
|
369
|
+
Returns:
|
|
370
|
+
The non-empty slots.
|
|
371
|
+
"""
|
|
372
|
+
template_slots = []
|
|
373
|
+
for name, slot in tracker.slots.items():
|
|
374
|
+
if name not in DEFAULT_SLOT_NAMES and slot.value is not None:
|
|
375
|
+
template_slots.append(
|
|
376
|
+
{
|
|
377
|
+
"name": name,
|
|
378
|
+
"value": str(slot.value),
|
|
379
|
+
"type": slot.type_name,
|
|
380
|
+
}
|
|
381
|
+
)
|
|
382
|
+
return template_slots
|
|
383
|
+
|
|
384
|
+
def _connect_vector_store_or_raise(
|
|
385
|
+
self, endpoints: Optional[AvailableEndpoints]
|
|
386
|
+
) -> None:
|
|
387
|
+
"""Connects to the vector store or raises an exception.
|
|
388
|
+
|
|
389
|
+
Raise exceptions for the following cases:
|
|
390
|
+
- The configuration is not specified
|
|
391
|
+
- Unable to connect to the vector store
|
|
392
|
+
|
|
393
|
+
Args:
|
|
394
|
+
endpoints: Endpoints configuration.
|
|
395
|
+
"""
|
|
396
|
+
config = endpoints.vector_store if endpoints else None
|
|
397
|
+
store_type = self.vector_store_config.get(VECTOR_STORE_TYPE_PROPERTY)
|
|
398
|
+
if config is None and store_type != DEFAULT_VECTOR_STORE_TYPE:
|
|
399
|
+
logger.error(
|
|
400
|
+
"enterprise_search_policy._connect_vector_store_or_raise.no_config"
|
|
401
|
+
)
|
|
402
|
+
raise VectorStoreConfigurationError(
|
|
403
|
+
"""No vector store specified. Please specify a vector
|
|
404
|
+
store in the endpoints configuration"""
|
|
405
|
+
)
|
|
406
|
+
try:
|
|
407
|
+
self.vector_store.connect(config) # type: ignore
|
|
408
|
+
except Exception as e:
|
|
409
|
+
logger.error(
|
|
410
|
+
"enterprise_search_policy._connect_vector_store_or_raise.connect_error",
|
|
411
|
+
error=e,
|
|
412
|
+
config=config,
|
|
413
|
+
)
|
|
414
|
+
raise VectorStoreConnectionError(
|
|
415
|
+
f"Unable to connect to the vector store. Error: {e}"
|
|
416
|
+
)
|
|
417
|
+
|
|
418
|
+
def _prepare_search_query(self, tracker: DialogueStateTracker, history: int) -> str:
|
|
419
|
+
"""Prepares the search query.
|
|
420
|
+
The search query is the last N messages in the conversation history.
|
|
421
|
+
|
|
422
|
+
Args:
|
|
423
|
+
tracker: The tracker containing the conversation history up to now.
|
|
424
|
+
history: The number of messages to include in the search query.
|
|
425
|
+
|
|
426
|
+
Returns:
|
|
427
|
+
The search query.
|
|
428
|
+
"""
|
|
429
|
+
transcript = []
|
|
430
|
+
for event in tracker.applied_events():
|
|
431
|
+
if isinstance(event, UserUttered) or isinstance(event, BotUttered):
|
|
432
|
+
transcript.append(sanitize_message_for_prompt(event.text))
|
|
433
|
+
|
|
434
|
+
search_query = " ".join(transcript[-history:][::-1])
|
|
435
|
+
logger.debug("search_query", search_query=search_query)
|
|
436
|
+
return search_query
|
|
437
|
+
|
|
438
|
+
async def predict_action_probabilities( # type: ignore[override]
|
|
439
|
+
self,
|
|
440
|
+
tracker: DialogueStateTracker,
|
|
441
|
+
domain: Domain,
|
|
442
|
+
endpoints: Optional[AvailableEndpoints],
|
|
443
|
+
rule_only_data: Optional[Dict[Text, Any]] = None,
|
|
444
|
+
**kwargs: Any,
|
|
445
|
+
) -> PolicyPrediction:
|
|
446
|
+
"""Predicts the next action the bot should take after seeing the tracker.
|
|
447
|
+
|
|
448
|
+
Args:
|
|
449
|
+
tracker: The tracker containing the conversation history up to now.
|
|
450
|
+
domain: The model's domain.
|
|
451
|
+
endpoints: The model's endpoints.
|
|
452
|
+
rule_only_data: Slots and loops which are specific to rules and hence
|
|
453
|
+
should be ignored by this policy.
|
|
454
|
+
**kwargs: Depending on the specified `needs` section and the resulting
|
|
455
|
+
graph structure the policy can use different input to make predictions.
|
|
456
|
+
|
|
457
|
+
Returns:
|
|
458
|
+
The prediction.
|
|
459
|
+
"""
|
|
460
|
+
logger_key = "enterprise_search_policy.predict_action_probabilities"
|
|
461
|
+
vector_search_threshold = self.vector_store_config.get(
|
|
462
|
+
VECTOR_STORE_THRESHOLD_PROPERTY, DEFAULT_VECTOR_STORE_THRESHOLD
|
|
463
|
+
)
|
|
464
|
+
llm = llm_factory(self.config.get(LLM_CONFIG_KEY), DEFAULT_LLM_CONFIG)
|
|
465
|
+
if not self.supports_current_stack_frame(
|
|
466
|
+
tracker, False, False
|
|
467
|
+
) or self.should_abstain_in_coexistence(tracker, True):
|
|
468
|
+
return self._prediction(self._default_predictions(domain))
|
|
469
|
+
|
|
470
|
+
if not self.vector_store:
|
|
471
|
+
logger.error(f"{logger_key}.no_vector_store")
|
|
472
|
+
return self._create_prediction_internal_error(domain, tracker)
|
|
473
|
+
|
|
474
|
+
try:
|
|
475
|
+
self._connect_vector_store_or_raise(endpoints)
|
|
476
|
+
except (VectorStoreConfigurationError, VectorStoreConnectionError) as e:
|
|
477
|
+
logger.error(f"{logger_key}.connection_error", error=e)
|
|
478
|
+
return self._create_prediction_internal_error(domain, tracker)
|
|
479
|
+
|
|
480
|
+
search_query = self._prepare_search_query(
|
|
481
|
+
tracker, int(self.max_messages_in_query)
|
|
482
|
+
)
|
|
483
|
+
tracker_state = tracker.current_state(EventVerbosity.AFTER_RESTART)
|
|
484
|
+
|
|
485
|
+
try:
|
|
486
|
+
documents = await self.vector_store.search(
|
|
487
|
+
query=search_query,
|
|
488
|
+
tracker_state=tracker_state,
|
|
489
|
+
threshold=vector_search_threshold,
|
|
490
|
+
)
|
|
491
|
+
except InformationRetrievalException as e:
|
|
492
|
+
logger.error(f"{logger_key}.search_error", error=e)
|
|
493
|
+
return self._create_prediction_internal_error(domain, tracker)
|
|
494
|
+
|
|
495
|
+
if not documents.results:
|
|
496
|
+
logger.info(f"{logger_key}.no_documents")
|
|
497
|
+
return self._create_prediction_cannot_handle(domain, tracker)
|
|
498
|
+
|
|
499
|
+
if self.use_llm:
|
|
500
|
+
prompt = self._render_prompt(tracker, documents.results)
|
|
501
|
+
llm_answer = await self._generate_llm_answer(llm, prompt)
|
|
502
|
+
|
|
503
|
+
if self.citation_enabled:
|
|
504
|
+
llm_answer = self.post_process_citations(llm_answer)
|
|
505
|
+
|
|
506
|
+
logger.debug(f"{logger_key}.llm_answer", llm_answer=llm_answer)
|
|
507
|
+
response = llm_answer
|
|
508
|
+
else:
|
|
509
|
+
response = documents.results[0].metadata.get("answer", None)
|
|
510
|
+
if not response:
|
|
511
|
+
logger.error(
|
|
512
|
+
f"{logger_key}.answer_key_missing_in_metadata",
|
|
513
|
+
search_results=documents.results,
|
|
514
|
+
)
|
|
515
|
+
logger.debug(
|
|
516
|
+
"enterprise_search_policy.predict_action_probabilities.no_llm",
|
|
517
|
+
search_results=documents,
|
|
518
|
+
)
|
|
519
|
+
|
|
520
|
+
if response is None:
|
|
521
|
+
return self._create_prediction_internal_error(domain, tracker)
|
|
522
|
+
|
|
523
|
+
action_metadata = {
|
|
524
|
+
"message": {
|
|
525
|
+
"text": response,
|
|
526
|
+
SEARCH_RESULTS_METADATA_KEY: [
|
|
527
|
+
result.text for result in documents.results
|
|
528
|
+
],
|
|
529
|
+
UTTER_SOURCE_METADATA_KEY: self.__class__.__name__,
|
|
530
|
+
SEARCH_QUERY_METADATA_KEY: search_query,
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
|
|
534
|
+
# telemetry call to track policy prediction
|
|
535
|
+
track_enterprise_search_policy_predict(
|
|
536
|
+
vector_store_type=self.vector_store_config.get(VECTOR_STORE_TYPE_PROPERTY),
|
|
537
|
+
embeddings_type=self.embeddings_config.get(PROVIDER_CONFIG_KEY),
|
|
538
|
+
embeddings_model=self.embeddings_config.get(MODEL_CONFIG_KEY)
|
|
539
|
+
or self.embeddings_config.get(MODEL_NAME_CONFIG_KEY),
|
|
540
|
+
embeddings_model_group_id=self.embeddings_config.get(
|
|
541
|
+
MODEL_GROUP_ID_CONFIG_KEY
|
|
542
|
+
),
|
|
543
|
+
llm_type=self.llm_config.get(PROVIDER_CONFIG_KEY),
|
|
544
|
+
llm_model=self.llm_config.get(MODEL_CONFIG_KEY)
|
|
545
|
+
or self.llm_config.get(MODEL_NAME_CONFIG_KEY),
|
|
546
|
+
llm_model_group_id=self.llm_config.get(MODEL_GROUP_ID_CONFIG_KEY),
|
|
547
|
+
citation_enabled=self.citation_enabled,
|
|
548
|
+
)
|
|
549
|
+
return self._create_prediction(
|
|
550
|
+
domain=domain, tracker=tracker, action_metadata=action_metadata
|
|
551
|
+
)
|
|
552
|
+
|
|
553
|
+
def _render_prompt(
|
|
554
|
+
self, tracker: DialogueStateTracker, documents: List[SearchResult]
|
|
555
|
+
) -> Text:
|
|
556
|
+
"""Renders the prompt from the template.
|
|
557
|
+
|
|
558
|
+
Args:
|
|
559
|
+
tracker: The tracker containing the conversation history up to now.
|
|
560
|
+
documents: The documents retrieved from search
|
|
561
|
+
|
|
562
|
+
Returns:
|
|
563
|
+
The rendered prompt.
|
|
564
|
+
"""
|
|
565
|
+
inputs = {
|
|
566
|
+
"current_conversation": tracker_as_readable_transcript(
|
|
567
|
+
tracker, max_turns=self.max_history
|
|
568
|
+
),
|
|
569
|
+
"docs": documents,
|
|
570
|
+
"slots": self._prepare_slots_for_template(tracker),
|
|
571
|
+
"citation_enabled": self.citation_enabled,
|
|
572
|
+
}
|
|
573
|
+
prompt = Template(self.prompt_template).render(**inputs)
|
|
574
|
+
log_llm(
|
|
575
|
+
logger=logger,
|
|
576
|
+
log_module="EnterpriseSearchPolicy",
|
|
577
|
+
log_event="enterprise_search_policy._render_prompt.prompt_rendered",
|
|
578
|
+
prompt=prompt,
|
|
579
|
+
)
|
|
580
|
+
return prompt
|
|
581
|
+
|
|
582
|
+
async def _generate_llm_answer(
|
|
583
|
+
self, llm: LLMClient, prompt: Text
|
|
584
|
+
) -> Optional[Text]:
|
|
585
|
+
try:
|
|
586
|
+
llm_response = await llm.acompletion(prompt)
|
|
587
|
+
llm_answer = llm_response.choices[0]
|
|
588
|
+
except Exception as e:
|
|
589
|
+
# unfortunately, langchain does not wrap LLM exceptions which means
|
|
590
|
+
# we have to catch all exceptions here
|
|
591
|
+
logger.error(
|
|
592
|
+
"enterprise_search_policy._generate_llm_answer.llm_error",
|
|
593
|
+
error=e,
|
|
594
|
+
)
|
|
595
|
+
llm_answer = None
|
|
596
|
+
|
|
597
|
+
return llm_answer
|
|
598
|
+
|
|
599
|
+
def _create_prediction(
|
|
600
|
+
self,
|
|
601
|
+
domain: Domain,
|
|
602
|
+
tracker: DialogueStateTracker,
|
|
603
|
+
action_metadata: Dict[Text, Any],
|
|
604
|
+
) -> PolicyPrediction:
|
|
605
|
+
"""Create a policy prediction result with ACTION_SEND_TEXT_NAME.
|
|
606
|
+
|
|
607
|
+
Args:
|
|
608
|
+
domain: The model's domain.
|
|
609
|
+
tracker: The tracker containing the conversation history up to now.
|
|
610
|
+
action_metadata: The metadata for the predicted action.
|
|
611
|
+
|
|
612
|
+
Returns:
|
|
613
|
+
The prediction.
|
|
614
|
+
"""
|
|
615
|
+
result = self._prediction_result(ACTION_SEND_TEXT_NAME, domain)
|
|
616
|
+
stack = tracker.stack
|
|
617
|
+
if not stack.is_empty():
|
|
618
|
+
stack.pop()
|
|
619
|
+
events: List[Event] = tracker.create_stack_updated_events(stack)
|
|
620
|
+
else:
|
|
621
|
+
events = []
|
|
622
|
+
|
|
623
|
+
return self._prediction(result, action_metadata=action_metadata, events=events)
|
|
624
|
+
|
|
625
|
+
def _create_prediction_internal_error(
|
|
626
|
+
self, domain: Domain, tracker: DialogueStateTracker
|
|
627
|
+
) -> PolicyPrediction:
|
|
628
|
+
return self._create_prediction_for_pattern(
|
|
629
|
+
domain, tracker, InternalErrorPatternFlowStackFrame()
|
|
630
|
+
)
|
|
631
|
+
|
|
632
|
+
def _create_prediction_cannot_handle(
|
|
633
|
+
self, domain: Domain, tracker: DialogueStateTracker
|
|
634
|
+
) -> PolicyPrediction:
|
|
635
|
+
return self._create_prediction_for_pattern(
|
|
636
|
+
domain, tracker, CannotHandlePatternFlowStackFrame()
|
|
637
|
+
)
|
|
638
|
+
|
|
639
|
+
def _create_prediction_for_pattern(
|
|
640
|
+
self,
|
|
641
|
+
domain: Domain,
|
|
642
|
+
tracker: DialogueStateTracker,
|
|
643
|
+
pattern_stack_frame: PatternFlowStackFrame,
|
|
644
|
+
) -> PolicyPrediction:
|
|
645
|
+
"""Create a policy prediction result for error.
|
|
646
|
+
|
|
647
|
+
We should cancel the current flow (hence ACTION_CANCEL_FLOW) and push a
|
|
648
|
+
pattern stack frame (Internal Error Pattern by default) to start the pattern.
|
|
649
|
+
|
|
650
|
+
Args:
|
|
651
|
+
domain: The model's domain.
|
|
652
|
+
tracker: The tracker containing the conversation history up to now.
|
|
653
|
+
pattern_stack_frame: The pattern stack frame to push.
|
|
654
|
+
|
|
655
|
+
Returns:
|
|
656
|
+
The prediction.
|
|
657
|
+
"""
|
|
658
|
+
# TODO: replace ACTION_CANCEL_FLOW (ATO-2097)
|
|
659
|
+
result = self._prediction_result(ACTION_CANCEL_FLOW, domain)
|
|
660
|
+
stack = tracker.stack
|
|
661
|
+
if not stack.is_empty():
|
|
662
|
+
stack.pop()
|
|
663
|
+
stack.push(pattern_stack_frame)
|
|
664
|
+
events: List[Event] = tracker.create_stack_updated_events(stack)
|
|
665
|
+
return self._prediction(result, action_metadata=None, events=events)
|
|
666
|
+
|
|
667
|
+
def _prediction_result(
|
|
668
|
+
self, action_name: Optional[Text], domain: Domain, score: Optional[float] = 1.0
|
|
669
|
+
) -> List[float]:
|
|
670
|
+
"""Creates a prediction result.
|
|
671
|
+
|
|
672
|
+
Args:
|
|
673
|
+
action_name: The name of the predicted action.
|
|
674
|
+
domain: The model's domain.
|
|
675
|
+
score: The score of the predicted action.
|
|
676
|
+
|
|
677
|
+
Returns:
|
|
678
|
+
The prediction result where the score is used for one hot encoding.
|
|
679
|
+
"""
|
|
680
|
+
result = self._default_predictions(domain)
|
|
681
|
+
if action_name:
|
|
682
|
+
result[domain.index_for_action(action_name)] = score # type: ignore[assignment]
|
|
683
|
+
return result
|
|
684
|
+
|
|
685
|
+
@classmethod
|
|
686
|
+
def load(
|
|
687
|
+
cls,
|
|
688
|
+
config: Dict[Text, Any],
|
|
689
|
+
model_storage: ModelStorage,
|
|
690
|
+
resource: Resource,
|
|
691
|
+
execution_context: ExecutionContext,
|
|
692
|
+
**kwargs: Any,
|
|
693
|
+
) -> "EnterpriseSearchPolicy":
|
|
694
|
+
"""Loads a trained policy (see parent class for full docstring)."""
|
|
695
|
+
|
|
696
|
+
# Perform health checks for both LLM and embeddings client configs
|
|
697
|
+
cls._perform_health_checks(config, "enterprise_search_policy.load")
|
|
698
|
+
|
|
699
|
+
prompt_template = None
|
|
700
|
+
try:
|
|
701
|
+
with model_storage.read_from(resource) as path:
|
|
702
|
+
prompt_template = rasa.shared.utils.io.read_file(
|
|
703
|
+
path / ENTERPRISE_SEARCH_PROMPT_FILE_NAME
|
|
704
|
+
)
|
|
705
|
+
except (FileNotFoundError, FileIOException) as e:
|
|
706
|
+
logger.warning(
|
|
707
|
+
"enterprise_search_policy.load.failed", error=e, resource=resource.name
|
|
708
|
+
)
|
|
709
|
+
|
|
710
|
+
store_type = config.get(VECTOR_STORE_PROPERTY, {}).get(
|
|
711
|
+
VECTOR_STORE_TYPE_PROPERTY
|
|
712
|
+
)
|
|
713
|
+
|
|
714
|
+
embeddings = cls._create_plain_embedder(config)
|
|
715
|
+
|
|
716
|
+
logger.info("enterprise_search_policy.load", config=config)
|
|
717
|
+
if store_type == DEFAULT_VECTOR_STORE_TYPE:
|
|
718
|
+
# if a vector store is not specified,
|
|
719
|
+
# default to using FAISS with the index stored in the model
|
|
720
|
+
# TODO figure out a way to get path without context manager
|
|
721
|
+
with model_storage.read_from(resource) as path:
|
|
722
|
+
vector_store = FAISS_Store(
|
|
723
|
+
embeddings=embeddings,
|
|
724
|
+
index_path=path,
|
|
725
|
+
docs_folder=None,
|
|
726
|
+
create_index=False,
|
|
727
|
+
)
|
|
728
|
+
else:
|
|
729
|
+
vector_store = create_from_endpoint_config(
|
|
730
|
+
config_type=store_type,
|
|
731
|
+
embeddings=embeddings,
|
|
732
|
+
) # type: ignore
|
|
733
|
+
|
|
734
|
+
return cls(
|
|
735
|
+
config,
|
|
736
|
+
model_storage,
|
|
737
|
+
resource,
|
|
738
|
+
execution_context,
|
|
739
|
+
vector_store=vector_store,
|
|
740
|
+
prompt_template=prompt_template,
|
|
741
|
+
)
|
|
742
|
+
|
|
743
|
+
@classmethod
|
|
744
|
+
def _get_local_knowledge_data(cls, config: Dict[str, Any]) -> Optional[List[str]]:
|
|
745
|
+
"""This is required only for local knowledge base types.
|
|
746
|
+
|
|
747
|
+
e.g. FAISS, to ensure that the graph component is retrained when the knowledge
|
|
748
|
+
base is updated.
|
|
749
|
+
"""
|
|
750
|
+
merged_config = {**cls.get_default_config(), **config}
|
|
751
|
+
|
|
752
|
+
store_type = merged_config.get(VECTOR_STORE_PROPERTY, {}).get(
|
|
753
|
+
VECTOR_STORE_TYPE_PROPERTY
|
|
754
|
+
)
|
|
755
|
+
if store_type != DEFAULT_VECTOR_STORE_TYPE:
|
|
756
|
+
return None
|
|
757
|
+
|
|
758
|
+
source = merged_config.get(VECTOR_STORE_PROPERTY, {}).get(SOURCE_PROPERTY)
|
|
759
|
+
if not source:
|
|
760
|
+
return None
|
|
761
|
+
|
|
762
|
+
docs = FAISS_Store.load_documents(source)
|
|
763
|
+
|
|
764
|
+
if len(docs) == 0:
|
|
765
|
+
return None
|
|
766
|
+
|
|
767
|
+
docs_as_strings = [
|
|
768
|
+
json.dumps(doc.dict(), ensure_ascii=False, sort_keys=True) for doc in docs
|
|
769
|
+
]
|
|
770
|
+
return sorted(docs_as_strings)
|
|
771
|
+
|
|
772
|
+
@classmethod
|
|
773
|
+
def fingerprint_addon(cls, config: Dict[str, Any]) -> Optional[str]:
|
|
774
|
+
"""Add a fingerprint of enterprise search policy for the graph."""
|
|
775
|
+
local_knowledge_data = cls._get_local_knowledge_data(config)
|
|
776
|
+
|
|
777
|
+
prompt_template = get_prompt_template(
|
|
778
|
+
config.get(PROMPT_CONFIG_KEY),
|
|
779
|
+
DEFAULT_ENTERPRISE_SEARCH_PROMPT_TEMPLATE,
|
|
780
|
+
)
|
|
781
|
+
|
|
782
|
+
llm_config = resolve_model_client_config(
|
|
783
|
+
config.get(LLM_CONFIG_KEY), EnterpriseSearchPolicy.__name__
|
|
784
|
+
)
|
|
785
|
+
embedding_config = resolve_model_client_config(
|
|
786
|
+
config.get(EMBEDDINGS_CONFIG_KEY), EnterpriseSearchPolicy.__name__
|
|
787
|
+
)
|
|
788
|
+
return deep_container_fingerprint(
|
|
789
|
+
[prompt_template, local_knowledge_data, llm_config, embedding_config]
|
|
790
|
+
)
|
|
791
|
+
|
|
792
|
+
@staticmethod
|
|
793
|
+
def post_process_citations(llm_answer: str) -> str:
|
|
794
|
+
"""Post-process the LLM answer.
|
|
795
|
+
|
|
796
|
+
Re-writes the bracketed numbers to start from 1 and
|
|
797
|
+
re-arranges the sources to follow the enumeration order.
|
|
798
|
+
|
|
799
|
+
Args:
|
|
800
|
+
llm_answer: The LLM answer.
|
|
801
|
+
|
|
802
|
+
Returns:
|
|
803
|
+
The post-processed LLM answer.
|
|
804
|
+
"""
|
|
805
|
+
logger.debug(
|
|
806
|
+
"enterprise_search_policy.post_process_citations", llm_answer=llm_answer
|
|
807
|
+
)
|
|
808
|
+
|
|
809
|
+
# Split llm_answer into answer and citations
|
|
810
|
+
try:
|
|
811
|
+
answer, citations = llm_answer.rsplit("Sources:", 1)
|
|
812
|
+
except ValueError:
|
|
813
|
+
# if there is no "Sources:" in the llm_answer
|
|
814
|
+
return llm_answer
|
|
815
|
+
|
|
816
|
+
# Find all source references in the answer
|
|
817
|
+
pattern = r"\[\s*(\d+(?:\s*,\s*\d+)*)\s*\]"
|
|
818
|
+
matches = re.findall(pattern, answer)
|
|
819
|
+
old_source_indices = [
|
|
820
|
+
int(num.strip()) for match in matches for num in match.split(",")
|
|
821
|
+
]
|
|
822
|
+
|
|
823
|
+
# Map old source references to the correct enumeration
|
|
824
|
+
renumber_mapping = {num: idx + 1 for idx, num in enumerate(old_source_indices)}
|
|
825
|
+
|
|
826
|
+
# remove whitespace from original source citations in answer
|
|
827
|
+
for match in matches:
|
|
828
|
+
answer = answer.replace(f"[{match}]", f"[{match.replace(' ', '')}]")
|
|
829
|
+
|
|
830
|
+
new_answer = []
|
|
831
|
+
for word in answer.split():
|
|
832
|
+
matches = re.findall(pattern, word)
|
|
833
|
+
if matches:
|
|
834
|
+
for match in matches:
|
|
835
|
+
if "," in match:
|
|
836
|
+
old_indices = [
|
|
837
|
+
int(num.strip()) for num in match.split(",") if num
|
|
838
|
+
]
|
|
839
|
+
new_indices = [
|
|
840
|
+
renumber_mapping[old_index]
|
|
841
|
+
for old_index in old_indices
|
|
842
|
+
if old_index in renumber_mapping
|
|
843
|
+
]
|
|
844
|
+
if not new_indices:
|
|
845
|
+
continue
|
|
846
|
+
|
|
847
|
+
word = word.replace(
|
|
848
|
+
match, f"{', '.join(map(str, new_indices))}"
|
|
849
|
+
)
|
|
850
|
+
else:
|
|
851
|
+
old_index = int(match.strip("[].,:;?!"))
|
|
852
|
+
new_index = renumber_mapping.get(old_index)
|
|
853
|
+
if not new_index:
|
|
854
|
+
continue
|
|
855
|
+
|
|
856
|
+
word = word.replace(str(old_index), str(new_index))
|
|
857
|
+
new_answer.append(word)
|
|
858
|
+
|
|
859
|
+
# join the words
|
|
860
|
+
joined_answer = " ".join(new_answer)
|
|
861
|
+
joined_answer += "\nSources:\n"
|
|
862
|
+
|
|
863
|
+
new_sources: List[str] = []
|
|
864
|
+
|
|
865
|
+
for line in citations.split("\n"):
|
|
866
|
+
pattern = r"(?<=\[)\d+"
|
|
867
|
+
match = re.search(pattern, line)
|
|
868
|
+
if match:
|
|
869
|
+
old_index = int(match.group(0))
|
|
870
|
+
new_index = renumber_mapping[old_index]
|
|
871
|
+
# replace only the first occurrence of the old index
|
|
872
|
+
line = line.replace(f"[{old_index}]", f"[{new_index}]", 1)
|
|
873
|
+
|
|
874
|
+
# insert the line into the new_index position
|
|
875
|
+
new_sources.insert(new_index - 1, line)
|
|
876
|
+
elif line.strip():
|
|
877
|
+
new_sources.append(line)
|
|
878
|
+
|
|
879
|
+
joined_sources = "\n".join(new_sources)
|
|
880
|
+
|
|
881
|
+
return joined_answer + joined_sources
|
|
882
|
+
|
|
883
|
+
@classmethod
|
|
884
|
+
def _perform_health_checks(
|
|
885
|
+
cls, config: Dict[Text, Any], log_source_method: str
|
|
886
|
+
) -> None:
|
|
887
|
+
# Perform health check of the LLM client config
|
|
888
|
+
llm_config = resolve_model_client_config(config.get(LLM_CONFIG_KEY, {}))
|
|
889
|
+
cls.perform_llm_health_check(
|
|
890
|
+
llm_config,
|
|
891
|
+
DEFAULT_LLM_CONFIG,
|
|
892
|
+
log_source_method,
|
|
893
|
+
EnterpriseSearchPolicy.__name__,
|
|
894
|
+
)
|
|
895
|
+
|
|
896
|
+
# Perform health check of the embeddings client config
|
|
897
|
+
embeddings_config = resolve_model_client_config(
|
|
898
|
+
config.get(EMBEDDINGS_CONFIG_KEY, {})
|
|
899
|
+
)
|
|
900
|
+
cls.perform_embeddings_health_check(
|
|
901
|
+
embeddings_config,
|
|
902
|
+
DEFAULT_EMBEDDINGS_CONFIG,
|
|
903
|
+
log_source_method,
|
|
904
|
+
EnterpriseSearchPolicy.__name__,
|
|
905
|
+
)
|