stoobly-agent 1.8.5__tar.gz → 1.9.1__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-1.8.5 → stoobly_agent-1.9.1}/PKG-INFO +1 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/pyproject.toml +1 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/__init__.py +1 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/configs_controller.py +3 -3
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_config_update_service.py +12 -12
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/intercept_cli.py +30 -7
- stoobly_agent-1.9.1/stoobly_agent/app/cli/scaffold/templates/app/.Dockerfile.context +6 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/.Makefile +6 -0
- stoobly_agent-1.9.1/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.overwrite +13 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/bin/configure +16 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/joined_request_adapter.py +1 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/log.py +52 -2
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/request_snapshot.py +0 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/scenario_snapshot.py +2 -3
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot_service.py +9 -8
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/helpers/apply.py +10 -5
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_mock_service.py +19 -6
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_record_service.py +16 -7
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/intercept_settings.py +12 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/request_facade.py +1 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/request_string.py +15 -9
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/body_parser_service.py +15 -4
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/replay_request_service.py +1 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/data_rules.py +16 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/custom_headers.py +1 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/lifecycle_hooks.py +1 -0
- stoobly_agent-1.9.1/stoobly_agent/config/constants/record_order.py +6 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/record_policy.py +2 -2
- stoobly_agent-1.9.1/stoobly_agent/public/18-es2015.beb31fe4a4dee3007cb2.js +1 -0
- stoobly_agent-1.9.1/stoobly_agent/public/18-es5.beb31fe4a4dee3007cb2.js +1 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/index.html +2 -2
- stoobly_agent-1.9.1/stoobly_agent/public/main-es2015.089b46f303768fbe864f.js +1 -0
- stoobly_agent-1.9.1/stoobly_agent/public/main-es5.089b46f303768fbe864f.js +1 -0
- stoobly_agent-1.8.5/stoobly_agent/public/runtime-es2015.b13c22b834b51724d30a.js → stoobly_agent-1.9.1/stoobly_agent/public/runtime-es2015.f8c814b38b27708e91c1.js +1 -1
- stoobly_agent-1.8.5/stoobly_agent/public/runtime-es5.b13c22b834b51724d30a.js → stoobly_agent-1.9.1/stoobly_agent/public/runtime-es5.f8c814b38b27708e91c1.js +1 -1
- stoobly_agent-1.8.5/stoobly_agent/public/styles.ab281309cf423b2cdcb0.css → stoobly_agent-1.9.1/stoobly_agent/public/styles.817f011ab81b18b0e5c2.css +1 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/scenario/config_scenario_set_test.py +3 -3
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/intercept/intercept_configure_test.py +5 -7
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/intercept/intercept_enable_test.py +3 -5
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_apply_test.py +143 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_prune_test.py +72 -3
- stoobly_agent-1.9.1/stoobly_agent/test/app/models/schemas/.stoobly/db/VERSION +1 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/record_test.py +3 -3
- stoobly_agent-1.8.5/stoobly_agent/app/cli/scaffold/templates/app/.Dockerfile.context +0 -6
- stoobly_agent-1.8.5/stoobly_agent/public/18-es2015.d07dd29def7e2574c5b7.js +0 -1
- stoobly_agent-1.8.5/stoobly_agent/public/18-es5.d07dd29def7e2574c5b7.js +0 -1
- stoobly_agent-1.8.5/stoobly_agent/public/main-es2015.ce00115b0520fa030f01.js +0 -1
- stoobly_agent-1.8.5/stoobly_agent/public/main-es5.ce00115b0520fa030f01.js +0 -1
- stoobly_agent-1.8.5/stoobly_agent/test/app/models/schemas/.stoobly/db/VERSION +0 -1
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/LICENSE +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/README.md +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/application_http_request_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/bodies_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/headers_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/proxy_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/query_params_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/replayed_response_headers_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/replayed_responses_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/requests_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/response_headers_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/responses_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/routes.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/scenarios_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/simple_http_request_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/api/statuses_controller.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/ca_cert_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/config_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/decorators/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/decorators/config.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/decorators/exec.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/dev_tools_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/endpoint_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/feature_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/handlers/request_cli_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/handlers/scenario_cli_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/certificate_authority.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoint_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_apply_context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_apply_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_import_context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/endpoints_import_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/feature_flags.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_mock_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_replay_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/handle_test_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/iterate_group_by.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/json_print.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/openapi_endpoint_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/print_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/project_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/replay_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/report_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/request_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/request_synchronize_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/run_command_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/scenario_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/schema_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/shell.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/synchronize_request_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/tabulate_print_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/test_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/test_replay_context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/trace_aliases.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/trace_context_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/validations.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/helpers/verify_raw_request_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/main_group.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/project_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/report_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/request_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/app.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/app_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/app_config.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/app_create_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/config.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/constants.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/containerized_app.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/app_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/constants.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/build_decorator.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/configure_gateway.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/service/types.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/build_decorator.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/decorators_factory.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/dns_decorator.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/mock_decorator.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/docker/workflow/reverse_proxy_decorator.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/env.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/hosts_file_manager.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/managed_services_docker_compose.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_config.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_create_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_delete_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_docker_compose.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_workflow.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/service_workflow_validate_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/.docker-compose.networks.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/Makefile +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/.config.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/bin/configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/mock/docker-compose.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/bin/configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/record/docker-compose.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/.docker-compose.test.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/bin/configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/build/test/docker-compose.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/.config.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/bin/configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/mock/docker-compose.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/bin/configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/record/docker-compose.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/.docker-compose.test.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/bin/configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/entrypoint/test/docker-compose.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/.config.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/.docker-compose.base.template.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/gateway/test/.docker-compose.test.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/.config.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/.docker-compose.base.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/exec/.docker-compose.exec.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/mock/.docker-compose.mock.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/stoobly-ui/record/.docker-compose.record.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/mock/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/mock/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/record/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/record/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/test/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/build/test/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/mock/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/mock/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/record/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/record/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/test/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/services/entrypoint/test/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.create +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.delete +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.disable +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.down +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.enable +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.list +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.logs +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.mkcert +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.reset +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.services +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.snapshot +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/exec/.up +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/mock/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/mock/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/record/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/record/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/test/.configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/build/workflows/test/.init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/constants.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/factory.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/bin/configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/fixtures.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/mock/public/.gitignore +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/record/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/bin/configure +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/bin/init +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/fixtures.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/workflow/test/public/.gitignore +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/validate_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/validate_exceptions.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_config.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_copy_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_create_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_env.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_log_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_run_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/workflow_validate_command.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scenario_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/snapshot_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/trace_cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/output.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/print_options.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/scenario.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/snapshot_migration.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/types/test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/request/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/request/python_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/response/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/mitmproxy/response/python_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/joined_request_string_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/request/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/request/python_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/response/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/response/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/orm/response/python_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/request/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/request/raw_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/request/stoobly_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/response/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/response/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/python/response/raw_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_http_request_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_http_response_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/request/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/request/python_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/response/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/raw_joined/response/python_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/stoobly/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/stoobly/request/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/adapters/stoobly/request/mitmproxy_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/body_model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/body.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/header.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/body_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/header_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/create_request_columns_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/log_event.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/request_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/search.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/snapshot_types.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/helpers/tiebreak_scenario_request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/local_db_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/orm_request_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/query_param_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/replayed_response_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/request_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/response_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/response_header_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/local_db/scenario_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/query_param.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/replayed_response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/response_header.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/scenario.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/stoobly/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/stoobly/request_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/factories/resource/stoobly/scenario_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/header_model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/helpers/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/helpers/create_request_params_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/query_param_model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/replayed_response_model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/request_model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/response_header_model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/response_model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/scenario_model.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/schemas/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/schemas/request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/endpoint.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/replayed_response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/request_components.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/models/types/scenario.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/constants/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/constants/custom_response_codes.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_replay_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_test_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/hot_reload.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/intercept_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/flow_mock.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/request_body_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/response_body_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mitmproxy/response_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/custom_not_found_response_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/eval_fixtures_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/eval_request_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/hashed_request_decorator.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/ignored_components_response_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/request_hasher.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/search_endpoint.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/mock/types/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/join_request_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/joined_request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/overwrite_scenario_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/proxy_request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/request_string_control.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/response_string.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/response_string_control.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/record/upload_request_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/alias_context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/alias_resolver.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/multipart.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/replay_scenario_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/rewrite_params_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/replay/trace_context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/run.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/simulate_intercept_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/context_abc.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/context_response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/diff_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/endpoint_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/mitmproxy_response_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/request_component_names_facade.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/requests_response_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/stoobly_response_adapter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/test_results_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/helpers/upload_test_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/context.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/contract.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/custom.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/diff.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/errors.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/fuzzy.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/matchers/handlers/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/test/test_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/allowed_request_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/publish_change_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/request_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/response_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/rewrite.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/utils/rewrite_rules_to_ignored_components_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/cli_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/firewall_action.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/intercept_mode.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/mode.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/constants/request_component.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/data_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/feature_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/firewall_rule.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/firewall_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/helpers/active_mode_settings_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/intercept_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/match_rule.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/match_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/parameter_rule.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/proxy_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/remote_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/rewrite_rule.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/rewrite_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/cli_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/proxy_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/remote_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/types/ui_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/ui_settings.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/settings/url_rule.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/cli.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/alias_resolve_strategy.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/env_vars.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/headers.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/intercept_policy.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/mock_policy.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/mode.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/query_params.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/replay_policy.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/request_origin.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/statuses.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/test_filter.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/test_output_level.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/constants/test_strategy.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/data_dir.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/mitmproxy.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/schema.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/settings.yml.sample +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/config/source_dir.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_03_17_060144_create_requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_03_17_074916_create_responses.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_05_10_003705_create_traces.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_05_10_003840_create_trace_aliases.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_06_29_234516_create_trace_requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_06_29_235155_add_trace_request_reference_to_trace_aliases.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_12_12_092437_align_requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2022_12_28_092917_add_filter_columns_to_requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_01_21_055426_create_scenarios.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_01_21_060225_add_scenario_id_reference_to_requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_02_02_022229_create_replayed_responses.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_03_20_192909_add_http_version_column_to_requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_03_20_220448_add_http_version_column_to_responses.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_04_18_071327_align_requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_05_15_212505_add_uuid_column_to_requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_05_15_213119_add_uuid_column_to_scenarios.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/2023_05_29_053649_add_overwritable_column_to_scenarios.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/db/migrations/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/agent_api.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/api.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/body_param_names_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/endpoints_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/header_names_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/endpoints.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/headers.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/pagination_query_params.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/projects.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/query_params.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/reports.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/requests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/response_headers.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/responses.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/scenarios.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/tests.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/traces.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/interfaces/users.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/json_response_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/organization_key.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/project_key.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/report_key.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/request_key.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/resource_key.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/scenario_key.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/test_key.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/keys/uuid_key.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/param_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/projects_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/query_param_names_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/reports_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/requests_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/response_header_names_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/response_param_names_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/scenarios_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/stoobly_api.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/test_responses_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/tests_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/api/users_resource.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/cache.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/logger.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/base.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/migrate_service.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/replayed_response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/scenario.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/trace.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/trace_alias.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/trace_request.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/orm_to_request_transformer.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/orm_to_requests_response_transformer.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/orm_to_stoobly_request_transformer.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/transformers/orm_to_stoobly_response_transformer.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/types/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/types/request_columns.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/types/response_columns.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/utils/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/utils/request_parse_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/utils/requests_response_builder.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/orm/utils/response_parse_handler.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/conditional_decorator.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/decode.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/jmespath.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/python_to_ruby_type.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/lib/utils/visitor.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/mock.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/0-es2015.c7c5a6d51b98cb85b9fc.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/0-es5.c7c5a6d51b98cb85b9fc.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/1-es2015.bb4492eeabe1fe937ada.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/1-es5.bb4492eeabe1fe937ada.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/10-es2015.56da22458086513ba0c7.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/10-es5.56da22458086513ba0c7.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/12-es2015.be58ed0ef449008b932e.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/12-es5.be58ed0ef449008b932e.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/13-es2015.6d3a4fd76d46bfa5f200.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/13-es5.6d3a4fd76d46bfa5f200.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/14-es2015.b6619d7742671d2a37fb.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/14-es5.b6619d7742671d2a37fb.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/15-es2015.d8855701408b0e1d7a3e.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/15-es5.d8855701408b0e1d7a3e.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/16-es2015.98fa59c2c96d2caac3c3.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/16-es5.98fa59c2c96d2caac3c3.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/17-es2015.7f60b56d1fd66d4d5544.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/17-es5.7f60b56d1fd66d4d5544.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/19-es2015.e5acb2c1e0e91717efc2.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/19-es5.e5acb2c1e0e91717efc2.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/2-es2015.51eb8544ea9a21f2874c.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/2-es5.51eb8544ea9a21f2874c.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/20-es2015.90544c488f1f0900bab4.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/20-es5.90544c488f1f0900bab4.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/21-es2015.63ed4e6b242fbc047bd6.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/21-es5.63ed4e6b242fbc047bd6.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/22-es2015.1e96ef651f96d51191e2.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/22-es5.1e96ef651f96d51191e2.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/23-es2015.6d3052555b4fac38f16d.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/23-es5.6d3052555b4fac38f16d.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/28-es2015.a2bf42f38e4dd771ccea.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/28-es5.a2bf42f38e4dd771ccea.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/29-es2015.18b515f07c88753c7eb6.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/29-es5.18b515f07c88753c7eb6.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/30-es2015.d4d3dc4101400cadf3f3.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/30-es5.d4d3dc4101400cadf3f3.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/31-es2015.e3ea815f75c19c217b7d.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/31-es5.e3ea815f75c19c217b7d.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/32-es2015.57553995bff0ae518501.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/32-es5.57553995bff0ae518501.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/33-es2015.da5ba1e5baa164921198.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/33-es5.da5ba1e5baa164921198.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/34-es2015.87acbb95cfb824650157.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/34-es5.87acbb95cfb824650157.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/35-es2015.4ffe6f7a196ed1a87fc7.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/35-es5.4ffe6f7a196ed1a87fc7.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/36-es2015.e3a104020eeec02cb8c4.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/36-es5.e3a104020eeec02cb8c4.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/37-es2015.3b472e6cf303201bbf2c.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/37-es5.3b472e6cf303201bbf2c.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/38-es2015.39dbf43d46cdc94f78c6.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/38-es5.39dbf43d46cdc94f78c6.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/39-es2015.e5475ea4fb6ec5c60741.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/39-es5.e5475ea4fb6ec5c60741.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/3rdpartylicenses.txt +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/4-es2015.f8ac5475bf103969b2d2.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/4-es5.f8ac5475bf103969b2d2.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/40-es2015.47b2873a8439717af6a7.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/40-es5.47b2873a8439717af6a7.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/41-es2015.69f2771002745c066976.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/41-es5.69f2771002745c066976.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/42-es2015.b590b92ede890155dcd6.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/42-es5.b590b92ede890155dcd6.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/43-es2015.ad1d956bffba561ba64c.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/43-es5.ad1d956bffba561ba64c.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/44-es2015.3ef2c17996ed5be95ced.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/44-es5.3ef2c17996ed5be95ced.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/45-es2015.3d65d27e0a7085e96356.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/45-es5.3d65d27e0a7085e96356.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/46-es2015.e4f0a5b127eae13c27c0.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/46-es5.e4f0a5b127eae13c27c0.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/47-es2015.c7d45334a70131f133b5.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/47-es5.c7d45334a70131f133b5.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/5-es2015.90ea7bd4439d9749e052.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/5-es5.90ea7bd4439d9749e052.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/6-es2015.5fb726c0555664300974.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/6-es5.5fb726c0555664300974.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/7-es2015.ba9f789e186a8e3962d3.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/7-es5.ba9f789e186a8e3962d3.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/8-es2015.b901639e2aeff1358c3d.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/8-es5.b901639e2aeff1358c3d.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/9-es2015.1d75413af5d96b4ff1e5.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/9-es5.1d75413af5d96b4ff1e5.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/CHANGELOG.md +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/README.md +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/_redirects +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/1.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/2.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/3.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/4.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/5.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/6.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/7.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/8.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/landscape.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/demo/mountain-cinematic.jpg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/checklist.svg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/data_center.svg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/idea.svg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/it_support.svg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/peak_mountain_3.svg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/illustrations/under_constructions_1.svg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/logo/colored.png +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/logo/colored.svg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/logo/white.png +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/assets/img/logo/white.svg +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/common-es2015.388805227aa99c527fba.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/common-es5.388805227aa99c527fba.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/favicon.ico +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/polyfills-es2015.8ce2adc69f283f6c4c5e.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/public/polyfills-es5.7530172ddcec11a10eb3.js +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/cli_mock_integration_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/firewall_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/match_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/project/config_project_set_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/config/rewrite_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/endpoint/endpoint_cli_apply_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/certificate_authority_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_additional_props_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_info_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_oauth2_scopes_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_missing_servers_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/openapi_endpoint_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/schema_builder_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/helpers/synchronize_request_service_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_delete_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_list_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_replay_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_reset_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_response_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_snapshot_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/request/request_test_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scaffold/cli_invoker.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scaffold/cli_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scaffold/e2e_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scaffold/hosts_file_manager_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_create_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_replay_integration_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_replay_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_reset_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_snapshot_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/scenario/scenario_test_integration_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/lifecycle_hooks_migrate.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_copy_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_migrate_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/cli/snapshot/snapshot_update_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/joined_request_string_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/request/orm_mitmproxy_request_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/request/orm_python_request_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/response/orm_mitmproxy_response_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/orm/response/orm_python_response_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/request/mitmproxy_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/request/raw_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/request/stoobly_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/response/mitmproxy_response_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/adapters/python/response/raw_response_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/factories/resource/local_db/helpers/log_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/factories/resource/local_db/helpers/tiebreak_scenario_request_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/factories/resource/local_db/request_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/factories/resource/local_db/response_adapter_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/schemas/.stoobly/db/stoobly_agent.sqlite3 +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/schemas/.stoobly/settings.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/schemas/.stoobly/tmp/options.json +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/models/schemas/request_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/mitmproxy/request_facade_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/mock/eval_fixtures_service_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/replay/body_parser_service_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/replay/rewrite_params_service_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/replay/trace_context_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/replay/visitor_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/test/helpers/test_results_builder_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/upload/request_string_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/proxy/upload/response_string_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/test/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/test/matchers/contract_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/test/matchers/diff_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/app/test/matchers/fuzzy_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/lifecycle_hooks_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/mock_scenario_lifecycle_hooks.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/mock_scenario_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/cli/mock_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/config/data_dir_test.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/__init__.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/endpoint_show_response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/lifecycle_hooks.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-additional-props.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-expanded.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-missing-info.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-missing-oauth2-scopes.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-missing-servers.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-references.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore-swagger-io.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/petstore.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/request_show_response.py +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/scaffold/docker-compose-assets-service.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/scaffold/docker-compose-local-service.yml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/scaffold/index.html +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/mock_data/uspto.yaml +0 -0
- {stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/test/test_helper.py +0 -0
@@ -1,2 +1,2 @@
|
|
1
1
|
COMMAND = 'stoobly-agent'
|
2
|
-
VERSION = '1.
|
2
|
+
VERSION = '1.9.1'
|
@@ -4,7 +4,7 @@ from mergedeep import merge
|
|
4
4
|
|
5
5
|
from stoobly_agent.app.api.simple_http_request_handler import SimpleHTTPRequestHandler
|
6
6
|
from stoobly_agent.app.cli.helpers.handle_config_update_service import (
|
7
|
-
context as handle_context, handle_intercept_active_update,
|
7
|
+
context as handle_context, handle_intercept_active_update, handle_order_update, handle_project_update, handle_scenario_update
|
8
8
|
)
|
9
9
|
from stoobly_agent.app.models.scenario_model import ScenarioModel
|
10
10
|
from stoobly_agent.app.proxy.intercept_settings import InterceptSettings
|
@@ -41,7 +41,7 @@ class ConfigsController:
|
|
41
41
|
)
|
42
42
|
elif active_mode == mode.RECORD:
|
43
43
|
context.render(
|
44
|
-
json = [record_policy.ALL, record_policy.
|
44
|
+
json = [record_policy.ALL, record_policy.API, record_policy.FOUND, record_policy.NOT_FOUND],
|
45
45
|
status = 200
|
46
46
|
)
|
47
47
|
elif active_mode == mode.REPLAY:
|
@@ -112,7 +112,7 @@ class ConfigsController:
|
|
112
112
|
_handle_context = handle_context()
|
113
113
|
|
114
114
|
handle_intercept_active_update(settings, _handle_context)
|
115
|
-
|
115
|
+
handle_order_update(settings, _handle_context)
|
116
116
|
handle_project_update(settings, _handle_context)
|
117
117
|
handle_scenario_update(settings, _handle_context)
|
118
118
|
|
@@ -6,7 +6,7 @@ from stoobly_agent.app.models.scenario_model import ScenarioModel
|
|
6
6
|
from stoobly_agent.app.settings.constants import intercept_mode
|
7
7
|
from stoobly_agent.app.settings.constants.intercept_mode import Mode
|
8
8
|
from stoobly_agent.app.settings import ProxySettings, Settings
|
9
|
-
from stoobly_agent.config.constants import
|
9
|
+
from stoobly_agent.config.constants import record_order
|
10
10
|
from stoobly_agent.lib.api.keys.project_key import ProjectKey
|
11
11
|
from stoobly_agent.lib.api.keys.scenario_key import ScenarioKey
|
12
12
|
|
@@ -28,15 +28,15 @@ def handle_intercept_active_update(new_settings: Settings, context: Context = No
|
|
28
28
|
|
29
29
|
if not was_active and is_active:
|
30
30
|
if _mode == intercept_mode.RECORD:
|
31
|
-
|
31
|
+
new_order = data_rule.record_order
|
32
32
|
scenario_key = data_rule.scenario_key
|
33
33
|
_scenario_key = __parse_scenario_key(scenario_key)
|
34
34
|
|
35
35
|
if _scenario_key:
|
36
36
|
scenario_model = ScenarioModel(new_settings)
|
37
37
|
|
38
|
-
if
|
39
|
-
# If
|
38
|
+
if new_order == record_order.OVERWRITE:
|
39
|
+
# If order is overwrite when recording, whenever intercept is enabled,
|
40
40
|
# set active scenario to be overwritable
|
41
41
|
scenario_model.update(_scenario_key.id, **{ 'overwritable': True })[1]
|
42
42
|
else:
|
@@ -44,16 +44,16 @@ def handle_intercept_active_update(new_settings: Settings, context: Context = No
|
|
44
44
|
elif was_active and not is_active:
|
45
45
|
if _mode == intercept_mode.RECORD:
|
46
46
|
old_proxy_settings = __current_proxy_settings(context)
|
47
|
-
|
47
|
+
old_order = __data_rule(old_proxy_settings).record_order
|
48
48
|
|
49
|
-
if
|
49
|
+
if old_order == record_order.OVERWRITE:
|
50
50
|
scenario_key = data_rule.scenario_key
|
51
51
|
_scenario_key = __parse_scenario_key(scenario_key)
|
52
52
|
|
53
53
|
if _scenario_key:
|
54
54
|
scenario_model = ScenarioModel(new_settings)
|
55
55
|
|
56
|
-
# If
|
56
|
+
# If order is overwrite when recording, whenever intercept is disabled,
|
57
57
|
# set active scenario to not be overwritable
|
58
58
|
scenario_model.update(_scenario_key.id, **{ 'overwritable': False })[1]
|
59
59
|
elif _mode == intercept_mode.MOCK:
|
@@ -73,7 +73,7 @@ def handle_scenario_update(new_settings: Settings, context = None):
|
|
73
73
|
if old_scenario_key != new_scenario_key:
|
74
74
|
data_rule = __data_rule(new_settings.proxy)
|
75
75
|
|
76
|
-
if data_rule.
|
76
|
+
if data_rule.record_order == record_order.OVERWRITE:
|
77
77
|
scenario_model = ScenarioModel(new_settings)
|
78
78
|
|
79
79
|
_old_scenario_key = __parse_scenario_key(old_scenario_key)
|
@@ -108,7 +108,7 @@ def handle_project_update(new_settings: Settings, context: Context = None):
|
|
108
108
|
if _project_key.id != _new_scenario_key.project_id:
|
109
109
|
data_rule.scenario_key = None
|
110
110
|
|
111
|
-
def
|
111
|
+
def handle_order_update(new_settings: Settings, context: Context = None):
|
112
112
|
data_rule = __data_rule(new_settings.proxy)
|
113
113
|
_mode = context['mode'] if context and context.get('mode') else new_settings.proxy.intercept.mode
|
114
114
|
|
@@ -116,10 +116,10 @@ def handle_policy_update(new_settings: Settings, context: Context = None):
|
|
116
116
|
old_data_rule = __data_rule(old_proxy_settings)
|
117
117
|
|
118
118
|
if _mode == intercept_mode.RECORD:
|
119
|
-
|
120
|
-
|
119
|
+
new_order = data_rule.record_order
|
120
|
+
old_order = old_data_rule.record_order
|
121
121
|
|
122
|
-
if
|
122
|
+
if new_order != old_order and old_order == record_order.OVERWRITE:
|
123
123
|
scenario_key = data_rule.scenario_key
|
124
124
|
_scenario_key = __parse_scenario_key(scenario_key)
|
125
125
|
|
@@ -3,10 +3,10 @@ import pdb
|
|
3
3
|
import sys
|
4
4
|
|
5
5
|
from stoobly_agent.app.settings import Settings
|
6
|
-
from stoobly_agent.config.constants import mode, mock_policy, record_policy, replay_policy
|
6
|
+
from stoobly_agent.config.constants import mode, mock_policy, record_order, record_policy, replay_policy
|
7
7
|
from stoobly_agent.lib.api.keys.project_key import ProjectKey
|
8
8
|
|
9
|
-
from .helpers.handle_config_update_service import handle_intercept_active_update,
|
9
|
+
from .helpers.handle_config_update_service import handle_intercept_active_update, handle_order_update
|
10
10
|
|
11
11
|
settings = Settings.instance()
|
12
12
|
|
@@ -17,16 +17,25 @@ if settings.cli.features.remote:
|
|
17
17
|
|
18
18
|
active_mode = settings.proxy.intercept.mode
|
19
19
|
|
20
|
+
def __get_order_options(active_mode):
|
21
|
+
if active_mode == mode.RECORD:
|
22
|
+
return [record_order.APPEND, record_order.OVERWRITE]
|
23
|
+
else:
|
24
|
+
return []
|
25
|
+
|
20
26
|
def __get_policy_options(active_mode):
|
21
27
|
if active_mode == mode.MOCK:
|
22
28
|
return [mock_policy.ALL, mock_policy.FOUND]
|
23
29
|
elif active_mode == mode.RECORD:
|
24
|
-
return [record_policy.ALL, record_policy.
|
30
|
+
return [record_policy.ALL, record_policy.API, record_policy.FOUND, record_policy.NOT_FOUND]
|
25
31
|
elif active_mode == mode.REPLAY:
|
26
32
|
return [replay_policy.ALL]
|
27
33
|
elif active_mode == mode.TEST:
|
28
34
|
return [mock_policy.FOUND]
|
35
|
+
else:
|
36
|
+
return []
|
29
37
|
|
38
|
+
order_options = __get_order_options(active_mode)
|
30
39
|
policy_options = __get_policy_options(active_mode)
|
31
40
|
|
32
41
|
@click.group(
|
@@ -69,11 +78,12 @@ def disable(**kwargs):
|
|
69
78
|
help="Configure intercept"
|
70
79
|
)
|
71
80
|
@click.option('--mode', type=click.Choice(mode_options))
|
81
|
+
@click.option('--order', type=click.Choice(order_options))
|
72
82
|
@click.option('--policy', type=click.Choice(policy_options))
|
73
83
|
def configure(**kwargs):
|
74
|
-
settings = Settings.instance()
|
84
|
+
settings: Settings = Settings.instance()
|
75
85
|
|
76
|
-
if not kwargs['mode'] and not kwargs['policy']:
|
86
|
+
if not kwargs['mode'] and not kwargs['order'] and not kwargs['policy']:
|
77
87
|
print("Error: Missing an option")
|
78
88
|
sys.exit(1)
|
79
89
|
|
@@ -89,6 +99,21 @@ def configure(**kwargs):
|
|
89
99
|
|
90
100
|
_mode = kwargs['mode'] or settings.proxy.intercept.mode
|
91
101
|
|
102
|
+
if kwargs['order']:
|
103
|
+
active_mode = settings.proxy.intercept.mode
|
104
|
+
|
105
|
+
if active_mode == mode.RECORD:
|
106
|
+
project_key = ProjectKey(settings.proxy.intercept.project_key)
|
107
|
+
data_rule = settings.proxy.data.data_rules(project_key.id)
|
108
|
+
data_rule.record_order = kwargs['order']
|
109
|
+
else:
|
110
|
+
print("Error: set --mode to a intercept mode that supports the order option", file=sys.stderr)
|
111
|
+
sys.exit(1)
|
112
|
+
|
113
|
+
handle_order_update(settings)
|
114
|
+
|
115
|
+
print(f"Updating {_mode} order to {kwargs['order']}")
|
116
|
+
|
92
117
|
if kwargs['policy']:
|
93
118
|
active_mode = settings.proxy.intercept.mode
|
94
119
|
valid_policies = __get_policy_options(active_mode)
|
@@ -109,8 +134,6 @@ def configure(**kwargs):
|
|
109
134
|
elif active_mode == mode.TEST:
|
110
135
|
data_rule.test_policy = kwargs['policy']
|
111
136
|
|
112
|
-
handle_policy_update(settings)
|
113
|
-
|
114
137
|
print(f"Updating {_mode} policy to {kwargs['policy']}")
|
115
138
|
|
116
139
|
settings.commit()
|
{stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/cli/scaffold/templates/app/.Makefile
RENAMED
@@ -143,6 +143,12 @@ scenario/list:
|
|
143
143
|
@export EXEC_COMMAND=.list && \
|
144
144
|
export EXEC_OPTIONS="$(options)" && \
|
145
145
|
$(stoobly_exec)
|
146
|
+
scenario/overwrite:
|
147
|
+
# Overwrite a scenario
|
148
|
+
@export EXEC_COMMAND=.overwrite && \
|
149
|
+
export EXEC_OPTIONS="$(options)" && \
|
150
|
+
export EXEC_ARGS="$(key)" && \
|
151
|
+
$(stoobly_exec)
|
146
152
|
scenario/reset:
|
147
153
|
# Resets a scenario to its last snapshot
|
148
154
|
@export EXEC_COMMAND=.reset && \:
|
@@ -0,0 +1,13 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
|
3
|
+
scenario_key=$1
|
4
|
+
|
5
|
+
if [ ! "$scenario_key" ]; then
|
6
|
+
echo "Missing argument 'scenario_key'"
|
7
|
+
stoobly-agent scenario list
|
8
|
+
exit
|
9
|
+
fi
|
10
|
+
|
11
|
+
stoobly-agent config scenario set "$scenario_key"
|
12
|
+
stoobly-agent intercept configure --mode record --order overwrite
|
13
|
+
stoobly-agent intercept disable
|
@@ -22,6 +22,14 @@ stoobly-agent config firewall set \
|
|
22
22
|
|
23
23
|
# Rewrite
|
24
24
|
echo "Configuring rewrite rules..."
|
25
|
+
stoobly-agent config rewrite set \
|
26
|
+
--method GET --method POST --method OPTIONS --method PUT --method DELETE \
|
27
|
+
--mode record \
|
28
|
+
--name authorization \
|
29
|
+
--pattern "$origin/?.*?" \
|
30
|
+
--type Header \
|
31
|
+
--value '' \
|
32
|
+
|
25
33
|
stoobly-agent config rewrite set \
|
26
34
|
--method GET --method POST --method OPTIONS --method PUT --method DELETE \
|
27
35
|
--mode record \
|
@@ -29,3 +37,11 @@ stoobly-agent config rewrite set \
|
|
29
37
|
--pattern "$origin/?.*?" \
|
30
38
|
--type Header \
|
31
39
|
--value '' \
|
40
|
+
|
41
|
+
stoobly-agent config rewrite set \
|
42
|
+
--method GET --method POST --method OPTIONS --method PUT --method DELETE \
|
43
|
+
--mode record \
|
44
|
+
--name set-cookie \
|
45
|
+
--pattern "$origin/?.*?" \
|
46
|
+
--type 'Response Header' \
|
47
|
+
--value '' \
|
@@ -46,7 +46,7 @@ class JoinedRequestAdapter():
|
|
46
46
|
def build_request_string(self):
|
47
47
|
request_string = RequestString(None)
|
48
48
|
|
49
|
-
delimitter = RequestStringCLRF
|
49
|
+
delimitter = RequestStringCLRF
|
50
50
|
request_string_toks = self.__split_joined_request_string[0].split(delimitter)
|
51
51
|
request_string.set(self.raw_request_string or delimitter.join(request_string_toks[1:]))
|
52
52
|
request_string.control = request_string_toks[0]
|
@@ -8,6 +8,7 @@ from stoobly_agent.config.data_dir import DataDir
|
|
8
8
|
from stoobly_agent.lib.logger import bcolors, Logger
|
9
9
|
|
10
10
|
from .log_event import LogEvent
|
11
|
+
from .request_snapshot import RequestSnapshot
|
11
12
|
from .snapshot_types import DELETE_ACTION, PUT_ACTION, Resource
|
12
13
|
|
13
14
|
EVENT_DELIMITTER = "\n"
|
@@ -67,6 +68,25 @@ class Log():
|
|
67
68
|
contents = self.read()
|
68
69
|
return self.build_raw_events(contents)
|
69
70
|
|
71
|
+
@property
|
72
|
+
def scenario_inverted_index(self):
|
73
|
+
index = {}
|
74
|
+
|
75
|
+
def handle_snapshot(snapshot: RequestSnapshot):
|
76
|
+
request_uuid = snapshot.uuid
|
77
|
+
if not request_uuid in index:
|
78
|
+
index[request_uuid] = []
|
79
|
+
|
80
|
+
index[request_uuid].append(event.resource_uuid)
|
81
|
+
|
82
|
+
for event in self.target_events:
|
83
|
+
if not event.is_scenario():
|
84
|
+
continue
|
85
|
+
|
86
|
+
event.snapshot().iter_request_snapshots(handle_snapshot)
|
87
|
+
|
88
|
+
return index
|
89
|
+
|
70
90
|
@property
|
71
91
|
def unprocessed_events(self) -> List[LogEvent]:
|
72
92
|
events = self.events
|
@@ -197,12 +217,18 @@ class Log():
|
|
197
217
|
|
198
218
|
resource_index[event.resource_uuid].append(event)
|
199
219
|
|
220
|
+
scenario_inverted_index = self.scenario_inverted_index
|
221
|
+
|
200
222
|
pruned_events = self.collapse(events)
|
201
223
|
for event in pruned_events:
|
202
224
|
snapshot = event.snapshot()
|
203
225
|
snapshot_exists = snapshot.exists
|
204
226
|
|
205
227
|
if event.action == DELETE_ACTION or not snapshot_exists:
|
228
|
+
if event.is_request() and event.resource_uuid in scenario_inverted_index:
|
229
|
+
# If a request is deleted, only prune if it's not also a part of a scenario
|
230
|
+
continue
|
231
|
+
|
206
232
|
Logger.instance(LOG_ID).info(f"{bcolors.OKBLUE}Removing{bcolors.ENDC} {event.resource} {event.resource_uuid}")
|
207
233
|
|
208
234
|
resource_events: List[LogEvent] = resource_index[event.resource_uuid]
|
@@ -218,8 +244,16 @@ class Log():
|
|
218
244
|
removed_events[event.uuid] = True
|
219
245
|
|
220
246
|
if event.action == DELETE_ACTION and snapshot_exists:
|
221
|
-
if
|
247
|
+
if dry_run:
|
248
|
+
continue
|
249
|
+
|
250
|
+
if event.is_scenario():
|
251
|
+
# We still need to check each request in a scenario to make sure another scenario does not depend on it
|
252
|
+
snapshot.remove(lambda snapshot: self.remove_request_snapshot(snapshot, scenario_inverted_index))
|
253
|
+
elif event.is_request():
|
254
|
+
# We have already checked that a scenario does not depend on the request above
|
222
255
|
snapshot.remove()
|
256
|
+
|
223
257
|
Logger.instance(LOG_ID).info(f"Removing {event.resource} snapshot")
|
224
258
|
|
225
259
|
def build_raw_events(self, contents: str) -> List[str]:
|
@@ -242,6 +276,8 @@ class Log():
|
|
242
276
|
'''
|
243
277
|
Remove DELETE events where the last processed event was a PUT
|
244
278
|
'''
|
279
|
+
|
280
|
+
# Build an index such that if the last event is DELETE_ACTION, then it will NOT exist in the index
|
245
281
|
index = {}
|
246
282
|
for event in processed_events:
|
247
283
|
if event.action == PUT_ACTION:
|
@@ -249,10 +285,18 @@ class Log():
|
|
249
285
|
elif event.action == DELETE_ACTION:
|
250
286
|
if event.resource_uuid in index:
|
251
287
|
del index[event.resource_uuid]
|
288
|
+
|
289
|
+
scenario_inverted_index = self.scenario_inverted_index
|
290
|
+
|
291
|
+
def keep(e: LogEvent):
|
292
|
+
if e.action != DELETE_ACTION:
|
293
|
+
return True
|
294
|
+
|
295
|
+
return e.action == DELETE_ACTION and e.is_request() and e.resource_uuid in scenario_inverted_index
|
252
296
|
|
253
297
|
return list(
|
254
298
|
filter(
|
255
|
-
|
299
|
+
keep,
|
256
300
|
unprocessed_events
|
257
301
|
)
|
258
302
|
)
|
@@ -289,6 +333,12 @@ class Log():
|
|
289
333
|
remaining_events = self.remove_dangling_events(processed_events, unprocessed_events)
|
290
334
|
return list(filter(lambda e: e.uuid not in remaining_version_uuids, remaining_events))
|
291
335
|
|
336
|
+
def remove_request_snapshot(self, snapshot: RequestSnapshot, scenario_inverted_index: dict = None):
|
337
|
+
scenario_inverted_index = scenario_inverted_index or self.scenario_inverted_index
|
338
|
+
|
339
|
+
if snapshot.uuid not in scenario_inverted_index:
|
340
|
+
snapshot.remove()
|
341
|
+
|
292
342
|
# Rotate log to history
|
293
343
|
def rotate(self):
|
294
344
|
if not os.path.exists(self.__log_file_path):
|
@@ -1,7 +1,6 @@
|
|
1
1
|
import json
|
2
2
|
import os
|
3
3
|
import pdb
|
4
|
-
import shutil
|
5
4
|
|
6
5
|
from typing import Callable, List
|
7
6
|
|
@@ -128,12 +127,12 @@ class ScenarioSnapshot(Snapshot):
|
|
128
127
|
if os.path.exists(metadata_file_path):
|
129
128
|
os.remove(metadata_file_path)
|
130
129
|
|
131
|
-
def remove_requests(self):
|
130
|
+
def remove_requests(self, handle_remove_request_snapshot = None):
|
132
131
|
requests_file_path = self.requests_path
|
133
132
|
|
134
133
|
if os.path.exists(requests_file_path):
|
135
134
|
# A request only every belongs to one scenario
|
136
|
-
self.iter_request_snapshots(self.__handle_remove_requests)
|
135
|
+
self.iter_request_snapshots(handle_remove_request_snapshot or self.__handle_remove_requests)
|
137
136
|
|
138
137
|
os.remove(requests_file_path)
|
139
138
|
|
@@ -14,15 +14,17 @@ def snapshot_request(request: Request, **options: RequestSnapshotOptions):
|
|
14
14
|
return
|
15
15
|
|
16
16
|
snapshot = RequestSnapshot(request.uuid)
|
17
|
-
|
18
17
|
snapshot.backup()
|
19
18
|
|
19
|
+
log = Log()
|
20
|
+
|
20
21
|
if action == PUT_ACTION:
|
21
22
|
snapshot.write(request, **options)
|
22
23
|
elif action == DELETE_ACTION:
|
23
|
-
|
24
|
+
inverted_scenario_index = log.scenario_inverted_index
|
24
25
|
|
25
|
-
|
26
|
+
# If a scenario currently depends on this request, we can't remove the snapshot until the scenario is also removed
|
27
|
+
log.remove_request_snapshot(snapshot, inverted_scenario_index)
|
26
28
|
|
27
29
|
try:
|
28
30
|
if action == PUT_ACTION:
|
@@ -40,7 +42,6 @@ def snapshot_scenario(scenario: Scenario, **options):
|
|
40
42
|
return
|
41
43
|
|
42
44
|
snapshot = ScenarioSnapshot(scenario.uuid)
|
43
|
-
|
44
45
|
snapshot.backup_metadata()
|
45
46
|
|
46
47
|
if action == PUT_ACTION:
|
@@ -50,13 +51,13 @@ def snapshot_scenario(scenario: Scenario, **options):
|
|
50
51
|
|
51
52
|
snapshot.backup_requests()
|
52
53
|
|
54
|
+
log = Log()
|
55
|
+
inverted_scenario_index = log.scenario_inverted_index
|
53
56
|
if action == PUT_ACTION:
|
54
|
-
snapshot.remove_requests()
|
57
|
+
snapshot.remove_requests(lambda snapshot: log.remove_request_snapshot(snapshot, inverted_scenario_index))
|
55
58
|
snapshot.write_requests(scenario, **options)
|
56
59
|
elif action == DELETE_ACTION:
|
57
|
-
snapshot.remove_requests()
|
58
|
-
|
59
|
-
log = Log()
|
60
|
+
snapshot.remove_requests(lambda snapshot: log.remove_request_snapshot(snapshot, inverted_scenario_index))
|
60
61
|
|
61
62
|
if action == PUT_ACTION:
|
62
63
|
log.put(scenario)
|
@@ -1,9 +1,11 @@
|
|
1
1
|
import pdb
|
2
2
|
|
3
|
+
from typing import List
|
4
|
+
|
3
5
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.log import Log
|
4
6
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.request_snapshot import RequestSnapshot
|
5
7
|
from stoobly_agent.app.models.factories.resource.local_db.helpers.scenario_snapshot import ScenarioSnapshot
|
6
|
-
from stoobly_agent.app.proxy.record import REQUEST_STRING_CLRF
|
8
|
+
from stoobly_agent.app.proxy.record import REQUEST_STRING_CLRF
|
7
9
|
from stoobly_agent.app.settings import Settings
|
8
10
|
from stoobly_agent.lib.logger import bcolors
|
9
11
|
|
@@ -71,6 +73,7 @@ class Apply():
|
|
71
73
|
if results:
|
72
74
|
status = results[1]
|
73
75
|
if status == 0 or status >= 400:
|
76
|
+
self.__logger(f"{bcolors.FAIL}Error{bcolors.ENDC} {results[0]}")
|
74
77
|
completed = False
|
75
78
|
break
|
76
79
|
|
@@ -218,14 +221,16 @@ class Apply():
|
|
218
221
|
|
219
222
|
snapshot_requests = {}
|
220
223
|
|
221
|
-
request_snapshots = snapshot.request_snapshots
|
224
|
+
request_snapshots: List[RequestSnapshot] = snapshot.request_snapshots
|
222
225
|
for request_snapshot in request_snapshots:
|
223
226
|
raw_request = request_snapshot.request
|
224
|
-
|
225
|
-
toks = raw_request.split(REQUEST_STRING_CLRF.encode(), 1)
|
226
227
|
|
228
|
+
if not raw_request:
|
229
|
+
return f"{request_snapshot.path} is missing", 400
|
230
|
+
|
231
|
+
toks = raw_request.split(REQUEST_STRING_CLRF, 1)
|
227
232
|
if len(toks) != 2:
|
228
|
-
return f"{
|
233
|
+
return f"{request_snapshot.path} contains an invalid request", 400
|
229
234
|
|
230
235
|
uuid = request_snapshot.uuid
|
231
236
|
res, status = self.__put_request(uuid, raw_request, scenario_id=scenario['id'])
|
@@ -3,7 +3,7 @@ import pdb
|
|
3
3
|
import requests
|
4
4
|
import time
|
5
5
|
|
6
|
-
from mitmproxy.http import
|
6
|
+
from mitmproxy.http import Request as MitmproxyRequest
|
7
7
|
from typing import Callable, TypedDict
|
8
8
|
|
9
9
|
from stoobly_agent.app.models.request_model import RequestModel
|
@@ -64,7 +64,7 @@ def handle_request_mock_generic(context: MockContext, **options: MockOptions):
|
|
64
64
|
|
65
65
|
return bad_request(
|
66
66
|
context.flow,
|
67
|
-
"Valid
|
67
|
+
"Valid mock policies: %s, Got: %s" %
|
68
68
|
([mock_policy.ALL, mock_policy.FOUND, mock_policy.NONE], policy)
|
69
69
|
)
|
70
70
|
|
@@ -88,18 +88,20 @@ def handle_request_mock_generic(context: MockContext, **options: MockOptions):
|
|
88
88
|
res = eval_request_with_retry(context, eval_request, **options)
|
89
89
|
|
90
90
|
context.with_response(res)
|
91
|
+
res = __after_mock_not_found(context)
|
91
92
|
elif policy == mock_policy.FOUND:
|
92
93
|
res = eval_request_with_retry(context, eval_request, **options)
|
93
94
|
|
94
95
|
context.with_response(res)
|
96
|
+
res = __after_mock_not_found(context)
|
95
97
|
|
96
|
-
if res.status_code
|
98
|
+
if res.status_code == custom_response_codes.NOT_FOUND:
|
97
99
|
try:
|
98
100
|
return __handle_found_policy(context) # Continue proxying the request
|
99
101
|
except RuntimeError:
|
100
102
|
# Do nothing, return custom error response
|
101
|
-
pass
|
102
|
-
|
103
|
+
pass
|
104
|
+
|
103
105
|
if res.status_code == custom_response_codes.NOT_FOUND:
|
104
106
|
if handle_failure:
|
105
107
|
res = handle_failure(context) or res
|
@@ -241,4 +243,15 @@ def __mock_hook(hook: str, context: MockContext):
|
|
241
243
|
lifecycle_hooks_module = intercept_settings.lifecycle_hooks
|
242
244
|
|
243
245
|
if hook in lifecycle_hooks_module:
|
244
|
-
lifecycle_hooks_module[hook](context)
|
246
|
+
lifecycle_hooks_module[hook](context)
|
247
|
+
|
248
|
+
def __after_mock_not_found(context: MockContext):
|
249
|
+
res = context.response
|
250
|
+
|
251
|
+
if res.status_code == custom_response_codes.NOT_FOUND:
|
252
|
+
__mock_hook(lifecycle_hooks.AFTER_MOCK_NOT_FOUND, context)
|
253
|
+
|
254
|
+
# context.response may have been modified by the hook
|
255
|
+
res = context.response
|
256
|
+
|
257
|
+
return res
|
{stoobly_agent-1.8.5 → stoobly_agent-1.9.1}/stoobly_agent/app/proxy/handle_record_service.py
RENAMED
@@ -9,7 +9,7 @@ from stoobly_agent.app.settings.constants.mode import TEST
|
|
9
9
|
from stoobly_agent.app.models.request_model import RequestModel
|
10
10
|
from stoobly_agent.app.proxy.intercept_settings import InterceptSettings
|
11
11
|
from stoobly_agent.config.constants.env_vars import ENV
|
12
|
-
from stoobly_agent.config.constants import lifecycle_hooks, record_policy
|
12
|
+
from stoobly_agent.config.constants import lifecycle_hooks, record_order, record_policy
|
13
13
|
from stoobly_agent.lib.logger import Logger
|
14
14
|
|
15
15
|
from .constants import custom_response_codes
|
@@ -17,6 +17,7 @@ from .mock.eval_request_service import inject_eval_request
|
|
17
17
|
from .record.context import RecordContext
|
18
18
|
from .record.overwrite_scenario_service import overwrite_scenario
|
19
19
|
from .record.upload_request_service import inject_upload_request
|
20
|
+
from .replay.body_parser_service import is_json, is_xml
|
20
21
|
from .utils.allowed_request_service import get_active_mode_policy
|
21
22
|
from .utils.response_handler import bad_request, disable_transfer_encoding
|
22
23
|
from .utils.rewrite import rewrite_request_response
|
@@ -42,6 +43,13 @@ def handle_response_record(context: RecordContext):
|
|
42
43
|
|
43
44
|
if active_record_policy == record_policy.ALL:
|
44
45
|
__record_request(context, request_model)
|
46
|
+
elif active_record_policy == record_policy.API:
|
47
|
+
response = flow.response
|
48
|
+
content_type: str = response.headers.get('content-type')
|
49
|
+
|
50
|
+
if content_type:
|
51
|
+
if is_json(content_type) or is_xml(content_type) or content_type.startswith('text/plain'):
|
52
|
+
__record_request(context, request_model)
|
45
53
|
elif active_record_policy == record_policy.FOUND:
|
46
54
|
res = inject_eval_request(request_model, intercept_settings)(request, [])
|
47
55
|
|
@@ -52,16 +60,12 @@ def handle_response_record(context: RecordContext):
|
|
52
60
|
|
53
61
|
if res.status_code == custom_response_codes.NOT_FOUND:
|
54
62
|
__record_request(context, request_model)
|
55
|
-
elif active_record_policy == record_policy.OVERWRITE:
|
56
|
-
overwrite_scenario(intercept_settings.scenario_key)
|
57
|
-
|
58
|
-
__record_request(context, request_model)
|
59
63
|
else:
|
60
64
|
if active_record_policy != record_policy.NONE:
|
61
65
|
return bad_request(
|
62
66
|
flow,
|
63
|
-
"Valid
|
64
|
-
([record_policy.ALL, record_policy.FOUND, record_policy.NOT_FOUND], active_record_policy)
|
67
|
+
"Valid record policies: %s, Got: %s" %
|
68
|
+
([record_policy.ALL, record_policy.API, record_policy.FOUND, record_policy.NOT_FOUND], active_record_policy)
|
65
69
|
)
|
66
70
|
|
67
71
|
def __record_handler(context: RecordContext, request_model: RequestModel):
|
@@ -79,6 +83,11 @@ def __record_handler(context: RecordContext, request_model: RequestModel):
|
|
79
83
|
context.flow = flow # Reset flow
|
80
84
|
|
81
85
|
def __record_request(context: RecordContext, request_model: RequestModel):
|
86
|
+
intercept_settings = context.intercept_settings
|
87
|
+
|
88
|
+
if intercept_settings.order == record_order.OVERWRITE:
|
89
|
+
overwrite_scenario(intercept_settings.scenario_key)
|
90
|
+
|
82
91
|
if os.environ.get(ENV) == TEST:
|
83
92
|
__record_handler(context, request_model)
|
84
93
|
else:
|