txt2stix 1.0.7__tar.gz → 1.0.8__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.
Files changed (260) hide show
  1. {txt2stix-1.0.7 → txt2stix-1.0.8}/PKG-INFO +1 -1
  2. {txt2stix-1.0.7 → txt2stix-1.0.8}/pyproject.toml +1 -1
  3. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_attack_flow.py +41 -10
  4. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/attack_flow.py +7 -3
  5. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/retriever.py +2 -1
  6. {txt2stix-1.0.7 → txt2stix-1.0.8}/.env.example +0 -0
  7. {txt2stix-1.0.7 → txt2stix-1.0.8}/.env.markdown +0 -0
  8. {txt2stix-1.0.7 → txt2stix-1.0.8}/.github/workflows/create-release.yml +0 -0
  9. {txt2stix-1.0.7 → txt2stix-1.0.8}/.github/workflows/run-tests.yml +0 -0
  10. {txt2stix-1.0.7 → txt2stix-1.0.8}/.gitignore +0 -0
  11. {txt2stix-1.0.7 → txt2stix-1.0.8}/LICENSE +0 -0
  12. {txt2stix-1.0.7 → txt2stix-1.0.8}/README.md +0 -0
  13. {txt2stix-1.0.7 → txt2stix-1.0.8}/docs/README.md +0 -0
  14. {txt2stix-1.0.7 → txt2stix-1.0.8}/docs/stix-mapping.md +0 -0
  15. {txt2stix-1.0.7 → txt2stix-1.0.8}/docs/txt2stix.png +0 -0
  16. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/__init__.py +0 -0
  17. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/extractions/ai/config.yaml +0 -0
  18. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/extractions/lookup/config.yaml +0 -0
  19. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/extractions/pattern/config.yaml +0 -0
  20. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/helpers/mimetype_filename_extension_list.csv +0 -0
  21. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/helpers/stix_relationship_types.txt +0 -0
  22. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/helpers/tlds.txt +0 -0
  23. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/helpers/windows_registry_key_prefix.txt +0 -0
  24. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/_README.md +0 -0
  25. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/_generate_lookups.py +0 -0
  26. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/attack_pattern.txt +0 -0
  27. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/campaign.txt +0 -0
  28. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/country_iso3166_alpha2.txt +0 -0
  29. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/course_of_action.txt +0 -0
  30. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/disarm_id_v1_5.txt +0 -0
  31. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/disarm_name_v1_5.txt +0 -0
  32. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/extensions.txt +0 -0
  33. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/identity.txt +0 -0
  34. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/infrastructure.txt +0 -0
  35. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/intrusion_set.txt +0 -0
  36. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/malware.txt +0 -0
  37. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_atlas_id_v4_5_2.txt +0 -0
  38. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_atlas_name_v4_5_2.txt +0 -0
  39. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_enterprise_aliases_v16_0.txt +0 -0
  40. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_enterprise_id_v16_0.txt +0 -0
  41. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_enterprise_name_v16_0.txt +0 -0
  42. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_ics_aliases_v16_0.txt +0 -0
  43. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_ics_id_v16_0.txt +0 -0
  44. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_ics_name_v16_0.txt +0 -0
  45. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_mobile_aliases_v16_0.txt +0 -0
  46. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_mobile_id_v16_0.txt +0 -0
  47. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_attack_mobile_name_v16_0.txt +0 -0
  48. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_capec_id_v3_9.txt +0 -0
  49. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_capec_name_v3_9.txt +0 -0
  50. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_cwe_id_v4_15.txt +0 -0
  51. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/mitre_cwe_name_v4_15.txt +0 -0
  52. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/threat_actor.txt +0 -0
  53. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/tld.txt +0 -0
  54. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/lookups/tool.txt +0 -0
  55. {txt2stix-1.0.7 → txt2stix-1.0.8}/includes/tests/test_cases.yaml +0 -0
  56. {txt2stix-1.0.7 → txt2stix-1.0.8}/requirements.txt +0 -0
  57. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/README.md +0 -0
  58. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/ai_country.txt +0 -0
  59. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/ai_mitre_attack_enterprise.txt +0 -0
  60. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/ai_mitre_attack_ics.txt +0 -0
  61. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/ai_mitre_attack_mobile.txt +0 -0
  62. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/ai_mitre_capec.txt +0 -0
  63. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/ai_mitre_cwe.txt +0 -0
  64. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/all_cases.txt +0 -0
  65. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_autonomous_system_number.txt +0 -0
  66. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_bank_card_all.txt +0 -0
  67. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_bank_card_amex.txt +0 -0
  68. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_bank_card_diners.txt +0 -0
  69. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_bank_card_discover.txt +0 -0
  70. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_bank_card_jcb.txt +0 -0
  71. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_bank_card_mastercard.txt +0 -0
  72. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_bank_card_union_pay.txt +0 -0
  73. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_bank_card_visa.txt +0 -0
  74. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_country_alpha2.txt +0 -0
  75. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_cpe_uri.txt +0 -0
  76. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_cryptocurrency_btc_transaction.txt +0 -0
  77. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_cryptocurrency_btc_wallet.txt +0 -0
  78. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_cryptocurrency_eth_transaction.txt +0 -0
  79. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_cryptocurrency_eth_wallet.txt +0 -0
  80. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_cryptocurrency_xmr_transaction.txt +0 -0
  81. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_cryptocurrency_xmr_wallet.txt +0 -0
  82. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_cve_id.txt +0 -0
  83. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_directory_unix.txt +0 -0
  84. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_directory_unix_file.txt +0 -0
  85. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_directory_windows.txt +0 -0
  86. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_directory_windows_with_file.txt +0 -0
  87. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_disarm.txt +0 -0
  88. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_disarm_name.txt +0 -0
  89. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_domain_name_only.txt +0 -0
  90. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_domain_name_subdomain.txt +0 -0
  91. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_email_address.txt +0 -0
  92. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_file_hash_md5.txt +0 -0
  93. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_file_hash_sha_1.txt +0 -0
  94. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_file_hash_sha_224.txt +0 -0
  95. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_file_hash_sha_256.txt +0 -0
  96. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_file_hash_sha_384.txt +0 -0
  97. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_file_hash_sha_512.txt +0 -0
  98. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_file_name.txt +0 -0
  99. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_host_name.txt +0 -0
  100. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_host_name_file.txt +0 -0
  101. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_host_name_path.txt +0 -0
  102. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_host_name_subdomain.txt +0 -0
  103. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_host_name_url.txt +0 -0
  104. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_iban_number.txt +0 -0
  105. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_ipv4_address_cidr.txt +0 -0
  106. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_ipv4_address_only.txt +0 -0
  107. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_ipv4_address_port.txt +0 -0
  108. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_ipv6_address_cidr.txt +0 -0
  109. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_ipv6_address_only.txt +0 -0
  110. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_ipv6_address_port.txt +0 -0
  111. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mac_address.txt +0 -0
  112. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_atlas.txt +0 -0
  113. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_atlas_name.txt +0 -0
  114. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_enterprise.txt +0 -0
  115. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_enterprise_aliases.txt +0 -0
  116. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_enterprise_name.txt +0 -0
  117. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_ics.txt +0 -0
  118. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_ics_aliases.txt +0 -0
  119. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_ics_name.txt +0 -0
  120. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_mobile.txt +0 -0
  121. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_mobile_aliases.txt +0 -0
  122. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_attack_mobile_name.txt +0 -0
  123. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_capec.txt +0 -0
  124. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_capec_name.txt +0 -0
  125. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_cwe.txt +0 -0
  126. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_mitre_cwe_name.txt +0 -0
  127. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_phone_number.txt +0 -0
  128. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_url.txt +0 -0
  129. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_url_file.txt +0 -0
  130. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_url_path.txt +0 -0
  131. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_user_agent.txt +0 -0
  132. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/generic_windows_registry_key.txt +0 -0
  133. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_attack_pattern.txt +0 -0
  134. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_campaign.txt +0 -0
  135. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_course_of_action.txt +0 -0
  136. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_identity.txt +0 -0
  137. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_infrastructure.txt +0 -0
  138. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_intrusion_set.txt +0 -0
  139. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_malware.txt +0 -0
  140. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_threat_actor.txt +0 -0
  141. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/extraction_types/lookup_tool.txt +0 -0
  142. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/attack_flow_demo.txt +0 -0
  143. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/attack_navigator_demo.txt +0 -0
  144. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/basic_relationship.txt +0 -0
  145. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/char_length_too_long.txt +0 -0
  146. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/descriptive_for_ai_relationships_1.txt +0 -0
  147. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/disarm_demo.txt +0 -0
  148. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/embedded_img_ignore.txt +0 -0
  149. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/embedded_link_ignore.txt +0 -0
  150. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/ip1.txt +0 -0
  151. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/ip2.txt +0 -0
  152. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/known_whitelist_match.txt +0 -0
  153. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/mitre_attack_enterprise_ai_demo.txt +0 -0
  154. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/mitre_attack_enterprise_lookup_demo.txt +0 -0
  155. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/mixed_extractions.txt +0 -0
  156. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/not_security_content.txt +0 -0
  157. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/test_ai_hash_error_with_stix2_lib.txt +0 -0
  158. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/test_aliases.txt +0 -0
  159. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/test_extraction_boundary.txt +0 -0
  160. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/manually_generated_reports/test_extraction_escapes.txt +0 -0
  161. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/APT28-Center-of-Storm-2017.txt +0 -0
  162. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/Bitdefender-Labs-Report-X-creat6958-en-EN.txt +0 -0
  163. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/FireEyeAPT39.txt +0 -0
  164. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/France_CERT_APT31_Pakdoor_TLPWHITE.txt +0 -0
  165. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/Group-IB_Ransomware_Uncovered_whitepaper_eng.txt +0 -0
  166. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/JOINT_CSA_HUNTING_RU_INTEL_SNAKE_MALWARE_20230509.txt +0 -0
  167. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/TA22-0126-QAKBOT-analysis-TLP-GREEN.txt +0 -0
  168. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/dinners_card.txt +0 -0
  169. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/mandiant-apt1.txt +0 -0
  170. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/data/real_intel_reports/mykings_report_final.txt +0 -0
  171. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/manual-tests/cases-ai-relationships.md +0 -0
  172. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/manual-tests/cases-extraction-type-ai.md +0 -0
  173. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/manual-tests/cases-extraction-type-lookup.md +0 -0
  174. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/manual-tests/cases-extraction-type-pattern.md +0 -0
  175. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/manual-tests/cases-standard-tests.md +0 -0
  176. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/scripts/generate_simple_extraction_test_cases_txt_files.py +0 -0
  177. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/__init__.py +0 -0
  178. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_bundler.py +0 -0
  179. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_extractors.py +0 -0
  180. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_indicator.py +0 -0
  181. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_lookups.py +0 -0
  182. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_main.py +0 -0
  183. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_retriever.py +0 -0
  184. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_run_txt2stix.py +0 -0
  185. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/test_utils.py +0 -0
  186. {txt2stix-1.0.7 → txt2stix-1.0.8}/tests/src/utils.py +0 -0
  187. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/__init__.py +0 -0
  188. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/__init__.py +0 -0
  189. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/anthropic.py +0 -0
  190. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/base.py +0 -0
  191. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/deepseek.py +0 -0
  192. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/gemini.py +0 -0
  193. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/openai.py +0 -0
  194. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/openrouter.py +0 -0
  195. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/prompts.py +0 -0
  196. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/ai_extractor/utils.py +0 -0
  197. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/bundler.py +0 -0
  198. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/common.py +0 -0
  199. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/credential_checker.py +0 -0
  200. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/extractions.py +0 -0
  201. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/indicator.py +0 -0
  202. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/lookups.py +0 -0
  203. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/__init__.py +0 -0
  204. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/__init__.py +0 -0
  205. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/base_extractor.py +0 -0
  206. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/README.md +0 -0
  207. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/__init__.py +0 -0
  208. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/amex_card_extractor.py +0 -0
  209. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/diners_card_extractor.py +0 -0
  210. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/discover_card_extractor.py +0 -0
  211. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/jcb_card_extractor.py +0 -0
  212. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/master_card_extractor.py +0 -0
  213. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/union_card_extractor.py +0 -0
  214. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/card/visa_card_extractor.py +0 -0
  215. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/crypto/__init__.py +0 -0
  216. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/crypto/btc_extractor.py +0 -0
  217. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/directory/__init__.py +0 -0
  218. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/directory/unix_directory_extractor.py +0 -0
  219. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/directory/unix_file_path_extractor.py +0 -0
  220. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/directory/windows_directory_path_extractor.py +0 -0
  221. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/directory/windows_file_path_extractor.py +0 -0
  222. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/domain/__init__.py +0 -0
  223. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/domain/domain_extractor.py +0 -0
  224. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/domain/hostname_extractor.py +0 -0
  225. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/domain/sub_domain_extractor.py +0 -0
  226. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/hashes/__init__.py +0 -0
  227. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/hashes/md5_extractor.py +0 -0
  228. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/hashes/sha1_extractor.py +0 -0
  229. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/hashes/sha224_extractor.py +0 -0
  230. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/hashes/sha2_256_exactor.py +0 -0
  231. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/hashes/sha2_512_exactor.py +0 -0
  232. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/hashes/sha3_256_exactor.py +0 -0
  233. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/hashes/sha3_512_exactor.py +0 -0
  234. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/helper.py +0 -0
  235. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/ip/__init__.py +0 -0
  236. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/ip/ipv4_cidr_extractor.py +0 -0
  237. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/ip/ipv4_extractor.py +0 -0
  238. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/ip/ipv4_port_extractor.py +0 -0
  239. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/ip/ipv6_cidr_extractor.py +0 -0
  240. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/ip/ipv6_extractor.py +0 -0
  241. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/ip/ipv6_port_extractor.py +0 -0
  242. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/__init__.py +0 -0
  243. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/asn_extractor.py +0 -0
  244. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/cpe_extractor.py +0 -0
  245. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/cve_extractor.py +0 -0
  246. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/email_extractor.py +0 -0
  247. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/filename_extractor.py +0 -0
  248. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/iban_extractor.py +0 -0
  249. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/mac_address_extractor.py +0 -0
  250. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/phonenumber_extractor.py +0 -0
  251. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/user_agent_extractor.py +0 -0
  252. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/others/windows_registry_key_extractor.py +0 -0
  253. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/url/__init__.py +0 -0
  254. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/url/url_extractor.py +0 -0
  255. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/url/url_file_extractor.py +0 -0
  256. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/pattern/extractors/url/url_path_extractor.py +0 -0
  257. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/stix.py +0 -0
  258. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/txt2stix.py +0 -0
  259. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix/utils.py +0 -0
  260. {txt2stix-1.0.7 → txt2stix-1.0.8}/txt2stix.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: txt2stix
3
- Version: 1.0.7
3
+ Version: 1.0.8
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"
7
+ version = "1.0.8"
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."
@@ -142,7 +142,7 @@ def test_extract_attack_flow_and_navigator(dummy_objects, dummy_report):
142
142
  mock_extract_flow.assert_called_once_with(text, techniques)
143
143
 
144
144
  mock_create_navigator_layer.assert_called_once_with(
145
- bundler.report, bundler.summary, mock_extract_flow.return_value, techniques
145
+ bundler.report, bundler.summary, mock_extract_flow.return_value, techniques, tactics
146
146
  )
147
147
 
148
148
  ### reset mocks
@@ -181,7 +181,7 @@ def test_extract_attack_flow_and_navigator(dummy_objects, dummy_report):
181
181
  mock_parse_flow.assert_not_called()
182
182
 
183
183
  mock_create_navigator_layer.assert_called_once_with(
184
- bundler.report, bundler.summary, mock_extract_flow.return_value, techniques
184
+ bundler.report, bundler.summary, mock_extract_flow.return_value, techniques, tactics
185
185
  )
186
186
 
187
187
  ### reset mocks
@@ -265,11 +265,25 @@ def test_create_navigator_layer(dummy_report):
265
265
  "T2003": dict(id="T2003", domain="mobile-attack", possible_tactics=tactics_2),
266
266
  }
267
267
 
268
- retval = create_navigator_layer(dummy_report, summary, flow, techniques)
268
+ retval = create_navigator_layer(
269
+ dummy_report,
270
+ summary,
271
+ flow,
272
+ techniques,
273
+ tactics={
274
+ "mobile-attack": {"version": "13.1"},
275
+ "ics-attack": {"version": "17.0"},
276
+ "enterprise-attack": {"version": "16.1"},
277
+ },
278
+ )
269
279
  assert len(retval) == 3
270
280
  assert retval == [
271
281
  {
272
- "version": "4.5",
282
+ "versions": {
283
+ "layer": "4.5",
284
+ "attack": '16.1',
285
+ "navigator": "5.1.0",
286
+ },
273
287
  "name": "some markdown document",
274
288
  "domain": "enterprise-attack",
275
289
  "description": "this is a summary",
@@ -295,7 +309,11 @@ def test_create_navigator_layer(dummy_report):
295
309
  "layout": {"layout": "side"},
296
310
  },
297
311
  {
298
- "version": "4.5",
312
+ "versions": {
313
+ "layer": "4.5",
314
+ "attack": '17.0',
315
+ "navigator": "5.1.0",
316
+ },
299
317
  "name": "some markdown document",
300
318
  "domain": "ics-attack",
301
319
  "description": "this is a summary",
@@ -321,7 +339,11 @@ def test_create_navigator_layer(dummy_report):
321
339
  "layout": {"layout": "side"},
322
340
  },
323
341
  {
324
- "version": "4.5",
342
+ "versions": {
343
+ "layer": "4.5",
344
+ "attack": '13.1',
345
+ "navigator": "5.1.0",
346
+ },
325
347
  "name": "some markdown document",
326
348
  "domain": "mobile-attack",
327
349
  "description": "this is a summary",
@@ -352,12 +374,17 @@ def test_create_navigator_layer(dummy_report):
352
374
  def test_create_navigator_layer__real_flow(dummy_report, dummy_flow, dummy_objects):
353
375
  tactics = get_all_tactics()
354
376
  techniques = get_techniques_from_extracted_objects(dummy_objects, tactics)
355
- retval = create_navigator_layer(dummy_report, "a summary", dummy_flow, techniques)
377
+ retval = create_navigator_layer(
378
+ dummy_report, "a summary", dummy_flow, techniques, tactics
379
+ )
356
380
  assert len(retval) == 2
357
- print(retval)
358
381
  assert retval == [
359
382
  {
360
- "version": "4.5",
383
+ "versions": {
384
+ "layer": "4.5",
385
+ "attack": tactics["ics-attack"]["version"],
386
+ "navigator": "5.1.0",
387
+ },
361
388
  "name": "some markdown document",
362
389
  "domain": "ics-attack",
363
390
  "description": "a summary",
@@ -398,7 +425,11 @@ def test_create_navigator_layer__real_flow(dummy_report, dummy_flow, dummy_objec
398
425
  "layout": {"layout": "side"},
399
426
  },
400
427
  {
401
- "version": "4.5",
428
+ "versions": {
429
+ "layer": "4.5",
430
+ "attack": tactics["enterprise-attack"]["version"],
431
+ "navigator": "5.1.0",
432
+ },
402
433
  "name": "some markdown document",
403
434
  "domain": "enterprise-attack",
404
435
  "description": "a summary",
@@ -147,7 +147,7 @@ def get_techniques_from_extracted_objects(objects: dict, tactics: dict):
147
147
  return techniques
148
148
 
149
149
 
150
- def create_navigator_layer(report, summary, flow: AttackFlowList, techniques):
150
+ def create_navigator_layer(report, summary, flow: AttackFlowList, techniques, tactics):
151
151
  domains = {}
152
152
  comments = {item.attack_technique_id: item.description for item in flow.items}
153
153
  for technique in techniques.values():
@@ -170,7 +170,11 @@ def create_navigator_layer(report, summary, flow: AttackFlowList, techniques):
170
170
  for domain, domain_techniques in domains.items():
171
171
  retval.append(
172
172
  {
173
- "version": "4.5",
173
+ "versions": {
174
+ "layer": "4.5",
175
+ "attack": tactics[domain]['version'],
176
+ "navigator": "5.1.0"
177
+ },
174
178
  "name": report.name,
175
179
  "domain": domain,
176
180
  "description": summary,
@@ -220,6 +224,6 @@ def extract_attack_flow_and_navigator(
220
224
 
221
225
  if ai_create_attack_navigator_layer:
222
226
  navigator = create_navigator_layer(
223
- bundler.report, bundler.summary, flow, techniques
227
+ bundler.report, bundler.summary, flow, techniques, tactics
224
228
  )
225
229
  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