lionagi 0.5.5__py3-none-any.whl → 0.6.0__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- lionagi/__init__.py +16 -24
- lionagi/{core/_class_registry.py → _class_registry.py} +51 -10
- lionagi/_errors.py +35 -0
- lionagi/libs/__init__.py +3 -0
- lionagi/libs/compress/__init__.py +3 -0
- lionagi/libs/compress/models.py +6 -2
- lionagi/libs/compress/utils.py +4 -16
- lionagi/libs/file/__init__.py +3 -0
- lionagi/libs/file/chunk.py +4 -0
- lionagi/libs/file/file_ops.py +4 -0
- lionagi/libs/file/params.py +4 -41
- lionagi/libs/file/process.py +4 -0
- lionagi/libs/file/save.py +5 -1
- lionagi/libs/{parse/flatten → nested}/flatten.py +4 -0
- lionagi/libs/{parse/nested → nested}/nfilter.py +4 -0
- lionagi/libs/{parse/nested → nested}/nget.py +6 -1
- lionagi/libs/{parse/nested → nested}/ninsert.py +5 -1
- lionagi/libs/{parse/nested → nested}/nmerge.py +4 -0
- lionagi/libs/{parse/nested → nested}/npop.py +5 -2
- lionagi/libs/{parse/nested → nested}/nset.py +6 -1
- lionagi/libs/{parse/flatten → nested}/unflatten.py +4 -0
- lionagi/libs/{parse/nested → nested}/utils.py +5 -1
- lionagi/libs/package/__init__.py +3 -0
- lionagi/libs/package/imports.py +6 -2
- lionagi/libs/package/management.py +7 -3
- lionagi/libs/package/params.py +4 -0
- lionagi/libs/package/system.py +4 -0
- lionagi/libs/parse.py +30 -0
- lionagi/libs/{parse/json → schema}/as_readable.py +10 -4
- lionagi/libs/{parse/string_parse/code_block.py → schema/extract_code_block.py} +4 -0
- lionagi/libs/{parse/string_parse/docstring.py → schema/extract_docstring.py} +4 -0
- lionagi/libs/{parse/string_parse/function_.py → schema/function_to_schema.py} +21 -9
- lionagi/libs/{parse/json/schema.py → schema/json_schema.py} +5 -1
- lionagi/libs/validate/common_field_validators.py +170 -0
- lionagi/libs/{parse/validate/keys.py → validate/fuzzy_match_keys.py} +42 -8
- lionagi/libs/{parse/validate/mapping.py → validate/fuzzy_validate_mapping.py} +41 -6
- lionagi/libs/{string_similarity/algorithms.py → validate/string_similarity.py} +115 -1
- lionagi/libs/{parse/validate/boolean.py → validate/validate_boolean.py} +42 -3
- lionagi/operations/__init__.py +13 -3
- lionagi/operations/brainstorm/__init__.py +3 -3
- lionagi/operations/brainstorm/brainstorm.py +33 -19
- lionagi/operations/brainstorm/prompt.py +4 -0
- lionagi/operations/plan/__init__.py +4 -0
- lionagi/operations/plan/plan.py +16 -13
- lionagi/operations/plan/prompt.py +4 -0
- lionagi/operations/select/__init__.py +4 -0
- lionagi/operations/select/prompt.py +4 -0
- lionagi/operations/select/select.py +1 -1
- lionagi/operations/select/utils.py +4 -4
- lionagi/{strategies → operations/strategies}/base.py +6 -2
- lionagi/{strategies → operations/strategies}/concurrent.py +8 -5
- lionagi/{strategies → operations/strategies}/concurrent_chunk.py +6 -3
- lionagi/{strategies → operations/strategies}/concurrent_sequential_chunk.py +8 -4
- lionagi/{strategies → operations/strategies}/params.py +10 -6
- lionagi/{strategies → operations/strategies}/sequential.py +6 -2
- lionagi/{strategies → operations/strategies}/sequential_chunk.py +7 -3
- lionagi/{strategies → operations/strategies}/sequential_concurrent_chunk.py +9 -4
- lionagi/{strategies → operations/strategies}/utils.py +6 -3
- lionagi/{core/models/__init__.py → operations/types.py} +3 -1
- lionagi/operations/utils.py +6 -3
- lionagi/operatives/action/function_calling.py +136 -0
- lionagi/operatives/action/manager.py +239 -0
- lionagi/operatives/action/request_response_model.py +90 -0
- lionagi/operatives/action/tool.py +141 -0
- lionagi/{protocols/operatives/action.py → operatives/action/utils.py} +52 -90
- lionagi/{core → operatives}/forms/base.py +9 -4
- lionagi/{core → operatives}/forms/form.py +8 -13
- lionagi/{core → operatives}/forms/report.py +5 -3
- lionagi/operatives/instruct/base.py +79 -0
- lionagi/operatives/instruct/instruct.py +105 -0
- lionagi/operatives/instruct/instruct_collection.py +52 -0
- lionagi/operatives/instruct/node.py +13 -0
- lionagi/{protocols/operatives → operatives/instruct}/prompts.py +0 -34
- lionagi/{protocols/operatives → operatives/instruct}/reason.py +14 -7
- lionagi/{integrations/anthropic_/version.py → operatives/manager.py} +5 -1
- lionagi/operatives/models/field_model.py +194 -0
- lionagi/operatives/models/model_params.py +307 -0
- lionagi/{core → operatives}/models/note.py +20 -28
- lionagi/{core → operatives}/models/operable_model.py +153 -71
- lionagi/{core → operatives}/models/schema_model.py +4 -3
- lionagi/{protocols/operatives → operatives}/operative.py +10 -7
- lionagi/{protocols/operatives → operatives}/step.py +67 -26
- lionagi/operatives/types.py +69 -0
- lionagi/protocols/_adapter.py +224 -0
- lionagi/protocols/_concepts.py +94 -0
- lionagi/protocols/generic/element.py +460 -0
- lionagi/protocols/generic/event.py +177 -0
- lionagi/protocols/generic/log.py +237 -0
- lionagi/{core → protocols}/generic/pile.py +172 -131
- lionagi/protocols/generic/processor.py +316 -0
- lionagi/protocols/generic/progression.py +500 -0
- lionagi/protocols/graph/edge.py +166 -0
- lionagi/protocols/graph/graph.py +290 -0
- lionagi/protocols/graph/node.py +109 -0
- lionagi/protocols/mail/exchange.py +116 -0
- lionagi/protocols/mail/mail.py +25 -0
- lionagi/protocols/mail/mailbox.py +47 -0
- lionagi/protocols/mail/manager.py +168 -0
- lionagi/protocols/mail/package.py +55 -0
- lionagi/protocols/messages/action_request.py +165 -0
- lionagi/protocols/messages/action_response.py +132 -0
- lionagi/{core/communication → protocols/messages}/assistant_response.py +55 -79
- lionagi/protocols/messages/base.py +73 -0
- lionagi/protocols/messages/instruction.py +582 -0
- lionagi/protocols/messages/manager.py +429 -0
- lionagi/protocols/messages/message.py +216 -0
- lionagi/protocols/messages/system.py +115 -0
- lionagi/protocols/messages/templates/assistant_response.jinja2 +6 -0
- lionagi/{core/communication → protocols/messages}/templates/instruction_message.jinja2 +2 -2
- lionagi/protocols/types.py +96 -0
- lionagi/service/__init__.py +10 -12
- lionagi/service/endpoints/base.py +517 -0
- lionagi/service/endpoints/chat_completion.py +102 -0
- lionagi/service/endpoints/match_endpoint.py +60 -0
- lionagi/service/endpoints/rate_limited_processor.py +145 -0
- lionagi/service/endpoints/token_calculator.py +209 -0
- lionagi/service/imodel.py +263 -96
- lionagi/service/manager.py +45 -0
- lionagi/service/providers/anthropic_/messages.py +64 -0
- lionagi/service/providers/groq_/chat_completions.py +56 -0
- lionagi/service/providers/openai_/chat_completions.py +62 -0
- lionagi/service/providers/openrouter_/chat_completions.py +62 -0
- lionagi/service/providers/perplexity_/__init__.py +3 -0
- lionagi/service/providers/perplexity_/chat_completions.py +40 -0
- lionagi/session/__init__.py +3 -0
- lionagi/session/branch.py +1287 -0
- lionagi/session/session.py +296 -0
- lionagi/settings.py +62 -118
- lionagi/utils.py +2386 -0
- lionagi/version.py +1 -1
- {lionagi-0.5.5.dist-info → lionagi-0.6.0.dist-info}/METADATA +7 -6
- lionagi-0.6.0.dist-info/RECORD +160 -0
- lionagi/core/action/action_manager.py +0 -289
- lionagi/core/action/base.py +0 -109
- lionagi/core/action/function_calling.py +0 -153
- lionagi/core/action/tool.py +0 -202
- lionagi/core/action/types.py +0 -16
- lionagi/core/communication/action_request.py +0 -163
- lionagi/core/communication/action_response.py +0 -149
- lionagi/core/communication/base_mail.py +0 -49
- lionagi/core/communication/instruction.py +0 -376
- lionagi/core/communication/message.py +0 -286
- lionagi/core/communication/message_manager.py +0 -543
- lionagi/core/communication/system.py +0 -116
- lionagi/core/communication/templates/assistant_response.jinja2 +0 -2
- lionagi/core/communication/types.py +0 -27
- lionagi/core/communication/utils.py +0 -256
- lionagi/core/forms/types.py +0 -13
- lionagi/core/generic/component.py +0 -422
- lionagi/core/generic/edge.py +0 -163
- lionagi/core/generic/element.py +0 -199
- lionagi/core/generic/graph.py +0 -377
- lionagi/core/generic/log.py +0 -151
- lionagi/core/generic/log_manager.py +0 -320
- lionagi/core/generic/node.py +0 -11
- lionagi/core/generic/progression.py +0 -395
- lionagi/core/generic/types.py +0 -23
- lionagi/core/generic/utils.py +0 -53
- lionagi/core/models/base.py +0 -28
- lionagi/core/models/field_model.py +0 -145
- lionagi/core/models/model_params.py +0 -194
- lionagi/core/models/types.py +0 -19
- lionagi/core/session/branch.py +0 -130
- lionagi/core/session/branch_mixins.py +0 -581
- lionagi/core/session/session.py +0 -163
- lionagi/core/session/types.py +0 -8
- lionagi/core/typing/__init__.py +0 -9
- lionagi/core/typing/_concepts.py +0 -173
- lionagi/core/typing/_id.py +0 -104
- lionagi/core/typing/_pydantic.py +0 -33
- lionagi/core/typing/_typing.py +0 -54
- lionagi/integrations/__init__.py +0 -0
- lionagi/integrations/_services.py +0 -17
- lionagi/integrations/anthropic_/AnthropicModel.py +0 -268
- lionagi/integrations/anthropic_/AnthropicService.py +0 -127
- lionagi/integrations/anthropic_/anthropic_max_output_token_data.yaml +0 -12
- lionagi/integrations/anthropic_/anthropic_price_data.yaml +0 -34
- lionagi/integrations/anthropic_/api_endpoints/api_request.py +0 -277
- lionagi/integrations/anthropic_/api_endpoints/data_models.py +0 -40
- lionagi/integrations/anthropic_/api_endpoints/match_response.py +0 -119
- lionagi/integrations/anthropic_/api_endpoints/messages/request/message_models.py +0 -14
- lionagi/integrations/anthropic_/api_endpoints/messages/request/request_body.py +0 -74
- lionagi/integrations/anthropic_/api_endpoints/messages/response/__init__.py +0 -0
- lionagi/integrations/anthropic_/api_endpoints/messages/response/content_models.py +0 -32
- lionagi/integrations/anthropic_/api_endpoints/messages/response/response_body.py +0 -101
- lionagi/integrations/anthropic_/api_endpoints/messages/response/usage_models.py +0 -25
- lionagi/integrations/groq_/GroqModel.py +0 -325
- lionagi/integrations/groq_/GroqService.py +0 -156
- lionagi/integrations/groq_/api_endpoints/__init__.py +0 -0
- lionagi/integrations/groq_/api_endpoints/data_models.py +0 -187
- lionagi/integrations/groq_/api_endpoints/groq_request.py +0 -288
- lionagi/integrations/groq_/api_endpoints/match_response.py +0 -106
- lionagi/integrations/groq_/api_endpoints/response_utils.py +0 -105
- lionagi/integrations/groq_/groq_max_output_token_data.yaml +0 -21
- lionagi/integrations/groq_/groq_price_data.yaml +0 -58
- lionagi/integrations/groq_/groq_rate_limits.yaml +0 -105
- lionagi/integrations/groq_/version.py +0 -5
- lionagi/integrations/litellm_/imodel.py +0 -76
- lionagi/integrations/ollama_/OllamaModel.py +0 -244
- lionagi/integrations/ollama_/OllamaService.py +0 -142
- lionagi/integrations/ollama_/api_endpoints/api_request.py +0 -179
- lionagi/integrations/ollama_/api_endpoints/chat_completion/message_models.py +0 -31
- lionagi/integrations/ollama_/api_endpoints/chat_completion/request_body.py +0 -46
- lionagi/integrations/ollama_/api_endpoints/chat_completion/response_body.py +0 -67
- lionagi/integrations/ollama_/api_endpoints/chat_completion/tool_models.py +0 -49
- lionagi/integrations/ollama_/api_endpoints/completion/__init__.py +0 -0
- lionagi/integrations/ollama_/api_endpoints/completion/request_body.py +0 -72
- lionagi/integrations/ollama_/api_endpoints/completion/response_body.py +0 -59
- lionagi/integrations/ollama_/api_endpoints/data_models.py +0 -15
- lionagi/integrations/ollama_/api_endpoints/embedding/__init__.py +0 -0
- lionagi/integrations/ollama_/api_endpoints/embedding/request_body.py +0 -33
- lionagi/integrations/ollama_/api_endpoints/embedding/response_body.py +0 -29
- lionagi/integrations/ollama_/api_endpoints/match_data_model.py +0 -62
- lionagi/integrations/ollama_/api_endpoints/match_response.py +0 -190
- lionagi/integrations/ollama_/api_endpoints/model/copy_model.py +0 -13
- lionagi/integrations/ollama_/api_endpoints/model/create_model.py +0 -28
- lionagi/integrations/ollama_/api_endpoints/model/delete_model.py +0 -11
- lionagi/integrations/ollama_/api_endpoints/model/list_model.py +0 -60
- lionagi/integrations/ollama_/api_endpoints/model/pull_model.py +0 -34
- lionagi/integrations/ollama_/api_endpoints/model/push_model.py +0 -35
- lionagi/integrations/ollama_/api_endpoints/model/show_model.py +0 -36
- lionagi/integrations/ollama_/api_endpoints/option_models.py +0 -68
- lionagi/integrations/openai_/OpenAIModel.py +0 -419
- lionagi/integrations/openai_/OpenAIService.py +0 -435
- lionagi/integrations/openai_/__init__.py +0 -0
- lionagi/integrations/openai_/api_endpoints/__init__.py +0 -3
- lionagi/integrations/openai_/api_endpoints/api_request.py +0 -277
- lionagi/integrations/openai_/api_endpoints/audio/__init__.py +0 -9
- lionagi/integrations/openai_/api_endpoints/audio/speech_models.py +0 -34
- lionagi/integrations/openai_/api_endpoints/audio/transcription_models.py +0 -136
- lionagi/integrations/openai_/api_endpoints/audio/translation_models.py +0 -41
- lionagi/integrations/openai_/api_endpoints/audio/types.py +0 -41
- lionagi/integrations/openai_/api_endpoints/batch/__init__.py +0 -17
- lionagi/integrations/openai_/api_endpoints/batch/batch_models.py +0 -146
- lionagi/integrations/openai_/api_endpoints/batch/cancel_batch.py +0 -7
- lionagi/integrations/openai_/api_endpoints/batch/create_batch.py +0 -26
- lionagi/integrations/openai_/api_endpoints/batch/list_batch.py +0 -37
- lionagi/integrations/openai_/api_endpoints/batch/request_object_models.py +0 -65
- lionagi/integrations/openai_/api_endpoints/batch/retrieve_batch.py +0 -7
- lionagi/integrations/openai_/api_endpoints/batch/types.py +0 -4
- lionagi/integrations/openai_/api_endpoints/chat_completions/__init__.py +0 -1
- lionagi/integrations/openai_/api_endpoints/chat_completions/request/__init__.py +0 -39
- lionagi/integrations/openai_/api_endpoints/chat_completions/request/message_models.py +0 -121
- lionagi/integrations/openai_/api_endpoints/chat_completions/request/request_body.py +0 -221
- lionagi/integrations/openai_/api_endpoints/chat_completions/request/response_format.py +0 -71
- lionagi/integrations/openai_/api_endpoints/chat_completions/request/stream_options.py +0 -14
- lionagi/integrations/openai_/api_endpoints/chat_completions/request/tool_choice_models.py +0 -17
- lionagi/integrations/openai_/api_endpoints/chat_completions/request/tool_models.py +0 -54
- lionagi/integrations/openai_/api_endpoints/chat_completions/request/types.py +0 -18
- lionagi/integrations/openai_/api_endpoints/chat_completions/response/__init__.py +0 -0
- lionagi/integrations/openai_/api_endpoints/chat_completions/response/choice_models.py +0 -62
- lionagi/integrations/openai_/api_endpoints/chat_completions/response/function_models.py +0 -16
- lionagi/integrations/openai_/api_endpoints/chat_completions/response/log_prob_models.py +0 -47
- lionagi/integrations/openai_/api_endpoints/chat_completions/response/message_models.py +0 -25
- lionagi/integrations/openai_/api_endpoints/chat_completions/response/response_body.py +0 -99
- lionagi/integrations/openai_/api_endpoints/chat_completions/response/types.py +0 -8
- lionagi/integrations/openai_/api_endpoints/chat_completions/response/usage_models.py +0 -24
- lionagi/integrations/openai_/api_endpoints/chat_completions/util.py +0 -46
- lionagi/integrations/openai_/api_endpoints/data_models.py +0 -23
- lionagi/integrations/openai_/api_endpoints/embeddings/__init__.py +0 -3
- lionagi/integrations/openai_/api_endpoints/embeddings/request_body.py +0 -79
- lionagi/integrations/openai_/api_endpoints/embeddings/response_body.py +0 -67
- lionagi/integrations/openai_/api_endpoints/files/__init__.py +0 -11
- lionagi/integrations/openai_/api_endpoints/files/delete_file.py +0 -20
- lionagi/integrations/openai_/api_endpoints/files/file_models.py +0 -56
- lionagi/integrations/openai_/api_endpoints/files/list_files.py +0 -27
- lionagi/integrations/openai_/api_endpoints/files/retrieve_file.py +0 -9
- lionagi/integrations/openai_/api_endpoints/files/upload_file.py +0 -38
- lionagi/integrations/openai_/api_endpoints/fine_tuning/__init__.py +0 -37
- lionagi/integrations/openai_/api_endpoints/fine_tuning/cancel_jobs.py +0 -9
- lionagi/integrations/openai_/api_endpoints/fine_tuning/create_jobs.py +0 -133
- lionagi/integrations/openai_/api_endpoints/fine_tuning/fine_tuning_job_checkpoint_models.py +0 -58
- lionagi/integrations/openai_/api_endpoints/fine_tuning/fine_tuning_job_event_models.py +0 -31
- lionagi/integrations/openai_/api_endpoints/fine_tuning/fine_tuning_job_models.py +0 -140
- lionagi/integrations/openai_/api_endpoints/fine_tuning/list_fine_tuning_checkpoints.py +0 -51
- lionagi/integrations/openai_/api_endpoints/fine_tuning/list_fine_tuning_events.py +0 -42
- lionagi/integrations/openai_/api_endpoints/fine_tuning/list_fine_tuning_jobs.py +0 -31
- lionagi/integrations/openai_/api_endpoints/fine_tuning/retrieve_jobs.py +0 -9
- lionagi/integrations/openai_/api_endpoints/fine_tuning/training_format.py +0 -30
- lionagi/integrations/openai_/api_endpoints/images/__init__.py +0 -9
- lionagi/integrations/openai_/api_endpoints/images/image_edit_models.py +0 -69
- lionagi/integrations/openai_/api_endpoints/images/image_models.py +0 -56
- lionagi/integrations/openai_/api_endpoints/images/image_variation_models.py +0 -56
- lionagi/integrations/openai_/api_endpoints/images/response_body.py +0 -30
- lionagi/integrations/openai_/api_endpoints/match_data_model.py +0 -197
- lionagi/integrations/openai_/api_endpoints/match_response.py +0 -336
- lionagi/integrations/openai_/api_endpoints/models/__init__.py +0 -7
- lionagi/integrations/openai_/api_endpoints/models/delete_fine_tuned_model.py +0 -17
- lionagi/integrations/openai_/api_endpoints/models/models_models.py +0 -31
- lionagi/integrations/openai_/api_endpoints/models/retrieve_model.py +0 -9
- lionagi/integrations/openai_/api_endpoints/moderations/__init__.py +0 -3
- lionagi/integrations/openai_/api_endpoints/moderations/request_body.py +0 -20
- lionagi/integrations/openai_/api_endpoints/moderations/response_body.py +0 -139
- lionagi/integrations/openai_/api_endpoints/uploads/__init__.py +0 -19
- lionagi/integrations/openai_/api_endpoints/uploads/add_upload_part.py +0 -11
- lionagi/integrations/openai_/api_endpoints/uploads/cancel_upload.py +0 -7
- lionagi/integrations/openai_/api_endpoints/uploads/complete_upload.py +0 -18
- lionagi/integrations/openai_/api_endpoints/uploads/create_upload.py +0 -17
- lionagi/integrations/openai_/api_endpoints/uploads/uploads_models.py +0 -52
- lionagi/integrations/openai_/image_token_calculator/__init__.py +0 -0
- lionagi/integrations/openai_/image_token_calculator/image_token_calculator.py +0 -98
- lionagi/integrations/openai_/image_token_calculator/openai_image_token_data.yaml +0 -15
- lionagi/integrations/openai_/openai_max_output_token_data.yaml +0 -12
- lionagi/integrations/openai_/openai_price_data.yaml +0 -26
- lionagi/integrations/openai_/version.py +0 -1
- lionagi/integrations/pandas_/__init__.py +0 -24
- lionagi/integrations/pandas_/extend_df.py +0 -61
- lionagi/integrations/pandas_/read.py +0 -103
- lionagi/integrations/pandas_/remove_rows.py +0 -61
- lionagi/integrations/pandas_/replace_keywords.py +0 -65
- lionagi/integrations/pandas_/save.py +0 -131
- lionagi/integrations/pandas_/search_keywords.py +0 -69
- lionagi/integrations/pandas_/to_df.py +0 -196
- lionagi/integrations/pandas_/update_cells.py +0 -54
- lionagi/integrations/perplexity_/PerplexityModel.py +0 -274
- lionagi/integrations/perplexity_/PerplexityService.py +0 -118
- lionagi/integrations/perplexity_/api_endpoints/__init__.py +0 -0
- lionagi/integrations/perplexity_/api_endpoints/api_request.py +0 -171
- lionagi/integrations/perplexity_/api_endpoints/chat_completions/__init__.py +0 -0
- lionagi/integrations/perplexity_/api_endpoints/chat_completions/request/__init__.py +0 -0
- lionagi/integrations/perplexity_/api_endpoints/chat_completions/request/request_body.py +0 -121
- lionagi/integrations/perplexity_/api_endpoints/chat_completions/response/__init__.py +0 -0
- lionagi/integrations/perplexity_/api_endpoints/chat_completions/response/response_body.py +0 -146
- lionagi/integrations/perplexity_/api_endpoints/data_models.py +0 -63
- lionagi/integrations/perplexity_/api_endpoints/match_response.py +0 -26
- lionagi/integrations/perplexity_/perplexity_max_output_token_data.yaml +0 -3
- lionagi/integrations/perplexity_/perplexity_price_data.yaml +0 -10
- lionagi/integrations/perplexity_/version.py +0 -1
- lionagi/integrations/pydantic_/__init__.py +0 -8
- lionagi/integrations/pydantic_/break_down_annotation.py +0 -81
- lionagi/integrations/pydantic_/new_model.py +0 -208
- lionagi/libs/constants.py +0 -98
- lionagi/libs/file/path.py +0 -301
- lionagi/libs/file/types.py +0 -22
- lionagi/libs/func/__init__.py +0 -0
- lionagi/libs/func/async_calls/__init__.py +0 -24
- lionagi/libs/func/async_calls/alcall.py +0 -210
- lionagi/libs/func/async_calls/bcall.py +0 -130
- lionagi/libs/func/async_calls/mcall.py +0 -134
- lionagi/libs/func/async_calls/pcall.py +0 -149
- lionagi/libs/func/async_calls/rcall.py +0 -217
- lionagi/libs/func/async_calls/tcall.py +0 -114
- lionagi/libs/func/async_calls/ucall.py +0 -85
- lionagi/libs/func/decorators.py +0 -277
- lionagi/libs/func/lcall.py +0 -57
- lionagi/libs/func/params.py +0 -64
- lionagi/libs/func/throttle.py +0 -119
- lionagi/libs/func/types.py +0 -39
- lionagi/libs/func/utils.py +0 -96
- lionagi/libs/package/types.py +0 -26
- lionagi/libs/parse/__init__.py +0 -1
- lionagi/libs/parse/flatten/__init__.py +0 -9
- lionagi/libs/parse/flatten/params.py +0 -52
- lionagi/libs/parse/json/__init__.py +0 -27
- lionagi/libs/parse/json/extract.py +0 -102
- lionagi/libs/parse/json/parse.py +0 -179
- lionagi/libs/parse/json/to_json.py +0 -71
- lionagi/libs/parse/nested/__init__.py +0 -33
- lionagi/libs/parse/nested/to_flat_list.py +0 -64
- lionagi/libs/parse/params.py +0 -0
- lionagi/libs/parse/string_parse/__init__.py +0 -11
- lionagi/libs/parse/type_convert/__init__.py +0 -19
- lionagi/libs/parse/type_convert/params.py +0 -145
- lionagi/libs/parse/type_convert/to_dict.py +0 -333
- lionagi/libs/parse/type_convert/to_list.py +0 -186
- lionagi/libs/parse/type_convert/to_num.py +0 -358
- lionagi/libs/parse/type_convert/to_str.py +0 -195
- lionagi/libs/parse/types.py +0 -9
- lionagi/libs/parse/validate/__init__.py +0 -14
- lionagi/libs/parse/validate/params.py +0 -62
- lionagi/libs/parse/xml/__init__.py +0 -10
- lionagi/libs/parse/xml/convert.py +0 -56
- lionagi/libs/parse/xml/parser.py +0 -93
- lionagi/libs/string_similarity/__init__.py +0 -32
- lionagi/libs/string_similarity/matcher.py +0 -102
- lionagi/libs/string_similarity/utils.py +0 -15
- lionagi/libs/utils.py +0 -266
- lionagi/protocols/adapters/__init__.py +0 -0
- lionagi/protocols/adapters/adapter.py +0 -79
- lionagi/protocols/adapters/json_adapter.py +0 -43
- lionagi/protocols/adapters/pandas_adapter.py +0 -96
- lionagi/protocols/configs/__init__.py +0 -0
- lionagi/protocols/configs/branch_config.py +0 -86
- lionagi/protocols/configs/id_config.py +0 -15
- lionagi/protocols/configs/imodel_config.py +0 -73
- lionagi/protocols/configs/log_config.py +0 -93
- lionagi/protocols/configs/retry_config.py +0 -29
- lionagi/protocols/configs/types.py +0 -15
- lionagi/protocols/operatives/instruct.py +0 -194
- lionagi/protocols/operatives/types.py +0 -19
- lionagi/protocols/registries/_component_registry.py +0 -23
- lionagi/protocols/registries/_pile_registry.py +0 -30
- lionagi/service/complete_request_info.py +0 -11
- lionagi/service/rate_limiter.py +0 -108
- lionagi/service/service.py +0 -41
- lionagi/service/service_match_util.py +0 -131
- lionagi/service/service_util.py +0 -72
- lionagi/service/token_calculator.py +0 -51
- lionagi/strategies/__init__.py +0 -0
- lionagi/strategies/types.py +0 -21
- lionagi-0.5.5.dist-info/RECORD +0 -374
- /lionagi/{core → libs/nested}/__init__.py +0 -0
- /lionagi/{core/action → libs/schema}/__init__.py +0 -0
- /lionagi/{core/communication → libs/validate}/__init__.py +0 -0
- /lionagi/{core/forms → operations/strategies}/__init__.py +0 -0
- /lionagi/{core/generic → operatives}/__init__.py +0 -0
- /lionagi/{core/session → operatives/action}/__init__.py +0 -0
- /lionagi/{integrations/anthropic_ → operatives/forms}/__init__.py +0 -0
- /lionagi/{core → operatives}/forms/utils.py +0 -0
- /lionagi/{integrations/anthropic_/api_endpoints → operatives/instruct}/__init__.py +0 -0
- /lionagi/{integrations/anthropic_/api_endpoints/messages → operatives/models}/__init__.py +0 -0
- /lionagi/{integrations/anthropic_/api_endpoints/messages/request → protocols/generic}/__init__.py +0 -0
- /lionagi/{integrations/groq_ → protocols/graph}/__init__.py +0 -0
- /lionagi/{integrations/litellm_ → protocols/mail}/__init__.py +0 -0
- /lionagi/{integrations/ollama_ → protocols/messages}/__init__.py +0 -0
- /lionagi/{core/communication → protocols/messages}/templates/README.md +0 -0
- /lionagi/{core/communication → protocols/messages}/templates/action_request.jinja2 +0 -0
- /lionagi/{core/communication → protocols/messages}/templates/action_response.jinja2 +0 -0
- /lionagi/{core/communication → protocols/messages}/templates/system_message.jinja2 +0 -0
- /lionagi/{core/communication → protocols/messages}/templates/tool_schemas.jinja2 +0 -0
- /lionagi/{integrations/ollama_/api_endpoints → service/endpoints}/__init__.py +0 -0
- /lionagi/{integrations/ollama_/api_endpoints/chat_completion → service/providers}/__init__.py +0 -0
- /lionagi/{integrations/ollama_/api_endpoints/model → service/providers/anthropic_}/__init__.py +0 -0
- /lionagi/{integrations/perplexity_ → service/providers/groq_}/__init__.py +0 -0
- /lionagi/{protocols/operatives → service/providers/openai_}/__init__.py +0 -0
- /lionagi/{protocols/registries → service/providers/openrouter_}/__init__.py +0 -0
- {lionagi-0.5.5.dist-info → lionagi-0.6.0.dist-info}/WHEEL +0 -0
- {lionagi-0.5.5.dist-info → lionagi-0.6.0.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,239 @@
|
|
1
|
+
# Copyright (c) 2023 - 2024, HaiyangLi <quantocean.li at gmail dot com>
|
2
|
+
#
|
3
|
+
# SPDX-License-Identifier: Apache-2.0
|
4
|
+
|
5
|
+
from typing import Any
|
6
|
+
|
7
|
+
from lionagi.protocols.types import (
|
8
|
+
ActionRequest,
|
9
|
+
EventStatus,
|
10
|
+
Execution,
|
11
|
+
Log,
|
12
|
+
Manager,
|
13
|
+
)
|
14
|
+
from lionagi.utils import to_list
|
15
|
+
|
16
|
+
from .function_calling import FunctionCalling
|
17
|
+
from .request_response_model import ActionRequestModel
|
18
|
+
from .tool import FuncTool, FuncToolRef, Tool, ToolRef
|
19
|
+
|
20
|
+
__all__ = ("ActionManager",)
|
21
|
+
|
22
|
+
|
23
|
+
class ActionManager(Manager):
|
24
|
+
|
25
|
+
def __init__(self, *args: FuncTool, **kwargs) -> None:
|
26
|
+
|
27
|
+
super().__init__()
|
28
|
+
self.registry: dict[str, Tool] = {}
|
29
|
+
|
30
|
+
tools = []
|
31
|
+
if args:
|
32
|
+
tools.extend(to_list(args, dropna=True, flatten=True))
|
33
|
+
if kwargs:
|
34
|
+
tools.extend(
|
35
|
+
to_list(kwargs, dropna=True, flatten=True, use_values=True)
|
36
|
+
)
|
37
|
+
self.register_tools(tools, update=True)
|
38
|
+
|
39
|
+
def __contains__(self, tool: FuncToolRef) -> bool:
|
40
|
+
"""Check if a tool is registered in the registry.
|
41
|
+
|
42
|
+
Supports checking by:
|
43
|
+
- Tool object
|
44
|
+
- Tool name (string)
|
45
|
+
- Callable function
|
46
|
+
|
47
|
+
Args:
|
48
|
+
tool: The tool to check for registration.
|
49
|
+
|
50
|
+
Returns:
|
51
|
+
bool: True if tool is registered, False otherwise.
|
52
|
+
"""
|
53
|
+
if isinstance(tool, Tool):
|
54
|
+
return tool.function in self.registry
|
55
|
+
elif isinstance(tool, str):
|
56
|
+
return tool in self.registry
|
57
|
+
elif callable(tool):
|
58
|
+
return tool.__name__ in self.registry
|
59
|
+
return False
|
60
|
+
|
61
|
+
def register_tool(
|
62
|
+
self,
|
63
|
+
tool: FuncTool,
|
64
|
+
update: bool = False,
|
65
|
+
) -> None:
|
66
|
+
"""Register a single tool in the registry.
|
67
|
+
|
68
|
+
If the tool is a callable function, it is automatically converted
|
69
|
+
to a Tool object. Existing tools can be updated if update=True.
|
70
|
+
|
71
|
+
Args:
|
72
|
+
tool: The tool to register (Tool object or callable).
|
73
|
+
update: If True, update existing tool; if False, raise error.
|
74
|
+
|
75
|
+
Raises:
|
76
|
+
ValueError: If tool already registered and update=False.
|
77
|
+
TypeError: If tool is not a Tool object or callable.
|
78
|
+
"""
|
79
|
+
if not update and tool in self:
|
80
|
+
name = None
|
81
|
+
if isinstance(tool, Tool):
|
82
|
+
name = tool.function
|
83
|
+
elif callable(tool):
|
84
|
+
name = tool.__name__
|
85
|
+
raise ValueError(f"Tool {name} is already registered.")
|
86
|
+
|
87
|
+
if callable(tool):
|
88
|
+
tool = Tool(func_callable=tool)
|
89
|
+
if not isinstance(tool, Tool):
|
90
|
+
raise TypeError("Please register a Tool object or callable.")
|
91
|
+
|
92
|
+
self.registry[tool.function] = tool
|
93
|
+
|
94
|
+
def register_tools(
|
95
|
+
self,
|
96
|
+
tools: list[FuncTool] | FuncTool,
|
97
|
+
update: bool = False,
|
98
|
+
) -> None:
|
99
|
+
"""Register multiple tools in the registry.
|
100
|
+
|
101
|
+
Handles both single tools and lists of tools. Each tool can be
|
102
|
+
either a Tool object or a callable function.
|
103
|
+
|
104
|
+
Args:
|
105
|
+
tools: Single tool or list of tools to register.
|
106
|
+
update: If True, update existing tools; if False, raise error.
|
107
|
+
|
108
|
+
Raises:
|
109
|
+
ValueError: If any tool is already registered.
|
110
|
+
TypeError: If any tool is not a Tool object or callable.
|
111
|
+
"""
|
112
|
+
tools_list = tools if isinstance(tools, list) else [tools]
|
113
|
+
[
|
114
|
+
self.register_tool(tool, update=update)
|
115
|
+
for tool in to_list(tools_list, dropna=True, flatten=True)
|
116
|
+
]
|
117
|
+
|
118
|
+
def match_tool(
|
119
|
+
self, action_request: ActionRequest | ActionRequestModel
|
120
|
+
) -> FunctionCalling:
|
121
|
+
if not isinstance(action_request, ActionRequest | ActionRequestModel):
|
122
|
+
raise TypeError(f"Unsupported type {type(action_request)}")
|
123
|
+
|
124
|
+
tool = self.registry.get(action_request.function, None)
|
125
|
+
if not isinstance(tool, Tool):
|
126
|
+
raise ValueError(
|
127
|
+
f"Function {action_request.function} is not registered."
|
128
|
+
)
|
129
|
+
return FunctionCalling(
|
130
|
+
func_tool=tool, arguments=action_request.arguments
|
131
|
+
)
|
132
|
+
|
133
|
+
async def invoke(
|
134
|
+
self, func_call: ActionRequestModel | ActionRequest
|
135
|
+
) -> FunctionCalling | Execution | None:
|
136
|
+
"""Invoke a tool based on the provided function call.
|
137
|
+
|
138
|
+
1. Matches function call to registered tool
|
139
|
+
2. Creates FunctionCalling instance
|
140
|
+
3. Invokes function with arguments
|
141
|
+
4. Logs execution details
|
142
|
+
5. Returns result
|
143
|
+
|
144
|
+
Args:
|
145
|
+
func_call: Function call specification in supported format.
|
146
|
+
log_manager: Optional logger for execution tracking.
|
147
|
+
|
148
|
+
Returns:
|
149
|
+
Result of tool invocation after processing pipeline.
|
150
|
+
|
151
|
+
Raises:
|
152
|
+
ValueError: If function not registered or call format invalid.
|
153
|
+
"""
|
154
|
+
try:
|
155
|
+
function_calling = self.match_tool(func_call)
|
156
|
+
except ValueError as e:
|
157
|
+
return Log(
|
158
|
+
content={
|
159
|
+
"event_type": "function_call",
|
160
|
+
"status": EventStatus.FAILED,
|
161
|
+
"error": str(e),
|
162
|
+
}
|
163
|
+
)
|
164
|
+
await function_calling.invoke()
|
165
|
+
return function_calling
|
166
|
+
|
167
|
+
@property
|
168
|
+
def schema_list(self) -> list[dict[str, Any]]:
|
169
|
+
"""List all tool schemas currently registered.
|
170
|
+
|
171
|
+
Returns:
|
172
|
+
List of OpenAI function schemas for all registered tools.
|
173
|
+
"""
|
174
|
+
return [tool.tool_schema for tool in self.registry.values()]
|
175
|
+
|
176
|
+
def get_tool_schema(
|
177
|
+
self,
|
178
|
+
tools: ToolRef = False,
|
179
|
+
auto_register: bool = True,
|
180
|
+
update: bool = False,
|
181
|
+
) -> dict:
|
182
|
+
"""Retrieve the schema for specific tools or all tools.
|
183
|
+
|
184
|
+
Args:
|
185
|
+
tools: Specification of which tools to retrieve schemas for.
|
186
|
+
If True, return all tools. If False, return empty dict.
|
187
|
+
Can also be a specific tool or list of tools.
|
188
|
+
**kwargs: Additional keyword arguments to include in output.
|
189
|
+
|
190
|
+
Returns:
|
191
|
+
Dictionary containing tool schemas and additional kwargs.
|
192
|
+
|
193
|
+
Raises:
|
194
|
+
ValueError: If a specified tool is not registered.
|
195
|
+
TypeError: If an unsupported tool type is provided.
|
196
|
+
"""
|
197
|
+
if isinstance(tools, list | tuple) and len(tools) == 1:
|
198
|
+
tools = tools[0]
|
199
|
+
if isinstance(tools, bool):
|
200
|
+
if tools is True:
|
201
|
+
return {"tools": self.schema_list}
|
202
|
+
return []
|
203
|
+
else:
|
204
|
+
schemas = self._get_tool_schema(
|
205
|
+
tools, auto_register=auto_register, update=update
|
206
|
+
)
|
207
|
+
return {"tools": schemas}
|
208
|
+
|
209
|
+
def _get_tool_schema(
|
210
|
+
self,
|
211
|
+
tool: Any,
|
212
|
+
auto_register: bool = True,
|
213
|
+
update: bool = False,
|
214
|
+
) -> dict[str, Any] | list[dict[str, Any]]:
|
215
|
+
if isinstance(tool, dict):
|
216
|
+
return tool
|
217
|
+
if callable(tool):
|
218
|
+
name = tool.__name__
|
219
|
+
if name not in self.registry:
|
220
|
+
if auto_register:
|
221
|
+
self.register_tool(tool, update=update)
|
222
|
+
else:
|
223
|
+
raise ValueError(f"Tool {name} is not registered.")
|
224
|
+
return self.registry[name].tool_schema
|
225
|
+
|
226
|
+
elif isinstance(tool, Tool) or isinstance(tool, str):
|
227
|
+
name = tool.function if isinstance(tool, Tool) else tool
|
228
|
+
if name in self.registry:
|
229
|
+
return self.registry[name].tool_schema
|
230
|
+
raise ValueError(f"Tool {name} is not registered.")
|
231
|
+
elif isinstance(tool, list):
|
232
|
+
return [
|
233
|
+
self._get_tool_schema(t, auto_register=auto_register)
|
234
|
+
for t in tool
|
235
|
+
]
|
236
|
+
raise TypeError(f"Unsupported type {type(tool)}")
|
237
|
+
|
238
|
+
|
239
|
+
__all__ = ["ActionManager"]
|
@@ -0,0 +1,90 @@
|
|
1
|
+
# Copyright (c) 2023 - 2024, HaiyangLi <quantocean.li at gmail dot com>
|
2
|
+
#
|
3
|
+
# SPDX-License-Identifier: Apache-2.0
|
4
|
+
|
5
|
+
from typing import Any
|
6
|
+
|
7
|
+
from pydantic import Field, field_validator
|
8
|
+
|
9
|
+
from lionagi.libs.validate.common_field_validators import (
|
10
|
+
validate_nullable_string_field,
|
11
|
+
)
|
12
|
+
from lionagi.utils import HashableModel, to_dict
|
13
|
+
|
14
|
+
from ..models.field_model import FieldModel
|
15
|
+
from .utils import (
|
16
|
+
action_requests_field_description,
|
17
|
+
arguments_field_description,
|
18
|
+
function_field_description,
|
19
|
+
parse_action_request,
|
20
|
+
)
|
21
|
+
|
22
|
+
__all__ = (
|
23
|
+
"ActionRequestModel",
|
24
|
+
"ACTION_REQUESTS_FIELD",
|
25
|
+
"ActionResponseModel",
|
26
|
+
"ACTION_RESPONSES_FIELD",
|
27
|
+
)
|
28
|
+
|
29
|
+
|
30
|
+
class ActionRequestModel(HashableModel):
|
31
|
+
|
32
|
+
function: str | None = Field(
|
33
|
+
None,
|
34
|
+
title="Function",
|
35
|
+
description=function_field_description,
|
36
|
+
examples=["multiply", "create_user"],
|
37
|
+
)
|
38
|
+
arguments: dict[str, Any] | None = Field(
|
39
|
+
None,
|
40
|
+
title="Arguments",
|
41
|
+
description=arguments_field_description,
|
42
|
+
)
|
43
|
+
|
44
|
+
@field_validator("arguments", mode="before")
|
45
|
+
def validate_arguments(cls, value: Any) -> dict[str, Any]:
|
46
|
+
return to_dict(
|
47
|
+
value,
|
48
|
+
fuzzy_parse=True,
|
49
|
+
recursive=True,
|
50
|
+
recursive_python_only=False,
|
51
|
+
)
|
52
|
+
|
53
|
+
@field_validator("function", mode="before")
|
54
|
+
def validate_function(cls, value: str) -> str:
|
55
|
+
return validate_nullable_string_field(cls, value, "function", False)
|
56
|
+
|
57
|
+
@classmethod
|
58
|
+
def create(cls, content: str):
|
59
|
+
try:
|
60
|
+
content = parse_action_request(content)
|
61
|
+
if content:
|
62
|
+
return [cls.model_validate(i) for i in content]
|
63
|
+
return []
|
64
|
+
except Exception:
|
65
|
+
return []
|
66
|
+
|
67
|
+
|
68
|
+
ACTION_REQUESTS_FIELD = FieldModel(
|
69
|
+
name="action_requests",
|
70
|
+
annotation=list[ActionRequestModel],
|
71
|
+
default_factory=list,
|
72
|
+
title="Actions",
|
73
|
+
description=action_requests_field_description,
|
74
|
+
)
|
75
|
+
|
76
|
+
|
77
|
+
class ActionResponseModel(HashableModel):
|
78
|
+
|
79
|
+
function: str = Field(default_factory=str, title="Function")
|
80
|
+
arguments: dict[str, Any] = Field(default_factory=dict)
|
81
|
+
output: Any = None
|
82
|
+
|
83
|
+
|
84
|
+
ACTION_RESPONSES_FIELD = FieldModel(
|
85
|
+
name="action_responses",
|
86
|
+
annotation=list[ActionResponseModel],
|
87
|
+
default_factory=list,
|
88
|
+
title="Actions",
|
89
|
+
description="**do not fill**",
|
90
|
+
)
|
@@ -0,0 +1,141 @@
|
|
1
|
+
# Copyright (c) 2023 - 2024, HaiyangLi <quantocean.li at gmail dot com>
|
2
|
+
#
|
3
|
+
# SPDX-License-Identifier: Apache-2.0
|
4
|
+
|
5
|
+
import inspect
|
6
|
+
from collections.abc import Callable
|
7
|
+
from typing import Any, Self, TypeAlias
|
8
|
+
|
9
|
+
from pydantic import Field, field_validator, model_validator
|
10
|
+
|
11
|
+
from lionagi.libs.schema.function_to_schema import function_to_schema
|
12
|
+
from lionagi.libs.validate.common_field_validators import validate_callable
|
13
|
+
from lionagi.protocols.types import Element
|
14
|
+
|
15
|
+
__all__ = (
|
16
|
+
"Tool",
|
17
|
+
"func_to_tool",
|
18
|
+
"FuncTool",
|
19
|
+
"FuncToolRef",
|
20
|
+
"ToolRef",
|
21
|
+
)
|
22
|
+
|
23
|
+
|
24
|
+
class Tool(Element):
|
25
|
+
"""A class for handling function calls with schema validation and processing.
|
26
|
+
|
27
|
+
This class wraps callable objects with optional pre and post processing,
|
28
|
+
schema validation, and provides utility methods for function inspection.
|
29
|
+
"""
|
30
|
+
|
31
|
+
func_callable: Callable[..., Any] = Field(
|
32
|
+
..., # ... indicates required field
|
33
|
+
description="The callable function to be wrapped by the tool",
|
34
|
+
exclude=True,
|
35
|
+
)
|
36
|
+
|
37
|
+
tool_schema: dict[str, Any] | None = Field(
|
38
|
+
default=None,
|
39
|
+
description="Schema describing the function's parameters and structure",
|
40
|
+
)
|
41
|
+
|
42
|
+
preprocessor: Callable[[Any], Any] | None = Field(
|
43
|
+
default=None,
|
44
|
+
description="Optional function for preprocessing inputs before execution",
|
45
|
+
exclude=True,
|
46
|
+
)
|
47
|
+
|
48
|
+
preprocessor_kwargs: dict[str, Any] = Field(
|
49
|
+
default_factory=dict,
|
50
|
+
description="Keyword arguments passed to the preprocessor function",
|
51
|
+
exclude=True,
|
52
|
+
)
|
53
|
+
|
54
|
+
postprocessor: Callable[[Any], Any] | None = Field(
|
55
|
+
default=None,
|
56
|
+
description="Optional function for postprocessing outputs after execution",
|
57
|
+
exclude=True,
|
58
|
+
)
|
59
|
+
|
60
|
+
postprocessor_kwargs: dict[str, Any] = Field(
|
61
|
+
default_factory=dict,
|
62
|
+
description="Keyword arguments passed to the postprocessor function",
|
63
|
+
exclude=True,
|
64
|
+
)
|
65
|
+
|
66
|
+
strict_func_call: bool = Field(
|
67
|
+
default=False,
|
68
|
+
description="Whether to enforce strict validation of function parameters",
|
69
|
+
)
|
70
|
+
|
71
|
+
@field_validator("func_callable", mode="before")
|
72
|
+
def _validate_func_callable(cls, value: Any) -> Callable[..., Any]:
|
73
|
+
return validate_callable(
|
74
|
+
cls, value, undefind_able=False, check_name=True
|
75
|
+
)
|
76
|
+
|
77
|
+
@model_validator(mode="after")
|
78
|
+
def _validate_tool_schema(self) -> Self:
|
79
|
+
if self.tool_schema is None:
|
80
|
+
self.tool_schema = function_to_schema(self.func_callable)
|
81
|
+
return self
|
82
|
+
|
83
|
+
@property
|
84
|
+
def function(self) -> str:
|
85
|
+
"""Get the name of the function from the schema.
|
86
|
+
|
87
|
+
Returns:
|
88
|
+
str: The name of the function as defined in the schema.
|
89
|
+
"""
|
90
|
+
return self.tool_schema["function"]["name"]
|
91
|
+
|
92
|
+
@property
|
93
|
+
def required_fields(self) -> set[str]:
|
94
|
+
"""Get the required fields from the schema.
|
95
|
+
|
96
|
+
Returns:
|
97
|
+
set[str]: Set of required field names.
|
98
|
+
"""
|
99
|
+
return set(self.tool_schema["function"]["parameters"]["required"])
|
100
|
+
|
101
|
+
@property
|
102
|
+
def minimum_acceptable_fields(self) -> set[str]:
|
103
|
+
"""Get the minimum required fields from function signature.
|
104
|
+
|
105
|
+
Returns:
|
106
|
+
set[str]: Set of minimum required field names.
|
107
|
+
"""
|
108
|
+
try:
|
109
|
+
a = {
|
110
|
+
k
|
111
|
+
for k, v in inspect.signature(
|
112
|
+
self.func_callable
|
113
|
+
).parameters.items()
|
114
|
+
if v.default == inspect.Parameter.empty
|
115
|
+
}
|
116
|
+
if "kwargs" in a:
|
117
|
+
a.remove("kwargs")
|
118
|
+
if "args" in a:
|
119
|
+
a.remove("args")
|
120
|
+
return a
|
121
|
+
except Exception:
|
122
|
+
return set()
|
123
|
+
|
124
|
+
@classmethod
|
125
|
+
def from_dict(cls, data: dict[str, Any]):
|
126
|
+
raise NotImplementedError("Tool.from_dict is not implemented.")
|
127
|
+
|
128
|
+
def to_dict(self) -> dict[str, Any]:
|
129
|
+
"""Convert Tool instance to dictionary.
|
130
|
+
|
131
|
+
Returns:
|
132
|
+
dict[str, Any]: Dictionary representation of the Tool.
|
133
|
+
"""
|
134
|
+
dict_ = super().to_dict()
|
135
|
+
dict_["function"] = self.function
|
136
|
+
return dict_
|
137
|
+
|
138
|
+
|
139
|
+
FuncTool: TypeAlias = Tool | Callable[..., Any]
|
140
|
+
FuncToolRef: TypeAlias = FuncTool | str
|
141
|
+
ToolRef: TypeAlias = FuncToolRef | list[FuncToolRef] | bool
|
@@ -3,21 +3,49 @@
|
|
3
3
|
# SPDX-License-Identifier: Apache-2.0
|
4
4
|
|
5
5
|
import re
|
6
|
+
from typing import Any
|
6
7
|
|
7
|
-
from
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
8
|
+
from pydantic import BaseModel
|
9
|
+
|
10
|
+
from lionagi.libs.validate.common_field_validators import (
|
11
|
+
validate_boolean_field,
|
12
|
+
validate_nullable_string_field,
|
13
|
+
)
|
14
|
+
from lionagi.utils import to_dict, to_json, to_list
|
15
|
+
|
16
|
+
from ..models.field_model import FieldModel
|
17
|
+
|
18
|
+
function_field_description = (
|
19
|
+
"Name of the function to call from the provided `tool_schemas`. "
|
20
|
+
"If no `tool_schemas` exist, set to None or leave blank. "
|
21
|
+
"Never invent new function names outside what's given."
|
22
|
+
)
|
23
|
+
|
24
|
+
arguments_field_description = (
|
25
|
+
"Dictionary of arguments for the chosen function. "
|
26
|
+
"Use only argument names/types defined in `tool_schemas`. "
|
27
|
+
"Never introduce extra argument names."
|
28
|
+
)
|
29
|
+
|
30
|
+
action_required_field_description = (
|
31
|
+
"Whether this step strictly requires performing actions. "
|
32
|
+
"If true, the requests in `action_requests` must be fulfilled, "
|
33
|
+
"assuming `tool_schemas` are available. "
|
34
|
+
"If false or no `tool_schemas` exist, actions are optional."
|
13
35
|
)
|
14
|
-
from lionagi.libs.parse import to_dict, to_json, validate_boolean
|
15
36
|
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
37
|
+
action_requests_field_description = (
|
38
|
+
"List of actions to be executed when `action_required` is true. "
|
39
|
+
"Each action must align with the available `tool_schemas`. "
|
40
|
+
"Leave empty if no actions are needed."
|
41
|
+
)
|
42
|
+
|
43
|
+
|
44
|
+
__all__ = (
|
45
|
+
"FUNCTION_FIELD",
|
46
|
+
"ARGUMENTS_FIELD",
|
47
|
+
"ACTION_REQUIRED_FIELD",
|
48
|
+
"parse_action_request",
|
21
49
|
)
|
22
50
|
|
23
51
|
|
@@ -30,12 +58,13 @@ def parse_action_request(content: str | dict) -> list[dict]:
|
|
30
58
|
|
31
59
|
elif isinstance(content, str):
|
32
60
|
json_blocks = to_json(content, fuzzy_parse=True)
|
33
|
-
print(json_blocks)
|
34
61
|
if not json_blocks:
|
35
62
|
pattern2 = r"```python\s*(.*?)\s*```"
|
36
63
|
_d = re.findall(pattern2, content, re.DOTALL)
|
37
|
-
json_blocks = [
|
38
|
-
json_blocks =
|
64
|
+
json_blocks = [to_json(match, fuzzy_parse=True) for match in _d]
|
65
|
+
json_blocks = to_list(json_blocks, dropna=True)
|
66
|
+
|
67
|
+
print(json_blocks)
|
39
68
|
|
40
69
|
elif content and isinstance(content, dict):
|
41
70
|
json_blocks = [content]
|
@@ -46,12 +75,11 @@ def parse_action_request(content: str | dict) -> list[dict]:
|
|
46
75
|
out = []
|
47
76
|
|
48
77
|
for i in json_blocks:
|
49
|
-
print(i)
|
50
78
|
j = {}
|
51
79
|
if isinstance(i, dict):
|
52
80
|
if "function" in i and isinstance(i["function"], dict):
|
53
81
|
if "name" in i["function"]:
|
54
|
-
i = i["function"]
|
82
|
+
i["function"] = i["function"]["name"]
|
55
83
|
for k, v in i.items():
|
56
84
|
k = (
|
57
85
|
k.replace("action_", "")
|
@@ -60,7 +88,7 @@ def parse_action_request(content: str | dict) -> list[dict]:
|
|
60
88
|
)
|
61
89
|
if k in ["name", "function", "recipient"]:
|
62
90
|
j["function"] = v
|
63
|
-
elif k in ["parameter", "argument", "arg"]:
|
91
|
+
elif k in ["parameter", "argument", "arg", "param"]:
|
64
92
|
j["arguments"] = to_dict(
|
65
93
|
v, str_type="json", fuzzy_parse=True, suppress=True
|
66
94
|
)
|
@@ -74,20 +102,11 @@ def parse_action_request(content: str | dict) -> list[dict]:
|
|
74
102
|
return out
|
75
103
|
|
76
104
|
|
77
|
-
def
|
78
|
-
|
79
|
-
return None
|
80
|
-
return value
|
81
|
-
|
82
|
-
|
83
|
-
def _validate_action_required(cls, value) -> bool:
|
84
|
-
try:
|
85
|
-
return validate_boolean(value)
|
86
|
-
except Exception:
|
87
|
-
return False
|
105
|
+
def validate_function_name(cls, value: Any) -> str | None:
|
106
|
+
return validate_nullable_string_field(cls, value, strict=False)
|
88
107
|
|
89
108
|
|
90
|
-
def
|
109
|
+
def validate_arguments(cls, value: Any) -> dict:
|
91
110
|
return to_dict(
|
92
111
|
value,
|
93
112
|
fuzzy_parse=True,
|
@@ -103,7 +122,7 @@ FUNCTION_FIELD = FieldModel(
|
|
103
122
|
title="Function",
|
104
123
|
description=function_field_description,
|
105
124
|
examples=["add", "multiply", "divide"],
|
106
|
-
validator=
|
125
|
+
validator=validate_function_name,
|
107
126
|
)
|
108
127
|
|
109
128
|
ARGUMENTS_FIELD = FieldModel(
|
@@ -113,7 +132,7 @@ ARGUMENTS_FIELD = FieldModel(
|
|
113
132
|
title="Action Arguments",
|
114
133
|
description=arguments_field_description,
|
115
134
|
examples=[{"num1": 1, "num2": 2}, {"x": "hello", "y": "world"}],
|
116
|
-
validator=
|
135
|
+
validator=validate_arguments,
|
117
136
|
validator_kwargs={"mode": "before"},
|
118
137
|
)
|
119
138
|
|
@@ -123,63 +142,6 @@ ACTION_REQUIRED_FIELD = FieldModel(
|
|
123
142
|
default=False,
|
124
143
|
title="Action Required",
|
125
144
|
description=action_required_field_description,
|
126
|
-
validator=
|
145
|
+
validator=lambda cls, v: validate_boolean_field(cls, v, False),
|
127
146
|
validator_kwargs={"mode": "before"},
|
128
147
|
)
|
129
|
-
|
130
|
-
|
131
|
-
class ActionRequestModel(BaseModel):
|
132
|
-
|
133
|
-
function: str | None = FUNCTION_FIELD.field_info
|
134
|
-
arguments: dict[str, Any] | None = ARGUMENTS_FIELD.field_info
|
135
|
-
|
136
|
-
@field_validator("arguments", mode="before")
|
137
|
-
def validate_arguments(cls, value: Any) -> dict[str, Any]:
|
138
|
-
return to_dict(
|
139
|
-
value,
|
140
|
-
fuzzy_parse=True,
|
141
|
-
recursive=True,
|
142
|
-
recursive_python_only=False,
|
143
|
-
)
|
144
|
-
|
145
|
-
@classmethod
|
146
|
-
def create(cls, content: str):
|
147
|
-
try:
|
148
|
-
content = parse_action_request(content)
|
149
|
-
if content:
|
150
|
-
return [cls.model_validate(i) for i in content]
|
151
|
-
return []
|
152
|
-
except Exception:
|
153
|
-
return []
|
154
|
-
|
155
|
-
|
156
|
-
class ActionResponseModel(BaseModel):
|
157
|
-
|
158
|
-
function: str = Field(default_factory=str)
|
159
|
-
arguments: dict[str, Any] = Field(default_factory=dict)
|
160
|
-
output: Any = None
|
161
|
-
|
162
|
-
|
163
|
-
ACTION_REQUESTS_FIELD = FieldModel(
|
164
|
-
name="action_requests",
|
165
|
-
annotation=list[ActionRequestModel],
|
166
|
-
default_factory=list,
|
167
|
-
title="Actions",
|
168
|
-
description=action_requests_field_description,
|
169
|
-
)
|
170
|
-
|
171
|
-
|
172
|
-
ACTION_RESPONSES_FIELD = FieldModel(
|
173
|
-
name="action_responses",
|
174
|
-
annotation=list[ActionResponseModel],
|
175
|
-
default_factory=list,
|
176
|
-
title="Actions",
|
177
|
-
description="**do not fill**",
|
178
|
-
)
|
179
|
-
|
180
|
-
__all__ = [
|
181
|
-
"ActionRequestModel",
|
182
|
-
"ActionResponseModel",
|
183
|
-
"ACTION_REQUESTS_FIELD",
|
184
|
-
"ACTION_RESPONSES_FIELD",
|
185
|
-
]
|
@@ -2,13 +2,18 @@
|
|
2
2
|
#
|
3
3
|
# SPDX-License-Identifier: Apache-2.0
|
4
4
|
|
5
|
-
from
|
5
|
+
from typing import Any, Literal
|
6
6
|
|
7
|
-
from
|
8
|
-
from
|
7
|
+
from pydantic import Field, field_validator
|
8
|
+
from pydantic_core import PydanticUndefined
|
9
9
|
|
10
|
+
from lionagi.protocols.types import Node
|
11
|
+
from lionagi.utils import UNDEFINED
|
10
12
|
|
11
|
-
|
13
|
+
from ..models.operable_model import OperableModel
|
14
|
+
|
15
|
+
|
16
|
+
class BaseForm(Node, OperableModel):
|
12
17
|
"""Base form class providing core functionality for form handling.
|
13
18
|
|
14
19
|
This class serves as a foundation for creating custom forms within the
|