Skip to main content

An API for parsing and creating MAEC content.

Project description

A Python library for parsing, manipulating, and generating Malware Attribute Enumeration and Characterization (MAEC™) v4.1 content.

Source:

https://github.com/MAECProject/python-maec

Documentation:

https://maec.readthedocs.io/

Information:

https://maecproject.github.io/

Download:

https://pypi.python.org/pypi/maec/

Build Status Code Health Version Badge Downloads Badge

Overview

A primary goal of the python-maec library is to remain faithful to both the MAEC standard and to customary Python practices. There are places where these will conflict, and the goal is to make the library intuitive both to those familiar with the XML schemas (but less familiar with Python) and also to experienced Python developers who want to add MAEC support to their programs.

There are currently two levels of APIs for dealing with MAEC content:

  • A low-level API is provided by auto-generated XML Schema - Python class bindings. These bindings were generated using generateDS. With these, any MAEC content can be parsed from or written to XML, but requires a bit more knowledge of the actual MAEC schemas. These “binding classes” are all located in the maec.bindings package.

  • A higher-level API consisting of manually designed Python classes. These “native classes” are intended to behave more like Python programmers would expect. As they are designed manually, they currently do not support the entire MAEC standard, but rather those object types we expect are used most frequently. These “native classes” also support exporting their content as Python dictionaries and lists, which can easily be converted to JSON. Importing from JSON is also supported.

Compatibility

The python-maec library is tested against Python 2.7 and 3.4+.

Versioning

Releases of the python-maec library will be given version numbers of the form major.minor.update.revision, where major, minor, and update correspond to the MAEC version being supported. The revision number is used to indicate new versions of the python-maec library itself.

Installation

The python-maec library can be installed via the distutils setup.py script included at the root directory:

$ python setup.py install

The python-maec library is also hosted on PyPI and can be installed with pip:

$ pip install maec

Dependencies

The maec package depends on the following Python libraries:

  • lxml

  • python-cybox

  • setuptools (only if installing using setup.py)

For Windows installers of the above libraries, we recommend looking here: http://www.lfd.uci.edu/~gohlke/pythonlibs. python-cybox can be found at https://github.com/CybOXProject/python-cybox/releases.

To build lxml on Ubuntu, you will need the following packages from the Ubuntu package repository:

  • python-dev

  • libxml2-dev

  • libxslt1-dev

  • zlib1g-dev

For more information about installing lxml, see http://lxml.de/installation.html.

Feedback

Bug reports and feature requests are welcome and encouraged. Pull requests are especially appreciated. Feel free to use the issue tracker on GitHub, join the MAEC Community Email Discussion List, or send an email directly to maec@mitre.org.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

maec-4.1.0.17.tar.gz (150.8 kB view details)

Uploaded Source

Built Distribution

maec-4.1.0.17-py2.py3-none-any.whl (133.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file maec-4.1.0.17.tar.gz.

File metadata

  • Download URL: maec-4.1.0.17.tar.gz
  • Upload date:
  • Size: 150.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.4.2 requests/2.20.1 setuptools/44.1.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/2.7.18

File hashes

Hashes for maec-4.1.0.17.tar.gz
Algorithm Hash digest
SHA256 d163626a11f27e046c3013d313e5b53ba97f8a9f2f563ac523be55dda6420235
MD5 ac01cee96f981061aa25bb729814fc3a
BLAKE2b-256 b97c858bc5344b35c3555b66abede328f1891d9ab06956e567cff23bc06ba68e

See more details on using hashes here.

File details

Details for the file maec-4.1.0.17-py2.py3-none-any.whl.

File metadata

  • Download URL: maec-4.1.0.17-py2.py3-none-any.whl
  • Upload date:
  • Size: 133.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.4.2 requests/2.20.1 setuptools/44.1.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/2.7.18

File hashes

Hashes for maec-4.1.0.17-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e6566684e606749ff75ef03f7c3454c6fff8f350fa159b4ef17cdd0e5c632ae6
MD5 fe8ad130af5c56c54c3bc42d9dfd74f9
BLAKE2b-256 42cdd22b126b389f2b18da33afdfbf2a60fa917894255b6daadd8e3e3be33159

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page