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,120 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
from typing import Any, Dict, Optional
|
|
4
|
+
|
|
5
|
+
import structlog
|
|
6
|
+
|
|
7
|
+
from rasa.shared.constants import (
|
|
8
|
+
OPENAI_PROVIDER,
|
|
9
|
+
RASA_PROVIDER,
|
|
10
|
+
)
|
|
11
|
+
from rasa.shared.providers._configs.rasa_llm_client_config import (
|
|
12
|
+
RasaLLMClientConfig,
|
|
13
|
+
)
|
|
14
|
+
from rasa.shared.providers.constants import (
|
|
15
|
+
LITE_LLM_API_BASE_FIELD,
|
|
16
|
+
LITE_LLM_API_KEY_FIELD,
|
|
17
|
+
)
|
|
18
|
+
from rasa.shared.providers.llm._base_litellm_client import _BaseLiteLLMClient
|
|
19
|
+
from rasa.utils.licensing import retrieve_license_from_env
|
|
20
|
+
|
|
21
|
+
structlogger = structlog.get_logger()
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
class RasaLLMClient(_BaseLiteLLMClient):
|
|
25
|
+
"""A client for interfacing with a Rasa-Hosted LLM endpoint that uses
|
|
26
|
+
|
|
27
|
+
Parameters:
|
|
28
|
+
model (str): The model or deployment name.
|
|
29
|
+
api_base (str): The base URL of the API endpoint.
|
|
30
|
+
kwargs: Any: Additional configuration parameters that can include, but
|
|
31
|
+
are not limited to model parameters and lite-llm specific
|
|
32
|
+
parameters. These parameters will be passed to the
|
|
33
|
+
completion/acompletion calls. To see what it can include, visit:
|
|
34
|
+
|
|
35
|
+
Raises:
|
|
36
|
+
ProviderClientValidationError: If validation of the client setup fails.
|
|
37
|
+
ProviderClientAPIException: If the API request fails.
|
|
38
|
+
"""
|
|
39
|
+
|
|
40
|
+
def __init__(
|
|
41
|
+
self,
|
|
42
|
+
model: str,
|
|
43
|
+
api_base: str,
|
|
44
|
+
**kwargs: Any,
|
|
45
|
+
):
|
|
46
|
+
super().__init__() # type: ignore
|
|
47
|
+
self._model = model
|
|
48
|
+
self._api_base = api_base
|
|
49
|
+
self._use_chat_completions_endpoint = True
|
|
50
|
+
self._extra_parameters = kwargs or {}
|
|
51
|
+
|
|
52
|
+
@property
|
|
53
|
+
def model(self) -> str:
|
|
54
|
+
return self._model
|
|
55
|
+
|
|
56
|
+
@property
|
|
57
|
+
def api_base(self) -> Optional[str]:
|
|
58
|
+
"""
|
|
59
|
+
Returns the base API URL for the openai llm client.
|
|
60
|
+
"""
|
|
61
|
+
return self._api_base
|
|
62
|
+
|
|
63
|
+
@property
|
|
64
|
+
def provider(self) -> str:
|
|
65
|
+
"""
|
|
66
|
+
Returns the provider name for the self hosted llm client.
|
|
67
|
+
|
|
68
|
+
Returns:
|
|
69
|
+
String representing the provider name.
|
|
70
|
+
"""
|
|
71
|
+
return RASA_PROVIDER
|
|
72
|
+
|
|
73
|
+
@property
|
|
74
|
+
def _litellm_model_name(self) -> str:
|
|
75
|
+
return f"{OPENAI_PROVIDER}/{self._model}"
|
|
76
|
+
|
|
77
|
+
@property
|
|
78
|
+
def _litellm_extra_parameters(self) -> Dict[str, Any]:
|
|
79
|
+
return self._extra_parameters
|
|
80
|
+
|
|
81
|
+
@property
|
|
82
|
+
def config(self) -> dict:
|
|
83
|
+
return RasaLLMClientConfig(
|
|
84
|
+
model=self._model,
|
|
85
|
+
api_base=self._api_base,
|
|
86
|
+
extra_parameters=self._extra_parameters,
|
|
87
|
+
).to_dict()
|
|
88
|
+
|
|
89
|
+
@property
|
|
90
|
+
def _completion_fn_args(self) -> Dict[str, Any]:
|
|
91
|
+
"""Returns the completion arguments for invoking a call through
|
|
92
|
+
LiteLLM's completion functions.
|
|
93
|
+
"""
|
|
94
|
+
fn_args = super()._completion_fn_args
|
|
95
|
+
fn_args.update(
|
|
96
|
+
{
|
|
97
|
+
LITE_LLM_API_BASE_FIELD: self.api_base,
|
|
98
|
+
LITE_LLM_API_KEY_FIELD: retrieve_license_from_env(),
|
|
99
|
+
}
|
|
100
|
+
)
|
|
101
|
+
return fn_args
|
|
102
|
+
|
|
103
|
+
@classmethod
|
|
104
|
+
def from_config(cls, config: Dict[str, Any]) -> RasaLLMClient:
|
|
105
|
+
try:
|
|
106
|
+
client_config = RasaLLMClientConfig.from_dict(config)
|
|
107
|
+
except ValueError as e:
|
|
108
|
+
message = "Cannot instantiate a client from the passed configuration."
|
|
109
|
+
structlogger.error(
|
|
110
|
+
"rasa_llm_client.from_config.error",
|
|
111
|
+
message=message,
|
|
112
|
+
config=config,
|
|
113
|
+
original_error=e,
|
|
114
|
+
)
|
|
115
|
+
raise
|
|
116
|
+
return cls(
|
|
117
|
+
model=client_config.model,
|
|
118
|
+
api_base=client_config.api_base,
|
|
119
|
+
**client_config.extra_parameters,
|
|
120
|
+
)
|
|
@@ -0,0 +1,276 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
import logging
|
|
4
|
+
import os
|
|
5
|
+
from typing import Any, Dict, List, Optional, Union
|
|
6
|
+
|
|
7
|
+
import structlog
|
|
8
|
+
from litellm import (
|
|
9
|
+
atext_completion,
|
|
10
|
+
text_completion,
|
|
11
|
+
)
|
|
12
|
+
|
|
13
|
+
from rasa.shared.constants import (
|
|
14
|
+
API_KEY,
|
|
15
|
+
SELF_HOSTED_VLLM_API_KEY_ENV_VAR,
|
|
16
|
+
SELF_HOSTED_VLLM_PREFIX,
|
|
17
|
+
)
|
|
18
|
+
from rasa.shared.exceptions import ProviderClientAPIException
|
|
19
|
+
from rasa.shared.providers._configs.self_hosted_llm_client_config import (
|
|
20
|
+
SelfHostedLLMClientConfig,
|
|
21
|
+
)
|
|
22
|
+
from rasa.shared.providers.constants import (
|
|
23
|
+
LITE_LLM_API_BASE_FIELD,
|
|
24
|
+
LITE_LLM_API_VERSION_FIELD,
|
|
25
|
+
)
|
|
26
|
+
from rasa.shared.providers.llm._base_litellm_client import _BaseLiteLLMClient
|
|
27
|
+
from rasa.shared.providers.llm.llm_response import LLMResponse
|
|
28
|
+
from rasa.shared.utils.io import suppress_logs
|
|
29
|
+
|
|
30
|
+
structlogger = structlog.get_logger()
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
class SelfHostedLLMClient(_BaseLiteLLMClient):
|
|
34
|
+
"""A client for interfacing with Self Hosted LLM endpoints that uses
|
|
35
|
+
|
|
36
|
+
Parameters:
|
|
37
|
+
model (str): The model or deployment name.
|
|
38
|
+
provider (str): The provider of the model.
|
|
39
|
+
api_base (str): The base URL of the API endpoint.
|
|
40
|
+
api_type (Optional[str]): The type of the API endpoint.
|
|
41
|
+
api_version (Optional[str]): The version of the API endpoint.
|
|
42
|
+
use_chat_completions_endpoint (Optional[bool]): Whether to use the chat
|
|
43
|
+
completions endpoint for completions. Defaults to True.
|
|
44
|
+
kwargs: Any: Additional configuration parameters that can include, but
|
|
45
|
+
are not limited to model parameters and lite-llm specific
|
|
46
|
+
parameters. These parameters will be passed to the
|
|
47
|
+
completion/acompletion calls. To see what it can include, visit:
|
|
48
|
+
|
|
49
|
+
Raises:
|
|
50
|
+
ProviderClientValidationError: If validation of the client setup fails.
|
|
51
|
+
ProviderClientAPIException: If the API request fails.
|
|
52
|
+
"""
|
|
53
|
+
|
|
54
|
+
def __init__(
|
|
55
|
+
self,
|
|
56
|
+
provider: str,
|
|
57
|
+
model: str,
|
|
58
|
+
api_base: str,
|
|
59
|
+
api_type: Optional[str] = None,
|
|
60
|
+
api_version: Optional[str] = None,
|
|
61
|
+
use_chat_completions_endpoint: Optional[bool] = True,
|
|
62
|
+
**kwargs: Any,
|
|
63
|
+
):
|
|
64
|
+
super().__init__() # type: ignore
|
|
65
|
+
self._provider = provider
|
|
66
|
+
self._model = model
|
|
67
|
+
self._api_base = api_base
|
|
68
|
+
self._api_type = api_type
|
|
69
|
+
self._api_version = api_version
|
|
70
|
+
self._use_chat_completions_endpoint = use_chat_completions_endpoint
|
|
71
|
+
self._extra_parameters = kwargs or {}
|
|
72
|
+
if self._extra_parameters.get(API_KEY) is None:
|
|
73
|
+
self._apply_dummy_api_key_if_missing()
|
|
74
|
+
|
|
75
|
+
@classmethod
|
|
76
|
+
def from_config(cls, config: Dict[str, Any]) -> SelfHostedLLMClient:
|
|
77
|
+
try:
|
|
78
|
+
client_config = SelfHostedLLMClientConfig.from_dict(config)
|
|
79
|
+
except ValueError as e:
|
|
80
|
+
message = "Cannot instantiate a client from the passed configuration."
|
|
81
|
+
structlogger.error(
|
|
82
|
+
"self_hosted_llm_client.from_config.error",
|
|
83
|
+
message=message,
|
|
84
|
+
config=config,
|
|
85
|
+
original_error=e,
|
|
86
|
+
)
|
|
87
|
+
raise
|
|
88
|
+
|
|
89
|
+
return cls(
|
|
90
|
+
model=client_config.model,
|
|
91
|
+
provider=client_config.provider,
|
|
92
|
+
api_base=client_config.api_base,
|
|
93
|
+
api_type=client_config.api_type,
|
|
94
|
+
api_version=client_config.api_version,
|
|
95
|
+
use_chat_completions_endpoint=client_config.use_chat_completions_endpoint,
|
|
96
|
+
**client_config.extra_parameters,
|
|
97
|
+
)
|
|
98
|
+
|
|
99
|
+
@property
|
|
100
|
+
def provider(self) -> str:
|
|
101
|
+
"""
|
|
102
|
+
Returns the provider name for the self hosted llm client.
|
|
103
|
+
|
|
104
|
+
Returns:
|
|
105
|
+
String representing the provider name.
|
|
106
|
+
"""
|
|
107
|
+
return self._provider
|
|
108
|
+
|
|
109
|
+
@property
|
|
110
|
+
def model(self) -> str:
|
|
111
|
+
"""
|
|
112
|
+
Returns the model name for the self hosted llm client.
|
|
113
|
+
|
|
114
|
+
Returns:
|
|
115
|
+
String representing the model name.
|
|
116
|
+
"""
|
|
117
|
+
return self._model
|
|
118
|
+
|
|
119
|
+
@property
|
|
120
|
+
def api_base(self) -> str:
|
|
121
|
+
"""
|
|
122
|
+
Returns the base URL for the API endpoint.
|
|
123
|
+
|
|
124
|
+
Returns:
|
|
125
|
+
String representing the base URL.
|
|
126
|
+
"""
|
|
127
|
+
return self._api_base
|
|
128
|
+
|
|
129
|
+
@property
|
|
130
|
+
def api_type(self) -> Optional[str]:
|
|
131
|
+
"""
|
|
132
|
+
Returns the type of the API endpoint. Currently only OpenAI is supported.
|
|
133
|
+
|
|
134
|
+
Returns:
|
|
135
|
+
String representing the API type.
|
|
136
|
+
"""
|
|
137
|
+
return self._api_type
|
|
138
|
+
|
|
139
|
+
@property
|
|
140
|
+
def api_version(self) -> Optional[str]:
|
|
141
|
+
"""
|
|
142
|
+
Returns the version of the API endpoint.
|
|
143
|
+
|
|
144
|
+
Returns:
|
|
145
|
+
String representing the API version.
|
|
146
|
+
"""
|
|
147
|
+
return self._api_version
|
|
148
|
+
|
|
149
|
+
@property
|
|
150
|
+
def config(self) -> Dict:
|
|
151
|
+
"""
|
|
152
|
+
Returns the configuration for the self hosted llm client.
|
|
153
|
+
Returns:
|
|
154
|
+
Dictionary containing the configuration.
|
|
155
|
+
"""
|
|
156
|
+
config = SelfHostedLLMClientConfig(
|
|
157
|
+
model=self._model,
|
|
158
|
+
provider=self._provider,
|
|
159
|
+
api_base=self._api_base,
|
|
160
|
+
api_type=self._api_type,
|
|
161
|
+
api_version=self._api_version,
|
|
162
|
+
use_chat_completions_endpoint=self._use_chat_completions_endpoint,
|
|
163
|
+
extra_parameters=self._extra_parameters,
|
|
164
|
+
)
|
|
165
|
+
return config.to_dict()
|
|
166
|
+
|
|
167
|
+
@property
|
|
168
|
+
def _litellm_model_name(self) -> str:
|
|
169
|
+
"""Returns the value of LiteLLM's model parameter to be used in
|
|
170
|
+
completion/acompletion in LiteLLM format:
|
|
171
|
+
|
|
172
|
+
<hosted_vllm>/<model or deployment name>
|
|
173
|
+
"""
|
|
174
|
+
if self.model and f"{SELF_HOSTED_VLLM_PREFIX}/" not in self.model:
|
|
175
|
+
return f"{SELF_HOSTED_VLLM_PREFIX}/{self.model}"
|
|
176
|
+
return self.model
|
|
177
|
+
|
|
178
|
+
@property
|
|
179
|
+
def _litellm_extra_parameters(self) -> Dict[str, Any]:
|
|
180
|
+
"""Returns optional configuration parameters specific
|
|
181
|
+
to the client provider and deployed model.
|
|
182
|
+
"""
|
|
183
|
+
return self._extra_parameters
|
|
184
|
+
|
|
185
|
+
@property
|
|
186
|
+
def _completion_fn_args(self) -> Dict[str, Any]:
|
|
187
|
+
"""Returns the completion arguments for invoking a call through
|
|
188
|
+
LiteLLM's completion functions.
|
|
189
|
+
"""
|
|
190
|
+
fn_args = super()._completion_fn_args
|
|
191
|
+
fn_args.update(
|
|
192
|
+
{
|
|
193
|
+
LITE_LLM_API_BASE_FIELD: self.api_base,
|
|
194
|
+
LITE_LLM_API_VERSION_FIELD: self.api_version,
|
|
195
|
+
}
|
|
196
|
+
)
|
|
197
|
+
return fn_args
|
|
198
|
+
|
|
199
|
+
@suppress_logs(log_level=logging.WARNING)
|
|
200
|
+
def _text_completion(self, prompt: Union[List[str], str]) -> LLMResponse:
|
|
201
|
+
"""
|
|
202
|
+
Synchronously generate completions for given prompt.
|
|
203
|
+
|
|
204
|
+
Args:
|
|
205
|
+
prompt: Prompt to generate the completion for.
|
|
206
|
+
Returns:
|
|
207
|
+
List of message completions.
|
|
208
|
+
Raises:
|
|
209
|
+
ProviderClientAPIException: If the API request fails.
|
|
210
|
+
"""
|
|
211
|
+
try:
|
|
212
|
+
response = text_completion(prompt=prompt, **self._completion_fn_args)
|
|
213
|
+
return self._format_text_completion_response(response)
|
|
214
|
+
except Exception as e:
|
|
215
|
+
raise ProviderClientAPIException(e)
|
|
216
|
+
|
|
217
|
+
@suppress_logs(log_level=logging.WARNING)
|
|
218
|
+
async def _atext_completion(self, prompt: Union[List[str], str]) -> LLMResponse:
|
|
219
|
+
"""
|
|
220
|
+
Asynchronously generate completions for given prompt.
|
|
221
|
+
|
|
222
|
+
Args:
|
|
223
|
+
prompt: Prompt to generate the completion for.
|
|
224
|
+
Returns:
|
|
225
|
+
List of message completions.
|
|
226
|
+
Raises:
|
|
227
|
+
ProviderClientAPIException: If the API request fails.
|
|
228
|
+
"""
|
|
229
|
+
try:
|
|
230
|
+
response = await atext_completion(prompt=prompt, **self._completion_fn_args)
|
|
231
|
+
return self._format_text_completion_response(response)
|
|
232
|
+
except Exception as e:
|
|
233
|
+
raise ProviderClientAPIException(e)
|
|
234
|
+
|
|
235
|
+
async def acompletion(self, messages: Union[List[str], str]) -> LLMResponse:
|
|
236
|
+
"""Asynchronous completion of the model with the given messages.
|
|
237
|
+
|
|
238
|
+
Method overrides the base class method to call the appropriate
|
|
239
|
+
completion method based on the configuration. If the chat completions
|
|
240
|
+
endpoint is enabled, the acompletion method is called. Otherwise, the
|
|
241
|
+
atext_completion method is called.
|
|
242
|
+
|
|
243
|
+
Args:
|
|
244
|
+
messages: The messages to be used for completion.
|
|
245
|
+
|
|
246
|
+
Returns:
|
|
247
|
+
The completion response.
|
|
248
|
+
"""
|
|
249
|
+
if self._use_chat_completions_endpoint:
|
|
250
|
+
return await super().acompletion(messages)
|
|
251
|
+
return await self._atext_completion(messages)
|
|
252
|
+
|
|
253
|
+
def completion(self, messages: Union[List[str], str]) -> LLMResponse:
|
|
254
|
+
"""Completion of the model with the given messages.
|
|
255
|
+
|
|
256
|
+
Method overrides the base class method to call the appropriate
|
|
257
|
+
completion method based on the configuration. If the chat completions
|
|
258
|
+
endpoint is enabled, the completion method is called. Otherwise, the
|
|
259
|
+
text_completion method is called.
|
|
260
|
+
|
|
261
|
+
Args:
|
|
262
|
+
messages: The messages to be used for completion.
|
|
263
|
+
|
|
264
|
+
Returns:
|
|
265
|
+
The completion response.
|
|
266
|
+
"""
|
|
267
|
+
if self._use_chat_completions_endpoint:
|
|
268
|
+
return super().completion(messages)
|
|
269
|
+
return self._text_completion(messages)
|
|
270
|
+
|
|
271
|
+
@staticmethod
|
|
272
|
+
def _apply_dummy_api_key_if_missing() -> None:
|
|
273
|
+
if not os.getenv(SELF_HOSTED_VLLM_API_KEY_ENV_VAR):
|
|
274
|
+
os.environ[SELF_HOSTED_VLLM_API_KEY_ENV_VAR] = (
|
|
275
|
+
"dummy_self_hosted_llm_api_key"
|
|
276
|
+
)
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
from typing import Dict, Type, Optional
|
|
2
|
+
|
|
3
|
+
from rasa.shared.constants import (
|
|
4
|
+
AZURE_OPENAI_PROVIDER,
|
|
5
|
+
HUGGINGFACE_LOCAL_EMBEDDING_PROVIDER,
|
|
6
|
+
OPENAI_PROVIDER,
|
|
7
|
+
SELF_HOSTED_PROVIDER,
|
|
8
|
+
RASA_PROVIDER,
|
|
9
|
+
SELF_HOSTED_VLLM_PREFIX,
|
|
10
|
+
)
|
|
11
|
+
from rasa.shared.providers.embedding.azure_openai_embedding_client import (
|
|
12
|
+
AzureOpenAIEmbeddingClient,
|
|
13
|
+
)
|
|
14
|
+
from rasa.shared.providers.embedding.default_litellm_embedding_client import (
|
|
15
|
+
DefaultLiteLLMEmbeddingClient,
|
|
16
|
+
)
|
|
17
|
+
from rasa.shared.providers.embedding.embedding_client import EmbeddingClient
|
|
18
|
+
from rasa.shared.providers.embedding.huggingface_local_embedding_client import (
|
|
19
|
+
HuggingFaceLocalEmbeddingClient,
|
|
20
|
+
)
|
|
21
|
+
from rasa.shared.providers.embedding.openai_embedding_client import (
|
|
22
|
+
OpenAIEmbeddingClient,
|
|
23
|
+
)
|
|
24
|
+
from rasa.shared.providers.llm.azure_openai_llm_client import AzureOpenAILLMClient
|
|
25
|
+
from rasa.shared.providers.llm.default_litellm_llm_client import DefaultLiteLLMClient
|
|
26
|
+
from rasa.shared.providers.llm.llm_client import LLMClient
|
|
27
|
+
from rasa.shared.providers.llm.openai_llm_client import OpenAILLMClient
|
|
28
|
+
from rasa.shared.providers.llm.self_hosted_llm_client import SelfHostedLLMClient
|
|
29
|
+
from rasa.shared.providers.llm.rasa_llm_client import RasaLLMClient
|
|
30
|
+
from rasa.shared.providers._configs.azure_openai_client_config import (
|
|
31
|
+
AzureOpenAIClientConfig,
|
|
32
|
+
)
|
|
33
|
+
from rasa.shared.providers._configs.default_litellm_client_config import (
|
|
34
|
+
DefaultLiteLLMClientConfig,
|
|
35
|
+
)
|
|
36
|
+
from rasa.shared.providers._configs.huggingface_local_embedding_client_config import (
|
|
37
|
+
HuggingFaceLocalEmbeddingClientConfig,
|
|
38
|
+
)
|
|
39
|
+
from rasa.shared.providers._configs.openai_client_config import OpenAIClientConfig
|
|
40
|
+
from rasa.shared.providers._configs.self_hosted_llm_client_config import (
|
|
41
|
+
SelfHostedLLMClientConfig,
|
|
42
|
+
)
|
|
43
|
+
from rasa.shared.providers._configs.rasa_llm_client_config import RasaLLMClientConfig
|
|
44
|
+
|
|
45
|
+
from rasa.shared.providers._configs.client_config import ClientConfig
|
|
46
|
+
|
|
47
|
+
_provider_to_llm_client_mapping: Dict[str, Type[LLMClient]] = {
|
|
48
|
+
OPENAI_PROVIDER: OpenAILLMClient,
|
|
49
|
+
AZURE_OPENAI_PROVIDER: AzureOpenAILLMClient,
|
|
50
|
+
SELF_HOSTED_PROVIDER: SelfHostedLLMClient,
|
|
51
|
+
RASA_PROVIDER: RasaLLMClient,
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
_provider_to_embedding_client_mapping: Dict[str, Type[EmbeddingClient]] = {
|
|
55
|
+
OPENAI_PROVIDER: OpenAIEmbeddingClient,
|
|
56
|
+
AZURE_OPENAI_PROVIDER: AzureOpenAIEmbeddingClient,
|
|
57
|
+
HUGGINGFACE_LOCAL_EMBEDDING_PROVIDER: HuggingFaceLocalEmbeddingClient,
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
_provider_to_client_config_class_mapping: Dict[str, Type] = {
|
|
61
|
+
OPENAI_PROVIDER: OpenAIClientConfig,
|
|
62
|
+
AZURE_OPENAI_PROVIDER: AzureOpenAIClientConfig,
|
|
63
|
+
HUGGINGFACE_LOCAL_EMBEDDING_PROVIDER: HuggingFaceLocalEmbeddingClientConfig,
|
|
64
|
+
SELF_HOSTED_PROVIDER: SelfHostedLLMClientConfig,
|
|
65
|
+
RASA_PROVIDER: RasaLLMClientConfig,
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
_provider_to_prefix_mapping: Dict[str, str] = {
|
|
70
|
+
# Specify the provider name as the key and its corresponding prefix as the value
|
|
71
|
+
# for providers where the prefix differs from the provider name.
|
|
72
|
+
SELF_HOSTED_PROVIDER: SELF_HOSTED_VLLM_PREFIX,
|
|
73
|
+
RASA_PROVIDER: OPENAI_PROVIDER,
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
def get_llm_client_from_provider(provider: Optional[str]) -> Type[LLMClient]:
|
|
78
|
+
return _provider_to_llm_client_mapping.get(provider, DefaultLiteLLMClient)
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
def get_embedding_client_from_provider(provider: str) -> Type[EmbeddingClient]:
|
|
82
|
+
return _provider_to_embedding_client_mapping.get(
|
|
83
|
+
provider, DefaultLiteLLMEmbeddingClient
|
|
84
|
+
)
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
def get_client_config_class_from_provider(provider: str) -> Type[ClientConfig]:
|
|
88
|
+
return _provider_to_client_config_class_mapping.get(
|
|
89
|
+
provider, DefaultLiteLLMClientConfig
|
|
90
|
+
)
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
def get_prefix_from_provider(provider: str) -> str:
|
|
94
|
+
return _provider_to_prefix_mapping.get(provider, provider)
|
|
File without changes
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
import os
|
|
4
|
+
from typing import Any, Dict, List
|
|
5
|
+
|
|
6
|
+
import structlog
|
|
7
|
+
from litellm import Router
|
|
8
|
+
|
|
9
|
+
from rasa.shared.constants import (
|
|
10
|
+
API_KEY,
|
|
11
|
+
LITELLM_PARAMS_KEY,
|
|
12
|
+
MODEL_CONFIG_KEY,
|
|
13
|
+
MODEL_GROUP_ID_CONFIG_KEY,
|
|
14
|
+
MODEL_LIST_KEY,
|
|
15
|
+
ROUTER_CONFIG_KEY,
|
|
16
|
+
SELF_HOSTED_VLLM_API_KEY_ENV_VAR,
|
|
17
|
+
SELF_HOSTED_VLLM_PREFIX,
|
|
18
|
+
USE_CHAT_COMPLETIONS_ENDPOINT_CONFIG_KEY,
|
|
19
|
+
)
|
|
20
|
+
from rasa.shared.exceptions import ProviderClientValidationError
|
|
21
|
+
from rasa.shared.providers._configs.litellm_router_client_config import (
|
|
22
|
+
LiteLLMRouterClientConfig,
|
|
23
|
+
)
|
|
24
|
+
from rasa.shared.utils.io import resolve_environment_variables
|
|
25
|
+
|
|
26
|
+
structlogger = structlog.get_logger()
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
class _BaseLiteLLMRouterClient:
|
|
30
|
+
"""An abstract base class for LiteLLM Router clients.
|
|
31
|
+
|
|
32
|
+
This class defines the interface and common functionality for all the router clients
|
|
33
|
+
based on LiteLLM.
|
|
34
|
+
|
|
35
|
+
The class is made private to prevent it from being part of the public-facing
|
|
36
|
+
interface, as it serves as an internal base class for specific implementations of
|
|
37
|
+
router clients that are based on LiteLLM router implementation.
|
|
38
|
+
|
|
39
|
+
Parameters:
|
|
40
|
+
model_group_id (str): The model group ID.
|
|
41
|
+
model_configurations (List[Dict[str, Any]]): The list of model configurations.
|
|
42
|
+
router_settings (Dict[str, Any]): The router settings.
|
|
43
|
+
kwargs (Optional[Dict[str, Any]]): Additional configuration parameters.
|
|
44
|
+
|
|
45
|
+
Raises:
|
|
46
|
+
ProviderClientValidationError: If validation of the client setup fails.
|
|
47
|
+
"""
|
|
48
|
+
|
|
49
|
+
def __init__(
|
|
50
|
+
self,
|
|
51
|
+
model_group_id: str,
|
|
52
|
+
model_configurations: List[Dict[str, Any]],
|
|
53
|
+
router_settings: Dict[str, Any],
|
|
54
|
+
use_chat_completions_endpoint: bool = True,
|
|
55
|
+
**kwargs: Any,
|
|
56
|
+
):
|
|
57
|
+
self._model_group_id = model_group_id
|
|
58
|
+
self._model_configurations = model_configurations
|
|
59
|
+
self._router_settings = router_settings
|
|
60
|
+
self._use_chat_completions_endpoint = use_chat_completions_endpoint
|
|
61
|
+
self._extra_parameters = kwargs or {}
|
|
62
|
+
self.additional_client_setup()
|
|
63
|
+
try:
|
|
64
|
+
resolved_model_configurations = (
|
|
65
|
+
self._resolve_env_vars_in_model_configurations()
|
|
66
|
+
)
|
|
67
|
+
self._router_client = Router(
|
|
68
|
+
model_list=resolved_model_configurations, **router_settings
|
|
69
|
+
)
|
|
70
|
+
except Exception as e:
|
|
71
|
+
event_info = "Cannot instantiate a router client."
|
|
72
|
+
structlogger.error(
|
|
73
|
+
"_base_litellm_router_client.init.error",
|
|
74
|
+
event_info=event_info,
|
|
75
|
+
model_group_id=model_group_id,
|
|
76
|
+
models=model_configurations,
|
|
77
|
+
router=router_settings,
|
|
78
|
+
original_error=e,
|
|
79
|
+
)
|
|
80
|
+
raise ProviderClientValidationError(f"{event_info} Original error: {e}")
|
|
81
|
+
|
|
82
|
+
def additional_client_setup(self) -> None:
|
|
83
|
+
"""Additional setup for the LiteLLM Router client."""
|
|
84
|
+
# If the model configuration is self-hosted VLLM, set a dummy API key if not
|
|
85
|
+
# provided. A bug in the LiteLLM library requires an API key to be set even if
|
|
86
|
+
# it is not required.
|
|
87
|
+
for model_configuration in self.model_configurations:
|
|
88
|
+
if (
|
|
89
|
+
f"{SELF_HOSTED_VLLM_PREFIX}/"
|
|
90
|
+
in model_configuration[LITELLM_PARAMS_KEY][MODEL_CONFIG_KEY]
|
|
91
|
+
and API_KEY not in model_configuration[LITELLM_PARAMS_KEY]
|
|
92
|
+
and not os.getenv(SELF_HOSTED_VLLM_API_KEY_ENV_VAR)
|
|
93
|
+
):
|
|
94
|
+
os.environ[SELF_HOSTED_VLLM_API_KEY_ENV_VAR] = "dummy api key"
|
|
95
|
+
return
|
|
96
|
+
|
|
97
|
+
@classmethod
|
|
98
|
+
def from_config(cls, config: Dict[str, Any]) -> _BaseLiteLLMRouterClient:
|
|
99
|
+
"""Instantiates a LiteLLM Router Embedding client from a configuration dict.
|
|
100
|
+
|
|
101
|
+
Args:
|
|
102
|
+
config: (Dict[str, Any]) The configuration dictionary.
|
|
103
|
+
|
|
104
|
+
Returns:
|
|
105
|
+
LiteLLMRouterLLMClient: The instantiated LiteLLM Router LLM client.
|
|
106
|
+
|
|
107
|
+
Raises:
|
|
108
|
+
ValueError: If the configuration is invalid.
|
|
109
|
+
"""
|
|
110
|
+
try:
|
|
111
|
+
client_config = LiteLLMRouterClientConfig.from_dict(config)
|
|
112
|
+
except (KeyError, ValueError) as e:
|
|
113
|
+
message = "Cannot instantiate a client from the passed configuration."
|
|
114
|
+
structlogger.error(
|
|
115
|
+
"litellm_router_llm_client.from_config.error",
|
|
116
|
+
message=message,
|
|
117
|
+
config=config,
|
|
118
|
+
original_error=e,
|
|
119
|
+
)
|
|
120
|
+
raise
|
|
121
|
+
|
|
122
|
+
return cls(
|
|
123
|
+
model_group_id=client_config.model_group_id,
|
|
124
|
+
model_configurations=client_config.litellm_model_list,
|
|
125
|
+
router_settings=client_config.litellm_router_settings,
|
|
126
|
+
use_chat_completions_endpoint=client_config.use_chat_completions_endpoint,
|
|
127
|
+
**client_config.extra_parameters,
|
|
128
|
+
)
|
|
129
|
+
|
|
130
|
+
@property
|
|
131
|
+
def model_group_id(self) -> str:
|
|
132
|
+
"""Returns the model group ID for the LiteLLM Router client."""
|
|
133
|
+
return self._model_group_id
|
|
134
|
+
|
|
135
|
+
@property
|
|
136
|
+
def model_configurations(self) -> List[Dict[str, Any]]:
|
|
137
|
+
"""Returns the model configurations for the LiteLLM Router client."""
|
|
138
|
+
return self._model_configurations
|
|
139
|
+
|
|
140
|
+
@property
|
|
141
|
+
def router_settings(self) -> Dict[str, Any]:
|
|
142
|
+
"""Returns the router settings for the LiteLLM Router client."""
|
|
143
|
+
return self._router_settings
|
|
144
|
+
|
|
145
|
+
@property
|
|
146
|
+
def router_client(self) -> Router:
|
|
147
|
+
"""Returns the instantiated LiteLLM Router client."""
|
|
148
|
+
return self._router_client
|
|
149
|
+
|
|
150
|
+
@property
|
|
151
|
+
def use_chat_completions_endpoint(self) -> bool:
|
|
152
|
+
"""Returns whether to use the chat completions endpoint."""
|
|
153
|
+
return self._use_chat_completions_endpoint
|
|
154
|
+
|
|
155
|
+
@property
|
|
156
|
+
def _litellm_extra_parameters(self) -> Dict[str, Any]:
|
|
157
|
+
"""
|
|
158
|
+
Returns the extra parameters for the LiteLLM Router client.
|
|
159
|
+
|
|
160
|
+
Returns:
|
|
161
|
+
Dictionary containing the model parameters.
|
|
162
|
+
"""
|
|
163
|
+
return self._extra_parameters
|
|
164
|
+
|
|
165
|
+
@property
|
|
166
|
+
def config(self) -> Dict:
|
|
167
|
+
"""Returns the configuration for the LiteLLM Router client in LiteLLM format."""
|
|
168
|
+
return {
|
|
169
|
+
MODEL_GROUP_ID_CONFIG_KEY: self.model_group_id,
|
|
170
|
+
MODEL_LIST_KEY: self.model_configurations,
|
|
171
|
+
ROUTER_CONFIG_KEY: self.router_settings,
|
|
172
|
+
USE_CHAT_COMPLETIONS_ENDPOINT_CONFIG_KEY: (
|
|
173
|
+
self.use_chat_completions_endpoint
|
|
174
|
+
),
|
|
175
|
+
**self._litellm_extra_parameters,
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
def _resolve_env_vars_in_model_configurations(self) -> List:
|
|
179
|
+
model_configuration_with_resolved_keys = []
|
|
180
|
+
for model_configuration in self.model_configurations:
|
|
181
|
+
resolved_model_configuration = resolve_environment_variables(
|
|
182
|
+
model_configuration
|
|
183
|
+
)
|
|
184
|
+
model_configuration_with_resolved_keys.append(resolved_model_configuration)
|
|
185
|
+
return model_configuration_with_resolved_keys
|