890 lines
		
	
	
		
			48 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			890 lines
		
	
	
		
			48 KiB
		
	
	
	
		
			Plaintext
		
	
	
| {
 | |
|  "cells": [
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 1,
 | |
|    "metadata": {
 | |
|     "nbsphinx": "hidden"
 | |
|    },
 | |
|    "outputs": [],
 | |
|    "source": [
 | |
|     "# Delete this cell to re-enable tracebacks\n",
 | |
|     "import sys\n",
 | |
|     "ipython = get_ipython()\n",
 | |
|     "\n",
 | |
|     "def hide_traceback(exc_tuple=None, filename=None, tb_offset=None,\n",
 | |
|     "                   exception_only=False, running_compiled_code=False):\n",
 | |
|     "    etype, value, tb = sys.exc_info()\n",
 | |
|     "    return ipython._showtraceback(etype, value, ipython.InteractiveTB.get_exception_only(etype, value))\n",
 | |
|     "\n",
 | |
|     "ipython.showtraceback = hide_traceback"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 2,
 | |
|    "metadata": {
 | |
|     "nbsphinx": "hidden"
 | |
|    },
 | |
|    "outputs": [],
 | |
|    "source": [
 | |
|     "# JSON output syntax highlighting\n",
 | |
|     "from __future__ import print_function\n",
 | |
|     "from pygments import highlight\n",
 | |
|     "from pygments.lexers import JsonLexer\n",
 | |
|     "from pygments.formatters import HtmlFormatter\n",
 | |
|     "from IPython.display import HTML\n",
 | |
|     "\n",
 | |
|     "original_print = print\n",
 | |
|     "\n",
 | |
|     "def json_print(inpt):\n",
 | |
|     "    string = str(inpt)\n",
 | |
|     "    if string[0] == '{':\n",
 | |
|     "        formatter = HtmlFormatter()\n",
 | |
|     "        return HTML('<style type=\"text/css\">{}</style>{}'.format(\n",
 | |
|     "                    formatter.get_style_defs('.highlight'),\n",
 | |
|     "                    highlight(string, JsonLexer(), formatter)))\n",
 | |
|     "    else:\n",
 | |
|     "        original_print(inpt)\n",
 | |
|     "\n",
 | |
|     "print = json_print"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "## Creating STIX Content"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "### Creating STIX Domain Objects\n",
 | |
|     "\n",
 | |
|     "To create a STIX object, provide keyword arguments to the type's constructor:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 3,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "data": {
 | |
|       "text/html": [
 | |
|        "<style type=\"text/css\">.highlight .hll { background-color: #ffffcc }\n",
 | |
|        ".highlight  { background: #f8f8f8; }\n",
 | |
|        ".highlight .c { color: #408080; font-style: italic } /* Comment */\n",
 | |
|        ".highlight .err { border: 1px solid #FF0000 } /* Error */\n",
 | |
|        ".highlight .k { color: #008000; font-weight: bold } /* Keyword */\n",
 | |
|        ".highlight .o { color: #666666 } /* Operator */\n",
 | |
|        ".highlight .ch { color: #408080; font-style: italic } /* Comment.Hashbang */\n",
 | |
|        ".highlight .cm { color: #408080; font-style: italic } /* Comment.Multiline */\n",
 | |
|        ".highlight .cp { color: #BC7A00 } /* Comment.Preproc */\n",
 | |
|        ".highlight .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */\n",
 | |
|        ".highlight .c1 { color: #408080; font-style: italic } /* Comment.Single */\n",
 | |
|        ".highlight .cs { color: #408080; font-style: italic } /* Comment.Special */\n",
 | |
|        ".highlight .gd { color: #A00000 } /* Generic.Deleted */\n",
 | |
|        ".highlight .ge { font-style: italic } /* Generic.Emph */\n",
 | |
|        ".highlight .gr { color: #FF0000 } /* Generic.Error */\n",
 | |
|        ".highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */\n",
 | |
|        ".highlight .gi { color: #00A000 } /* Generic.Inserted */\n",
 | |
|        ".highlight .go { color: #888888 } /* Generic.Output */\n",
 | |
|        ".highlight .gp { color: #000080; font-weight: bold } /* Generic.Prompt */\n",
 | |
|        ".highlight .gs { font-weight: bold } /* Generic.Strong */\n",
 | |
|        ".highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */\n",
 | |
|        ".highlight .gt { color: #0044DD } /* Generic.Traceback */\n",
 | |
|        ".highlight .kc { color: #008000; font-weight: bold } /* Keyword.Constant */\n",
 | |
|        ".highlight .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */\n",
 | |
|        ".highlight .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */\n",
 | |
|        ".highlight .kp { color: #008000 } /* Keyword.Pseudo */\n",
 | |
|        ".highlight .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */\n",
 | |
|        ".highlight .kt { color: #B00040 } /* Keyword.Type */\n",
 | |
|        ".highlight .m { color: #666666 } /* Literal.Number */\n",
 | |
|        ".highlight .s { color: #BA2121 } /* Literal.String */\n",
 | |
|        ".highlight .na { color: #7D9029 } /* Name.Attribute */\n",
 | |
|        ".highlight .nb { color: #008000 } /* Name.Builtin */\n",
 | |
|        ".highlight .nc { color: #0000FF; font-weight: bold } /* Name.Class */\n",
 | |
|        ".highlight .no { color: #880000 } /* Name.Constant */\n",
 | |
|        ".highlight .nd { color: #AA22FF } /* Name.Decorator */\n",
 | |
|        ".highlight .ni { color: #999999; font-weight: bold } /* Name.Entity */\n",
 | |
|        ".highlight .ne { color: #D2413A; font-weight: bold } /* Name.Exception */\n",
 | |
|        ".highlight .nf { color: #0000FF } /* Name.Function */\n",
 | |
|        ".highlight .nl { color: #A0A000 } /* Name.Label */\n",
 | |
|        ".highlight .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */\n",
 | |
|        ".highlight .nt { color: #008000; font-weight: bold } /* Name.Tag */\n",
 | |
|        ".highlight .nv { color: #19177C } /* Name.Variable */\n",
 | |
|        ".highlight .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */\n",
 | |
|        ".highlight .w { color: #bbbbbb } /* Text.Whitespace */\n",
 | |
|        ".highlight .mb { color: #666666 } /* Literal.Number.Bin */\n",
 | |
|        ".highlight .mf { color: #666666 } /* Literal.Number.Float */\n",
 | |
|        ".highlight .mh { color: #666666 } /* Literal.Number.Hex */\n",
 | |
|        ".highlight .mi { color: #666666 } /* Literal.Number.Integer */\n",
 | |
|        ".highlight .mo { color: #666666 } /* Literal.Number.Oct */\n",
 | |
|        ".highlight .sa { color: #BA2121 } /* Literal.String.Affix */\n",
 | |
|        ".highlight .sb { color: #BA2121 } /* Literal.String.Backtick */\n",
 | |
|        ".highlight .sc { color: #BA2121 } /* Literal.String.Char */\n",
 | |
|        ".highlight .dl { color: #BA2121 } /* Literal.String.Delimiter */\n",
 | |
|        ".highlight .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */\n",
 | |
|        ".highlight .s2 { color: #BA2121 } /* Literal.String.Double */\n",
 | |
|        ".highlight .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */\n",
 | |
|        ".highlight .sh { color: #BA2121 } /* Literal.String.Heredoc */\n",
 | |
|        ".highlight .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */\n",
 | |
|        ".highlight .sx { color: #008000 } /* Literal.String.Other */\n",
 | |
|        ".highlight .sr { color: #BB6688 } /* Literal.String.Regex */\n",
 | |
|        ".highlight .s1 { color: #BA2121 } /* Literal.String.Single */\n",
 | |
|        ".highlight .ss { color: #19177C } /* Literal.String.Symbol */\n",
 | |
|        ".highlight .bp { color: #008000 } /* Name.Builtin.Pseudo */\n",
 | |
|        ".highlight .fm { color: #0000FF } /* Name.Function.Magic */\n",
 | |
|        ".highlight .vc { color: #19177C } /* Name.Variable.Class */\n",
 | |
|        ".highlight .vg { color: #19177C } /* Name.Variable.Global */\n",
 | |
|        ".highlight .vi { color: #19177C } /* Name.Variable.Instance */\n",
 | |
|        ".highlight .vm { color: #19177C } /* Name.Variable.Magic */\n",
 | |
|        ".highlight .il { color: #666666 } /* Literal.Number.Integer.Long */</style><div class=\"highlight\"><pre><span></span><span class=\"p\">{</span>\n",
 | |
|        "    <span class=\"nt\">"type"</span><span class=\"p\">:</span> <span class=\"s2\">"indicator"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"id"</span><span class=\"p\">:</span> <span class=\"s2\">"indicator--548af3be-39d7-4a3e-93c2-1a63cccf8951"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"created"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:24.193Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"modified"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:24.193Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"name"</span><span class=\"p\">:</span> <span class=\"s2\">"File hash for malware variant"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"pattern"</span><span class=\"p\">:</span> <span class=\"s2\">"[file:hashes.md5 = 'd41d8cd98f00b204e9800998ecf8427e']"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"valid_from"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:24.193659Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"labels"</span><span class=\"p\">:</span> <span class=\"p\">[</span>\n",
 | |
|        "        <span class=\"s2\">"malicious-activity"</span>\n",
 | |
|        "    <span class=\"p\">]</span>\n",
 | |
|        "<span class=\"p\">}</span>\n",
 | |
|        "</pre></div>\n"
 | |
|       ],
 | |
|       "text/plain": [
 | |
|        "<IPython.core.display.HTML object>"
 | |
|       ]
 | |
|      },
 | |
|      "execution_count": 3,
 | |
|      "metadata": {},
 | |
|      "output_type": "execute_result"
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "from stix2 import Indicator\n",
 | |
|     "\n",
 | |
|     "indicator = Indicator(name=\"File hash for malware variant\",\n",
 | |
|     "                      labels=[\"malicious-activity\"],\n",
 | |
|     "                      pattern=\"[file:hashes.md5 = 'd41d8cd98f00b204e9800998ecf8427e']\")\n",
 | |
|     "print(indicator)"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "Certain required attributes of all objects will be set automatically if not provided as keyword arguments:\n",
 | |
|     "\n",
 | |
|     "-  If not provided, ``type`` will be set automatically to the correct type. You can also provide the type explicitly, but this is not necessary:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 4,
 | |
|    "metadata": {},
 | |
|    "outputs": [],
 | |
|    "source": [
 | |
|     "indicator2 = Indicator(type='indicator',\n",
 | |
|     "                       labels=[\"malicious-activity\"],\n",
 | |
|     "                       pattern=\"[file:hashes.md5 = 'd41d8cd98f00b204e9800998ecf8427e']\")"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "Passing a value for ``type`` that does not match the class being constructed will cause an error:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 5,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "ename": "InvalidValueError",
 | |
|      "evalue": "Invalid value for Indicator 'type': must equal 'indicator'.",
 | |
|      "output_type": "error",
 | |
|      "traceback": [
 | |
|       "\u001b[0;31mInvalidValueError\u001b[0m\u001b[0;31m:\u001b[0m Invalid value for Indicator 'type': must equal 'indicator'.\n"
 | |
|      ]
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "indicator3 = Indicator(type='xxx',\n",
 | |
|     "                       labels=[\"malicious-activity\"],\n",
 | |
|     "                       pattern=\"[file:hashes.md5 = 'd41d8cd98f00b204e9800998ecf8427e']\")"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "-  If not provided, ``id`` will be generated randomly. If you provide an\n",
 | |
|     "   ``id`` argument, it must begin with the correct prefix:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 6,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "ename": "InvalidValueError",
 | |
|      "evalue": "Invalid value for Indicator 'id': must start with 'indicator--'.",
 | |
|      "output_type": "error",
 | |
|      "traceback": [
 | |
|       "\u001b[0;31mInvalidValueError\u001b[0m\u001b[0;31m:\u001b[0m Invalid value for Indicator 'id': must start with 'indicator--'.\n"
 | |
|      ]
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "indicator4 = Indicator(id=\"campaign--63ce9068-b5ab-47fa-a2cf-a602ea01f21a\",\n",
 | |
|     "                       labels=[\"malicious-activity\"],\n",
 | |
|     "                       pattern=\"[file:hashes.md5 = 'd41d8cd98f00b204e9800998ecf8427e']\")"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "For indicators, ``labels`` and ``pattern`` are required and cannot be set automatically. Trying to create an indicator that is missing one of these properties will result in an error:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 7,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "ename": "MissingPropertiesError",
 | |
|      "evalue": "No values for required properties for Indicator: (labels, pattern).",
 | |
|      "output_type": "error",
 | |
|      "traceback": [
 | |
|       "\u001b[0;31mMissingPropertiesError\u001b[0m\u001b[0;31m:\u001b[0m No values for required properties for Indicator: (labels, pattern).\n"
 | |
|      ]
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "indicator = Indicator()"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "However, the required ``valid_from`` attribute on Indicators will be set to the current time if not provided as a keyword argument.\n",
 | |
|     "\n",
 | |
|     "Once created, the object acts like a frozen dictionary. Properties can be accessed using the standard Python dictionary syntax:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 8,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "data": {
 | |
|       "text/plain": [
 | |
|        "'File hash for malware variant'"
 | |
|       ]
 | |
|      },
 | |
|      "execution_count": 8,
 | |
|      "metadata": {},
 | |
|      "output_type": "execute_result"
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "indicator['name']"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "Or access properties using the standard Python attribute syntax:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 9,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "data": {
 | |
|       "text/plain": [
 | |
|        "'File hash for malware variant'"
 | |
|       ]
 | |
|      },
 | |
|      "execution_count": 9,
 | |
|      "metadata": {},
 | |
|      "output_type": "execute_result"
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "indicator.name"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "Attempting to modify any attributes will raise an error:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 10,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "ename": "TypeError",
 | |
|      "evalue": "'Indicator' object does not support item assignment",
 | |
|      "output_type": "error",
 | |
|      "traceback": [
 | |
|       "\u001b[0;31mTypeError\u001b[0m\u001b[0;31m:\u001b[0m 'Indicator' object does not support item assignment\n"
 | |
|      ]
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "indicator['name'] = \"This is a revised name\""
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 11,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "ename": "ImmutableError",
 | |
|      "evalue": "Cannot modify 'name' property in 'Indicator' after creation.",
 | |
|      "output_type": "error",
 | |
|      "traceback": [
 | |
|       "\u001b[0;31mImmutableError\u001b[0m\u001b[0;31m:\u001b[0m Cannot modify 'name' property in 'Indicator' after creation.\n"
 | |
|      ]
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "indicator.name = \"This is a revised name\""
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "To update the properties of an object, see the [Versioning](versioning.ipynb) section."
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "Creating a Malware object follows the same pattern:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 12,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "data": {
 | |
|       "text/html": [
 | |
|        "<style type=\"text/css\">.highlight .hll { background-color: #ffffcc }\n",
 | |
|        ".highlight  { background: #f8f8f8; }\n",
 | |
|        ".highlight .c { color: #408080; font-style: italic } /* Comment */\n",
 | |
|        ".highlight .err { border: 1px solid #FF0000 } /* Error */\n",
 | |
|        ".highlight .k { color: #008000; font-weight: bold } /* Keyword */\n",
 | |
|        ".highlight .o { color: #666666 } /* Operator */\n",
 | |
|        ".highlight .ch { color: #408080; font-style: italic } /* Comment.Hashbang */\n",
 | |
|        ".highlight .cm { color: #408080; font-style: italic } /* Comment.Multiline */\n",
 | |
|        ".highlight .cp { color: #BC7A00 } /* Comment.Preproc */\n",
 | |
|        ".highlight .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */\n",
 | |
|        ".highlight .c1 { color: #408080; font-style: italic } /* Comment.Single */\n",
 | |
|        ".highlight .cs { color: #408080; font-style: italic } /* Comment.Special */\n",
 | |
|        ".highlight .gd { color: #A00000 } /* Generic.Deleted */\n",
 | |
|        ".highlight .ge { font-style: italic } /* Generic.Emph */\n",
 | |
|        ".highlight .gr { color: #FF0000 } /* Generic.Error */\n",
 | |
|        ".highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */\n",
 | |
|        ".highlight .gi { color: #00A000 } /* Generic.Inserted */\n",
 | |
|        ".highlight .go { color: #888888 } /* Generic.Output */\n",
 | |
|        ".highlight .gp { color: #000080; font-weight: bold } /* Generic.Prompt */\n",
 | |
|        ".highlight .gs { font-weight: bold } /* Generic.Strong */\n",
 | |
|        ".highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */\n",
 | |
|        ".highlight .gt { color: #0044DD } /* Generic.Traceback */\n",
 | |
|        ".highlight .kc { color: #008000; font-weight: bold } /* Keyword.Constant */\n",
 | |
|        ".highlight .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */\n",
 | |
|        ".highlight .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */\n",
 | |
|        ".highlight .kp { color: #008000 } /* Keyword.Pseudo */\n",
 | |
|        ".highlight .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */\n",
 | |
|        ".highlight .kt { color: #B00040 } /* Keyword.Type */\n",
 | |
|        ".highlight .m { color: #666666 } /* Literal.Number */\n",
 | |
|        ".highlight .s { color: #BA2121 } /* Literal.String */\n",
 | |
|        ".highlight .na { color: #7D9029 } /* Name.Attribute */\n",
 | |
|        ".highlight .nb { color: #008000 } /* Name.Builtin */\n",
 | |
|        ".highlight .nc { color: #0000FF; font-weight: bold } /* Name.Class */\n",
 | |
|        ".highlight .no { color: #880000 } /* Name.Constant */\n",
 | |
|        ".highlight .nd { color: #AA22FF } /* Name.Decorator */\n",
 | |
|        ".highlight .ni { color: #999999; font-weight: bold } /* Name.Entity */\n",
 | |
|        ".highlight .ne { color: #D2413A; font-weight: bold } /* Name.Exception */\n",
 | |
|        ".highlight .nf { color: #0000FF } /* Name.Function */\n",
 | |
|        ".highlight .nl { color: #A0A000 } /* Name.Label */\n",
 | |
|        ".highlight .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */\n",
 | |
|        ".highlight .nt { color: #008000; font-weight: bold } /* Name.Tag */\n",
 | |
|        ".highlight .nv { color: #19177C } /* Name.Variable */\n",
 | |
|        ".highlight .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */\n",
 | |
|        ".highlight .w { color: #bbbbbb } /* Text.Whitespace */\n",
 | |
|        ".highlight .mb { color: #666666 } /* Literal.Number.Bin */\n",
 | |
|        ".highlight .mf { color: #666666 } /* Literal.Number.Float */\n",
 | |
|        ".highlight .mh { color: #666666 } /* Literal.Number.Hex */\n",
 | |
|        ".highlight .mi { color: #666666 } /* Literal.Number.Integer */\n",
 | |
|        ".highlight .mo { color: #666666 } /* Literal.Number.Oct */\n",
 | |
|        ".highlight .sa { color: #BA2121 } /* Literal.String.Affix */\n",
 | |
|        ".highlight .sb { color: #BA2121 } /* Literal.String.Backtick */\n",
 | |
|        ".highlight .sc { color: #BA2121 } /* Literal.String.Char */\n",
 | |
|        ".highlight .dl { color: #BA2121 } /* Literal.String.Delimiter */\n",
 | |
|        ".highlight .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */\n",
 | |
|        ".highlight .s2 { color: #BA2121 } /* Literal.String.Double */\n",
 | |
|        ".highlight .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */\n",
 | |
|        ".highlight .sh { color: #BA2121 } /* Literal.String.Heredoc */\n",
 | |
|        ".highlight .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */\n",
 | |
|        ".highlight .sx { color: #008000 } /* Literal.String.Other */\n",
 | |
|        ".highlight .sr { color: #BB6688 } /* Literal.String.Regex */\n",
 | |
|        ".highlight .s1 { color: #BA2121 } /* Literal.String.Single */\n",
 | |
|        ".highlight .ss { color: #19177C } /* Literal.String.Symbol */\n",
 | |
|        ".highlight .bp { color: #008000 } /* Name.Builtin.Pseudo */\n",
 | |
|        ".highlight .fm { color: #0000FF } /* Name.Function.Magic */\n",
 | |
|        ".highlight .vc { color: #19177C } /* Name.Variable.Class */\n",
 | |
|        ".highlight .vg { color: #19177C } /* Name.Variable.Global */\n",
 | |
|        ".highlight .vi { color: #19177C } /* Name.Variable.Instance */\n",
 | |
|        ".highlight .vm { color: #19177C } /* Name.Variable.Magic */\n",
 | |
|        ".highlight .il { color: #666666 } /* Literal.Number.Integer.Long */</style><div class=\"highlight\"><pre><span></span><span class=\"p\">{</span>\n",
 | |
|        "    <span class=\"nt\">"type"</span><span class=\"p\">:</span> <span class=\"s2\">"malware"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"id"</span><span class=\"p\">:</span> <span class=\"s2\">"malware--3d7f0c1c-616a-4868-aa7b-150821d2a429"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"created"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:46.584Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"modified"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:46.584Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"name"</span><span class=\"p\">:</span> <span class=\"s2\">"Poison Ivy"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"labels"</span><span class=\"p\">:</span> <span class=\"p\">[</span>\n",
 | |
|        "        <span class=\"s2\">"remote-access-trojan"</span>\n",
 | |
|        "    <span class=\"p\">]</span>\n",
 | |
|        "<span class=\"p\">}</span>\n",
 | |
|        "</pre></div>\n"
 | |
|       ],
 | |
|       "text/plain": [
 | |
|        "<IPython.core.display.HTML object>"
 | |
|       ]
 | |
|      },
 | |
|      "execution_count": 12,
 | |
|      "metadata": {},
 | |
|      "output_type": "execute_result"
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "from stix2 import Malware\n",
 | |
|     "\n",
 | |
|     "malware = Malware(name=\"Poison Ivy\",\n",
 | |
|     "                  labels=['remote-access-trojan'])\n",
 | |
|     "print(malware)"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "As with indicators, the ``type``, ``id``, ``created``, and ``modified`` properties will be set automatically if not provided. For Malware objects, the ``labels`` and ``name`` properties must be provided.\n",
 | |
|     "\n",
 | |
|     "You can see the full list of SDO classes [here](../api/stix2.v20.sdo.rst)."
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "### Creating Relationships\n",
 | |
|     "\n",
 | |
|     "STIX 2 Relationships are separate objects, not properties of the object on either side of the relationship. They are constructed similarly to other STIX objects. The ``type``, ``id``, ``created``, and ``modified`` properties are added automatically if not provided. Callers must provide the ``relationship_type``, ``source_ref``, and ``target_ref`` properties."
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 13,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "data": {
 | |
|       "text/html": [
 | |
|        "<style type=\"text/css\">.highlight .hll { background-color: #ffffcc }\n",
 | |
|        ".highlight  { background: #f8f8f8; }\n",
 | |
|        ".highlight .c { color: #408080; font-style: italic } /* Comment */\n",
 | |
|        ".highlight .err { border: 1px solid #FF0000 } /* Error */\n",
 | |
|        ".highlight .k { color: #008000; font-weight: bold } /* Keyword */\n",
 | |
|        ".highlight .o { color: #666666 } /* Operator */\n",
 | |
|        ".highlight .ch { color: #408080; font-style: italic } /* Comment.Hashbang */\n",
 | |
|        ".highlight .cm { color: #408080; font-style: italic } /* Comment.Multiline */\n",
 | |
|        ".highlight .cp { color: #BC7A00 } /* Comment.Preproc */\n",
 | |
|        ".highlight .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */\n",
 | |
|        ".highlight .c1 { color: #408080; font-style: italic } /* Comment.Single */\n",
 | |
|        ".highlight .cs { color: #408080; font-style: italic } /* Comment.Special */\n",
 | |
|        ".highlight .gd { color: #A00000 } /* Generic.Deleted */\n",
 | |
|        ".highlight .ge { font-style: italic } /* Generic.Emph */\n",
 | |
|        ".highlight .gr { color: #FF0000 } /* Generic.Error */\n",
 | |
|        ".highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */\n",
 | |
|        ".highlight .gi { color: #00A000 } /* Generic.Inserted */\n",
 | |
|        ".highlight .go { color: #888888 } /* Generic.Output */\n",
 | |
|        ".highlight .gp { color: #000080; font-weight: bold } /* Generic.Prompt */\n",
 | |
|        ".highlight .gs { font-weight: bold } /* Generic.Strong */\n",
 | |
|        ".highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */\n",
 | |
|        ".highlight .gt { color: #0044DD } /* Generic.Traceback */\n",
 | |
|        ".highlight .kc { color: #008000; font-weight: bold } /* Keyword.Constant */\n",
 | |
|        ".highlight .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */\n",
 | |
|        ".highlight .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */\n",
 | |
|        ".highlight .kp { color: #008000 } /* Keyword.Pseudo */\n",
 | |
|        ".highlight .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */\n",
 | |
|        ".highlight .kt { color: #B00040 } /* Keyword.Type */\n",
 | |
|        ".highlight .m { color: #666666 } /* Literal.Number */\n",
 | |
|        ".highlight .s { color: #BA2121 } /* Literal.String */\n",
 | |
|        ".highlight .na { color: #7D9029 } /* Name.Attribute */\n",
 | |
|        ".highlight .nb { color: #008000 } /* Name.Builtin */\n",
 | |
|        ".highlight .nc { color: #0000FF; font-weight: bold } /* Name.Class */\n",
 | |
|        ".highlight .no { color: #880000 } /* Name.Constant */\n",
 | |
|        ".highlight .nd { color: #AA22FF } /* Name.Decorator */\n",
 | |
|        ".highlight .ni { color: #999999; font-weight: bold } /* Name.Entity */\n",
 | |
|        ".highlight .ne { color: #D2413A; font-weight: bold } /* Name.Exception */\n",
 | |
|        ".highlight .nf { color: #0000FF } /* Name.Function */\n",
 | |
|        ".highlight .nl { color: #A0A000 } /* Name.Label */\n",
 | |
|        ".highlight .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */\n",
 | |
|        ".highlight .nt { color: #008000; font-weight: bold } /* Name.Tag */\n",
 | |
|        ".highlight .nv { color: #19177C } /* Name.Variable */\n",
 | |
|        ".highlight .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */\n",
 | |
|        ".highlight .w { color: #bbbbbb } /* Text.Whitespace */\n",
 | |
|        ".highlight .mb { color: #666666 } /* Literal.Number.Bin */\n",
 | |
|        ".highlight .mf { color: #666666 } /* Literal.Number.Float */\n",
 | |
|        ".highlight .mh { color: #666666 } /* Literal.Number.Hex */\n",
 | |
|        ".highlight .mi { color: #666666 } /* Literal.Number.Integer */\n",
 | |
|        ".highlight .mo { color: #666666 } /* Literal.Number.Oct */\n",
 | |
|        ".highlight .sa { color: #BA2121 } /* Literal.String.Affix */\n",
 | |
|        ".highlight .sb { color: #BA2121 } /* Literal.String.Backtick */\n",
 | |
|        ".highlight .sc { color: #BA2121 } /* Literal.String.Char */\n",
 | |
|        ".highlight .dl { color: #BA2121 } /* Literal.String.Delimiter */\n",
 | |
|        ".highlight .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */\n",
 | |
|        ".highlight .s2 { color: #BA2121 } /* Literal.String.Double */\n",
 | |
|        ".highlight .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */\n",
 | |
|        ".highlight .sh { color: #BA2121 } /* Literal.String.Heredoc */\n",
 | |
|        ".highlight .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */\n",
 | |
|        ".highlight .sx { color: #008000 } /* Literal.String.Other */\n",
 | |
|        ".highlight .sr { color: #BB6688 } /* Literal.String.Regex */\n",
 | |
|        ".highlight .s1 { color: #BA2121 } /* Literal.String.Single */\n",
 | |
|        ".highlight .ss { color: #19177C } /* Literal.String.Symbol */\n",
 | |
|        ".highlight .bp { color: #008000 } /* Name.Builtin.Pseudo */\n",
 | |
|        ".highlight .fm { color: #0000FF } /* Name.Function.Magic */\n",
 | |
|        ".highlight .vc { color: #19177C } /* Name.Variable.Class */\n",
 | |
|        ".highlight .vg { color: #19177C } /* Name.Variable.Global */\n",
 | |
|        ".highlight .vi { color: #19177C } /* Name.Variable.Instance */\n",
 | |
|        ".highlight .vm { color: #19177C } /* Name.Variable.Magic */\n",
 | |
|        ".highlight .il { color: #666666 } /* Literal.Number.Integer.Long */</style><div class=\"highlight\"><pre><span></span><span class=\"p\">{</span>\n",
 | |
|        "    <span class=\"nt\">"type"</span><span class=\"p\">:</span> <span class=\"s2\">"relationship"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"id"</span><span class=\"p\">:</span> <span class=\"s2\">"relationship--34ddc7b4-4965-4615-b286-1c8bbaa1e7db"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"created"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:49.474Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"modified"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:49.474Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"relationship_type"</span><span class=\"p\">:</span> <span class=\"s2\">"indicates"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"source_ref"</span><span class=\"p\">:</span> <span class=\"s2\">"indicator--548af3be-39d7-4a3e-93c2-1a63cccf8951"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"target_ref"</span><span class=\"p\">:</span> <span class=\"s2\">"malware--3d7f0c1c-616a-4868-aa7b-150821d2a429"</span>\n",
 | |
|        "<span class=\"p\">}</span>\n",
 | |
|        "</pre></div>\n"
 | |
|       ],
 | |
|       "text/plain": [
 | |
|        "<IPython.core.display.HTML object>"
 | |
|       ]
 | |
|      },
 | |
|      "execution_count": 13,
 | |
|      "metadata": {},
 | |
|      "output_type": "execute_result"
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "from stix2 import Relationship\n",
 | |
|     "\n",
 | |
|     "relationship = Relationship(relationship_type='indicates',\n",
 | |
|     "                            source_ref=indicator.id,\n",
 | |
|     "                            target_ref=malware.id)\n",
 | |
|     "print(relationship)"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "The ``source_ref`` and ``target_ref`` properties can be either the ID's of other STIX objects, or the STIX objects themselves. For readability, Relationship objects can also be constructed with the ``source_ref``, ``relationship_type``, and ``target_ref`` as positional (non-keyword) arguments:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 14,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "data": {
 | |
|       "text/html": [
 | |
|        "<style type=\"text/css\">.highlight .hll { background-color: #ffffcc }\n",
 | |
|        ".highlight  { background: #f8f8f8; }\n",
 | |
|        ".highlight .c { color: #408080; font-style: italic } /* Comment */\n",
 | |
|        ".highlight .err { border: 1px solid #FF0000 } /* Error */\n",
 | |
|        ".highlight .k { color: #008000; font-weight: bold } /* Keyword */\n",
 | |
|        ".highlight .o { color: #666666 } /* Operator */\n",
 | |
|        ".highlight .ch { color: #408080; font-style: italic } /* Comment.Hashbang */\n",
 | |
|        ".highlight .cm { color: #408080; font-style: italic } /* Comment.Multiline */\n",
 | |
|        ".highlight .cp { color: #BC7A00 } /* Comment.Preproc */\n",
 | |
|        ".highlight .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */\n",
 | |
|        ".highlight .c1 { color: #408080; font-style: italic } /* Comment.Single */\n",
 | |
|        ".highlight .cs { color: #408080; font-style: italic } /* Comment.Special */\n",
 | |
|        ".highlight .gd { color: #A00000 } /* Generic.Deleted */\n",
 | |
|        ".highlight .ge { font-style: italic } /* Generic.Emph */\n",
 | |
|        ".highlight .gr { color: #FF0000 } /* Generic.Error */\n",
 | |
|        ".highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */\n",
 | |
|        ".highlight .gi { color: #00A000 } /* Generic.Inserted */\n",
 | |
|        ".highlight .go { color: #888888 } /* Generic.Output */\n",
 | |
|        ".highlight .gp { color: #000080; font-weight: bold } /* Generic.Prompt */\n",
 | |
|        ".highlight .gs { font-weight: bold } /* Generic.Strong */\n",
 | |
|        ".highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */\n",
 | |
|        ".highlight .gt { color: #0044DD } /* Generic.Traceback */\n",
 | |
|        ".highlight .kc { color: #008000; font-weight: bold } /* Keyword.Constant */\n",
 | |
|        ".highlight .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */\n",
 | |
|        ".highlight .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */\n",
 | |
|        ".highlight .kp { color: #008000 } /* Keyword.Pseudo */\n",
 | |
|        ".highlight .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */\n",
 | |
|        ".highlight .kt { color: #B00040 } /* Keyword.Type */\n",
 | |
|        ".highlight .m { color: #666666 } /* Literal.Number */\n",
 | |
|        ".highlight .s { color: #BA2121 } /* Literal.String */\n",
 | |
|        ".highlight .na { color: #7D9029 } /* Name.Attribute */\n",
 | |
|        ".highlight .nb { color: #008000 } /* Name.Builtin */\n",
 | |
|        ".highlight .nc { color: #0000FF; font-weight: bold } /* Name.Class */\n",
 | |
|        ".highlight .no { color: #880000 } /* Name.Constant */\n",
 | |
|        ".highlight .nd { color: #AA22FF } /* Name.Decorator */\n",
 | |
|        ".highlight .ni { color: #999999; font-weight: bold } /* Name.Entity */\n",
 | |
|        ".highlight .ne { color: #D2413A; font-weight: bold } /* Name.Exception */\n",
 | |
|        ".highlight .nf { color: #0000FF } /* Name.Function */\n",
 | |
|        ".highlight .nl { color: #A0A000 } /* Name.Label */\n",
 | |
|        ".highlight .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */\n",
 | |
|        ".highlight .nt { color: #008000; font-weight: bold } /* Name.Tag */\n",
 | |
|        ".highlight .nv { color: #19177C } /* Name.Variable */\n",
 | |
|        ".highlight .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */\n",
 | |
|        ".highlight .w { color: #bbbbbb } /* Text.Whitespace */\n",
 | |
|        ".highlight .mb { color: #666666 } /* Literal.Number.Bin */\n",
 | |
|        ".highlight .mf { color: #666666 } /* Literal.Number.Float */\n",
 | |
|        ".highlight .mh { color: #666666 } /* Literal.Number.Hex */\n",
 | |
|        ".highlight .mi { color: #666666 } /* Literal.Number.Integer */\n",
 | |
|        ".highlight .mo { color: #666666 } /* Literal.Number.Oct */\n",
 | |
|        ".highlight .sa { color: #BA2121 } /* Literal.String.Affix */\n",
 | |
|        ".highlight .sb { color: #BA2121 } /* Literal.String.Backtick */\n",
 | |
|        ".highlight .sc { color: #BA2121 } /* Literal.String.Char */\n",
 | |
|        ".highlight .dl { color: #BA2121 } /* Literal.String.Delimiter */\n",
 | |
|        ".highlight .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */\n",
 | |
|        ".highlight .s2 { color: #BA2121 } /* Literal.String.Double */\n",
 | |
|        ".highlight .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */\n",
 | |
|        ".highlight .sh { color: #BA2121 } /* Literal.String.Heredoc */\n",
 | |
|        ".highlight .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */\n",
 | |
|        ".highlight .sx { color: #008000 } /* Literal.String.Other */\n",
 | |
|        ".highlight .sr { color: #BB6688 } /* Literal.String.Regex */\n",
 | |
|        ".highlight .s1 { color: #BA2121 } /* Literal.String.Single */\n",
 | |
|        ".highlight .ss { color: #19177C } /* Literal.String.Symbol */\n",
 | |
|        ".highlight .bp { color: #008000 } /* Name.Builtin.Pseudo */\n",
 | |
|        ".highlight .fm { color: #0000FF } /* Name.Function.Magic */\n",
 | |
|        ".highlight .vc { color: #19177C } /* Name.Variable.Class */\n",
 | |
|        ".highlight .vg { color: #19177C } /* Name.Variable.Global */\n",
 | |
|        ".highlight .vi { color: #19177C } /* Name.Variable.Instance */\n",
 | |
|        ".highlight .vm { color: #19177C } /* Name.Variable.Magic */\n",
 | |
|        ".highlight .il { color: #666666 } /* Literal.Number.Integer.Long */</style><div class=\"highlight\"><pre><span></span><span class=\"p\">{</span>\n",
 | |
|        "    <span class=\"nt\">"type"</span><span class=\"p\">:</span> <span class=\"s2\">"relationship"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"id"</span><span class=\"p\">:</span> <span class=\"s2\">"relationship--0a646403-f7e7-4cfd-b945-cab5cde05857"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"created"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:51.417Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"modified"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:51.417Z"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"relationship_type"</span><span class=\"p\">:</span> <span class=\"s2\">"indicates"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"source_ref"</span><span class=\"p\">:</span> <span class=\"s2\">"indicator--548af3be-39d7-4a3e-93c2-1a63cccf8951"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"target_ref"</span><span class=\"p\">:</span> <span class=\"s2\">"malware--3d7f0c1c-616a-4868-aa7b-150821d2a429"</span>\n",
 | |
|        "<span class=\"p\">}</span>\n",
 | |
|        "</pre></div>\n"
 | |
|       ],
 | |
|       "text/plain": [
 | |
|        "<IPython.core.display.HTML object>"
 | |
|       ]
 | |
|      },
 | |
|      "execution_count": 14,
 | |
|      "metadata": {},
 | |
|      "output_type": "execute_result"
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "relationship2 = Relationship(indicator, 'indicates', malware)\n",
 | |
|     "print(relationship2)"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "markdown",
 | |
|    "metadata": {},
 | |
|    "source": [
 | |
|     "### Creating Bundles\n",
 | |
|     "\n",
 | |
|     "STIX Bundles can be created by passing objects as arguments to the Bundle constructor. All required properties (``type``, ``id``, and ``spec_version``) will be set automatically if not provided, or can be provided as keyword arguments:"
 | |
|    ]
 | |
|   },
 | |
|   {
 | |
|    "cell_type": "code",
 | |
|    "execution_count": 15,
 | |
|    "metadata": {},
 | |
|    "outputs": [
 | |
|     {
 | |
|      "data": {
 | |
|       "text/html": [
 | |
|        "<style type=\"text/css\">.highlight .hll { background-color: #ffffcc }\n",
 | |
|        ".highlight  { background: #f8f8f8; }\n",
 | |
|        ".highlight .c { color: #408080; font-style: italic } /* Comment */\n",
 | |
|        ".highlight .err { border: 1px solid #FF0000 } /* Error */\n",
 | |
|        ".highlight .k { color: #008000; font-weight: bold } /* Keyword */\n",
 | |
|        ".highlight .o { color: #666666 } /* Operator */\n",
 | |
|        ".highlight .ch { color: #408080; font-style: italic } /* Comment.Hashbang */\n",
 | |
|        ".highlight .cm { color: #408080; font-style: italic } /* Comment.Multiline */\n",
 | |
|        ".highlight .cp { color: #BC7A00 } /* Comment.Preproc */\n",
 | |
|        ".highlight .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */\n",
 | |
|        ".highlight .c1 { color: #408080; font-style: italic } /* Comment.Single */\n",
 | |
|        ".highlight .cs { color: #408080; font-style: italic } /* Comment.Special */\n",
 | |
|        ".highlight .gd { color: #A00000 } /* Generic.Deleted */\n",
 | |
|        ".highlight .ge { font-style: italic } /* Generic.Emph */\n",
 | |
|        ".highlight .gr { color: #FF0000 } /* Generic.Error */\n",
 | |
|        ".highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */\n",
 | |
|        ".highlight .gi { color: #00A000 } /* Generic.Inserted */\n",
 | |
|        ".highlight .go { color: #888888 } /* Generic.Output */\n",
 | |
|        ".highlight .gp { color: #000080; font-weight: bold } /* Generic.Prompt */\n",
 | |
|        ".highlight .gs { font-weight: bold } /* Generic.Strong */\n",
 | |
|        ".highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */\n",
 | |
|        ".highlight .gt { color: #0044DD } /* Generic.Traceback */\n",
 | |
|        ".highlight .kc { color: #008000; font-weight: bold } /* Keyword.Constant */\n",
 | |
|        ".highlight .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */\n",
 | |
|        ".highlight .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */\n",
 | |
|        ".highlight .kp { color: #008000 } /* Keyword.Pseudo */\n",
 | |
|        ".highlight .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */\n",
 | |
|        ".highlight .kt { color: #B00040 } /* Keyword.Type */\n",
 | |
|        ".highlight .m { color: #666666 } /* Literal.Number */\n",
 | |
|        ".highlight .s { color: #BA2121 } /* Literal.String */\n",
 | |
|        ".highlight .na { color: #7D9029 } /* Name.Attribute */\n",
 | |
|        ".highlight .nb { color: #008000 } /* Name.Builtin */\n",
 | |
|        ".highlight .nc { color: #0000FF; font-weight: bold } /* Name.Class */\n",
 | |
|        ".highlight .no { color: #880000 } /* Name.Constant */\n",
 | |
|        ".highlight .nd { color: #AA22FF } /* Name.Decorator */\n",
 | |
|        ".highlight .ni { color: #999999; font-weight: bold } /* Name.Entity */\n",
 | |
|        ".highlight .ne { color: #D2413A; font-weight: bold } /* Name.Exception */\n",
 | |
|        ".highlight .nf { color: #0000FF } /* Name.Function */\n",
 | |
|        ".highlight .nl { color: #A0A000 } /* Name.Label */\n",
 | |
|        ".highlight .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */\n",
 | |
|        ".highlight .nt { color: #008000; font-weight: bold } /* Name.Tag */\n",
 | |
|        ".highlight .nv { color: #19177C } /* Name.Variable */\n",
 | |
|        ".highlight .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */\n",
 | |
|        ".highlight .w { color: #bbbbbb } /* Text.Whitespace */\n",
 | |
|        ".highlight .mb { color: #666666 } /* Literal.Number.Bin */\n",
 | |
|        ".highlight .mf { color: #666666 } /* Literal.Number.Float */\n",
 | |
|        ".highlight .mh { color: #666666 } /* Literal.Number.Hex */\n",
 | |
|        ".highlight .mi { color: #666666 } /* Literal.Number.Integer */\n",
 | |
|        ".highlight .mo { color: #666666 } /* Literal.Number.Oct */\n",
 | |
|        ".highlight .sa { color: #BA2121 } /* Literal.String.Affix */\n",
 | |
|        ".highlight .sb { color: #BA2121 } /* Literal.String.Backtick */\n",
 | |
|        ".highlight .sc { color: #BA2121 } /* Literal.String.Char */\n",
 | |
|        ".highlight .dl { color: #BA2121 } /* Literal.String.Delimiter */\n",
 | |
|        ".highlight .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */\n",
 | |
|        ".highlight .s2 { color: #BA2121 } /* Literal.String.Double */\n",
 | |
|        ".highlight .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */\n",
 | |
|        ".highlight .sh { color: #BA2121 } /* Literal.String.Heredoc */\n",
 | |
|        ".highlight .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */\n",
 | |
|        ".highlight .sx { color: #008000 } /* Literal.String.Other */\n",
 | |
|        ".highlight .sr { color: #BB6688 } /* Literal.String.Regex */\n",
 | |
|        ".highlight .s1 { color: #BA2121 } /* Literal.String.Single */\n",
 | |
|        ".highlight .ss { color: #19177C } /* Literal.String.Symbol */\n",
 | |
|        ".highlight .bp { color: #008000 } /* Name.Builtin.Pseudo */\n",
 | |
|        ".highlight .fm { color: #0000FF } /* Name.Function.Magic */\n",
 | |
|        ".highlight .vc { color: #19177C } /* Name.Variable.Class */\n",
 | |
|        ".highlight .vg { color: #19177C } /* Name.Variable.Global */\n",
 | |
|        ".highlight .vi { color: #19177C } /* Name.Variable.Instance */\n",
 | |
|        ".highlight .vm { color: #19177C } /* Name.Variable.Magic */\n",
 | |
|        ".highlight .il { color: #666666 } /* Literal.Number.Integer.Long */</style><div class=\"highlight\"><pre><span></span><span class=\"p\">{</span>\n",
 | |
|        "    <span class=\"nt\">"type"</span><span class=\"p\">:</span> <span class=\"s2\">"bundle"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"id"</span><span class=\"p\">:</span> <span class=\"s2\">"bundle--f83477e5-f853-47e1-a267-43f3aa1bd5b0"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"spec_version"</span><span class=\"p\">:</span> <span class=\"s2\">"2.0"</span><span class=\"p\">,</span>\n",
 | |
|        "    <span class=\"nt\">"objects"</span><span class=\"p\">:</span> <span class=\"p\">[</span>\n",
 | |
|        "        <span class=\"p\">{</span>\n",
 | |
|        "            <span class=\"nt\">"type"</span><span class=\"p\">:</span> <span class=\"s2\">"indicator"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"id"</span><span class=\"p\">:</span> <span class=\"s2\">"indicator--548af3be-39d7-4a3e-93c2-1a63cccf8951"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"created"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:24.193Z"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"modified"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:24.193Z"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"name"</span><span class=\"p\">:</span> <span class=\"s2\">"File hash for malware variant"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"pattern"</span><span class=\"p\">:</span> <span class=\"s2\">"[file:hashes.md5 = 'd41d8cd98f00b204e9800998ecf8427e']"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"valid_from"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:24.193659Z"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"labels"</span><span class=\"p\">:</span> <span class=\"p\">[</span>\n",
 | |
|        "                <span class=\"s2\">"malicious-activity"</span>\n",
 | |
|        "            <span class=\"p\">]</span>\n",
 | |
|        "        <span class=\"p\">},</span>\n",
 | |
|        "        <span class=\"p\">{</span>\n",
 | |
|        "            <span class=\"nt\">"type"</span><span class=\"p\">:</span> <span class=\"s2\">"malware"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"id"</span><span class=\"p\">:</span> <span class=\"s2\">"malware--3d7f0c1c-616a-4868-aa7b-150821d2a429"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"created"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:46.584Z"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"modified"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:46.584Z"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"name"</span><span class=\"p\">:</span> <span class=\"s2\">"Poison Ivy"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"labels"</span><span class=\"p\">:</span> <span class=\"p\">[</span>\n",
 | |
|        "                <span class=\"s2\">"remote-access-trojan"</span>\n",
 | |
|        "            <span class=\"p\">]</span>\n",
 | |
|        "        <span class=\"p\">},</span>\n",
 | |
|        "        <span class=\"p\">{</span>\n",
 | |
|        "            <span class=\"nt\">"type"</span><span class=\"p\">:</span> <span class=\"s2\">"relationship"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"id"</span><span class=\"p\">:</span> <span class=\"s2\">"relationship--34ddc7b4-4965-4615-b286-1c8bbaa1e7db"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"created"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:49.474Z"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"modified"</span><span class=\"p\">:</span> <span class=\"s2\">"2018-04-05T18:32:49.474Z"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"relationship_type"</span><span class=\"p\">:</span> <span class=\"s2\">"indicates"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"source_ref"</span><span class=\"p\">:</span> <span class=\"s2\">"indicator--548af3be-39d7-4a3e-93c2-1a63cccf8951"</span><span class=\"p\">,</span>\n",
 | |
|        "            <span class=\"nt\">"target_ref"</span><span class=\"p\">:</span> <span class=\"s2\">"malware--3d7f0c1c-616a-4868-aa7b-150821d2a429"</span>\n",
 | |
|        "        <span class=\"p\">}</span>\n",
 | |
|        "    <span class=\"p\">]</span>\n",
 | |
|        "<span class=\"p\">}</span>\n",
 | |
|        "</pre></div>\n"
 | |
|       ],
 | |
|       "text/plain": [
 | |
|        "<IPython.core.display.HTML object>"
 | |
|       ]
 | |
|      },
 | |
|      "execution_count": 15,
 | |
|      "metadata": {},
 | |
|      "output_type": "execute_result"
 | |
|     }
 | |
|    ],
 | |
|    "source": [
 | |
|     "from stix2 import Bundle\n",
 | |
|     "\n",
 | |
|     "bundle = Bundle(indicator, malware, relationship)\n",
 | |
|     "print(bundle)"
 | |
|    ]
 | |
|   }
 | |
|  ],
 | |
|  "metadata": {
 | |
|   "kernelspec": {
 | |
|    "display_name": "Python 3",
 | |
|    "language": "python",
 | |
|    "name": "python3"
 | |
|   },
 | |
|   "language_info": {
 | |
|    "codemirror_mode": {
 | |
|     "name": "ipython",
 | |
|     "version": 3
 | |
|    },
 | |
|    "file_extension": ".py",
 | |
|    "mimetype": "text/x-python",
 | |
|    "name": "python",
 | |
|    "nbconvert_exporter": "python",
 | |
|    "pygments_lexer": "ipython3",
 | |
|    "version": "3.6.5"
 | |
|   }
 | |
|  },
 | |
|  "nbformat": 4,
 | |
|  "nbformat_minor": 2
 | |
| }
 |