stoobly-agent 0.34.8__tar.gz → 0.34.9__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.
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/PKG-INFO +1 -1
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/pyproject.toml +1 -1
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/__init__.py +1 -1
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/requests_controller.py +1 -1
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/endpoints_import_service.py +70 -11
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/openapi_endpoint_adapter.py +108 -207
- stoobly_agent-0.34.9/stoobly_agent/app/cli/helpers/schema_builder.py +35 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/body_parser_service.py +1 -1
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/run.py +0 -1
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/cli.py +11 -2
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_info_test.py +25 -15
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_oauth2_scopes_test.py +26 -16
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_servers_test.py +25 -15
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_test.py +79 -9
- stoobly_agent-0.34.9/stoobly_agent/test/app/cli/helpers/schema_builder_test.py +73 -0
- stoobly_agent-0.34.9/stoobly_agent/test/app/models/schemas/.stoobly/db/VERSION +1 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/replay/body_parser_service_test.py +3 -3
- stoobly_agent-0.34.8/stoobly_agent/app/cli/helpers/schema_builder.py +0 -112
- stoobly_agent-0.34.8/stoobly_agent/test/app/cli/helpers/schema_builder_test.py +0 -58
- stoobly_agent-0.34.8/stoobly_agent/test/app/models/schemas/.stoobly/db/VERSION +0 -1
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/LICENSE +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/README.md +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/application_http_request_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/bodies_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/configs_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/headers_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/proxy_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/query_params_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/replayed_response_headers_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/replayed_responses_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/response_headers_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/responses_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/routes.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/scenarios_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/simple_http_request_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/api/statuses_controller.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/ca_cert_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/ca_cert_installer.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/config_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/decorators/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/decorators/config.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/decorators/exec.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/dev_tools_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/endpoint_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/feature_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/handlers/request_cli_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/handlers/scenario_cli_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/endpoint_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/endpoints_apply_context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/endpoints_apply_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/endpoints_import_context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/feature_flags.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/handle_config_update_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/handle_mock_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/handle_replay_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/handle_test_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/iterate_group_by.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/json_print.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/print_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/project_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/replay_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/report_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/request_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/request_synchronize_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/run_command_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/scenario_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/synchronize_request_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/tabulate_print_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/test_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/test_replay_context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/trace_aliases.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/trace_context_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/validations.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/helpers/verify_raw_request_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/intercept_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/main_group.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/project_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/report_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/request_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/scenario_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/snapshot_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/trace_cli.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/types/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/types/output.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/types/print_options.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/types/request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/types/scenario.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/cli/types/test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/joined_request_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/mitmproxy/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/mitmproxy/request/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/mitmproxy/request/python_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/mitmproxy/response/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/mitmproxy/response/python_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/orm/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/orm/joined_request_string_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/orm/request/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/orm/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/orm/request/python_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/orm/response/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/orm/response/mitmproxy_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/orm/response/python_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/python/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/python/request/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/python/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/python/request/raw_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/python/request/stoobly_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/python/response/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/python/response/mitmproxy_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/python/response/raw_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/raw_http_request_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/raw_http_response_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/raw_joined/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/raw_joined/request/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/raw_joined/request/python_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/raw_joined/response/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/raw_joined/response/python_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/stoobly/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/stoobly/request/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/adapters/stoobly/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/body_model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/body.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/header.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/body_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/header_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/create_request_columns_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/log.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/log_event.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/request_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/request_snapshot.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/scenario_snapshot.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/search.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot_types.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/helpers/tiebreak_scenario_request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/local_db_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/orm_request_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/query_param_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/replayed_response_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/request_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/response_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/response_header_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/local_db/scenario_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/query_param.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/replayed_response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/response_header.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/scenario.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/stoobly/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/stoobly/request_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/factories/resource/stoobly/scenario_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/header_model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/helpers/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/helpers/apply.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/helpers/create_request_params_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/query_param_model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/replayed_response_model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/request_model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/response_header_model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/response_model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/scenario_model.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/schemas/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/schemas/request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/types/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/types/endpoint.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/types/replayed_response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/types/request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/types/request_components.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/types/response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/models/types/scenario.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/constants/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/constants/custom_response_codes.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/handle_mock_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/handle_record_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/handle_replay_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/handle_test_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/hot_reload.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/intercept_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/intercept_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mitmproxy/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mitmproxy/flow_mock.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mitmproxy/request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mitmproxy/request_body_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mitmproxy/request_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mitmproxy/response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mitmproxy/response_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/custom_not_found_response_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/eval_fixtures_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/eval_request_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/hashed_request_decorator.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/ignored_components_response_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/request_hasher.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/search_endpoint.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/mock/types/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/join_request_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/joined_request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/overwrite_scenario_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/proxy_request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/request_string.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/request_string_control.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/response_string.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/response_string_control.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/record/upload_request_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/alias_context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/alias_resolver.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/multipart.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/replay_request_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/replay_scenario_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/rewrite_params_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/trace_context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/simulate_intercept_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/context_abc.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/context_response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/diff_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/endpoint_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/mitmproxy_response_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/request_component_names_facade.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/requests_response_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/stoobly_response_adapter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/test_results_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/helpers/upload_test_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/matchers/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/matchers/context.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/matchers/contract.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/matchers/custom.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/matchers/diff.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/matchers/errors.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/matchers/fuzzy.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/matchers/handlers/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/test/test_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/utils/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/utils/allowed_request_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/utils/publish_change_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/utils/request_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/utils/response_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/utils/rewrite_rules_to_ignored_components_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/cli_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/constants/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/constants/firewall_action.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/constants/intercept_mode.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/constants/mode.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/constants/request_component.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/data_rules.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/data_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/feature_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/firewall_rule.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/firewall_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/helpers/active_mode_settings_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/intercept_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/match_rule.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/match_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/parameter_rule.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/proxy_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/remote_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/rewrite_rule.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/rewrite_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/types/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/types/cli_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/types/proxy_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/types/remote_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/types/ui_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/ui_settings.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/settings/url_rule.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/alias_resolve_strategy.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/custom_headers.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/env_vars.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/headers.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/lifecycle_hooks.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/mock_policy.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/mode.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/record_policy.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/replay_policy.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/request_origin.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/statuses.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/test_filter.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/test_output_level.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/constants/test_strategy.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/data_dir.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/mitmproxy.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/schema.yml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/settings.yml.sample +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/config/source_dir.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2022_03_17_060144_create_requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2022_03_17_074916_create_responses.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2022_05_10_003705_create_traces.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2022_05_10_003840_create_trace_aliases.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2022_06_29_234516_create_trace_requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2022_06_29_235155_add_trace_request_reference_to_trace_aliases.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2022_12_12_092437_align_requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2022_12_28_092917_add_filter_columns_to_requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_01_21_055426_create_scenarios.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_01_21_060225_add_scenario_id_reference_to_requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_02_02_022229_create_replayed_responses.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_03_20_192909_add_http_version_column_to_requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_03_20_220448_add_http_version_column_to_responses.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_04_18_071327_align_requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_05_15_212505_add_uuid_column_to_requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_05_15_213119_add_uuid_column_to_scenarios.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/2023_05_29_053649_add_overwritable_column_to_scenarios.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/db/migrations/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/agent_api.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/api.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/body_param_names_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/endpoints_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/header_names_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/endpoints.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/headers.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/pagination_query_params.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/projects.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/query_params.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/reports.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/requests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/response_headers.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/responses.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/scenarios.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/tests.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/traces.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/interfaces/users.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/json_response_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/organization_key.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/project_key.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/report_key.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/request_key.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/resource_key.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/scenario_key.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/test_key.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/keys/uuid_key.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/param_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/projects_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/query_param_names_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/reports_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/requests_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/response_header_names_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/response_param_names_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/scenarios_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/stoobly_api.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/test_responses_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/tests_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/api/users_resource.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/cache.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/logger.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/base.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/migrate_service.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/replayed_response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/scenario.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/trace.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/trace_alias.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/trace_request.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/transformers/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/transformers/orm_to_request_transformer.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/transformers/orm_to_requests_response_transformer.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/transformers/orm_to_stoobly_request_transformer.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/transformers/orm_to_stoobly_response_transformer.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/types/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/types/request_columns.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/types/response_columns.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/utils/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/utils/request_parse_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/utils/requests_response_builder.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/orm/utils/response_parse_handler.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/utils/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/utils/conditional_decorator.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/utils/decode.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/utils/jmespath.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/utils/python_to_ruby_type.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/lib/utils/visitor.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/mock.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/0-es2015.c7c5a6d51b98cb85b9fc.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/0-es5.c7c5a6d51b98cb85b9fc.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/1-es2015.bb4492eeabe1fe937ada.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/1-es5.bb4492eeabe1fe937ada.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/10-es2015.56da22458086513ba0c7.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/10-es5.56da22458086513ba0c7.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/12-es2015.be58ed0ef449008b932e.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/12-es5.be58ed0ef449008b932e.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/13-es2015.220b4a1adf4cacb294e5.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/13-es5.220b4a1adf4cacb294e5.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/14-es2015.b6619d7742671d2a37fb.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/14-es5.b6619d7742671d2a37fb.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/15-es2015.d8855701408b0e1d7a3e.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/15-es5.d8855701408b0e1d7a3e.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/16-es2015.98fa59c2c96d2caac3c3.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/16-es5.98fa59c2c96d2caac3c3.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/17-es2015.7f60b56d1fd66d4d5544.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/17-es5.7f60b56d1fd66d4d5544.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/18-es2015.10cdd5c608b10d90d19a.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/18-es5.10cdd5c608b10d90d19a.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/19-es2015.78ec0e9fd228b5104712.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/19-es5.78ec0e9fd228b5104712.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/2-es2015.51eb8544ea9a21f2874c.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/2-es5.51eb8544ea9a21f2874c.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/20-es2015.90544c488f1f0900bab4.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/20-es5.90544c488f1f0900bab4.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/21-es2015.63ed4e6b242fbc047bd6.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/21-es5.63ed4e6b242fbc047bd6.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/22-es2015.1e96ef651f96d51191e2.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/22-es5.1e96ef651f96d51191e2.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/23-es2015.6d3052555b4fac38f16d.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/23-es5.6d3052555b4fac38f16d.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/28-es2015.a2bf42f38e4dd771ccea.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/28-es5.a2bf42f38e4dd771ccea.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/29-es2015.18b515f07c88753c7eb6.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/29-es5.18b515f07c88753c7eb6.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/30-es2015.d4d3dc4101400cadf3f3.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/30-es5.d4d3dc4101400cadf3f3.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/31-es2015.e3ea815f75c19c217b7d.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/31-es5.e3ea815f75c19c217b7d.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/32-es2015.57553995bff0ae518501.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/32-es5.57553995bff0ae518501.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/33-es2015.da5ba1e5baa164921198.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/33-es5.da5ba1e5baa164921198.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/34-es2015.87acbb95cfb824650157.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/34-es5.87acbb95cfb824650157.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/35-es2015.61a7ae8da93df94fab06.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/35-es5.61a7ae8da93df94fab06.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/36-es2015.e3a104020eeec02cb8c4.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/36-es5.e3a104020eeec02cb8c4.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/37-es2015.3b472e6cf303201bbf2c.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/37-es5.3b472e6cf303201bbf2c.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/38-es2015.39dbf43d46cdc94f78c6.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/38-es5.39dbf43d46cdc94f78c6.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/39-es2015.e5475ea4fb6ec5c60741.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/39-es5.e5475ea4fb6ec5c60741.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/3rdpartylicenses.txt +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/4-es2015.f8ac5475bf103969b2d2.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/4-es5.f8ac5475bf103969b2d2.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/40-es2015.47b2873a8439717af6a7.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/40-es5.47b2873a8439717af6a7.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/41-es2015.69f2771002745c066976.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/41-es5.69f2771002745c066976.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/42-es2015.b590b92ede890155dcd6.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/42-es5.b590b92ede890155dcd6.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/43-es2015.ad1d956bffba561ba64c.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/43-es5.ad1d956bffba561ba64c.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/44-es2015.3ef2c17996ed5be95ced.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/44-es5.3ef2c17996ed5be95ced.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/45-es2015.3d65d27e0a7085e96356.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/45-es5.3d65d27e0a7085e96356.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/46-es2015.e4f0a5b127eae13c27c0.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/46-es5.e4f0a5b127eae13c27c0.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/47-es2015.c7d45334a70131f133b5.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/47-es5.c7d45334a70131f133b5.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/5-es2015.90ea7bd4439d9749e052.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/5-es5.90ea7bd4439d9749e052.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/6-es2015.5fb726c0555664300974.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/6-es5.5fb726c0555664300974.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/7-es2015.c359dbb640e2af507221.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/7-es5.c359dbb640e2af507221.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/8-es2015.b901639e2aeff1358c3d.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/8-es5.b901639e2aeff1358c3d.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/9-es2015.cfc1101139d6ae75731b.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/9-es5.cfc1101139d6ae75731b.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/CHANGELOG.md +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/README.md +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/_redirects +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/1.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/2.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/3.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/4.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/5.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/6.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/7.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/8.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/landscape.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/demo/mountain-cinematic.jpg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/illustrations/checklist.svg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/illustrations/data_center.svg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/illustrations/idea.svg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/illustrations/it_support.svg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/illustrations/peak_mountain_3.svg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/illustrations/under_constructions_1.svg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/logo/colored.png +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/logo/colored.svg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/logo/white.png +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/assets/img/logo/white.svg +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/common-es2015.388805227aa99c527fba.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/common-es5.388805227aa99c527fba.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/favicon.ico +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/index.html +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/main-es2015.ccd46ac1b6638ddf2066.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/main-es5.ccd46ac1b6638ddf2066.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/polyfills-es2015.8ce2adc69f283f6c4c5e.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/polyfills-es5.7530172ddcec11a10eb3.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/runtime-es2015.08e65883d390cd16c15b.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/runtime-es5.08e65883d390cd16c15b.js +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/public/styles.ab281309cf423b2cdcb0.css +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/cli_mock_integration_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/config/firewall_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/config/match_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/config/project/config_project_set_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/config/rewrite_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/config/scenario/config_scenario_set_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/endpoint/endpoint_cli_apply_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_additional_props_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/helpers/synchronize_request_service_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/intercept/intercept_configure_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/intercept/intercept_enable_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/request/request_delete_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/request/request_list_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/request/request_replay_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/request/request_reset_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/request/request_response_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/request/request_snapshot_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/request/request_test_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/scenario/scenario_create_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/scenario/scenario_replay_integration_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/scenario/scenario_replay_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/scenario/scenario_reset_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/scenario/scenario_snapshot_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/scenario/scenario_test_integration_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/snapshot/snapshot_apply_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/snapshot/snapshot_prune_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/cli/snapshot/snapshot_update_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/orm/joined_request_string_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/orm/request/orm_mitmproxy_request_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/orm/request/orm_python_request_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/orm/response/orm_mitmproxy_response_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/orm/response/orm_python_response_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/python/request/mitmproxy_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/python/request/raw_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/python/request/stoobly_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/python/response/mitmproxy_response_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/adapters/python/response/raw_response_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/factories/resource/local_db/helpers/log_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/factories/resource/local_db/helpers/tiebreak_scenario_request_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/factories/resource/local_db/request_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/factories/resource/local_db/response_adapter_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/schemas/.stoobly/db/stoobly_agent.sqlite3 +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/schemas/.stoobly/settings.yml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/schemas/.stoobly/tmp/options.json +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/models/schemas/request_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/mitmproxy/request_facade_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/mock/eval_fixtures_service_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/replay/rewrite_params_service_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/replay/trace_context_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/replay/visitor_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/test/helpers/test_results_builder_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/upload/request_string_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/proxy/upload/response_string_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/test/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/test/matchers/contract_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/test/matchers/diff_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/app/test/matchers/fuzzy_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/cli/mock_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/cli/record_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/config/data_dir_test.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/__init__.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/endpoint_show_response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/petstore-additional-props.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/petstore-expanded.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/petstore-missing-info.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/petstore-missing-oauth2-scopes.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/petstore-missing-servers.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/petstore-references.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/petstore-swagger-io.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/petstore.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/request_show_response.py +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/mock_data/uspto.yaml +0 -0
- {stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/test/test_helper.py +0 -0
@@ -1,2 +1,2 @@
|
|
1
1
|
COMMAND = 'stoobly-agent'
|
2
|
-
VERSION = '0.34.
|
2
|
+
VERSION = '0.34.9'
|
@@ -41,7 +41,7 @@ class RequestsController:
|
|
41
41
|
return
|
42
42
|
|
43
43
|
raw_requests = body_params.get('requests')
|
44
|
-
payloads_delimitter = body_params.get('payloads_delimitter') or REQUEST_DELIMITTER
|
44
|
+
payloads_delimitter = body_params.get('payloads_delimitter') or REQUEST_DELIMITTER
|
45
45
|
toks = raw_requests.split(payloads_delimitter)
|
46
46
|
|
47
47
|
if len(toks) % 2 != 0:
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import json
|
2
2
|
import requests
|
3
3
|
import sys
|
4
|
-
from typing import Dict
|
4
|
+
from typing import Dict, TypedDict, Optional
|
5
5
|
|
6
6
|
from .endpoints_import_context import EndpointsImportContext
|
7
7
|
from stoobly_agent.app.models.types import ENDPOINT_COMPONENT_NAMES
|
@@ -16,12 +16,19 @@ from stoobly_agent.lib.api.response_header_names_resource import ResponseHeaderN
|
|
16
16
|
from stoobly_agent.lib.api.response_param_names_resource import ResponseParamNamesResource
|
17
17
|
from stoobly_agent.lib.logger import bcolors
|
18
18
|
|
19
|
+
class ComponentImportArgs(TypedDict):
|
20
|
+
project_id: int
|
21
|
+
endpoint_id: int
|
22
|
+
resource: EndpointsResource
|
23
|
+
component: RequestComponentName
|
24
|
+
parents: Optional[Dict]
|
25
|
+
|
19
26
|
def import_endpoints(context: EndpointsImportContext):
|
20
27
|
for endpoint in context.endpoints:
|
21
28
|
for endpoint_handler in context.endpoint_handlers:
|
22
29
|
endpoint_handler(endpoint)
|
23
30
|
|
24
|
-
try:
|
31
|
+
try:
|
25
32
|
res = import_endpoint(context.project_id, context.resources['endpoint'], endpoint)
|
26
33
|
except requests.HTTPError as e:
|
27
34
|
error_handler(e, f"Failed to import endpoint: {endpoint['method']} {endpoint['path']}")
|
@@ -57,7 +64,12 @@ def import_endpoint(project_id: int, endpoint_resource: EndpointsResource, endpo
|
|
57
64
|
|
58
65
|
res.raise_for_status()
|
59
66
|
|
60
|
-
def import_header_name(
|
67
|
+
def import_header_name(args: ComponentImportArgs):
|
68
|
+
project_id = args['project_id']
|
69
|
+
endpoint_id = args['endpoint_id']
|
70
|
+
header_name_resource = args['resource']
|
71
|
+
header_name = args['component']
|
72
|
+
|
61
73
|
res: requests.Response = header_name_resource.create(endpoint_id, {
|
62
74
|
'name': header_name.get('name'),
|
63
75
|
'is_deterministic': header_name.get('is_deterministic', True),
|
@@ -68,7 +80,18 @@ def import_header_name(project_id: int, endpoint_id: int, header_name_resource:
|
|
68
80
|
|
69
81
|
res.raise_for_status()
|
70
82
|
|
71
|
-
def import_body_param_name(
|
83
|
+
def import_body_param_name(args: ComponentImportArgs):
|
84
|
+
project_id = args['project_id']
|
85
|
+
endpoint_id = args['endpoint_id']
|
86
|
+
body_param_name_resource = args['resource']
|
87
|
+
body_param_name = args['component']
|
88
|
+
parents = args['parents']
|
89
|
+
|
90
|
+
body_param_name_id = None
|
91
|
+
parent_id = body_param_name.get('body_param_name_id')
|
92
|
+
if parent_id:
|
93
|
+
body_param_name_id = parents[parent_id]
|
94
|
+
|
72
95
|
res: requests.Response = body_param_name_resource.create(endpoint_id, {
|
73
96
|
'name': body_param_name.get('name'),
|
74
97
|
'is_deterministic': body_param_name.get('is_deterministic', True),
|
@@ -77,11 +100,20 @@ def import_body_param_name(project_id: int, endpoint_id: int, body_param_name_re
|
|
77
100
|
'query': body_param_name.get('query'),
|
78
101
|
'endpoint_id': endpoint_id,
|
79
102
|
'project_id': project_id,
|
103
|
+
'body_param_name_id': body_param_name_id
|
80
104
|
})
|
81
105
|
|
82
106
|
res.raise_for_status()
|
83
107
|
|
84
|
-
|
108
|
+
res_id = res.json()['id']
|
109
|
+
parents[body_param_name['id']] = res_id
|
110
|
+
|
111
|
+
def import_query_param_name(args: ComponentImportArgs):
|
112
|
+
project_id = args['project_id']
|
113
|
+
endpoint_id = args['endpoint_id']
|
114
|
+
query_param_name_resource = args['resource']
|
115
|
+
query_param_name = args['component']
|
116
|
+
|
85
117
|
res: requests.Response = query_param_name_resource.create(endpoint_id, {
|
86
118
|
'name': query_param_name.get('name'),
|
87
119
|
'is_deterministic': query_param_name.get('is_deterministic', True),
|
@@ -92,7 +124,18 @@ def import_query_param_name(project_id: int, endpoint_id: int, query_param_name_
|
|
92
124
|
|
93
125
|
res.raise_for_status()
|
94
126
|
|
95
|
-
def import_response_param_name(
|
127
|
+
def import_response_param_name(args: ComponentImportArgs):
|
128
|
+
project_id = args['project_id']
|
129
|
+
endpoint_id = args['endpoint_id']
|
130
|
+
response_param_name_resource = args['resource']
|
131
|
+
response_param_name = args['component']
|
132
|
+
parents = args['parents']
|
133
|
+
|
134
|
+
response_param_name_id = None
|
135
|
+
parent_id = response_param_name.get('response_param_name_id')
|
136
|
+
if parent_id:
|
137
|
+
response_param_name_id = parents[parent_id]
|
138
|
+
|
96
139
|
res: requests.Response = response_param_name_resource.create(endpoint_id, {
|
97
140
|
'name': response_param_name.get('name'),
|
98
141
|
'is_deterministic': response_param_name.get('is_deterministic', True),
|
@@ -101,11 +144,21 @@ def import_response_param_name(project_id: int, endpoint_id: int, response_param
|
|
101
144
|
'query': response_param_name.get('query'),
|
102
145
|
'endpoint_id': endpoint_id,
|
103
146
|
'project_id': project_id,
|
147
|
+
'response_param_name_id': response_param_name_id
|
104
148
|
})
|
105
149
|
|
106
150
|
res.raise_for_status()
|
107
151
|
|
108
|
-
|
152
|
+
res_id = res.json()['id']
|
153
|
+
parents[response_param_name['id']] = res_id
|
154
|
+
|
155
|
+
|
156
|
+
def import_response_header_name(args: ComponentImportArgs):
|
157
|
+
project_id = args['project_id']
|
158
|
+
endpoint_id = args['endpoint_id']
|
159
|
+
response_header_name_resource = args['resource']
|
160
|
+
response_header_name = args['component']
|
161
|
+
|
109
162
|
res: requests.Response = response_header_name_resource.create(endpoint_id, {
|
110
163
|
'name': response_header_name.get('name'),
|
111
164
|
'is_deterministic': response_header_name.get('is_deterministic', True),
|
@@ -124,14 +177,20 @@ component_name_import_dispatch = {
|
|
124
177
|
ENDPOINT_COMPONENT_NAMES[4]: import_response_param_name
|
125
178
|
}
|
126
179
|
|
127
|
-
def process_import(component_name: str, *args):
|
128
|
-
return component_name_import_dispatch[component_name](*args)
|
129
|
-
|
130
180
|
def import_component_names(project_id: int, endpoint_id: int, endpoint: EndpointShowResponse, resources: Dict[str, EndpointsResource]):
|
131
181
|
for component_name in ENDPOINT_COMPONENT_NAMES:
|
182
|
+
parents: Dict[int, int] = {}
|
132
183
|
for component in endpoint.get(f'{component_name}s', {}):
|
133
184
|
resource = resources[component_name]
|
134
|
-
|
185
|
+
args = {
|
186
|
+
'project_id': project_id,
|
187
|
+
'endpoint_id': endpoint_id,
|
188
|
+
'resource': resource,
|
189
|
+
'component': component,
|
190
|
+
'parents': parents
|
191
|
+
}
|
192
|
+
component_name_import_dispatch[component_name](args)
|
193
|
+
|
135
194
|
|
136
195
|
def cleanup_endpoint(project_id: int, endpoint_id: int, resource: EndpointsResource):
|
137
196
|
print(f"{bcolors.OKBLUE}Cleaning up partial import...{bcolors.ENDC}")
|
@@ -114,9 +114,13 @@ class OpenApiEndpointAdapter():
|
|
114
114
|
operation = path[http_method]
|
115
115
|
required_query_params = []
|
116
116
|
required_body_params = []
|
117
|
+
literal_query_params = []
|
117
118
|
|
118
119
|
parameters = operation.get("parameters", {})
|
119
120
|
for parameter in parameters:
|
121
|
+
if '$ref' in parameter.keys():
|
122
|
+
parameter = self.__dereference(components, parameter['$ref'])
|
123
|
+
|
120
124
|
if parameter['in'] == 'query':
|
121
125
|
# query_param: RequestComponentName = {}
|
122
126
|
# query_param['name'] = parameter['name']
|
@@ -131,39 +135,10 @@ class OpenApiEndpointAdapter():
|
|
131
135
|
if not endpoint.get('query_param_names'):
|
132
136
|
endpoint['query_param_names'] = []
|
133
137
|
|
134
|
-
schema = parameter
|
135
|
-
|
136
|
-
|
137
|
-
param_value = None
|
138
|
-
if open_api_type == 'array':
|
139
|
-
item_type = schema['items']['type']
|
140
|
-
default_value = schema['items'].get('default')
|
141
|
-
item_default = None
|
142
|
-
if default_value:
|
143
|
-
item_default = {'value': default_value}
|
144
|
-
else:
|
145
|
-
item_default = {'value': self.__open_api_to_default_python_type(item_type)}
|
146
|
-
|
147
|
-
param_value = [item_default]
|
138
|
+
schema = parameter.get('schema', {})
|
139
|
+
self.__extract_param_properties(components, required_query_params, {parameter['name']: schema}, literal_query_params, curr_id=len(literal_query_params)+1)
|
148
140
|
|
149
|
-
|
150
|
-
else:
|
151
|
-
default_value = schema.get('default')
|
152
|
-
if default_value:
|
153
|
-
param_value = default_value
|
154
|
-
else:
|
155
|
-
param_value = self.__open_api_to_default_python_type(open_api_type)
|
156
|
-
|
157
|
-
literal_query_param = {
|
158
|
-
parameter['name']: {
|
159
|
-
'value': param_value,
|
160
|
-
'required': parameter.get('required', False),
|
161
|
-
}
|
162
|
-
}
|
163
|
-
|
164
|
-
if not endpoint.get('literal_query_params'):
|
165
|
-
endpoint['literal_query_params'] = {}
|
166
|
-
endpoint['literal_query_params'].update(literal_query_param)
|
141
|
+
endpoint['literal_query_params'] = literal_query_params
|
167
142
|
|
168
143
|
elif parameter['in'] == 'header':
|
169
144
|
header: RequestComponentName = {}
|
@@ -206,39 +181,16 @@ class OpenApiEndpointAdapter():
|
|
206
181
|
request_body = operation.get("requestBody", {})
|
207
182
|
required_request_body = request_body.get("required")
|
208
183
|
required_body_params = []
|
209
|
-
literal_body_params =
|
210
|
-
request_body_array = False
|
184
|
+
literal_body_params = []
|
211
185
|
|
212
186
|
content = request_body.get("content", {})
|
213
187
|
for mimetype, media_type in content.items():
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
# If Spec Component reference, look it up in components
|
218
|
-
if '$ref' in schema:
|
219
|
-
reference = schema['$ref']
|
220
|
-
self.__dereference(components, reference, required_body_params, literal_body_params)
|
221
|
-
else:
|
222
|
-
required_body_params = schema.get('required', [])
|
188
|
+
schema = media_type.get('schema')
|
189
|
+
if schema:
|
190
|
+
self.__extract_param_properties(components, required_body_params, {'tmp': schema}, literal_body_params)
|
223
191
|
|
224
|
-
|
225
|
-
|
226
|
-
if schema_type == 'object':
|
227
|
-
param_properties = schema.get('properties', {})
|
228
|
-
elif schema_type == 'array':
|
229
|
-
request_body_array = True
|
230
|
-
param_properties = {'tmp': schema['items']}
|
231
|
-
|
232
|
-
for property_key, property_value in param_properties.items():
|
233
|
-
if property_key in required_body_params:
|
234
|
-
param_properties[property_key]['required'] = True
|
235
|
-
|
236
|
-
if not endpoint.get('literal_body_params'):
|
237
|
-
endpoint['literal_body_params'] = {}
|
238
|
-
|
239
|
-
self.__extract_param_properties(components, None, required_body_params, param_properties, literal_body_params)
|
240
|
-
|
241
|
-
endpoint['literal_body_params'] = literal_body_params
|
192
|
+
if literal_body_params:
|
193
|
+
endpoint['literal_body_params'] = literal_body_params
|
242
194
|
|
243
195
|
# Only support first media type
|
244
196
|
break
|
@@ -249,10 +201,7 @@ class OpenApiEndpointAdapter():
|
|
249
201
|
|
250
202
|
literal_body_params = endpoint.get('literal_body_params')
|
251
203
|
if literal_body_params:
|
252
|
-
|
253
|
-
self.__convert_literal_component_param(endpoint, required_body_params, literal_body_params, 'body_param_name', 'literal_body_params')
|
254
|
-
else:
|
255
|
-
self.__convert_literal_component_param(endpoint, required_body_params, [literal_body_params], 'body_param_name', 'literal_body_params')
|
204
|
+
self.__convert_literal_component_param(endpoint, required_body_params, literal_body_params, 'body_param_name', 'literal_body_params')
|
256
205
|
|
257
206
|
# Responses -> construct lists of response header and response param name resources
|
258
207
|
responses = operation.get('responses', {})
|
@@ -332,74 +281,90 @@ class OpenApiEndpointAdapter():
|
|
332
281
|
|
333
282
|
return list(literal_params)[-2]
|
334
283
|
|
335
|
-
def __extract_param_properties(self, components,
|
336
|
-
|
337
|
-
|
338
|
-
|
339
|
-
flatten: bool = False
|
284
|
+
def __extract_param_properties(self, components, required_component_params, schema_object, literal_component_params, curr_id=0, parent_id=None, parent=None, query_string=''):
|
285
|
+
# Name of the schema object (i.e. the name of the body_param_name or response_param_name component)
|
286
|
+
property_name = list(schema_object.keys())[0]
|
340
287
|
|
341
|
-
|
342
|
-
|
343
|
-
if property_name not in literal_body_params:
|
344
|
-
literal_body_params[property_name] = {'value': {}}
|
288
|
+
# The actual OpenAPI schema object
|
289
|
+
property_schema = list(schema_object.values())[0]
|
345
290
|
|
346
|
-
|
347
|
-
|
291
|
+
if '$ref' in property_schema.keys():
|
292
|
+
property_schema = self.__dereference(components, property_schema.get('$ref'))
|
348
293
|
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
294
|
+
# Generates the entire query string for this particular property (ex: Pets[*].name for property 'name' of a 'Pet' element in the 'Pets' array
|
295
|
+
if property_name == 'tmp':
|
296
|
+
query = query_string
|
297
|
+
else:
|
298
|
+
if property_name.endswith('Element'):
|
299
|
+
query = f"{query_string}[*]"
|
300
|
+
elif query_string == '':
|
301
|
+
query = property_name
|
302
|
+
else:
|
303
|
+
query = f"{query_string}.{property_name}"
|
355
304
|
|
356
|
-
|
357
|
-
|
305
|
+
# A schema is traversable if it has one more non-empty nested schema objects
|
306
|
+
traversable = property_schema.get('properties') or property_schema.get('items') or property_schema.get('allOf')
|
307
|
+
|
308
|
+
if not traversable:
|
309
|
+
# Ex: {'name': {'type': 'string', 'description': 'Name of pet', 'Example': 'Buddy'}}
|
310
|
+
if property_name != 'tmp':
|
311
|
+
literal_val_type = self.__open_api_to_default_python_type(property_schema.get('type', 'object'))
|
312
|
+
literal_val = {'name': property_name, 'value': literal_val_type, 'required': property_schema.get('required', False), 'query': query, 'id': curr_id, 'parent_id': parent_id}
|
313
|
+
literal_component_params.append(literal_val)
|
314
|
+
return curr_id
|
315
|
+
|
316
|
+
if 'properties' in property_schema.keys():
|
317
|
+
# Ex: {'tmp': {'type': 'object', 'required': ['name'], 'properties': {'name': {'type': 'string'}, 'tag': {'type': 'string'}}}}
|
318
|
+
required_component_params += property_schema.get('required', [])
|
319
|
+
|
320
|
+
# curr_id_tmp is the parent_id of all elements in param_properties
|
321
|
+
# Should be set to parent_id when property_name is 'tmp' to handle case where a schema uses the 'allOf' keyword since curr_id will change between every recursive call on each 'part' element in the allOf list
|
322
|
+
curr_id_tmp = parent_id if property_name == 'tmp' else curr_id
|
323
|
+
|
324
|
+
literal_val = parent if property_name == 'tmp' else {'name': property_name, 'value': {}, 'required': property_schema.get('schema_required', False), 'query': query, 'id': curr_id, 'parent_id': parent_id}
|
325
|
+
|
326
|
+
if property_name != 'tmp':
|
327
|
+
literal_component_params.append(literal_val)
|
328
|
+
|
329
|
+
param_properties = property_schema.get('properties')
|
330
|
+
for property_key, property_value in param_properties.items():
|
331
|
+
if property_key in required_component_params:
|
332
|
+
if property_value.get('type') == 'object':
|
333
|
+
# Necessary to avoid overwriting the 'required' list of an object-type schema
|
334
|
+
property_value['schema_required'] = True
|
335
|
+
else:
|
358
336
|
property_value['required'] = True
|
359
|
-
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
if property_name not in literal_body_params:
|
368
|
-
literal_body_params[property_name] = {'value': []}
|
369
|
-
if property_type_dict.get('required') == True:
|
370
|
-
literal_body_params[property_name]['required'] = True
|
371
|
-
|
372
|
-
self.__extract_param_properties(components, reference, required_body_params, param_properties, literal_body_params, nested_parameters=True)
|
373
|
-
|
337
|
+
required_component_params.remove(property_key)
|
338
|
+
curr_id = self.__extract_param_properties(components, required_component_params, {property_key: property_value}, literal_component_params, curr_id=curr_id+1, parent_id=curr_id_tmp, parent=literal_val, query_string=query)
|
339
|
+
|
340
|
+
elif property_schema.get('type') == 'array':
|
341
|
+
# Ex: {'tmp': {'type': 'array', 'items': {'$ref': '#/components/schemas/NewPet'}}}
|
342
|
+
if property_name == 'tmp':
|
343
|
+
schema_object = {"Element": property_schema['items']}
|
344
|
+
curr_id = self.__extract_param_properties(components, required_component_params, schema_object, literal_component_params, curr_id=curr_id+1, parent_id=parent_id, parent=parent, query_string=query)
|
374
345
|
else:
|
375
|
-
|
376
|
-
literal_val = {'value':
|
377
|
-
|
378
|
-
|
379
|
-
|
380
|
-
|
381
|
-
|
382
|
-
|
383
|
-
|
384
|
-
|
385
|
-
|
386
|
-
|
387
|
-
|
388
|
-
|
389
|
-
|
390
|
-
|
391
|
-
|
392
|
-
|
393
|
-
|
394
|
-
|
395
|
-
elif type(literal_body_params[most_recent_param]['value']) is list:
|
396
|
-
literal_body_params[most_recent_param]['value'].append(literal_val)
|
397
|
-
else:
|
398
|
-
literal_body_params[property_name] = literal_val
|
399
|
-
|
400
|
-
literal_body_params.pop('tmp', None)
|
346
|
+
schema_object = {f"{property_name}Element": property_schema['items']}
|
347
|
+
literal_val = {'name': property_name, 'value': [], 'required': property_schema.get('required', False), 'query': query, 'id': curr_id, 'parent_id': parent_id}
|
348
|
+
literal_component_params.append(literal_val)
|
349
|
+
curr_id = self.__extract_param_properties(components, required_component_params, schema_object, literal_component_params, curr_id=curr_id+1, parent_id=curr_id, parent=parent, query_string=query)
|
350
|
+
|
351
|
+
elif 'allOf' in property_schema.keys():
|
352
|
+
# Ex: {'Element': {'type': 'object', 'allOf': [{'$ref': '#/components/schemas/NewPet'}, {'type': 'object', 'required': ['id'], 'properties': {'id': {'type': 'integer', 'format': 'int64'}}}]}}
|
353
|
+
all_of = property_schema.get('allOf')
|
354
|
+
literal_val = parent if property_name == 'tmp' else {'name': property_name, 'value': {}, 'required': property_schema.get('self_required', False), 'query': query, 'id': curr_id, 'parent_id': parent_id}
|
355
|
+
if property_name != 'tmp':
|
356
|
+
literal_component_params.append(literal_val)
|
357
|
+
|
358
|
+
curr_id_tmp = parent_id if property_name == 'tmp' else curr_id
|
359
|
+
for part in all_of:
|
360
|
+
required_component_params = part.get('required', [])
|
361
|
+
curr_id = self.__extract_param_properties(components, required_component_params, {'tmp': part}, literal_component_params, curr_id=curr_id, parent_id=curr_id_tmp, parent=literal_val, query_string=query)
|
362
|
+
|
363
|
+
return curr_id
|
364
|
+
|
401
365
|
|
402
|
-
|
366
|
+
# Returns the schema object located at the given reference path
|
367
|
+
def __dereference(self, components: Spec, reference: str):
|
403
368
|
# '#/components/schemas/NewPet'
|
404
369
|
if not reference.startswith('#'):
|
405
370
|
print('external references are not supported yet')
|
@@ -412,55 +377,13 @@ class OpenApiEndpointAdapter():
|
|
412
377
|
component_name = component_data[1]
|
413
378
|
component = components.get(component_type, {})
|
414
379
|
|
415
|
-
# If component_type is 'headers'
|
416
|
-
# Example: '#components/headers/X-RateLimit-Limit'
|
417
|
-
if component_type == "headers":
|
418
|
-
# In this case, literal_body_params represents a header rather than request or response body params
|
419
|
-
literal_body_params['name'] = component_name
|
420
|
-
header_example = component.get('example')
|
421
|
-
if header_example:
|
422
|
-
literal_body_params['values'].append(header_example)
|
423
|
-
literal_body_params['is_required'] = component.get('is_required', False)
|
424
|
-
literal_body_params['is_deterministic'] = True
|
425
|
-
return literal_body_params
|
426
|
-
|
427
380
|
# Example: {'type': 'object', 'required': ['name'], 'properties': {'name': {'type': 'string'}, 'tag': {'type': 'string'}}}
|
428
381
|
body_spec = component.content()[component_name]
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
if schema_type == 'object':
|
435
|
-
param_properties = body_spec.get('properties', {})
|
436
|
-
elif schema_type == 'array':
|
437
|
-
param_properties = {'tmp': body_spec['items']}
|
438
|
-
|
439
|
-
all_of = body_spec.get('allOf')
|
440
|
-
any_of = body_spec.get('anyOf')
|
441
|
-
one_of = body_spec.get('oneOf')
|
442
|
-
|
443
|
-
if param_properties:
|
444
|
-
for param_prop_key, param_prop_val in param_properties.items():
|
445
|
-
if param_prop_key in required_body_params:
|
446
|
-
param_prop_val['required'] = True
|
447
|
-
required_body_params.remove(param_prop_key)
|
448
|
-
|
449
|
-
self.__extract_param_properties(components, None, required_body_params, param_properties, literal_body_params, nested_parameters=nested_parameters)
|
450
|
-
|
451
|
-
elif all_of:
|
452
|
-
for part in all_of:
|
453
|
-
required_body_params = part.get('required', [])
|
454
|
-
nested_reference = part.get('$ref')
|
455
|
-
if nested_reference:
|
456
|
-
self.__extract_param_properties(components, nested_reference, required_body_params, {'tmp': part}, literal_body_params)
|
457
|
-
else:
|
458
|
-
self.__extract_param_properties(components, None, required_body_params, {'tmp': part}, literal_body_params)
|
459
|
-
|
460
|
-
# TODO
|
461
|
-
# elif any_of or one_of:
|
462
|
-
|
463
|
-
return param_properties
|
382
|
+
|
383
|
+
if '$ref' in body_spec.keys():
|
384
|
+
body_spec = self.__dereference(components, body_spec.get('$ref'))
|
385
|
+
|
386
|
+
return body_spec
|
464
387
|
|
465
388
|
def __convert_literal_component_param(self, endpoint: EndpointShowResponse,
|
466
389
|
required_component_params: List[str], literal_component_params: Union[dict, list],
|
@@ -608,32 +531,14 @@ class OpenApiEndpointAdapter():
|
|
608
531
|
continue
|
609
532
|
|
610
533
|
# Construct response param name components
|
611
|
-
literal_response_params =
|
612
|
-
response_body_array = False
|
534
|
+
literal_response_params = []
|
613
535
|
required_response_params = []
|
614
536
|
response_content = response_definition.get('content', {})
|
615
537
|
for mimetype, media_type in response_content.items():
|
616
|
-
|
617
|
-
|
538
|
+
schema = media_type.get('schema')
|
539
|
+
if schema:
|
540
|
+
self.__extract_param_properties(components, required_response_params, {'tmp': schema}, literal_response_params)
|
618
541
|
|
619
|
-
if '$ref' in schema:
|
620
|
-
reference = schema['$ref']
|
621
|
-
self.__dereference(components, reference, required_response_params, literal_response_params)
|
622
|
-
else:
|
623
|
-
schema_type = schema.get('type')
|
624
|
-
if schema_type:
|
625
|
-
if schema_type == 'object':
|
626
|
-
param_properties = schema.get('properties', {})
|
627
|
-
elif schema_type == 'array':
|
628
|
-
response_body_array = True
|
629
|
-
param_properties = {'tmp': schema['items']}
|
630
|
-
|
631
|
-
for property_key, property_value in param_properties.items():
|
632
|
-
if property_key in required_response_params:
|
633
|
-
param_properties[property_key]['required'] = True
|
634
|
-
|
635
|
-
self.__extract_param_properties(components, None, required_response_params, param_properties, literal_response_params)
|
636
|
-
|
637
542
|
if literal_response_params:
|
638
543
|
endpoint['literal_response_params'] = literal_response_params
|
639
544
|
|
@@ -642,10 +547,7 @@ class OpenApiEndpointAdapter():
|
|
642
547
|
|
643
548
|
literal_response_params = endpoint.get('literal_response_params')
|
644
549
|
if literal_response_params:
|
645
|
-
|
646
|
-
self.__convert_literal_component_param(endpoint, required_response_params, literal_response_params, 'response_param_name', 'literal_response_params')
|
647
|
-
else:
|
648
|
-
self.__convert_literal_component_param(endpoint, required_response_params, [literal_response_params], 'response_param_name', 'literal_response_params')
|
550
|
+
self.__convert_literal_component_param(endpoint, required_response_params, literal_response_params, 'response_param_name', 'literal_response_params')
|
649
551
|
|
650
552
|
# Construct response header name components
|
651
553
|
response_headers = response_definition.get('headers', {})
|
@@ -654,14 +556,13 @@ class OpenApiEndpointAdapter():
|
|
654
556
|
response_header_name['name'] = header_name
|
655
557
|
|
656
558
|
if '$ref' in header_definition:
|
657
|
-
|
658
|
-
|
659
|
-
|
660
|
-
|
661
|
-
|
662
|
-
|
663
|
-
|
664
|
-
response_header_name['is_deterministic'] = True
|
559
|
+
header_definition = self.__dereference(components, header_definition.get('$ref'))
|
560
|
+
|
561
|
+
header_example = header_definition.get('example')
|
562
|
+
if header_example:
|
563
|
+
response_header_name['value']= header_example
|
564
|
+
response_header_name['is_required'] = header_definition.get('is_required', False)
|
565
|
+
response_header_name['is_deterministic'] = True
|
665
566
|
|
666
567
|
if not endpoint.get('response_header_names'):
|
667
568
|
endpoint['response_header_names'] = []
|
@@ -0,0 +1,35 @@
|
|
1
|
+
import pdb
|
2
|
+
|
3
|
+
from typing import Union
|
4
|
+
|
5
|
+
from stoobly_agent.lib.api.interfaces.endpoints import RequestComponentName
|
6
|
+
from stoobly_agent.lib.utils.python_to_ruby_type import convert
|
7
|
+
|
8
|
+
class SchemaBuilder:
|
9
|
+
###
|
10
|
+
#
|
11
|
+
# @param endpoint_id [Integer]
|
12
|
+
# @param param_column_name [String] e.g. query_param_name, body_param_name, response_param_name
|
13
|
+
#
|
14
|
+
def __init__(self, endpoint_id, param_column_name: str):
|
15
|
+
self.endpoint_id = endpoint_id
|
16
|
+
self.param_column_name: str = param_column_name
|
17
|
+
|
18
|
+
def build(self, params):
|
19
|
+
params_list = []
|
20
|
+
for literal_param in params:
|
21
|
+
param: RequestComponentName = {
|
22
|
+
'endpoint_id': self.endpoint_id,
|
23
|
+
'name': literal_param['name'],
|
24
|
+
'query': literal_param['query'],
|
25
|
+
'is_required': literal_param['required'],
|
26
|
+
'inferred_type': convert(self.__infer_type(literal_param['value'])),
|
27
|
+
'is_deterministic': True,
|
28
|
+
'id': literal_param['id'],
|
29
|
+
f"{self.param_column_name}_id": literal_param['parent_id']
|
30
|
+
}
|
31
|
+
params_list.append(param)
|
32
|
+
return params_list
|
33
|
+
|
34
|
+
def __infer_type(self, val) -> str:
|
35
|
+
return str(val.__class__)
|
{stoobly_agent-0.34.8 → stoobly_agent-0.34.9}/stoobly_agent/app/proxy/replay/body_parser_service.py
RENAMED
@@ -76,7 +76,7 @@ def parse_multipart_form_data(content, content_type) -> Dict[bytes, bytes]:
|
|
76
76
|
|
77
77
|
params_array = []
|
78
78
|
for ele in decoded_multipart:
|
79
|
-
params_array.append((decode(ele[0]),
|
79
|
+
params_array.append((decode(ele[0]), ele[1]))
|
80
80
|
|
81
81
|
return MultiDict(params_array)
|
82
82
|
|