txt2stix 1.0.7__tar.gz → 1.0.9__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {txt2stix-1.0.7 → txt2stix-1.0.9}/PKG-INFO +1 -1
- {txt2stix-1.0.7 → txt2stix-1.0.9}/pyproject.toml +1 -1
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/attack_flow_demo.txt +3 -1
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/manual-tests/cases-standard-tests.md +18 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_attack_flow.py +112 -31
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/attack_flow.py +23 -8
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/retriever.py +2 -1
- {txt2stix-1.0.7 → txt2stix-1.0.9}/.env.example +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/.env.markdown +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/.github/workflows/create-release.yml +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/.github/workflows/run-tests.yml +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/.gitignore +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/LICENSE +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/README.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/docs/README.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/docs/stix-mapping.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/docs/txt2stix.png +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/extractions/ai/config.yaml +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/extractions/lookup/config.yaml +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/extractions/pattern/config.yaml +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/helpers/mimetype_filename_extension_list.csv +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/helpers/stix_relationship_types.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/helpers/tlds.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/helpers/windows_registry_key_prefix.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/_README.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/_generate_lookups.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/attack_pattern.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/campaign.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/country_iso3166_alpha2.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/course_of_action.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/disarm_id_v1_5.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/disarm_name_v1_5.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/extensions.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/identity.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/infrastructure.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/intrusion_set.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/malware.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_atlas_id_v4_5_2.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_atlas_name_v4_5_2.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_enterprise_aliases_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_enterprise_id_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_enterprise_name_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_ics_aliases_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_ics_id_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_ics_name_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_mobile_aliases_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_mobile_id_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_mobile_name_v16_0.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_capec_id_v3_9.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_capec_name_v3_9.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_cwe_id_v4_15.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_cwe_name_v4_15.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/threat_actor.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/tld.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/tool.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/includes/tests/test_cases.yaml +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/requirements.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/README.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/ai_country.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/ai_mitre_attack_enterprise.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/ai_mitre_attack_ics.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/ai_mitre_attack_mobile.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/ai_mitre_capec.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/ai_mitre_cwe.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/all_cases.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_autonomous_system_number.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_all.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_amex.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_diners.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_discover.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_jcb.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_mastercard.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_union_pay.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_visa.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_country_alpha2.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cpe_uri.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_btc_transaction.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_btc_wallet.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_eth_transaction.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_eth_wallet.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_xmr_transaction.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_xmr_wallet.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cve_id.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_directory_unix.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_directory_unix_file.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_directory_windows.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_directory_windows_with_file.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_disarm.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_disarm_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_domain_name_only.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_domain_name_subdomain.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_email_address.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_file_hash_md5.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_file_hash_sha_1.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_file_hash_sha_224.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_file_hash_sha_256.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_file_hash_sha_384.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_file_hash_sha_512.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_file_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_host_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_host_name_file.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_host_name_path.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_host_name_subdomain.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_host_name_url.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_iban_number.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_ipv4_address_cidr.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_ipv4_address_only.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_ipv4_address_port.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_ipv6_address_cidr.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_ipv6_address_only.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_ipv6_address_port.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mac_address.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_atlas.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_atlas_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_enterprise.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_enterprise_aliases.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_enterprise_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_ics.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_ics_aliases.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_ics_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_mobile.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_mobile_aliases.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_attack_mobile_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_capec.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_capec_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_cwe.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_mitre_cwe_name.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_phone_number.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_url.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_url_file.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_url_path.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_user_agent.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_windows_registry_key.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_attack_pattern.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_campaign.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_course_of_action.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_identity.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_infrastructure.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_intrusion_set.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_malware.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_threat_actor.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/lookup_tool.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/attack_navigator_demo.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/basic_relationship.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/char_length_too_long.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/descriptive_for_ai_relationships_1.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/disarm_demo.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/embedded_img_ignore.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/embedded_link_ignore.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/ip1.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/ip2.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/known_whitelist_match.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/mitre_attack_enterprise_ai_demo.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/mitre_attack_enterprise_lookup_demo.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/mixed_extractions.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/not_security_content.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/test_ai_hash_error_with_stix2_lib.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/test_aliases.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/test_extraction_boundary.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/test_extraction_escapes.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/APT28-Center-of-Storm-2017.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/Bitdefender-Labs-Report-X-creat6958-en-EN.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/FireEyeAPT39.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/France_CERT_APT31_Pakdoor_TLPWHITE.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/Group-IB_Ransomware_Uncovered_whitepaper_eng.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/JOINT_CSA_HUNTING_RU_INTEL_SNAKE_MALWARE_20230509.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/TA22-0126-QAKBOT-analysis-TLP-GREEN.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/dinners_card.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/mandiant-apt1.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/real_intel_reports/mykings_report_final.txt +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/manual-tests/cases-ai-relationships.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/manual-tests/cases-extraction-type-ai.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/manual-tests/cases-extraction-type-lookup.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/manual-tests/cases-extraction-type-pattern.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/scripts/generate_simple_extraction_test_cases_txt_files.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_bundler.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_extractors.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_indicator.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_lookups.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_main.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_retriever.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_run_txt2stix.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/test_utils.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/tests/src/utils.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/anthropic.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/base.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/deepseek.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/gemini.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/openai.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/openrouter.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/prompts.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/ai_extractor/utils.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/bundler.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/common.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/credential_checker.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/extractions.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/indicator.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/lookups.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/base_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/README.md +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/amex_card_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/diners_card_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/discover_card_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/jcb_card_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/master_card_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/union_card_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/card/visa_card_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/crypto/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/crypto/btc_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/directory/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/directory/unix_directory_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/directory/unix_file_path_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/directory/windows_directory_path_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/directory/windows_file_path_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/domain/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/domain/domain_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/domain/hostname_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/domain/sub_domain_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/hashes/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/hashes/md5_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/hashes/sha1_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/hashes/sha224_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/hashes/sha2_256_exactor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/hashes/sha2_512_exactor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/hashes/sha3_256_exactor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/hashes/sha3_512_exactor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/helper.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/ip/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/ip/ipv4_cidr_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/ip/ipv4_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/ip/ipv4_port_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/ip/ipv6_cidr_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/ip/ipv6_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/ip/ipv6_port_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/asn_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/cpe_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/cve_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/email_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/filename_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/iban_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/mac_address_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/phonenumber_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/user_agent_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/others/windows_registry_key_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/url/__init__.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/url/url_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/url/url_file_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/pattern/extractors/url/url_path_extractor.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/stix.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/txt2stix.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix/utils.py +0 -0
- {txt2stix-1.0.7 → txt2stix-1.0.9}/txt2stix.py +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: txt2stix
|
3
|
-
Version: 1.0.
|
3
|
+
Version: 1.0.9
|
4
4
|
Summary: txt2stix is a Python script that is designed to identify and extract IoCs and TTPs from text files, identify the relationships between them, convert them to STIX 2.1 objects, and output as a STIX 2.1 bundle.
|
5
5
|
Project-URL: Homepage, https://github.com/muchdogesec/txt2stix
|
6
6
|
Project-URL: Issues, https://github.com/muchdogesec/txt2stix/issues
|
@@ -4,7 +4,7 @@ build-backend = "hatchling.build"
|
|
4
4
|
|
5
5
|
[project]
|
6
6
|
name = "txt2stix"
|
7
|
-
version = "1.0.
|
7
|
+
version = "1.0.9"
|
8
8
|
authors = [{ name = "dogesec" }]
|
9
9
|
maintainers = [{ name = "dogesec" }]
|
10
10
|
description = "txt2stix is a Python script that is designed to identify and extract IoCs and TTPs from text files, identify the relationships between them, convert them to STIX 2.1 objects, and output as a STIX 2.1 bundle."
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/manually_generated_reports/attack_flow_demo.txt
RENAMED
@@ -4,4 +4,6 @@ Due to password protection, the zip files are able to bypass some AV detections.
|
|
4
4
|
|
5
5
|
The zip files are extracted and usually contain a malicious document, such as a .doc, .pdf, or .xls. Some examples are malware.pdf and bad.com
|
6
6
|
|
7
|
-
The extracted files contain malicious macros that connect to a C2 server 1.1.1.1
|
7
|
+
The extracted files contain malicious macros that connect to a C2 server 1.1.1.1
|
8
|
+
|
9
|
+
And here is a mobile ID to test behaviour of multiple matrices T1630.001
|
@@ -486,6 +486,24 @@ python3 txt2stix.py \
|
|
486
486
|
--report_id 3b160a8d-12dd-4e7c-aee8-5af6e371b425
|
487
487
|
```
|
488
488
|
|
489
|
+
with two domains
|
490
|
+
|
491
|
+
no indicators
|
492
|
+
|
493
|
+
```shell
|
494
|
+
python3 txt2stix.py \
|
495
|
+
--relationship_mode ai \
|
496
|
+
--ai_settings_relationships openai:gpt-5 \
|
497
|
+
--input_file tests/data/manually_generated_reports/attack_flow_demo.txt \
|
498
|
+
--name 'Test MITRE ATT&CK Flow demo' \
|
499
|
+
--tlp_level clear \
|
500
|
+
--confidence 100 \
|
501
|
+
--use_extractions 'ai_mitre_attack_*' \
|
502
|
+
--ai_settings_extractions openai:gpt-5 \
|
503
|
+
--ai_create_attack_flow \
|
504
|
+
--report_id ccc8c844-6a89-4762-b4e7-77c918fa4b8f
|
505
|
+
```
|
506
|
+
|
489
507
|
### attack navigator demo
|
490
508
|
|
491
509
|
```shell
|
@@ -8,6 +8,7 @@ from txt2stix.attack_flow import (
|
|
8
8
|
create_navigator_layer,
|
9
9
|
get_all_tactics,
|
10
10
|
get_techniques_from_extracted_objects,
|
11
|
+
parse_domain_flow,
|
11
12
|
parse_flow,
|
12
13
|
extract_attack_flow_and_navigator,
|
13
14
|
)
|
@@ -21,31 +22,30 @@ def test_parse_flow(dummy_report, dummy_objects, dummy_flow):
|
|
21
22
|
techniques = get_techniques_from_extracted_objects(dummy_objects, tactics)
|
22
23
|
flow = dummy_flow
|
23
24
|
report = dummy_report
|
24
|
-
expected_ids =
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
25
|
+
expected_ids = {
|
26
|
+
"attack-pattern--1b22b676-9347-4c55-9a35-ef0dc653db5b",
|
27
|
+
"x-mitre-tactic--298fe907-7931-4fd2-8131-2814dd493134",
|
28
|
+
"attack-action--1fd63972-ef98-5da5-81f5-4090c7dfa585",
|
29
|
+
"extension-definition--fb9c968a-745b-4ade-9b25-c324172197f4",
|
30
|
+
"attack-pattern--1a80d097-54df-41d8-9d33-34e755ec5e72",
|
31
|
+
"report--9c88fbcb-8c0d-4124-868b-3dcb1e9b696c",
|
32
|
+
"attack-flow--bb21585c-5f82-55cf-b73d-89b5217ef092",
|
33
|
+
"relationship--22e97298-819a-55ac-b57b-2185ffb72c62",
|
34
|
+
"x-mitre-tactic--2558fd61-8c75-4730-94c4-11926db2a263",
|
35
|
+
"attack-action--c7e06b10-252d-520d-82eb-e32314bbec34",
|
36
|
+
"x-mitre-tactic--696af733-728e-49d7-8261-75fdc590f453",
|
37
|
+
"x-mitre-tactic--5bc1d813-693e-4823-9961-abf9af4b0e92",
|
38
|
+
"attack-pattern--f9e9365a-9ca2-4d9c-8e7c-050d73d1101a",
|
39
|
+
"attack-action--51dc1572-cb10-581b-b9ef-9e589615ecaa",
|
40
|
+
"relationship--931f6b0d-5136-534a-93bc-8cce065e04dc",
|
41
|
+
"attack-pattern--0fe075d5-beac-4d02-b93e-0f874997db72",
|
42
|
+
"attack-flow--b48ec5d9-407c-5e4a-a6d0-fe851cd4ea0e",
|
43
|
+
"attack-action--e03c89ba-a476-5509-ac0a-049b61514be7",
|
44
|
+
}
|
44
45
|
|
45
46
|
flow_objects = parse_flow(report, flow, techniques, tactics)
|
46
47
|
assert {obj["id"] for obj in flow_objects} == expected_ids
|
47
48
|
|
48
|
-
|
49
49
|
def test_parse_flow__no_success(dummy_report):
|
50
50
|
flow_objects = parse_flow(
|
51
51
|
dummy_report,
|
@@ -61,6 +61,48 @@ def test_parse_flow__no_success(dummy_report):
|
|
61
61
|
assert len(flow_objects) == 0
|
62
62
|
|
63
63
|
|
64
|
+
@pytest.mark.parametrize(
|
65
|
+
["domain", "expected_ids"],
|
66
|
+
[
|
67
|
+
("mobile-attack", set()),
|
68
|
+
[
|
69
|
+
"ics-attack",
|
70
|
+
{
|
71
|
+
"x-mitre-tactic--298fe907-7931-4fd2-8131-2814dd493134",
|
72
|
+
"x-mitre-tactic--696af733-728e-49d7-8261-75fdc590f453",
|
73
|
+
"attack-pattern--1b22b676-9347-4c55-9a35-ef0dc653db5b",
|
74
|
+
"relationship--22e97298-819a-55ac-b57b-2185ffb72c62",
|
75
|
+
"attack-action--1fd63972-ef98-5da5-81f5-4090c7dfa585",
|
76
|
+
"attack-pattern--0fe075d5-beac-4d02-b93e-0f874997db72",
|
77
|
+
"attack-flow--bb21585c-5f82-55cf-b73d-89b5217ef092",
|
78
|
+
"attack-action--51dc1572-cb10-581b-b9ef-9e589615ecaa",
|
79
|
+
},
|
80
|
+
],
|
81
|
+
[
|
82
|
+
"enterprise-attack",
|
83
|
+
{
|
84
|
+
"attack-action--e03c89ba-a476-5509-ac0a-049b61514be7",
|
85
|
+
"relationship--931f6b0d-5136-534a-93bc-8cce065e04dc",
|
86
|
+
"attack-flow--b48ec5d9-407c-5e4a-a6d0-fe851cd4ea0e",
|
87
|
+
"attack-pattern--f9e9365a-9ca2-4d9c-8e7c-050d73d1101a",
|
88
|
+
"x-mitre-tactic--2558fd61-8c75-4730-94c4-11926db2a263",
|
89
|
+
"attack-pattern--1a80d097-54df-41d8-9d33-34e755ec5e72",
|
90
|
+
"x-mitre-tactic--5bc1d813-693e-4823-9961-abf9af4b0e92",
|
91
|
+
"attack-action--c7e06b10-252d-520d-82eb-e32314bbec34",
|
92
|
+
},
|
93
|
+
],
|
94
|
+
],
|
95
|
+
)
|
96
|
+
def test_parse_domain_flow(dummy_report, dummy_objects, dummy_flow, domain, expected_ids):
|
97
|
+
tactics = get_all_tactics()
|
98
|
+
techniques = get_techniques_from_extracted_objects(dummy_objects, tactics)
|
99
|
+
flow = dummy_flow
|
100
|
+
report = dummy_report
|
101
|
+
flow_objects = parse_domain_flow(report, flow, techniques, tactics, domain)
|
102
|
+
print([domain, {obj["id"] for obj in flow_objects}], ",")
|
103
|
+
assert {obj["id"] for obj in flow_objects} == expected_ids
|
104
|
+
|
105
|
+
|
64
106
|
def test_get_techniques_from_extracted_objects(dummy_objects):
|
65
107
|
tactics = get_all_tactics()
|
66
108
|
techniques = get_techniques_from_extracted_objects(dummy_objects, tactics)
|
@@ -142,7 +184,11 @@ def test_extract_attack_flow_and_navigator(dummy_objects, dummy_report):
|
|
142
184
|
mock_extract_flow.assert_called_once_with(text, techniques)
|
143
185
|
|
144
186
|
mock_create_navigator_layer.assert_called_once_with(
|
145
|
-
bundler.report,
|
187
|
+
bundler.report,
|
188
|
+
bundler.summary,
|
189
|
+
mock_extract_flow.return_value,
|
190
|
+
techniques,
|
191
|
+
tactics,
|
146
192
|
)
|
147
193
|
|
148
194
|
### reset mocks
|
@@ -181,7 +227,11 @@ def test_extract_attack_flow_and_navigator(dummy_objects, dummy_report):
|
|
181
227
|
mock_parse_flow.assert_not_called()
|
182
228
|
|
183
229
|
mock_create_navigator_layer.assert_called_once_with(
|
184
|
-
bundler.report,
|
230
|
+
bundler.report,
|
231
|
+
bundler.summary,
|
232
|
+
mock_extract_flow.return_value,
|
233
|
+
techniques,
|
234
|
+
tactics,
|
185
235
|
)
|
186
236
|
|
187
237
|
### reset mocks
|
@@ -265,11 +315,25 @@ def test_create_navigator_layer(dummy_report):
|
|
265
315
|
"T2003": dict(id="T2003", domain="mobile-attack", possible_tactics=tactics_2),
|
266
316
|
}
|
267
317
|
|
268
|
-
retval = create_navigator_layer(
|
318
|
+
retval = create_navigator_layer(
|
319
|
+
dummy_report,
|
320
|
+
summary,
|
321
|
+
flow,
|
322
|
+
techniques,
|
323
|
+
tactics={
|
324
|
+
"mobile-attack": {"version": "13.1"},
|
325
|
+
"ics-attack": {"version": "17.0"},
|
326
|
+
"enterprise-attack": {"version": "16.1"},
|
327
|
+
},
|
328
|
+
)
|
269
329
|
assert len(retval) == 3
|
270
330
|
assert retval == [
|
271
331
|
{
|
272
|
-
"
|
332
|
+
"versions": {
|
333
|
+
"layer": "4.5",
|
334
|
+
"attack": "16.1",
|
335
|
+
"navigator": "5.1.0",
|
336
|
+
},
|
273
337
|
"name": "some markdown document",
|
274
338
|
"domain": "enterprise-attack",
|
275
339
|
"description": "this is a summary",
|
@@ -295,7 +359,11 @@ def test_create_navigator_layer(dummy_report):
|
|
295
359
|
"layout": {"layout": "side"},
|
296
360
|
},
|
297
361
|
{
|
298
|
-
"
|
362
|
+
"versions": {
|
363
|
+
"layer": "4.5",
|
364
|
+
"attack": "17.0",
|
365
|
+
"navigator": "5.1.0",
|
366
|
+
},
|
299
367
|
"name": "some markdown document",
|
300
368
|
"domain": "ics-attack",
|
301
369
|
"description": "this is a summary",
|
@@ -321,7 +389,11 @@ def test_create_navigator_layer(dummy_report):
|
|
321
389
|
"layout": {"layout": "side"},
|
322
390
|
},
|
323
391
|
{
|
324
|
-
"
|
392
|
+
"versions": {
|
393
|
+
"layer": "4.5",
|
394
|
+
"attack": "13.1",
|
395
|
+
"navigator": "5.1.0",
|
396
|
+
},
|
325
397
|
"name": "some markdown document",
|
326
398
|
"domain": "mobile-attack",
|
327
399
|
"description": "this is a summary",
|
@@ -352,12 +424,17 @@ def test_create_navigator_layer(dummy_report):
|
|
352
424
|
def test_create_navigator_layer__real_flow(dummy_report, dummy_flow, dummy_objects):
|
353
425
|
tactics = get_all_tactics()
|
354
426
|
techniques = get_techniques_from_extracted_objects(dummy_objects, tactics)
|
355
|
-
retval = create_navigator_layer(
|
427
|
+
retval = create_navigator_layer(
|
428
|
+
dummy_report, "a summary", dummy_flow, techniques, tactics
|
429
|
+
)
|
356
430
|
assert len(retval) == 2
|
357
|
-
print(retval)
|
358
431
|
assert retval == [
|
359
432
|
{
|
360
|
-
"
|
433
|
+
"versions": {
|
434
|
+
"layer": "4.5",
|
435
|
+
"attack": tactics["ics-attack"]["version"],
|
436
|
+
"navigator": "5.1.0",
|
437
|
+
},
|
361
438
|
"name": "some markdown document",
|
362
439
|
"domain": "ics-attack",
|
363
440
|
"description": "a summary",
|
@@ -398,7 +475,11 @@ def test_create_navigator_layer__real_flow(dummy_report, dummy_flow, dummy_objec
|
|
398
475
|
"layout": {"layout": "side"},
|
399
476
|
},
|
400
477
|
{
|
401
|
-
"
|
478
|
+
"versions": {
|
479
|
+
"layer": "4.5",
|
480
|
+
"attack": tactics["enterprise-attack"]["version"],
|
481
|
+
"navigator": "5.1.0",
|
482
|
+
},
|
402
483
|
"name": "some markdown document",
|
403
484
|
"domain": "enterprise-attack",
|
404
485
|
"description": "a summary",
|
@@ -16,15 +16,26 @@ def parse_flow(report, flow: AttackFlowList, techniques, tactics):
|
|
16
16
|
logging.info(f"flow.success = {flow.success}")
|
17
17
|
if not flow.success:
|
18
18
|
return []
|
19
|
-
|
19
|
+
objects = [report, attack_flow_ExtensionDefinitionSMO]
|
20
|
+
for domain in ["enterprise-attack", "mobile-attack", "ics-attack"]:
|
21
|
+
flow_objects = parse_domain_flow(report, flow, techniques, tactics, domain)
|
22
|
+
objects.extend(flow_objects)
|
23
|
+
return objects
|
24
|
+
|
25
|
+
def parse_domain_flow(report, flow: AttackFlowList, techniques, tactics, domain):
|
26
|
+
flow_objects = []
|
27
|
+
flow_obj = None
|
20
28
|
last_action = None
|
21
29
|
for i, item in enumerate(flow.items):
|
22
30
|
try:
|
23
31
|
technique = techniques[item.attack_technique_id]
|
32
|
+
if technique["domain"] != domain:
|
33
|
+
continue
|
24
34
|
tactic_id = technique["possible_tactics"][
|
25
35
|
flow.tactic_mapping[item.attack_technique_id]
|
26
36
|
]
|
27
37
|
technique_obj = technique["stix_obj"]
|
38
|
+
|
28
39
|
tactic_obj = tactics[technique["domain"]][tactic_id]
|
29
40
|
action_obj = AttackAction(
|
30
41
|
**{
|
@@ -40,16 +51,16 @@ def parse_flow(report, flow: AttackFlowList, techniques, tactics):
|
|
40
51
|
allow_custom=True,
|
41
52
|
)
|
42
53
|
action_obj.effect_refs.clear()
|
43
|
-
if
|
54
|
+
if not flow_obj:
|
44
55
|
flow_obj = {
|
45
56
|
"type": "attack-flow",
|
46
|
-
"id":
|
57
|
+
"id": "attack-flow--"+str(uuid.uuid5(UUID_NAMESPACE, f"attack-flow+{domain}+{report.id}")),
|
47
58
|
"spec_version": "2.1",
|
48
59
|
"created": report.created,
|
49
60
|
"modified": report.modified,
|
50
61
|
"created_by_ref": report.created_by_ref,
|
51
62
|
"start_refs": [action_obj["id"]],
|
52
|
-
"name": report.name,
|
63
|
+
"name": f"[{domain.split('-')[0].upper()}] {report.name}",
|
53
64
|
"description": report.description,
|
54
65
|
"scope": "malware",
|
55
66
|
"external_references": report.external_references,
|
@@ -61,7 +72,7 @@ def parse_flow(report, flow: AttackFlowList, techniques, tactics):
|
|
61
72
|
type="relationship",
|
62
73
|
spec_version="2.1",
|
63
74
|
id="relationship--"
|
64
|
-
+ str(uuid.uuid5(UUID_NAMESPACE, f"attack-flow+{report.id}")),
|
75
|
+
+ str(uuid.uuid5(UUID_NAMESPACE, f"attack-flow+{report.id}+{flow_obj['id']}")),
|
65
76
|
created_by_ref=report.created_by_ref,
|
66
77
|
created=report.created,
|
67
78
|
modified=report.modified,
|
@@ -147,7 +158,7 @@ def get_techniques_from_extracted_objects(objects: dict, tactics: dict):
|
|
147
158
|
return techniques
|
148
159
|
|
149
160
|
|
150
|
-
def create_navigator_layer(report, summary, flow: AttackFlowList, techniques):
|
161
|
+
def create_navigator_layer(report, summary, flow: AttackFlowList, techniques, tactics):
|
151
162
|
domains = {}
|
152
163
|
comments = {item.attack_technique_id: item.description for item in flow.items}
|
153
164
|
for technique in techniques.values():
|
@@ -170,7 +181,11 @@ def create_navigator_layer(report, summary, flow: AttackFlowList, techniques):
|
|
170
181
|
for domain, domain_techniques in domains.items():
|
171
182
|
retval.append(
|
172
183
|
{
|
173
|
-
"
|
184
|
+
"versions": {
|
185
|
+
"layer": "4.5",
|
186
|
+
"attack": tactics[domain]['version'],
|
187
|
+
"navigator": "5.1.0"
|
188
|
+
},
|
174
189
|
"name": report.name,
|
175
190
|
"domain": domain,
|
176
191
|
"description": summary,
|
@@ -220,6 +235,6 @@ def extract_attack_flow_and_navigator(
|
|
220
235
|
|
221
236
|
if ai_create_attack_navigator_layer:
|
222
237
|
navigator = create_navigator_layer(
|
223
|
-
bundler.report, bundler.summary, flow, techniques
|
238
|
+
bundler.report, bundler.summary, flow, techniques, tactics
|
224
239
|
)
|
225
240
|
return flow, navigator
|
@@ -28,8 +28,9 @@ class STIXObjectRetriever:
|
|
28
28
|
|
29
29
|
def get_attack_tactics(self, matrix):
|
30
30
|
endpoint = urljoin(self.api_root, f"v1/attack-{matrix}/objects/?attack_type=Tactic")
|
31
|
+
version_url = urljoin(self.api_root, f'v1/attack-{matrix}/versions/installed/')
|
31
32
|
tactics = self._retrieve_objects(endpoint)
|
32
|
-
retval =
|
33
|
+
retval = dict(version=self.session.get(version_url).json()['latest'])
|
33
34
|
for tac in tactics:
|
34
35
|
retval[tac['x_mitre_shortname']] = tac
|
35
36
|
retval[tac['external_references'][0]['external_id']] = tac
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/includes/lookups/mitre_attack_enterprise_aliases_v16_0.txt
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/ai_mitre_attack_enterprise.txt
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_autonomous_system_number.txt
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_discover.txt
RENAMED
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_mastercard.txt
RENAMED
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_bank_card_union_pay.txt
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_btc_wallet.txt
RENAMED
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_eth_wallet.txt
RENAMED
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_cryptocurrency_xmr_wallet.txt
RENAMED
File without changes
|
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_directory_unix_file.txt
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{txt2stix-1.0.7 → txt2stix-1.0.9}/tests/data/extraction_types/generic_domain_name_subdomain.txt
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|