/maltego-stix2

Generation of STIX2 compliant entities for Maltego

Primary LanguagePythonApache License 2.0Apache-2.0

alt text

Maltego STIX2 entities

This project allows you to generate a set of Maltego entities generated from official STIX 2 schemas. It also contains generic transforms to explore the properties of STIX 2 entities. The set of entities with the default configuration provided here is also distributed in the official Maltego Transform Hub.

Dependencies in submodules

We are using the following assets to generate STIX2 Maltego entities:

Usage

If you are only using the default Maltego entities and don't want to customize anything, you can install the entities distributed in the official Maltego Transform Hub.

If you want to customize these entities (heritage with other entities, default transform to explore STIX2 properties), you can use this project to generate your own set of entities.

If you want to build your own transforms using these entities, you can install the maltego_stix2 python package to help you write them. It contains the definition of the entities to be able to return them in your transforms, as well as utility functions to translate a Maltego entity into and from a STIX2 object. A template for such a transform is provided in ./trx-demo.

Configuration

Generation

$ git clone https://github.com/amr-cossi/maltego-stix2
$ cd maltego-stix2
$ git submodule init

Requirements

Please install the following requirements before generating the Maltego-STIX2 entities:

  • Python >= 3.6
  • Libraries in ./requirements.txt
$ pip3 install -r requirements.txt

For any customization of the heritage configuration of the entities, a custom version of the maltego-stix2 package has to be installed:

$ pip3 install .

Generate

To generate the entities.mtz file:

$ git submodule update --remote
$ ./build_entities.sh (--with-opencti)

To generate the transforms.mtz file (the transforms require installing this library in your environment):

$ python3 setup.py install
$ ./build_transforms.sh (--with-opencti)

To run the transforms locally, make sure the path to TRX project.py is set up in ./local_config.py

For any customization of the types of the entities, a custom version of the maltego-stix2 package has to be re-installed:

$ pip3 install .

Import

Import the files output/entities.mtz and output/transforms.mtz in Maltego using the "Import config" menu.

If you use an iTDS, import the file output/importable_itds_config.csv in your iTDS management platform.

Contributing

Code of Conduct

We follow a standard Code of Conduct that we expect project participants to adhere to. Please read the full text so that you can understand what actions will and will not be tolerated.

How to contribute

This module is not a huge project with an intense roadmap. Feel free to contribute through issues linked to pull requests for new features and bug solving.

TODO: known wanted enhancements

  • Rely on external library to parse JSON-ref files
  • Add missing icons for some observables