crewai-cli 1.14.8a3.dev20260624__tar.gz → 1.14.8a4__tar.gz
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.
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/PKG-INFO +2 -2
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/pyproject.toml +1 -1
- crewai_cli-1.14.8a4/src/crewai_cli/__init__.py +1 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/experimental/skills/main.py +29 -1
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/pyproject.toml +1 -1
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/declarative_flow/pyproject.toml +1 -1
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/pyproject.toml +1 -1
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/tool/pyproject.toml +1 -1
- crewai_cli-1.14.8a4/tests/skills/test_safe_extract.py +140 -0
- crewai_cli-1.14.8a3.dev20260624/src/crewai_cli/__init__.py +0 -1
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/.gitignore +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/README.md +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/add_crew_to_flow.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/constants.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/providers/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/providers/auth0.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/providers/base_provider.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/providers/entra_id.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/providers/keycloak.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/providers/okta.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/providers/workos.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/token.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/utils.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/checkpoint_cli.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/checkpoint_tui.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/cli.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/command.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/config.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/constants.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/create_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/create_flow.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/create_json_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/crew_chat.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/crew_run_tui.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/deploy/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/deploy/archive.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/deploy/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/deploy/validate.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/enterprise/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/enterprise/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/evaluate_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/experimental/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/experimental/skills/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/git.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/install_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/kickoff_flow.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/memory_tui.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/organization/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/organization/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/plot_flow.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/plus_api.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/provider.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/py.typed +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/remote_template/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/remote_template/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/replay_from_task.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/reset_memories_command.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/run_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/run_declarative_flow.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/settings/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/settings/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/shared/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/shared/token_manager.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/task_outputs.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/AGENTS.md +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/.gitignore +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/README.md +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/config/agents.yaml +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/config/tasks.yaml +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/knowledge/user_preference.txt +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/skills/.gitkeep +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/tools/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/tools/custom_tool.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/declarative_flow/.gitignore +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/declarative_flow/README.md +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/declarative_flow/flow.yaml +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/.gitignore +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/README.md +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/crews/content_crew/config/agents.yaml +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/crews/content_crew/config/tasks.yaml +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/crews/content_crew/content_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/skills/.gitkeep +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/tools/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/tools/custom_tool.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/tool/.gitignore +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/tool/README.md +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/tool/src/{{folder_name}}/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/tool/src/{{folder_name}}/tool.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/tools/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/tools/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/train_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/triggers/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/triggers/main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/tui_picker.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/update_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/user_data.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/utils.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/version.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/test_auth0.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/test_entra_id.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/test_keycloak.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/test_okta.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/test_workos.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/test_auth_main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/test_utils.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/deploy/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/deploy/test_archive.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/deploy/test_deploy_main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/deploy/test_validate.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/enterprise/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/enterprise/test_main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/experimental/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/experimental/skills/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/experimental/skills/test_main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/organization/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/organization/test_main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/skills/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_cli.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_click_compatibility.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_config.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_constants.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_create_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_create_flow.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_crew_run_tui.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_crew_test.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_flow_commands.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_git.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_install_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_kickoff_flow.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_plus_api.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_run_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_run_declarative_flow.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_settings_command.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_token_manager.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_train_crew.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_utils.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/test_version.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/tools/__init__.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/tools/test_main.py +0 -0
- {crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/triggers/test_main.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: crewai-cli
|
|
3
|
-
Version: 1.14.
|
|
3
|
+
Version: 1.14.8a4
|
|
4
4
|
Summary: CLI for CrewAI — scaffold, run, deploy and manage AI agent crews.
|
|
5
5
|
Project-URL: Homepage, https://crewai.com
|
|
6
6
|
Project-URL: Documentation, https://docs.crewai.com
|
|
@@ -10,7 +10,7 @@ Requires-Python: <3.14,>=3.10
|
|
|
10
10
|
Requires-Dist: appdirs~=1.4.4
|
|
11
11
|
Requires-Dist: certifi
|
|
12
12
|
Requires-Dist: click<9,>=8.1.7
|
|
13
|
-
Requires-Dist: crewai-core==1.14.
|
|
13
|
+
Requires-Dist: crewai-core==1.14.8a4
|
|
14
14
|
Requires-Dist: cryptography>=42.0
|
|
15
15
|
Requires-Dist: httpx~=0.28.1
|
|
16
16
|
Requires-Dist: packaging>=23.0
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
__version__ = "1.14.8a4"
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/experimental/skills/main.py
RENAMED
|
@@ -378,12 +378,40 @@ class SkillCommand(BaseCommand, PlusAPIMixin):
|
|
|
378
378
|
|
|
379
379
|
|
|
380
380
|
def _safe_extractall(tf: tarfile.TarFile, dest: Path) -> None:
|
|
381
|
-
"""Path-traversal-safe extraction for Python
|
|
381
|
+
"""Path-traversal-safe extraction for Python versions without tar filters.
|
|
382
|
+
|
|
383
|
+
Validates both the member's own path and, for symlink/hardlink members,
|
|
384
|
+
the link target. Without the link-target check a malicious archive can
|
|
385
|
+
plant a symlink that escapes ``dest`` (e.g. ``link -> /home/user/.ssh``)
|
|
386
|
+
followed by a regular member written *through* that link
|
|
387
|
+
(``link/authorized_keys``), escaping ``dest`` even though every member
|
|
388
|
+
name resolves inside it. This mirrors the protection that
|
|
389
|
+
``tarfile.extractall(..., filter="data")`` provides when available.
|
|
390
|
+
"""
|
|
382
391
|
dest_resolved = dest.resolve()
|
|
383
392
|
for member in tf.getmembers():
|
|
384
393
|
member_path = (dest / member.name).resolve()
|
|
385
394
|
if not member_path.is_relative_to(dest_resolved):
|
|
386
395
|
raise ValueError(f"Blocked path traversal attempt: {member.name!r}")
|
|
396
|
+
if not (member.isfile() or member.isdir() or member.issym() or member.islnk()):
|
|
397
|
+
raise ValueError(f"Blocked unsupported tar member: {member.name!r}")
|
|
398
|
+
if member.issym() or member.islnk():
|
|
399
|
+
link_target = member.linkname
|
|
400
|
+
# Absolute link targets always escape the destination.
|
|
401
|
+
if os.path.isabs(link_target):
|
|
402
|
+
raise ValueError(
|
|
403
|
+
f"Blocked link target escaping destination: "
|
|
404
|
+
f"{member.name!r} -> {link_target!r}"
|
|
405
|
+
)
|
|
406
|
+
# Hardlink names are relative to the archive root; symlink
|
|
407
|
+
# targets are relative to the member's own directory.
|
|
408
|
+
anchor = dest if member.islnk() else (dest / member.name).parent
|
|
409
|
+
resolved_target = (anchor / link_target).resolve()
|
|
410
|
+
if not resolved_target.is_relative_to(dest_resolved):
|
|
411
|
+
raise ValueError(
|
|
412
|
+
f"Blocked link target escaping destination: "
|
|
413
|
+
f"{member.name!r} -> {link_target!r}"
|
|
414
|
+
)
|
|
387
415
|
tf.extractall(dest) # noqa: S202
|
|
388
416
|
|
|
389
417
|
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
"""Regression tests for path-traversal-safe archive extraction.
|
|
2
|
+
|
|
3
|
+
Guards against symlink/hardlink-based path traversal in the fallback used on
|
|
4
|
+
Python versions without tarfile extraction filters. The filtered path relies on
|
|
5
|
+
`tarfile.extractall(..., filter="data")`; the fallback must provide the same
|
|
6
|
+
protection by validating link targets, not just member names.
|
|
7
|
+
"""
|
|
8
|
+
|
|
9
|
+
from __future__ import annotations
|
|
10
|
+
|
|
11
|
+
import io
|
|
12
|
+
import tarfile
|
|
13
|
+
from pathlib import Path
|
|
14
|
+
|
|
15
|
+
import pytest
|
|
16
|
+
|
|
17
|
+
from crewai_cli.experimental.skills.main import _safe_extractall
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
def _tar_from_members(build) -> tarfile.TarFile:
|
|
21
|
+
"""Build an in-memory tar archive via `build(tf)` and return it for reading."""
|
|
22
|
+
buf = io.BytesIO()
|
|
23
|
+
with tarfile.open(fileobj=buf, mode="w") as tf:
|
|
24
|
+
build(tf)
|
|
25
|
+
buf.seek(0)
|
|
26
|
+
return tarfile.open(fileobj=buf, mode="r")
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
def test_blocks_symlink_escaping_destination(tmp_path: Path) -> None:
|
|
30
|
+
"""A symlink whose target escapes dest, plus a file written through it,
|
|
31
|
+
must be rejected before anything is extracted."""
|
|
32
|
+
outside = tmp_path / "outside"
|
|
33
|
+
outside.mkdir()
|
|
34
|
+
dest = tmp_path / "dest"
|
|
35
|
+
dest.mkdir()
|
|
36
|
+
|
|
37
|
+
def build(tf: tarfile.TarFile) -> None:
|
|
38
|
+
link = tarfile.TarInfo("link")
|
|
39
|
+
link.type = tarfile.SYMTYPE
|
|
40
|
+
link.linkname = str(outside) # absolute path outside dest
|
|
41
|
+
tf.addfile(link)
|
|
42
|
+
payload = b"pwned"
|
|
43
|
+
info = tarfile.TarInfo("link/evil.txt")
|
|
44
|
+
info.size = len(payload)
|
|
45
|
+
tf.addfile(info, io.BytesIO(payload))
|
|
46
|
+
|
|
47
|
+
with _tar_from_members(build) as tf:
|
|
48
|
+
with pytest.raises(ValueError, match="escaping destination"):
|
|
49
|
+
_safe_extractall(tf, dest)
|
|
50
|
+
|
|
51
|
+
assert not (outside / "evil.txt").exists()
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
def test_blocks_relative_symlink_escaping_destination(tmp_path: Path) -> None:
|
|
55
|
+
"""A relative symlink (../..) that escapes dest is also rejected."""
|
|
56
|
+
dest = tmp_path / "dest"
|
|
57
|
+
dest.mkdir()
|
|
58
|
+
|
|
59
|
+
def build(tf: tarfile.TarFile) -> None:
|
|
60
|
+
link = tarfile.TarInfo("sub/link")
|
|
61
|
+
link.type = tarfile.SYMTYPE
|
|
62
|
+
link.linkname = "../../outside" # escapes dest from sub/
|
|
63
|
+
tf.addfile(link)
|
|
64
|
+
|
|
65
|
+
with _tar_from_members(build) as tf:
|
|
66
|
+
with pytest.raises(ValueError, match="escaping destination"):
|
|
67
|
+
_safe_extractall(tf, dest)
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
def test_blocks_hardlink_escaping_destination(tmp_path: Path) -> None:
|
|
71
|
+
"""A hardlink whose target escapes dest is rejected."""
|
|
72
|
+
dest = tmp_path / "dest"
|
|
73
|
+
dest.mkdir()
|
|
74
|
+
|
|
75
|
+
def build(tf: tarfile.TarFile) -> None:
|
|
76
|
+
link = tarfile.TarInfo("escape")
|
|
77
|
+
link.type = tarfile.LNKTYPE
|
|
78
|
+
link.linkname = "../outside.txt" # escapes archive root
|
|
79
|
+
tf.addfile(link)
|
|
80
|
+
|
|
81
|
+
with _tar_from_members(build) as tf:
|
|
82
|
+
with pytest.raises(ValueError, match="escaping destination"):
|
|
83
|
+
_safe_extractall(tf, dest)
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
def test_blocks_special_tar_member(tmp_path: Path) -> None:
|
|
87
|
+
"""Special tar members such as FIFOs are rejected."""
|
|
88
|
+
dest = tmp_path / "dest"
|
|
89
|
+
dest.mkdir()
|
|
90
|
+
|
|
91
|
+
def build(tf: tarfile.TarFile) -> None:
|
|
92
|
+
fifo = tarfile.TarInfo("pipe")
|
|
93
|
+
fifo.type = tarfile.FIFOTYPE
|
|
94
|
+
tf.addfile(fifo)
|
|
95
|
+
|
|
96
|
+
with _tar_from_members(build) as tf:
|
|
97
|
+
with pytest.raises(ValueError, match="unsupported tar member"):
|
|
98
|
+
_safe_extractall(tf, dest)
|
|
99
|
+
|
|
100
|
+
|
|
101
|
+
def test_allows_benign_relative_symlink(tmp_path: Path) -> None:
|
|
102
|
+
"""A symlink that stays within dest is permitted."""
|
|
103
|
+
dest = tmp_path / "dest"
|
|
104
|
+
dest.mkdir()
|
|
105
|
+
|
|
106
|
+
def build(tf: tarfile.TarFile) -> None:
|
|
107
|
+
payload = b"hi"
|
|
108
|
+
info = tarfile.TarInfo("real.txt")
|
|
109
|
+
info.size = len(payload)
|
|
110
|
+
tf.addfile(info, io.BytesIO(payload))
|
|
111
|
+
link = tarfile.TarInfo("alias.txt")
|
|
112
|
+
link.type = tarfile.SYMTYPE
|
|
113
|
+
link.linkname = "real.txt" # stays inside dest
|
|
114
|
+
tf.addfile(link)
|
|
115
|
+
|
|
116
|
+
with _tar_from_members(build) as tf:
|
|
117
|
+
_safe_extractall(tf, dest)
|
|
118
|
+
|
|
119
|
+
assert (dest / "real.txt").read_bytes() == b"hi"
|
|
120
|
+
assert (dest / "alias.txt").is_symlink()
|
|
121
|
+
assert (dest / "alias.txt").readlink() == Path("real.txt")
|
|
122
|
+
|
|
123
|
+
|
|
124
|
+
def test_allows_benign_archive(tmp_path: Path) -> None:
|
|
125
|
+
"""An ordinary archive of regular files extracts correctly."""
|
|
126
|
+
dest = tmp_path / "dest"
|
|
127
|
+
dest.mkdir()
|
|
128
|
+
|
|
129
|
+
def build(tf: tarfile.TarFile) -> None:
|
|
130
|
+
for name, body in (("SKILL.md", b"# skill"), ("scripts/run.py", b"print(1)")):
|
|
131
|
+
payload = body
|
|
132
|
+
info = tarfile.TarInfo(name)
|
|
133
|
+
info.size = len(payload)
|
|
134
|
+
tf.addfile(info, io.BytesIO(payload))
|
|
135
|
+
|
|
136
|
+
with _tar_from_members(build) as tf:
|
|
137
|
+
_safe_extractall(tf, dest)
|
|
138
|
+
|
|
139
|
+
assert (dest / "SKILL.md").read_bytes() == b"# skill"
|
|
140
|
+
assert (dest / "scripts" / "run.py").read_bytes() == b"print(1)"
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
__version__ = "1.14.8a3.dev20260624"
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/__init__.py
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/constants.py
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/main.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/token.py
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/authentication/utils.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/enterprise/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/experimental/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/organization/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/remote_template/__init__.py
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/remote_template/main.py
RENAMED
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/reset_memories_command.py
RENAMED
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/run_declarative_flow.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/shared/token_manager.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/__init__.py
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/.gitignore
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/README.md
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/crew.py
RENAMED
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/crew/main.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/.gitignore
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/README.md
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/flow/main.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/tool/.gitignore
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/src/crewai_cli/templates/tool/README.md
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/__init__.py
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/test_auth0.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/providers/test_okta.py
RENAMED
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/authentication/test_auth_main.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/experimental/skills/__init__.py
RENAMED
|
File without changes
|
{crewai_cli-1.14.8a3.dev20260624 → crewai_cli-1.14.8a4}/tests/experimental/skills/test_main.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|