<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE rfc SYSTEM "rfc2629.dtd">
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" category="std" docName="draft-lehmann-idmefv2-02" ipr="trust200902" consensus="true" obsoletes="4765">
  <front>
    <title abbrev="IDMEFv2">The Incident Detection Message Exchange Format version 2 (IDMEFv2)</title>
    <author fullname="Gilles Lehmann">
      <organization>Telecom SudParis</organization>
      <address>
        <postal>
          <country>FR</country>
        </postal>
        <email>gilles.lehmann@telecom-sudparis.eu</email>
      </address>
    </author>
    <date day="11" month="October" year="2023"/>
    <keyword>RFC4765</keyword>
    <keyword>RFC4766</keyword>
    <keyword>IDMEF</keyword>
    <abstract>
      <t>The Incident Detection Message Exchange Format version 2 (IDMEFv2) defines a
        date representation for security incidents detected on cyber and/or physical
        infrastructures.</t>
      <t>The format is agnostic so it can be used in standalone or combined cyber
        (SIEM), physical (PSIM) and availability (NMS) monitoring systems. IDMEFv2 can
        also be used to represent man made or natural hazards threats.</t>
      <t>IDMEFv2 improves situational awareness by facilitating correlation of multiple types
        of events using the same base format thus enabling efficient detection of complex
        and combined cyber and physical attacks and incidents.</t>
      <t>If approved this draft will obsolete RFC4765.</t>
    </abstract>
  </front>
  <middle>
    <section>
      <name>Introduction</name>
      <t>The Incident Detection Message Exchange Format (IDMEF) is intended to solve
            the problem of security monitoring compartmentalization by proposing a single format to represent
            any type of incident, whether cyber or physical, intentional or accidental, natural or man-made.</t>
      <t>Indeed security is often associated  to the Confidentiality-Integrity-Availability triad,
            performance and availability management systems are still run independently
            from security management systems.</t>
      <t>Additionally, with the adoption and integration of Internet of Things (IoT)
            and Industrial Internet of Things (IIoT) devices, and the exponential emergence
            of smart systems (transport, cities, buildings, etc), an increasingly interconnected mesh of cyber-physical systems (CPS) has emerged.
            This expansion of the attack and incident surfaces blurs the once-clear functions of cybersecurity and physical security.</t>
      <t>Finally, as IT infrastructure moves out of data centers it  becomes more exposed to
            external threats, including natural and man-made hazards,</t>
      <t>Incident detection systems have traditionally focused on detecting cyber incidents or physical incident or availability  incidents.
            There is an increasing need nowadays to have a unified view and management of all those incidents and their interconnection.</t>
      <t>To achieve this goal the Incident Detection Message Exchange Format offers a unique data representation for
            multiple types of events:</t>
      <ul>
            <li>
                <t>Cyber-security events (e.g. authentication failure/success, virus/malware
                    detection, bruteforce/scan detection, etc.)</t>
            </li>
            <li>
                <t>Physical security events (e.g. intrusion detection, object detection,
                    face or activity recognition, fire/smoke/noise/rain detection, etc.)</t>
            </li>
            <li>
                <t>Availability/observability/performance events (e.g. system failure, service malfunction,
                    performance decrease, etc.)</t>
            </li>
            <li>
                <t>Natural and man made hazards events (e.g. wildfires, avalanches, droughts, earthquakes,
                    pollution, fire, explosion, etc.)</t>
            </li>
        </ul>
      <section>
        <name>IDMEFv2 deployment architecture</name>
        <t>IDMEFv2 can be used to exchange incident detection information between specialized managers
                (SIEM, PSIM, NMS) and a universal "Cyber &amp; Physical SIEM" (CPSIEM) or directly from specialized analyzers and
                a CPSIEM.</t>
        <figure anchor="global_view">
          <name>IDMEF Use Architecture</name>
          <artwork type="ascii-art" align="center">                   +-----------------------------+    +---------+
                   |    "Universal" CPSIEM       |&lt;---| Hazards |
                   +-----------------------------+    +---------+
                       |          |         |
                    +------+   +-----+   +------+
    Managers        | PSIM |   | NMS |   | SIEM |
                    +------+   +-----+   +------+
                       |          |         |
                   +--------+ +----------+ +-----+
Analyzers/Sensors  |Physical| |Monitoring| |Cyber|
                   +--------+ +----------+ +-----+
                       |           |          |
                  +-------------------------------+
                  |    Cyber &amp; Physical System    |
                  +-------------------------------+</artwork>
        </figure>
        <t>Thanks to its universality IDMEFv2 improves situational awareness by enabling correlation of multiple types
                of events using the same base format.</t>
        <t>This document defines a model serialization methodes for the purpose of describing and sharing these events.</t>
      </section>
      <section>
        <name>IDMEFv1 (Intrusion Detection Message Exchange Format) -  RFC 4765 - Legacy</name>
        <t>IDMEFv2 (Incident Detection Message Exchange Format) is based on IDMEFv1 (Intrusion Detection Message Exchange Format) concepts. But IDMEFv1 was cyber intrusion focused as IDMFv2 perimeter is much larger. Thus retro-compatibility although partly possible has not been a priority.</t>
      </section>
      <section>
        <name>Relationship between IDMEFv2 and other event/incident formats</name>
        <t>IDMEFv2 focuses essentialy on high level event/incident correlation and detection.There are
                many standard and proprietary formats on the incident detection market and in particular on the cybersecurity market.
                IDMEFv2 is complementary to most of these formats.</t>
        <t>IDMEFv1 (Intrusion Detection Message Exchange Format - RFC 4765) : IDMEFv2 (Incident Detection) replaces and obsoletes IDMEFv1
                (Intrusion Detection) by covering a wider spectrum.</t>
        <t>IODEFv2 (Incident Object Definition Exchange Format - RFC 5070) : IDMEFv2 helps detect incident. When an incident is detected it will
                be analysed and eventually fully described and shared with other security teams through IODEFv2.
                IODEFv2. IDMEF is used upstream IODEFv2. IDMEfv2 ALerts can be “attached” to IODEFv2 object
                to provide technical details about incidents.</t>
        <t>Syslog (System Logging) : Syslog is a loosy format with no formal structuration. Syslog can
                be used by sensors to send information to analyzers. Out of those multi-format
                syslogs the analyzer might detect an incident or an event of interest. The analyzer
                will then use IDMEFv2 to notify the manager which might correlate this information
                with other datas to confirm the incident.</t>
        <t>SNMP (Simple Network Management Protocol) : SNMP polls information from devices which is then compared to thresholds
                to detect incident. IDMEFv2 can be used when incident is detected downstream of
                SNMP to communicate the incident to the manager. IDMEFv2 can have a similar role as SNMP Traps.</t>
        <t>STIX (Structured Threat Information Expression) : is a language and serialization format used to exchange cyber threat intelligence (CTI).
                IDMEFv2 can help detect incidents which might lead to the creation and sharing of STIX information.
                Cyber analyzer  can also rely on STIX information to detect incidents that will be notified in IDMEFv2 format.</t>
        <t>SIEM proprietory formats (CEF, LEEF, ECS, CIM, ...) : By covering cyber, physical and
                monitoring incidents type, IDMEFv2 offers a wider spectrum than those formats.
                Gateways between IDMEFv2 and those formats can be developped to connect legacy
                cyber detection systems to an IDMEFv2 architecture.</t>
      </section>
    </section>
    <section>
      <name>Terminology</name>
      <section>
        <name>Keywords</name>
        <t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
                "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
                document are to be interpreted as described in <xref target="RFC2119"/>.</t>
      </section>
      <section>
        <name>Normative sections</name>
        <t>Implementations of IDMEFv2 are REQUIRED to fully implement:</t>
        <ul>
                <li>
                    <t>The data types defined in <xref target="data-types"/></t>
                </li>
                <li>
                    <t>The data model defined in <xref target="model"/></t>
                </li>
                <li>
                    <t>The JavaScript Object Notation (JSON) serialization method <xref target="json-sm"/>.</t>
                </li>
            </ul>
      </section>
      <section>
        <name>Concepts related to event processing</name>
        <section>
          <name>Event</name>
          <t>An event is something that triggered a notice. Any incident starts off as an event
                    or a combination of events, but not all events result in an incident.
                    An event need not be an indication of wrongdoing. E.g. someone successfully logging in
                    or entering a building is an event.</t>
        </section>
        <section>
          <name>Incident</name>
          <t>An incident is an event that compromises or has a significant probability of compromising
                    at least one of the organization's security criteria such as Confidentiality, Integrity
                    or Availability.
                    An incident may affect a production tool, personnel, etc.
                    It may be logical, physical or organizational in nature.
                    Last but not least, an incident may be caused on purpose or by accident.</t>
        </section>
        <section>
          <name>Alert</name>
          <t>An alert is a notification/message that a particular event/incident (or series of events/incidents)
                    has occurred.</t>
        </section>
        <section>
          <name>Manager</name>
          <t>The manager is the central console toward which all analyzers send their alerts.
                    The manager collects, correlates, stores and display the alerts to the operators.</t>
          <t>Example :
                    - A SIEM (Security Information &amp; Event Management) or a Log Manager)
                    - A PSIM (Physical Security Information Management)
                    - A NMS (Network Management System)
                    - A CPSIEM (Cyber &amp; Physical Security Information Management System)</t>
        </section>
        <section>
          <name>Operator</name>
          <t>The level 1 operator is in charge of receiving manager notifications and identify or confirm when an event should be considered as an incident. The operator must also decide if there is a know resolution for this incident or if it needs a deeper analysys.</t>
        </section>
        <section>
          <name>Analyst</name>
          <t>The analyst will be contacted by the operator to analyze complex incidents that can’t be easily resolved. The investigation starts with the IDMEFv2 information but the analyst might need more information like raw logs for a deeper forensics.</t>
        </section>
        <section>
          <name>Attack</name>
          <t>An attack is an attempt to destroy, expose, alter, disable, steal or gain unauthorized access
                    to or make unauthorized use of a cyber or physical asset. An attack is one or many kinds of
                    incidents.</t>
        </section>
        <section>
          <name>Correlation</name>
          <t>Correlation is the identification of relationships between two or more events.</t>
        </section>
        <section>
          <name>Aggregation</name>
          <t>Aggregation is the consolidation of similar events into a single event.</t>
        </section>
      </section>
    </section>
    <section anchor="data-types">
      <name>The IDMEF Data Types</name>
      <t>Each object inside the IDMEF data model has an associated data type.
            This type may be used to validate the content of incoming IDMEF messages.</t>
      <section>
        <name>Classes</name>
        <t>The classes are meant to group related attributes together.
                Some of the classes may be instanciated multiple times (e.g. Source, Target, etc.)
                while others may only appear once in an IDMEF message (e.g. Analyzer).</t>
      </section>
      <section>
        <name>Numbers</name>
        <section anchor="data-types-integers">
          <name>Integers</name>
          <t>Integers inside the IDMEF data model are expressed using the following ABNF <xref target="RFC5234"/>
                    grammar:</t>
          <sourcecode type="none">integer         =  *1minus int
int             =  zero / ( digit1-9 *DIGIT )
minus           =  %x2D                           ; -
zero            =  %0x30                          ; 0
digit1-9        =  %x31-39                        ; 1-9</sourcecode>
          <t>E.g. 123.</t>
          <t>Such values are indicated with the "INT" type annotation in the model.</t>
        </section>
        <section>
          <name>Floating-point values</name>
          <t>Floating-point values inside the IDMEF data model are expressed using
                    the following ABNF grammar:</t>
          <sourcecode type="none">float           =  integer *1frac
frac            =  decimal-point 1*DIGIT
decimal-point   =  %x2E                            ; .</sourcecode>
          <t>This grammar reuses some of the production rules listed in <xref target="data-types-integers"/>.</t>
          <t>E.g. 12.34.</t>
          <t>Such values are indicated with the "FLOAT" type annotation in the model.</t>
        </section>
      </section>
      <section>
        <name>Strings</name>
        <t>Strings are series of characters from the <xref target="UNICODE"/> standard
                and are used to represent a text.</t>
        <t>For readability, this document uses quotes (") to delimit strings, but please note
                that these quotes are not syntactically part of the actual strings.</t>
        <t>E.g. "Hello world".</t>
        <t>Some of the strings used in the IDMEFv2 data model follow a stricter syntax.
                These are included below for completeness.</t>
        <t>Such values are indicated with the "STRING" type annotation in the model.</t>
        <section anchor="data-types-enums">
          <name>Enumerations</name>
          <t>Enumerations are special strings used when valid values for an IDMEF attribute
                    are restricted to those present in a predefined list.</t>
          <t>Such values are indicated with the "ENUM" type annotation in the model.</t>
        </section>
        <section>
          <name>Timestamps</name>
          <t>Timestamps are used to indicate a specific moment in time.
                    The timestamps used in the IDMEF data model follow the syntax defined by the
                    "date-time" production rule of the grammar in <xref target="RFC3339"/> ch 5.6.</t>
          <t>E.g. "1985-04-12T23:59:59.52Z" represents a moment just before April 5th, 1985
                    in Coordinated Universal Time (UTC).</t>
          <t>Such values are indicated with the "TIMESTAMP" type annotation in the model.</t>
        </section>
        <section>
          <name>Geographical Locations</name>
          <t>Some attributes inside the IDMEF data model may refer to geographical locations
                    using a set of coordinates. The reference system for all geographical coordinates
                    is a geographic coordinate reference system, using the World Geodetic System 1984
                    <xref target="WGS84"/>. The reference system used is the same as for the Global Positioning
                    System (GPS).</t>
          <t>The format for such values can be either "latitude,longitude" or "latitude,longitude,altitude".
                    Each of these coordinates is represented as a floating-point value. The latitude and longitude
                    are expressed in degrees while the altitude is expressed in meters.</t>
          <t>E.g. "48.8584,2.2945,276.13" matches the (3-dimensional) geographical location
                    for the top floor or the Eiffel Tower located in Paris, France, while "48.8584,2.2945"
                    matches the same location in two dimensions (with the altitude removed).</t>
          <t>Such values are indicated with the "GEOLOC" type annotation in the model.</t>
        </section>
        <section>
          <name>UNECE Location Codes (UN/LOCODE)</name>
          <t>Some attributes inside the IDMEF data model may refer to geographical locations
                    using Locations Codes. These codes can be assimilated to an enumeration, where the
                    list of possible values is defined in the United Nations Economic Commission
                    for Europe (UNECE) Codes for Trade <xref target="UN-LOCODE"/>.</t>
          <t>E.g. "FR PAR" is the Location Code for the city of Paris, France.</t>
          <t>Such values are indicated with the "UNLOCODE" type annotation in the model.</t>
        </section>
        <section>
          <name>Uniform Resource Identifiers (URIs)</name>
          <t>The IDMEF data model uses Uniform Resource Identifiers (URIs), as defined in
                    <xref target="RFC3986"/>, when referring to external resources.
                    Unless otherwise specified, either a Uniform Resource Location (URL) or
                    a Uniform Resource Name (URN) may be used where a URI is expected.</t>
          <t>E.g. both "https://example.com/resource" and "urn:myapp:resource" are valid
                    Uniform Resource Identifiers.</t>
          <t>Such values are indicated with the "URI" type annotation in the model.</t>
        </section>
        <section>
          <name>IP Addresses</name>
          <t>IP addresses inside the IDMEF data model are expressed as strings using the
                    traditionnal dotted-decimal notation for IPv4 addresses (defined by the
                    "dotnum" production rule in the grammar in <xref target="RFC5321"/>),
                    while IPv6 addresses are expressed using the text representation defined in
                    <xref target="RFC4291"/> ch 2.2.</t>
          <t>E.g. "192.0.2.1" represents a valid IPv4 address, while "::1/128" represents
                    a valid IPv6 address.</t>
          <t>It is RECOMMENDED that implementations follow the recommendations for IPv6
                    text representation stated in <xref target="RFC5952"/>.</t>
          <t>Such values are indicated with the "IP" type annotation in the model.</t>
        </section>
        <section>
          <name>E-mail addresses</name>
          <t>E-mail addresses inside the IDMEF data model are expressed as strings
                    using the address specification syntax defined in <xref target="RFC5322"/> ch 3.4.1.</t>
          <t>E.g. "root@example.com".</t>
          <t>Such values are indicated with the "EMAIL" type annotation in the model.</t>
        </section>
        <section>
          <name>Attachment names</name>
          <t>Attachments inside the IDMEF data model are identified using
                    a unique name, composed of a string whose character set is limited to the ASCII
                    letters (A-Z a-z) and digits (0-9).</t>
          <t>E.g. "state" is a valid name for an attachment.</t>
          <t>The constraint on name unicity is enforced per class. That is,
                    but it is not
                    possible for two attachments to share the same name inside the same alert.</t>
          <t>Such values are indicated with the "ID" type annotation in the model.</t>
        </section>
        <section>
          <name>Media types</name>
          <t>Media types are used in the IDMEF data model to describe an attachment's content.
                    The syntax for such values is defined in <xref target="RFC2046"/>.</t>
          <t>IANA keeps a list of all currently registered media types in the Media Types
                    registry .</t>
          <t>E.g. "application/xml" or "text/plain; charset=utf-8".</t>
          <t>Such values are indicated with the "MEDIATYPE" type annotation in the model.</t>
        </section>
        <section>
          <name>Universally Unique IDentifiers (UUIDs)</name>
          <t>Universally Unique Identifiers (UUIDs) are used to uniquely identify IDMEF messages.
                    It is also possible for an IDMEF message to reference other IDMEF messages using
                    their UUIDs. The syntax for UUIDs is defined in <xref target="RFC4122"/>.</t>
          <t>To limit the risk of UUID collisions, implementors SHOULD NOT generate version 4
                    UUIDs (randomly or pseudo-randomly generated UUIDs).</t>
          <t>E.g. "ba2e4ef4-8719-42bb-a712-d6e8871c5c5a".</t>
          <t>UUIDs are case-insensitive when used in comparisons.</t>
          <t>Such values are indicated with the "UUID" type annotation in the model.</t>
        </section>
        <section>
          <name>Protocol Names</name>
          <t>Such values are indicated with the "PROTOCOL" type annotation in the model.</t>
        </section>
        <section>
          <name>IDMEF Paths</name>
          <t>This document defines a way to represent the path to every possible attribute
                    inside an IDMEF message. For conciseness, the top-level "Alert" class is omitted
                    from the path.</t>
          <t>This representation can be used in contexts where the path to an IDMEF attribute
                    is expected. An example of such usage can be seen in the definition of the
                    "AggrCondition" attribute inside the <xref target="class_alert">Alert class</xref>.</t>
          <t>The syntax for these IDMEF paths is expressed in the following ABNF grammar:</t>
          <sourcecode type="none">class-name      =  "Analyzer" / "Sensor" / "Source" / "Target" /
                   "Vector" / "Attachment"
attribute-name  =  1*ALPHA
class-reference =  class-name "."
num             =  *1"-" 1*DIGIT
list-index      =  "(" num ")"
path            =  *1class-reference attribute-name *1list-index</sourcecode>
          <t>Valid attribute names are limited to those defined for the specified
                    class-reference (or in the top-level "Alert" class if class-reference
                    is omitted).</t>
          <t>For example, the following path refers to the "CeaseTime" attribute
                    of the top-level "Alert" class: "CeaseTime".</t>
          <t>Likewise, the following path refers to the "Name" attribute of the
                    "Analyzer" class: "Analyzer.Name".</t>
          <t>For attributes defined as lists (see <xref target="data-types-lists"/>), the path may
                    include the (0-based) index for an entry inside the list.
                    The index defaults to 0 if omitted.
                    This means that several (valid) representations may be used to reference
                    the same IDMEF attribute when list attributes are involved.</t>
          <t>For example, both of the following paths refer to the IP address of the first
                    source associated with an IDMEF message:</t>
          <sourcecode type="none">Source.IP
Source(0).IP</sourcecode>
          <t>Compatible implementations MUST reject paths that reference an unknown
                    class, an unknown attribute, or use a list-index for an IDMEF field
                    which is not defined as a list.</t>
          <t>A compatible implementation MUST also normalize paths before comparing them
                    (e.g. by stripping the text "(0)" from paths referring to list attributes).</t>
        </section>
        <section>
          <name>Hashes</name>
          <t>Hashes are sometimes used inside the data model to protect the integrity
                    (and optionally, authenticity) of attachments.</t>
          <t>The syntax for these values is "function:hash_result", where "function" refers to
                    one of the hashing function names listed in 
                    and "hash_result" contains the hexadecimal notation for the hash result obtained
                    by calling the specified hash function on the input value.</t>
          <t>In the context of IDMEF, either a keyless or keyed hash function may be used
                    to process the raw input value.</t>
          <t>E.g. "sha256:a02735ed8b10ad432d557bd4849c0dac3b23d64706e0618716d6df2def338374"</t>
          <t>Hashes are case-insensitive when used in comparisons.</t>
          <t>Such values are indicated with the "HASH" type annotation in the model.</t>
        </section>
      </section>
      <section anchor="data-types-lists">
        <name>Lists</name>
        <t>Some attributes of the IDMEF data model accept ordered lists of values.</t>
        <t>Such ordered lists are indicated with the "X[]" type annotation in the model.
                where "X" refers to one of the data types defined in <xref target="data-types"/>.
                For example, "ENUM[]" refers to an ordered list of enumeration values.</t>
      </section>
    </section>
    <section>
      <name>The IDMEF extension</name>
      <t>In order to support the dynamic nature of security operations and
            to adapt to specific needs, the
            IDMEFv2  data model will need to continue to evolve.  This section
            discusses how new data elements can be incorporated into the IDMEFv2.
            There is support to add additional enumerated values and new attributes.</t>
      <t>These extension mechanisms are designed so that adding new data
            elements is possible without requiring modifications to this
            document.  Extensions can be implemented publicly or privately.  With
            proven value, well-documented extensions can be incorporated into
            future versions of the specification.</t>
      <section>
        <name>Extending the Enumerated Values of Attributes</name>
        <t>Additional enumerated values can be added to select attributes either
                through the use of specially marked attributes with the "ext-" prefix
                or through a set of corresponding IANA registries.  The former
                approach allows for the extension to remain private.  The latter
                approach is public.</t>
        <section anchor="private-extension-enum">
          <name>Private Extension of Enumerated Values</name>
          <t>The data model supports adding new enumerated values to an attribute
                    without public registration.  For each attribute that supports this
                    extension technique, there is a corresponding attribute in the same
                    element whose name is identical but with a prefix of "ext-".  This
                    special attribute is referred to as the extension attribute.  The
                    attribute being extended is referred to as an extensible attribute.
                    For example, an extensible attribute named "foo" will have a
                    corresponding extension attribute named "ext-foo".  An element may
                    have many extensible attributes.</t>
          <t>In addition to a corresponding extension attribute, each extensible
                    attribute has "ext-value" as one its possible enumerated values.
                    Selection of this particular value in an extensible attribute signals
                    that the extension attribute contains data.  Otherwise, this
                    "ext-value" value has no meaning.</t>
          <t>In order to add a new enumerated value to an extensible attribute,
                    the value of this attribute MUST be set to "ext-value", and the new
                    desired value MUST be set in the corresponding extension attribute.
                    For example, extending the Category  attribute of the Analyzer class
                    would look as follows:</t>
          <sourcecode type="json">Analyzer: {
    ...
    "Category":["ext-value"],
    "ext-Category": "my-new-analyzer-category",
    ....
}</sourcecode>
          <t>A given extension attribute MUST NOT be set unless the corresponding
                    extensible attribute has been set to "ext-value".</t>
        </section>
        <section>
          <name>Public Extension of Enumerated Values</name>
          <t>The data model also supports publicly extending select enumerated
                    attributes.  A new entry can be added by registering a new entry in
                    the appropriate IANA registry. Section (<xref target="iana-registries"/>) provides a mapping
                    between the extensible attributes and their corresponding registry.</t>
        </section>
      </section>
      <section>
        <name>Private Extension of Attributes</name>
        <t>Use of new attributes is possible through the use of the attachment class.
                New attributes and their corresponding values should be stored in the Content
                attribute of an Attachment and the ContentEnconding must be set to JSON.
                For example creating a new attribute to store the email of the operator (in
                charge of solving the incident) will look as follows:</t>
        <sourcecode type="json">"Attachment" : [
    {
    "Name": "Operator",
    "ContentEnconding": "JSON",
    "Content": "{\"OperatorMail\":\"John.Does@acme.com\"}",
    }
[</sourcecode>
      </section>
    </section>
    <section anchor="model">
      <name>The IDMEF Data Model</name>
      <t>In this section, the individual components of the IDMEF data model will be discussed in detail.  For each class, the semantics will be described.</t>
      <section>
        <name>Overview</name>
        <figure anchor="overview-classes">
          <name>IDMEFv2 Overview Classes</name>
          <artwork type="ascii-art" align="center">                         +--------+     +-----+
                         |Analyzer|---&gt; |Alert|
                         +--------+     +-----+
                             ||
                          +------+
                          |Sensor|
                          +------+
            \--------\       /\
             ) Vector )     /  \
            /--------/     /    \
+------+                  +------+
|Source|                  |Target|
+------+                  +------+</artwork>
        </figure>
        <t>An IDMEF message is composed of an instance of the <xref target="class_alert">Alert class</xref> representing
                the overall properties of the message. It also contains exactly one instance of the
                <xref target="class_analyzer">Analyzer class</xref> and zero or more instances of the <xref target="class_sensor">Sensor class</xref>.</t>
        <t>The message may also describe various aspects of an event using the <xref target="class_source">Source</xref>,
                <xref target="class_target">Target</xref> and <xref target="class_vector">Vector</xref> classes.</t>
        <t>Last but not least, it may also include zero or more instances of the
                <xref target="class_attachment">Attachment class</xref>, e.g. captured files or network packets related
                to the event for example.</t>
        <t>The relationship between the main Alert class and other classes of the data model
                is shown in <xref target="diagram-classes"/> (attributes are omitted for clarity).</t>
        <figure anchor="diagram-classes">
          <name>IDMEFv2 Classes</name>
          <artwork type="ascii-art" align="center">+-------+            +-------------
| Alert |&lt;&gt;----------|  Analyzer  |
+-------+            +------------+
|       |       0..* +------------+
|       |&lt;&gt;----------|   Sensor   |
|       |            +------------+
|       |       0..* +------------+
|       |&lt;&gt;----------|   Source   |
|       |            +------------+
|       |       0..* +------------+
|       |&lt;&gt;----------|   Target   |
|       |            +------------+
|       |       0..* +------------+
|       |&lt;&gt;----------|   Vector   |
|       |            +------------+
|       |       0..* +------------+
|       |&lt;&gt;----------| Attachment |
+-------+            +------------+</artwork>
        </figure>
        <t>It is important to note that the data model does not specify how an alert
                should be categorized or identified.
                For example, an attacker scanning a network for machines listening on a specific
                port may be identified by one analyzer as a single attack against multiple targets,
                while another analyzer may identify it as multiple attacks from a single source.
                However, once an analyzer has determined the type of alert it plans on sending,
                the data model dictates how that alert should be formatted.</t>
      </section>
      <section anchor="class_alert">
        <name>The Alert Class</name>
        <t>The Alert class contains high level information about the event that triggered the alert.</t>
        <figure anchor="class_alert_diagram">
          <name>The Alert class</name>
          <artwork type="ascii-art" align="center">+---------------------------+
|           Alert           |
+---------------------------+
| STRING      Version       |
| UUID        ID            |
| STRING      Entity        |
| ENUM[]      Category      |
| STRING      ext-Category  |
| ENUM        Cause         |
| STRING      Description   |
| ENUM        Status        |
| ENUM        Priority      |
| FLOAT       Confidence    |
| STRING      Note          |
| TIMESTAMP   CreateTime    |
| TIMESTAMP   StartTime     |
| TIMESTAMP   EndTime       |
| STRING[]    AltNames      |
| STRING[]    AltCategory   |
| URI[]       Ref           |
| UUID[]      CorrelID      |
| CONDITION[] AggrCondition |
| UUID[]      PredID        |
| UUID[]      RelID         |
+---------------------------+</artwork>
        </figure>
        <t>The aggregate classes that make up Alert are:</t>
        <dl newline="true">
                    <dt>Analyzer</dt>
                    <dd>
                        <t>Exactly one.
                            An instance of the <xref target="class_analyzer">Analyzer class</xref> that describes the
                            tool/device responsible for the analysis that resulted in the alert being
                            created and sent.</t>
                    </dd>
                
                    <dt>Sensor</dt>
                    <dd>
                        <t>Zero or more.
                            Instances of the <xref target="class_sensor">Sensor class</xref> used to describe the sensor(s)
                            that captured the information used during the analysis.</t>
                        <t>Depending on the tools/devices used to detect incidents, an Analyzer may rely
                            on the output from a single sensor or from multiple sensors to generate alerts.
                            In addition, the Analyzer and Sensor may actually be part of the same physical
                            device and may share some of their attributes (e.g. IP, Hostname, Model, etc.).</t>
                    </dd>
                
                    <dt>Source</dt>
                    <dd>
                        <t>Zero or more.
                            Instances of the <xref target="class_source">Source class</xref> used to describe the source(s)
                            of the incident (e.g. attackers, faulty device, etc.).</t>
                    </dd>
                
                    <dt>Target</dt>
                    <dd>
                        <t>Zero or more.
                            Instances of the <xref target="class_target">Target class</xref> used to describe the target(s)
                            of the incident, i.e. the impacted devices/users/services/locations.</t>
                    </dd>
                
                    <dt>Vector</dt>
                    <dd>
                        <t>Zero or more.
                            Instances of the <xref target="class_vector">Vector class</xref> used to describe the means
                            which were employed by the sources to disrupt the targets.</t>
                        <t>E.g. to describe a drone crashing into a building and resulting in service loss
                            or a malware email delivered opened in a mailbox and resulting in service loss.</t>
                    </dd>
                
                    <dt>Attachment</dt>
                    <dd>
                        <t>Zero or more.
                            Instances of the <xref target="class_attachment">Attachment class</xref> used to describe
                            the electronic artifacts captured in relation with the event.</t>
                        <t>The intent of the Attachment class is to keep track of the electronic files
                            left as a trail during the event.
                            This may include things like on-disk files (e.g. malware samples), network
                            packet captures, videos or still images from a camera feed, voice recording, etc.</t>
                    </dd>
                </dl>
        <t>The Alert class has the following attributes:</t>
        <dl newline="true">
                    <dt>Version</dt>
                    <dd>
                        <t>Mandatory.
                            The version of the IDMEF format in use by this alert.</t>
                        <t>During the drafts tuning period the version is equal to the draft version.
                            Therefore it is "2.D.V01" for Draft V01.</t>
                    </dd>
                
                    <dt>ID</dt>
                    <dd>
                        <t>Mandatory.
                            Unique identifier for the alert.</t>
                    </dd>
                
                    <dt>Entity</dt>
                    <dd>
                        <t>Optional.
                            Tenant ID to support multi-tenancy (e.g. decentralized infrastructure,
                            local agency, subsidiary  company, etc.).</t>
                        <t>Should be used when there are multiple sites/locations or multiple tenants
                            (e.g. by Managed Security Services Providers).</t>
                    </dd>
                
                    <dt>Category</dt>
                    <dd>
                        <t>Optional.
                            The incident's category &amp; subcategory as listed in <xref target="ENISA-RIST"/>
                            using the format "category.subcategory" (e.g. "Attempt.Exploit").</t>
                        <table anchor="enum-alert-category"><name>Incident taxonomy</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>Abusive.Spam</t>
                                        </td>
                                        <td>
                                            <t>Or 'Unsolicited Bulk Email', this means that the recipient has not granted verifiable permission for the message to be sent and that the message is sent as part of a larger collection of messages, all having a functionally comparable content. This IOC refers to resources, which make up a SPAM infrastructure, be it a harvesters like address verification, URLs in spam e-mails etc.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>Abusive.Harassment</t>
                                        </td>
                                        <td>
                                            <t>Discretization or discrimination of somebody, e.g. cyber stalking, racism or threats against one or more individuals.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>2</t>
                                        </td>
                                        <td>
                                            <t>Abusive.Illicit</t>
                                        </td>
                                        <td>
                                            <t>Child Sexual Exploitation (CSE), Sexual content, glorification of violence, etc.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>3</t>
                                        </td>
                                        <td>
                                            <t>Malicious.System</t>
                                        </td>
                                        <td>
                                            <t>System infected with malware, e.g. PC, smartphone or server infected with a rootkit. Most often this refers to a connection to a sinkholed C2 server</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>4</t>
                                        </td>
                                        <td>
                                            <t>Malicious.Botnet</t>
                                        </td>
                                        <td>
                                            <t>Command-and-control server contacted by malware on infected systems.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>5</t>
                                        </td>
                                        <td>
                                            <t>Malicious.Distribution</t>
                                        </td>
                                        <td>
                                            <t>URI used for malware distribution, e.g. a download URL included in fake invoice malware spam or exploit-kits (on websites).</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>6</t>
                                        </td>
                                        <td>
                                            <t>Malicious.Configuration</t>
                                        </td>
                                        <td>
                                            <t>URI hosting a malware configuration file, e.g. web-injects for a banking trojan.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>7</t>
                                        </td>
                                        <td>
                                            <t>Recon.Scanning</t>
                                        </td>
                                        <td>
                                            <t>Attacks that send requests to a system to discover weaknesses. This also includes testing processes to gather information on hosts, services and accounts. Examples: fingerd, DNS querying, ICMP, SMTP (EXPN, RCPT, ...), port scanning.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>8</t>
                                        </td>
                                        <td>
                                            <t>Recon.Sniffing</t>
                                        </td>
                                        <td>
                                            <t>Observing and recording of network traffic (wiretapping).</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>9</t>
                                        </td>
                                        <td>
                                            <t>Recon.SocialEngineering</t>
                                        </td>
                                        <td>
                                            <t>Gathering information from a human being in a non-technical way (e.g. lies, tricks, bribes, or threats).</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>10</t>
                                        </td>
                                        <td>
                                            <t>Attempt.Exploit</t>
                                        </td>
                                        <td>
                                            <t>An attempt to compromise a system or to disrupt any service by exploiting vulnerabilities with a standardised identifier such as CVE name (e.g. buffer overflow, backdoor, cross site scripting, etc.)</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>11</t>
                                        </td>
                                        <td>
                                            <t>Attempt.Login</t>
                                        </td>
                                        <td>
                                            <t>Multiple login attempts (Guessing / cracking of passwords, brute force). This IOC refers to a resource, which has been observed to perform brute-force attacks over a given application protocol.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>12</t>
                                        </td>
                                        <td>
                                            <t>Attempt.NewSignature</t>
                                        </td>
                                        <td>
                                            <t>An attack using an unknown exploit.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>13</t>
                                        </td>
                                        <td>
                                            <t>Intrusion.AdminCompromise</t>
                                        </td>
                                        <td>
                                            <t>Compromise of a system where the attacker gained administrative privileges.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>14</t>
                                        </td>
                                        <td>
                                            <t>Intrusion.UserCompromise</t>
                                        </td>
                                        <td>
                                            <t>Compromise of a system using an unprivileged (user/service) account.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>15</t>
                                        </td>
                                        <td>
                                            <t>Intrusion.AppCompromise</t>
                                        </td>
                                        <td>
                                            <t>Compromise of an application by exploiting (un-)known software vulnerabilities, e.g. SQL injection.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>16</t>
                                        </td>
                                        <td>
                                            <t>Intrusion.SysCompromise</t>
                                        </td>
                                        <td>
                                            <t>Compromise of a system, e.g. unauthorised logins or commands. This includes compromising attempts on honeypot systems.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>17</t>
                                        </td>
                                        <td>
                                            <t>Intrusion.Burglary</t>
                                        </td>
                                        <td>
                                            <t>Physical intrusion, e.g. into corporate building or data-centre.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>18</t>
                                        </td>
                                        <td>
                                            <t>Availability.DoS</t>
                                        </td>
                                        <td>
                                            <t>Denial of Service attack, e.g. sending specially crafted requests to a web application which causes the application to crash or slow down.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>19</t>
                                        </td>
                                        <td>
                                            <t>Availability.DDoS</t>
                                        </td>
                                        <td>
                                            <t>Distributed Denial of Service attack, e.g. SYN-Flood or UDP-based reflection/amplification attacks.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>20</t>
                                        </td>
                                        <td>
                                            <t>Availability.Misconf</t>
                                        </td>
                                        <td>
                                            <t>Software misconfiguration resulting in service availability issues, e.g. DNS server with outdated DNSSEC Root Zone KSK.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>21</t>
                                        </td>
                                        <td>
                                            <t>Availability.Theft</t>
                                        </td>
                                        <td>
                                            <t>Physical theft, e.g. stolen laptop computer, stolen USB key, stolen paper document, etc.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>22</t>
                                        </td>
                                        <td>
                                            <t>Availability.Sabotage</t>
                                        </td>
                                        <td>
                                            <t>Physical sabotage, e.g cutting wires or malicious arson.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>23</t>
                                        </td>
                                        <td>
                                            <t>Availability.Outage</t>
                                        </td>
                                        <td>
                                            <t>Outage caused e.g. by air condition failure or natural disaster.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>24</t>
                                        </td>
                                        <td>
                                            <t>Availability.Failure</t>
                                        </td>
                                        <td>
                                            <t>Failure, malfunction (e.g. : bug, wear, faults, etc.)</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>25</t>
                                        </td>
                                        <td>
                                            <t>Information.
                                                UnauthorizedAccess</t>
                                        </td>
                                        <td>
                                            <t>Unauthorised access to information, e.g. by abusing stolen login credentials for a system or application, intercepting traffic or gaining access to physical documents.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>26</t>
                                        </td>
                                        <td>
                                            <t>Information.
                                                UnauthorizedModification</t>
                                        </td>
                                        <td>
                                            <t>Unauthorised modification of information, e.g. by an attacker abusing stolen login credentials for a system or application or a ransomware encrypting data. Also includes defacements.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>27</t>
                                        </td>
                                        <td>
                                            <t>Information.DataLoss</t>
                                        </td>
                                        <td>
                                            <t>Loss of data, e.g. caused by harddisk failure or physical theft.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>28</t>
                                        </td>
                                        <td>
                                            <t>Information.DataLeak</t>
                                        </td>
                                        <td>
                                            <t>Leaked confidential information like credentials or personal data.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>29</t>
                                        </td>
                                        <td>
                                            <t>Fraud.UnauthorizedUsage</t>
                                        </td>
                                        <td>
                                            <t>Using resources for unauthorised purposes including profit-making ventures, e.g. the use of e-mail to participate in illegal profit chain letters or pyramid schemes.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>30</t>
                                        </td>
                                        <td>
                                            <t>Fraud.Copyright</t>
                                        </td>
                                        <td>
                                            <t>Offering or Installing copies of unlicensed commercial software or other copyright protected materials (Warez).</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>31</t>
                                        </td>
                                        <td>
                                            <t>Fraud.Masquerade</t>
                                        </td>
                                        <td>
                                            <t>Type of attack in which one entity illegitimately impersonates the identity of another in order to benefit from it.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>32</t>
                                        </td>
                                        <td>
                                            <t>Fraud.Phishing</t>
                                        </td>
                                        <td>
                                            <t>Masquerading as another entity in order to persuade the user to reveal private credentials. This IOC most often refers to a URL, which is used to phish user credentials.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>33</t>
                                        </td>
                                        <td>
                                            <t>Vulnerable.Crypto</t>
                                        </td>
                                        <td>
                                            <t>Publicly accessible services offering weak crypto, e.g. web servers susceptible to POODLE/FREAK attacks.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>34</t>
                                        </td>
                                        <td>
                                            <t>Vulnerable.DDoS</t>
                                        </td>
                                        <td>
                                            <t>Publicly accessible services that can be abused for conducting DDoS reflection/amplification attacks, e.g. DNS open-resolvers or NTP servers with monlist enabled.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>35</t>
                                        </td>
                                        <td>
                                            <t>Vulnerable.Surface</t>
                                        </td>
                                        <td>
                                            <t>Potentially unwanted publicly accessible services, e.g. Telnet, RDP or VNC.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>36</t>
                                        </td>
                                        <td>
                                            <t>Vulnerable.Disclosure</t>
                                        </td>
                                        <td>
                                            <t>Publicly accessible services potentially disclosing sensitive information, e.g. SNMP or Redis.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>37</t>
                                        </td>
                                        <td>
                                            <t>Vulnerable.System</t>
                                        </td>
                                        <td>
                                            <t>A system which is vulnerable to certain attacks. Example: misconfigured client proxy settings (example: WPAD), outdated operating system version, XSS vulnerabilities, etc.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>38</t>
                                        </td>
                                        <td>
                                            <t>Geophysical.Earthquake</t>
                                        </td>
                                        <td>
                                            <t>A hazard originating from solid earth. This term is used interchangeably with the term geological hazard.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>39</t>
                                        </td>
                                        <td>
                                            <t>Geophysical.MassMovement</t>
                                        </td>
                                        <td>
                                            <t>A hazard originating from solid earth. This term is used interchangeably with the term geological hazard.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>40</t>
                                        </td>
                                        <td>
                                            <t>Geophysical.Volcanic</t>
                                        </td>
                                        <td>
                                            <t>A hazard originating from solid earth. This term is used interchangeably with the term geological hazard.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>41</t>
                                        </td>
                                        <td>
                                            <t>Meteorological.
                                                Temperature</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by short-lived, micro- to meso-scale extreme weather and atmospheric conditions that last from minutes to days.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>42</t>
                                        </td>
                                        <td>
                                            <t>Meteorological.Fog</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by short-lived, micro- to meso-scale extreme weather and atmospheric conditions that last from minutes to days.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>43</t>
                                        </td>
                                        <td>
                                            <t>Meteorological.Storm</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by short-lived, micro- to meso-scale extreme weather and atmospheric conditions that last from minutes to days.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>44</t>
                                        </td>
                                        <td>
                                            <t>Hydrological.Flood</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by the occurrence, movement, and distribution of surface and subsurface freshwater and saltwater.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>45</t>
                                        </td>
                                        <td>
                                            <t>Hydrological.Landslide</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by the occurrence, movement, and distribution of surface and subsurface freshwater and saltwater.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>46</t>
                                        </td>
                                        <td>
                                            <t>Hydrological.Wave</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by the occurrence, movement, and distribution of surface and subsurface freshwater and saltwater.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>47</t>
                                        </td>
                                        <td>
                                            <t>Climatological.Drought</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by long-lived, meso- to macro-scale atmospheric processes ranging from intra-seasonal to multi-decadal climate variability.​</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>48</t>
                                        </td>
                                        <td>
                                            <t>Climatological.
                                                LakeOutburst</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by long-lived, meso- to macro-scale atmospheric processes ranging from intra-seasonal to multi-decadal climate variability.​</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>49</t>
                                        </td>
                                        <td>
                                            <t>Climatological.Wildfire</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by long-lived, meso- to macro-scale atmospheric processes ranging from intra-seasonal to multi-decadal climate variability.​</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>50</t>
                                        </td>
                                        <td>
                                            <t>Biological.Epidemic</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by the exposure to living organisms and their toxic substances (e.g. venom, mold) or vector-borne diseases that they may carry. Examples are venomous wildlife and insects, poisonous plants, and mosquitoes carrying disease-causing agents such as parasites, bacteria, or viruses (e.g. malaria).</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>51</t>
                                        </td>
                                        <td>
                                            <t>Biological.Insect</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by the exposure to living organisms and their toxic substances (e.g. venom, mold) or vector-borne diseases that they may carry. Examples are venomous wildlife and insects, poisonous plants, and mosquitoes carrying disease-causing agents such as parasites, bacteria, or viruses (e.g. malaria).</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>52</t>
                                        </td>
                                        <td>
                                            <t>Biological.Animal</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by the exposure to living organisms and their toxic substances (e.g. venom, mold) or vector-borne diseases that they may carry. Examples are venomous wildlife and insects, poisonous plants, and mosquitoes carrying disease-causing agents such as parasites, bacteria, or viruses (e.g. malaria).</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>53</t>
                                        </td>
                                        <td>
                                            <t>Extraterrestrial.Impact</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by asteroids, meteoroids, and comets as they pass near-earth, enter the Earth’s atmosphere, and/or strike the Earth, and by changes in interplanetary conditions that effect the Earth’s magnetosphere, ionosphere, and thermosphere.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>54</t>
                                        </td>
                                        <td>
                                            <t>Extraterrestrial.
                                                SpaceWeather</t>
                                        </td>
                                        <td>
                                            <t>A hazard caused by asteroids, meteoroids, and comets as they pass near-earth, enter the Earth’s atmosphere, and/or strike the Earth, and by changes in interplanetary conditions that effect the Earth’s magnetosphere, ionosphere, and thermosphere.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>55</t>
                                        </td>
                                        <td>
                                            <t>Other.Uncategorised</t>
                                        </td>
                                        <td>
                                            <t>All incidents which don't fit in one of the given categories should be put into this class or the incident is not categorised.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>56</t>
                                        </td>
                                        <td>
                                            <t>Other.Undetermined</t>
                                        </td>
                                        <td>
                                            <t>The categorisation of the incident is unknown/undetermined.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>57</t>
                                        </td>
                                        <td>
                                            <t>Test.Test</t>
                                        </td>
                                        <td>
                                            <t>Meant for testing.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>58</t>
                                        </td>
                                        <td>
                                            <t>ext-value</t>
                                        </td>
                                        <td>
                                            <t>A value used to indicate that this attribute is extended and the actual value is provided using the corresponding ext-* attribute. (see <xref target="private-extension-enum"/>)</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>ext-Category</dt>
                    <dd>
                        <t>Optional.
                            A means by which to extend the Category attribute. (see <xref target="private-extension-enum"/>)</t>
                    </dd>
                
                    <dt>Cause</dt>
                    <dd>
                        <t>Optional.
                            Alert cause.
                            The cause can be modified by any analyser on the way of the alert and later
                            by the operator and/or the analyst if new investigation reveals and confirms
                            a different cause of the event.</t>
                        <table anchor="enum-alert-cause"><name>Incident causes</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>Normal</t>
                                        </td>
                                        <td>
                                            <t>The event is related to an expected phenomenon or to a
                                                phenomenon that does not qualify as out of the ordinary.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>Error</t>
                                        </td>
                                        <td>
                                            <t>The event is related to a human error.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>2</t>
                                        </td>
                                        <td>
                                            <t>Malicious</t>
                                        </td>
                                        <td>
                                            <t>The event is related to malicious code or malicious actions.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>3</t>
                                        </td>
                                        <td>
                                            <t>Malfunction</t>
                                        </td>
                                        <td>
                                            <t>The event is related to a device or service malfunction.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>4</t>
                                        </td>
                                        <td>
                                            <t>Hazard</t>
                                        </td>
                                        <td>
                                            <t>The event is related to a hazard phenomenon.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>5</t>
                                        </td>
                                        <td>
                                            <t>Unknown</t>
                                        </td>
                                        <td>
                                            <t>The cause of the event is unknown.</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>Description</dt>
                    <dd>
                        <t>Optional.
                            Short free text human-readable description of the event.
                            The description can add detail to the alert classification for easiest/faster comprehension by the operator.
                            Example :
                            * Cryptoware WannaCry blocked on pegasus server
                            * Unknown person entering through east doorway</t>
                    </dd>
                
                    <dt>Status</dt>
                    <dd>
                        <t>Optional.
                            Event state in the overall event lifecycle.</t>
                        <table anchor="enum-alert-status"><name>Incident statuses</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>Event</t>
                                        </td>
                                        <td>
                                            <t>The event is still considered as an harmless event and should not be treated.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>Incident</t>
                                        </td>
                                        <td>
                                            <t>The event is considered as an incident and should be taken care of.</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>Priority</dt>
                    <dd>
                        <t>Optional.
                            Priority of the alert.
                            Priority is defined by conbining impact and urgency. It indicates how fast the incident should be taken care of.
                            Impact defines the enormity of the situation and mostly deals with “How Many” or “how much” question. It can be in terms of people, finances, systems, etc. How many people and/or systems impacted, how badly are they impacted (is there potential physical impact ?) , how much financial loss, severity of legal liabilities,... Impact could be considered equivalent to "Severity".
                            Urgency is associated with time. The time it takes to have the perceived Impact. For example, a high impact incident may have low urgency if the impact will not affect the business until the end of the financial year.</t>
                        <table anchor="enum-alert-priority"><name>Incident severities</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>Unknown</t>
                                        </td>
                                        <td>
                                            <t>Priority unknow</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>Info</t>
                                        </td>
                                        <td>
                                            <t>No priority, the alert is informational</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>2</t>
                                        </td>
                                        <td>
                                            <t>Low</t>
                                        </td>
                                        <td>
                                            <t>Low priority</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>3</t>
                                        </td>
                                        <td>
                                            <t>Medium</t>
                                        </td>
                                        <td>
                                            <t>Medium priority</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>4</t>
                                        </td>
                                        <td>
                                            <t>High</t>
                                        </td>
                                        <td>
                                            <t>High priority</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>Confidence</dt>
                    <dd>
                        <t>Optional.
                            A floating-point value between 0 and 1 indicating the analyzer's confidence
                            in its own reliability of this particular detection, where 0 means
                            that the detection is surely incorrect while 1 means there is no doubt
                            about the detection made.</t>
                    </dd>
                
                    <dt>Note</dt>
                    <dd>
                        <t>Optional.
                            Free text human-readable additional note, possibly a longer description
                            of the incident if is not already obvious.</t>
                        <t>The Note attribute can be used to store any additional information. It can be additional information about the event and/or about the incident resolution, although the incident resolution information should in principle be stored elsewhere (with a link with the external tool in AltNames)</t>
                    </dd>
                
                    <dt>CreateTime</dt>
                    <dd>
                        <t>Mandatory.
                            Timestamp indicating when the message was created.</t>
                    </dd>
                
                    <dt>StartTime</dt>
                    <dd>
                        <t>Optional.
                            Timestamp indicating the deduced start of the event.</t>
                        <t>StartTime can be later than CreateTime in case or Alerts created from forecast information (e.g. Snow Storm in two days staring at 10h00)</t>
                    </dd>
                
                    <dt>EndTime</dt>
                    <dd>
                        <t>Optional.
                            Timestamp indicating the deduced end of the event.</t>
                    </dd>
                
                    <dt>AltNames</dt>
                    <dd>
                        <t>Optional.
                            Alternative identifiers; strings which help pair the event to internal
                            systems' information (for example ticket IDs inside a request tracking
                            systems).</t>
                    </dd>
                
                    <dt>AltCategory</dt>
                    <dd>
                        <t>Optional.
                            Alternate categories from a reference other than <xref target="ENISA-RIST"/>
                            (e.g. MISP, MITRE ATT@CK or another proprietary/internal reference).</t>
                    </dd>
                
                    <dt>Ref</dt>
                    <dd>
                        <t>Optional.
                            References to sources of information related to the alert and/or
                            vulnerability, and specific to this alert.</t>
                        <t>This MAY be a URL to additional info, or a URN in a registered or
                            unregistered ad-hoc namespace bearing reasonable information value
                            and uniqueness, such as "urn:cve:CVE-2013-2266".</t>
                    </dd>
                
                    <dt>CorrelID</dt>
                    <dd>
                        <t>Optional.
                            Identifiers for the  messages which were used as information sources
                            to create this message, in case the message has been created based on
                            correlation/analysis/deduction from other messages.</t>
                    </dd>
                
                    <dt>AggrCondition</dt>
                    <dd>
                        <t>Optional.
                            A list of IDMEF fields used to aggregate events. The values for these
                            fields will be the same in all aggregated events.</t>
                        <t>This attribute should mostly be set by intermediary nodes, which detect
                            duplicates, or aggregate events, spanning multiple detection windows,
                            into a longer one.</t>
                        <t>The "StartTime" and "EndTime" attributes are used in conjunction
                            with this attribute to describe the aggregation window.</t>
                    </dd>
                
                    <dt>PredID</dt>
                    <dd>
                        <t>Optional.
                            A list containing the identifiers of previous messages
                            which are obsoleted by this message.</t>
                        <t>The obsoleted alerts SHOULD NOT be used anymore.
                            This field can be used to "update" an alert.</t>
                    </dd>
                
                    <dt>RelID</dt>
                    <dd>
                        <t>Optional.
                            A list containing the identifiers of other messages related
                            to this message.</t>
                    </dd>
                </dl>
      </section>
      <section anchor="class_analyzer">
        <name>The Analyzer Class</name>
        <t>The Analyzer class describes the module that has analyzed the data
                captured by the sensors, identified an event of interest and decided
                to create an alert.</t>
        <figure anchor="class_analyzer_diagram">
          <name>The Analyzer class</name>
          <artwork type="ascii-art" align="center">+-----------------------+
|       Analyzer        |
+-----------------------+
| IP       IP           |
| STRING   Name         |
| STRING   Hostname     |
| STRING   Model        |
| ENUM[]   Type         |
| ENUM[]   Category     |
| STRING   ext-Category |
| ENUM[]   Data         |
| STRING   ext-Data     |
| ENUM[]   Method       |
| STRING   ext-Method   |
| GEOLOC   GeoLocation  |
| UNLOCODE UnLocation   |
| STRING   Location     |
+-----------------------+</artwork>
        </figure>
        <t>The Analyzer class has the following attributes:</t>
        <dl newline="true">
                    <dt>IP</dt>
                    <dd>
                        <t>Mandatory. Analyzer IP address.</t>
                    </dd>
                
                    <dt>Name</dt>
                    <dd>
                        <t>Mandatory. Name of the analyzer, which must be reasonably unique, however still bear some meaningful sense.</t>
                        <t>This attribute usually denotes the hierarchy of organizational units
                            the detector belongs to and its own name.
                            It MAY also be used to distinguish multiple analyzers running with
                            the same IP address.</t>
                    </dd>
                
                    <dt>Hostname</dt>
                    <dd>
                        <t>Optional. Hostname of this analyzer.</t>
                        <t>SHOULD be a fully-qualified domain name.</t>
                    </dd>
                
                    <dt>Model</dt>
                    <dd>
                        <t>Optional. Analyzer model description (usually its generic name,
                            brand and version).</t>
                    </dd>
                
                    <dt>Type</dt>
                    <dd>
                        <t>Optional. Analyzer type.</t>
                        <table anchor="enum-analyzer-type"><name>Analyzer types</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>Cyber</t>
                                        </td>
                                        <td>
                                            <t>The analyzer specializes in the detection of cyber incidents</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>Physical</t>
                                        </td>
                                        <td>
                                            <t>The analyzer specializes in the detection of physical incidents</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>2</t>
                                        </td>
                                        <td>
                                            <t>Availability</t>
                                        </td>
                                        <td>
                                            <t>The analyzer specializes in the detection of availability incidents</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>3</t>
                                        </td>
                                        <td>
                                            <t>Combined</t>
                                        </td>
                                        <td>
                                            <t>The analyzer specilizes in detections that combine data from multiple
                                                domains (e.g. a combination of Cyber and Availability data)</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>Category</dt>
                    <dd>
                        <t>Optional. Analyzer categories.</t>
                        <table anchor="enum-analyzer-category"><name>Analyzer categories</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>1DLiS</t>
                                        </td>
                                        <td>
                                            <t>1D LIDAR Sensor</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>2DLiS</t>
                                        </td>
                                        <td>
                                            <t>2D LIDAR Sensor</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>2</t>
                                        </td>
                                        <td>
                                            <t>3DLiS</t>
                                        </td>
                                        <td>
                                            <t>3D LIDAR Sensor</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>3</t>
                                        </td>
                                        <td>
                                            <t>1DLaS</t>
                                        </td>
                                        <td>
                                            <t>1D Laser Sensor</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>4</t>
                                        </td>
                                        <td>
                                            <t>2DLaS</t>
                                        </td>
                                        <td>
                                            <t>2D Laser Sensor</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>5</t>
                                        </td>
                                        <td>
                                            <t>3DLaS</t>
                                        </td>
                                        <td>
                                            <t>3D Laser Sensor</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>6</t>
                                        </td>
                                        <td>
                                            <t>VAD</t>
                                        </td>
                                        <td>
                                            <t>Voice Activity Detection</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>7</t>
                                        </td>
                                        <td>
                                            <t>HAR</t>
                                        </td>
                                        <td>
                                            <t>Human Activity Detection</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>8</t>
                                        </td>
                                        <td>
                                            <t>FRC</t>
                                        </td>
                                        <td>
                                            <t>Face Recognition Camera</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>9</t>
                                        </td>
                                        <td>
                                            <t>VNIR</t>
                                        </td>
                                        <td>
                                            <t>Visible and Near-InfraRed</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>10</t>
                                        </td>
                                        <td>
                                            <t>SWIR</t>
                                        </td>
                                        <td>
                                            <t>Short Wavelength InfraRed</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>11</t>
                                        </td>
                                        <td>
                                            <t>MWIR</t>
                                        </td>
                                        <td>
                                            <t>Middle Wavelength InfraRed</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>12</t>
                                        </td>
                                        <td>
                                            <t>LWIR</t>
                                        </td>
                                        <td>
                                            <t>Long Wavelength InfraRed</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>13</t>
                                        </td>
                                        <td>
                                            <t>ADS</t>
                                        </td>
                                        <td>
                                            <t>Anti-Drone System</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>14</t>
                                        </td>
                                        <td>
                                            <t>ODC</t>
                                        </td>
                                        <td>
                                            <t>Object Detection Camera</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>15</t>
                                        </td>
                                        <td>
                                            <t>DDOS</t>
                                        </td>
                                        <td>
                                            <t>Anti-DDoS (Distributed Denial of Service) protection</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>16</t>
                                        </td>
                                        <td>
                                            <t>SPAM</t>
                                        </td>
                                        <td>
                                            <t>Spam detection, phishing detection, etc.</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>17</t>
                                        </td>
                                        <td>
                                            <t>AV</t>
                                        </td>
                                        <td>
                                            <t>Signature-based virus/malware detection</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>18</t>
                                        </td>
                                        <td>
                                            <t>EDR</t>
                                        </td>
                                        <td>
                                            <t>Endpoint Detection and Response</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>19</t>
                                        </td>
                                        <td>
                                            <t>FW</t>
                                        </td>
                                        <td>
                                            <t>Firewall</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>20</t>
                                        </td>
                                        <td>
                                            <t>NIDS</t>
                                        </td>
                                        <td>
                                            <t>Network Intrusion Detection System</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>21</t>
                                        </td>
                                        <td>
                                            <t>HIDS</t>
                                        </td>
                                        <td>
                                            <t>Host Intrusion Detection System</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>22</t>
                                        </td>
                                        <td>
                                            <t>WIDS</t>
                                        </td>
                                        <td>
                                            <t>Wi-Fi Intrusion Detection System</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>23</t>
                                        </td>
                                        <td>
                                            <t>PROX</t>
                                        </td>
                                        <td>
                                            <t>Proxy, e.g. detection of violations to the company's security policy</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>24</t>
                                        </td>
                                        <td>
                                            <t>WAF</t>
                                        </td>
                                        <td>
                                            <t>Web Application Firewall</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>25</t>
                                        </td>
                                        <td>
                                            <t>HPT</t>
                                        </td>
                                        <td>
                                            <t>Honeypot</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>26</t>
                                        </td>
                                        <td>
                                            <t>LOG</t>
                                        </td>
                                        <td>
                                            <t>Log analyzer</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>27</t>
                                        </td>
                                        <td>
                                            <t>IAM</t>
                                        </td>
                                        <td>
                                            <t>Identity and Access Management tool</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>28</t>
                                        </td>
                                        <td>
                                            <t>VPN</t>
                                        </td>
                                        <td>
                                            <t>Devices/tools related to Virtual Private Network</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>29</t>
                                        </td>
                                        <td>
                                            <t>ETL</t>
                                        </td>
                                        <td>
                                            <t>Extract-Transform-Load tools</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>30</t>
                                        </td>
                                        <td>
                                            <t>RASP</t>
                                        </td>
                                        <td>
                                            <t>Runtime Application Self-Protection</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>31</t>
                                        </td>
                                        <td>
                                            <t>BAST</t>
                                        </td>
                                        <td>
                                            <t>Clientless Remote Desktop Gateway / administration bastions</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>32</t>
                                        </td>
                                        <td>
                                            <t>NAC</t>
                                        </td>
                                        <td>
                                            <t>Devices/tools related to Network Access Control</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>33</t>
                                        </td>
                                        <td>
                                            <t>SIEM</t>
                                        </td>
                                        <td>
                                            <t>Security Information and Event Management systems</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>34</t>
                                        </td>
                                        <td>
                                            <t>NMS</t>
                                        </td>
                                        <td>
                                            <t>Network Management Systems</t>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>35</t>
                                        </td>
                                        <td>
                                            <t>ext-value</t>
                                        </td>
                                        <td>
                                            <t>A value used to indicate that this attribute is extended and the actual value is provided using the corresponding ext-* attribute.  (see <xref target="private-extension-enum"/>)</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>ext-Category</dt>
                    <dd>
                        <t>Optional.
                            A means by which to extend the Category attribute.  (see <xref target="private-extension-enum"/>)</t>
                    </dd>
                
                    <dt>Data</dt>
                    <dd>
                        <t>Optional. Type of data analyzed during the detection.</t>
                        <table anchor="enum-analyzer-data"><name>Analyzer data</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>Light</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>Noise</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>2</t>
                                        </td>
                                        <td>
                                            <t>Touch</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>3</t>
                                        </td>
                                        <td>
                                            <t>Images</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>4</t>
                                        </td>
                                        <td>
                                            <t>Vibrations</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>5</t>
                                        </td>
                                        <td>
                                            <t>Lidar</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>6</t>
                                        </td>
                                        <td>
                                            <t>Thermic</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>7</t>
                                        </td>
                                        <td>
                                            <t>Seismic</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>8</t>
                                        </td>
                                        <td>
                                            <t>Temperature</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>9</t>
                                        </td>
                                        <td>
                                            <t>Rain</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>10</t>
                                        </td>
                                        <td>
                                            <t>Water</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>11</t>
                                        </td>
                                        <td>
                                            <t>Humidity</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>12</t>
                                        </td>
                                        <td>
                                            <t>Particles</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>13</t>
                                        </td>
                                        <td>
                                            <t>Contact</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>14</t>
                                        </td>
                                        <td>
                                            <t>MagneticField</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>15</t>
                                        </td>
                                        <td>
                                            <t>Acoustics</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>16</t>
                                        </td>
                                        <td>
                                            <t>Fog</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>17</t>
                                        </td>
                                        <td>
                                            <t>External</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>18</t>
                                        </td>
                                        <td>
                                            <t>Reporting</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>19</t>
                                        </td>
                                        <td>
                                            <t>Connection</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>20</t>
                                        </td>
                                        <td>
                                            <t>Datagram</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>21</t>
                                        </td>
                                        <td>
                                            <t>Content</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>22</t>
                                        </td>
                                        <td>
                                            <t>Data</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>23</t>
                                        </td>
                                        <td>
                                            <t>File</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>24</t>
                                        </td>
                                        <td>
                                            <t>Flow</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>25</t>
                                        </td>
                                        <td>
                                            <t>Log</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>26</t>
                                        </td>
                                        <td>
                                            <t>Protocol</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>27</t>
                                        </td>
                                        <td>
                                            <t>Host</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>28</t>
                                        </td>
                                        <td>
                                            <t>Network</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>29</t>
                                        </td>
                                        <td>
                                            <t>Alert</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>30</t>
                                        </td>
                                        <td>
                                            <t>Relay</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>31</t>
                                        </td>
                                        <td>
                                            <t>Auth</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>32</t>
                                        </td>
                                        <td>
                                            <t>SNMP</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>33</t>
                                        </td>
                                        <td>
                                            <t>ext-value</t>
                                        </td>
                                        <td>
                                            <t>A value used to indicate that this attribute is extended and the actual value is provided using the corresponding ext-* attribute. (see <xref target="private-extension-enum"/>)</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>ext-Data</dt>
                    <dd>
                        <t>Optional.
                            A means by which to extend the Data attribute.  (see <xref target="private-extension-enum"/>)</t>
                    </dd>
                
                    <dt>Method</dt>
                    <dd>
                        <t>Optional. Detection method.</t>
                        <table anchor="enum-analyzer-method"><name>Analyzer methods</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>Biometric</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>Policy</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>2</t>
                                        </td>
                                        <td>
                                            <t>Heat</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>3</t>
                                        </td>
                                        <td>
                                            <t>Movement</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>4</t>
                                        </td>
                                        <td>
                                            <t>Blackhole</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>5</t>
                                        </td>
                                        <td>
                                            <t>Signature</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>6</t>
                                        </td>
                                        <td>
                                            <t>Statistical</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>7</t>
                                        </td>
                                        <td>
                                            <t>Heuristic</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>8</t>
                                        </td>
                                        <td>
                                            <t>Integrity</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>9</t>
                                        </td>
                                        <td>
                                            <t>Honeypot</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>10</t>
                                        </td>
                                        <td>
                                            <t>Tarpit</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>11</t>
                                        </td>
                                        <td>
                                            <t>Recon</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>12</t>
                                        </td>
                                        <td>
                                            <t>Correlation</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>13</t>
                                        </td>
                                        <td>
                                            <t>Monitor</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>14</t>
                                        </td>
                                        <td>
                                            <t>AI</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>15</t>
                                        </td>
                                        <td>
                                            <t>Threshold</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>16</t>
                                        </td>
                                        <td>
                                            <t>ext-value</t>
                                        </td>
                                        <td>
                                            <t>A value used to indicate that this attribute is extended and the actual value is provided using the corresponding ext-* attribute. (see <xref target="private-extension-enum"/>)</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>ext-Method</dt>
                    <dd>
                        <t>Optional.
                            A means by which to extend the Method attribute.  (see <xref target="private-extension-enum"/>)</t>
                    </dd>
                
                    <dt>GeoLocation</dt>
                    <dd>
                        <t>Optional. GPS coordinates for the analyzer.</t>
                    </dd>
                
                    <dt>UnLocation</dt>
                    <dd>
                        <t>Optional. Standard UN/Locode for the analyzer.</t>
                    </dd>
                
                    <dt>Location</dt>
                    <dd>
                        <t>Optional. Internal name for the location of the analyzer.</t>
                    </dd>
                </dl>
      </section>
      <section anchor="class_sensor">
        <name>The Sensor Class</name>
        <t>The Sensor class describes the module that captured the data before sending
                it to an analyzer. The Sensor may be a subpart of the Analyzer.</t>
        <figure anchor="class_sensor_diagram">
          <name>The Sensor class</name>
          <artwork type="ascii-art" align="center">+----------------------+
|        Sensor        |
+----------------------+
| IP       IP          |
| STRING   Name        |
| STRING   Hostname    |
| STRING   Model       |
| GEOLOC   GeoLocation |
| UNLOCODE UnLocation  |
| STRING   Location    |
| STRING   CaptureZone |
+----------------------+</artwork>
        </figure>
        <t>The Sensor class has the following attributes:</t>
        <dl newline="true">
                    <dt>IP</dt>
                    <dd>
                        <t>Mandatory. The sensor's IP address.</t>
                    </dd>
                
                    <dt>Name</dt>
                    <dd>
                        <t>Mandatory. Name of the sensor, which must be reasonably unique,
                            however still bear some meaningful sense.</t>
                        <t>This attribute usually denotes the hierarchy of organizational units
                            the sensor belongs to and its own name.
                            It MAY also be used to distinguish multiple sensors running with
                            the same IP address.</t>
                    </dd>
                
                    <dt>Hostname</dt>
                    <dd>
                        <t>Optional. The sensor's hostname.</t>
                        <t>This SHOULD be a fully qualified domain name, but may not conform
                            exactly because values extracted from logs, messages, DNS, etc.
                            may themselves be malformed.</t>
                        <t>An empty string MAY be used to explicitly state that this value
                            was inquired but not found (missing DNS entry).</t>
                    </dd>
                
                    <dt>Model</dt>
                    <dd>
                        <t>Optional. The sensor model's description (usually its generic name,
                            brand and version).</t>
                    </dd>
                
                    <dt>GeoLocation</dt>
                    <dd>
                        <t>Optional. GPS coordinates for the analyzerr.</t>
                    </dd>
                
                    <dt>UnLocation</dt>
                    <dd>
                        <t>Optional. Standard UN/Locode for the sensor.</t>
                    </dd>
                
                    <dt>Location</dt>
                    <dd>
                        <t>Optional. Internal name for the location of the sensor.</t>
                    </dd>
                
                    <dt>CaptureZone</dt>
                    <dd>
                        <t>Optional. A string that describes the "capture zone" of the sensor,
                            as a JSON-serialized string.</t>
                        <t>Depending on the type of sensor, the capture zone may for instance
                            refer to:</t>
                        <ul>
                            <li>
                                <t>A JSON object describing a camera's settings (elevation, horizontal
                                    and vertical field of view, azimuth, etc.)</t>
                            </li>
                            <li>
                                <t>A description of the IP network where packet capture is taking place.</t>
                            </li>
                        </ul>
                    </dd>
                </dl>
      </section>
      <section anchor="class_source">
        <name>The Source Class</name>
        <t>The Source class describes the origin(s) of the event(s) leading up to the alert.</t>
        <figure anchor="class_source_diagram">
          <name>The Source class</name>
          <artwork type="ascii-art" align="center">+------------------------+
|         Source         |
+------------------------+
| IP         IP          |
| STRING     Hostname    |
| STRING     Note        |
| STRING[]   TI          |
| STRING     User        |
| EMAIL      Email       |
| PROTOCOL[] Protocol    |
| INT[]      Port        |
| GEOLOC     GeoLocation |
| UNLOCODE   UnLocation  |
| STRING     Location    |
| ID[]       Attachment  |
+------------------------+</artwork>
        </figure>
        <t>The Source class has the following attributes:</t>
        <dl newline="true">
                    <dt>IP</dt>
                    <dd>
                        <t>Optional. Source IP address.</t>
                    </dd>
                
                    <dt>Hostname</dt>
                    <dd>
                        <t>Optional. Hostname of this source.</t>
                        <t>This SHOULD be a fully qualified domain name, but may not conform
                            exactly because values extracted from logs, messages, DNS, etc.
                            may themselves be malformed.</t>
                        <t>An empty string MAY be used to explicitly state that this value
                            was inquired but not found (missing DNS entry).</t>
                    </dd>
                
                    <dt>Note</dt>
                    <dd>
                        <t>Optional. Free text human-readable additional note for this source.</t>
                    </dd>
                
                    <dt>TI</dt>
                    <dd>
                        <t>Optional. Threat Intelligence data about the source.</t>
                        <t>Values in this list MUST use the format "attribute:origin",
                            where "attribute" refers to the attribute inside this source
                            found inside a Threat Intelligence database, and "origin"
                            contains a short identifier for the Threat Intelligence database.
                            E.g. "IP:Dshield".</t>
                        <t>Please note that the same attribute may appear multiple times
                            inside the list (because a match was found in multiple
                            Threat Intelligence databases).</t>
                    </dd>
                
                    <dt>User</dt>
                    <dd>
                        <t>Optional. User ID or login responsible for the alert.</t>
                    </dd>
                
                    <dt>Email</dt>
                    <dd>
                        <t>Optional. Email address responsible for the alert.</t>
                        <t>E.g. the value of the "Reply-To" or "From" header inside
                            a phishing e-mail.</t>
                    </dd>
                
                    <dt>Protocol</dt>
                    <dd>
                        <t>Optional. Protocols related to connections from/to this source.</t>
                        <t>If several protocols are stacked, they MUST be ordered from
                            the lowest (the closest to the medium) to the highest (the closest
                            to the application) according to the ISO/OSI model.</t>
                    </dd>
                
                    <dt>Port</dt>
                    <dd>
                        <t>Optional. Source ports involved in the alert.</t>
                        <t>Values in this list MUST be integers and MUST be in the range 1-65535.</t>
                    </dd>
                
                    <dt>GeoLocation</dt>
                    <dd>
                        <t>Optional. GPS coordinates for the source.</t>
                    </dd>
                
                    <dt>UnLocation</dt>
                    <dd>
                        <t>Optional. Standard UN/Locode for the source.</t>
                    </dd>
                
                    <dt>Location</dt>
                    <dd>
                        <t>Optional. Internal name for the location of the source.</t>
                    </dd>
                
                    <dt>Attachment</dt>
                    <dd>
                        <t>Optional. Identifiers for attachments related to this source.</t>
                        <t>Each identifier listed here MUST match the "Name" attribute for one
                            of the attachments described using the <xref target="class_attachment">Attachment class</xref>.</t>
                    </dd>
                </dl>
      </section>
      <section anchor="class_target">
        <name>The Target Class</name>
        <t>The Target class describes the target(s) impacted by the event(s) leading up to the alert.</t>
        <figure anchor="class_target_diagram">
          <name>The Target class</name>
          <artwork type="ascii-art" align="center">+------------------------+
|         Target         |
+------------------------+
| IP         IP          |
| STRING     Hostname    |
| STRING     Note        |
| STRING     Service     |
| STRING     User        |
| EMAIL      Email       |
| INT[]      Port        |
| GEOLOC     GeoLocation |
| UNLOCODE   UnLocation  |
| STRING     Location    |
| ID[]       Attachment  |
+------------------------+</artwork>
        </figure>
        <t>The Target class has the following attributes:</t>
        <dl newline="true">
                    <dt>IP</dt>
                    <dd>
                        <t>Optional. Target IP address.</t>
                    </dd>
                
                    <dt>Hostname</dt>
                    <dd>
                        <t>Optional. Hostname of this target.</t>
                        <t>This SHOULD be a fully qualified domain name, but may not conform
                            exactly because values extracted from logs, messages, DNS, etc.
                            may themselves be malformed.</t>
                        <t>An empty string MAY be used to explicitly state that this value
                            was inquired but not found (missing DNS entry).</t>
                    </dd>
                
                    <dt>Note</dt>
                    <dd>
                        <t>Optional. Free text human-readable additional note for this target.</t>
                    </dd>
                
                    <dt>Service</dt>
                    <dd>
                        <t>Optional. Service or process impacted by the alert.</t>
                    </dd>
                
                    <dt>User</dt>
                    <dd>
                        <t>Optional. User ID or login targeted by the alert.</t>
                    </dd>
                
                    <dt>Email</dt>
                    <dd>
                        <t>Optional. Email address targeted by the alert.</t>
                        <t>E.g. the value of the "To" header inside a phishing e-mail.</t>
                    </dd>
                
                    <dt>Port</dt>
                    <dd>
                        <t>Optional. Target ports involved in the alert.</t>
                        <t>Values in this list MUST be integers and MUST be in the range 1-65535.</t>
                    </dd>
                
                    <dt>GeoLocation</dt>
                    <dd>
                        <t>Optional. GPS coordinates for the target.</t>
                    </dd>
                
                    <dt>UnLocation</dt>
                    <dd>
                        <t>Optional. Standard UN/Locode for the target.</t>
                    </dd>
                
                    <dt>Location</dt>
                    <dd>
                        <t>Optional. Internal name for the location of the target.</t>
                    </dd>
                
                    <dt>Attachment</dt>
                    <dd>
                        <t>Optional. Identifiers for attachments related to this target.</t>
                        <t>Each identifier listed here MUST match the "Name" attribute for one
                            of the attachments described using the <xref target="class_attachment">Attachment class</xref>.</t>
                    </dd>
                </dl>
      </section>
      <section anchor="class_vector">
        <name>The Vector Class</name>
        <t>The Vector class describes the vector(s) of the event(s) leading up to the alert.
                •       Name, location, description, …</t>
        <figure anchor="class_vector_diagram">
          <name>The Vector class</name>
          <artwork type="ascii-art" align="center">+-------------------------+
|         Vector          |
+-------------------------+
| ENUM[]     Category     |
| STRING     ext-Category |
| STRING     Name         |
| STRING     Note         |
| STRING[]   TI           |
| GEOLOC     GeoLocation  |
| FLOAT      GeoRadius    |
| UNLOCODE   UnLocation   |
| STRING     Location     |
| ID[]       Attachment   |
+-------------------------+</artwork>
        </figure>
        <t>The Vector class has the following attributes:</t>
        <dl newline="true">
                    <dt>Category</dt>
                    <dd>
                        <t>Mandatory. Category for the detected "vector".</t>
                        <table anchor="enum-vector-category"><name>Vector categories</name>
                            
                            <thead>
                                    <tr>
                                        <th>
                                            <t>Rank</t>
                                        </th>
                                        <th>
                                            <t>Keyword</t>
                                        </th>
                                        <th>
                                            <t>Description</t>
                                        </th>
                                    </tr>
                                </thead><tbody>
                                    <tr>
                                        <td>
                                            <t>0</t>
                                        </td>
                                        <td>
                                            <t>Unknown</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>1</t>
                                        </td>
                                        <td>
                                            <t>Face</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>2</t>
                                        </td>
                                        <td>
                                            <t>RunningMan</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>3</t>
                                        </td>
                                        <td>
                                            <t>Human</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>4</t>
                                        </td>
                                        <td>
                                            <t>Man</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>5</t>
                                        </td>
                                        <td>
                                            <t>Woman</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>6</t>
                                        </td>
                                        <td>
                                            <t>Children</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>7</t>
                                        </td>
                                        <td>
                                            <t>Animal</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>8</t>
                                        </td>
                                        <td>
                                            <t>Object</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>9</t>
                                        </td>
                                        <td>
                                            <t>Blast</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>10</t>
                                        </td>
                                        <td>
                                            <t>Fire</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>11</t>
                                        </td>
                                        <td>
                                            <t>Wind</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>12</t>
                                        </td>
                                        <td>
                                            <t>Snow</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>13</t>
                                        </td>
                                        <td>
                                            <t>Rain</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>14</t>
                                        </td>
                                        <td>
                                            <t>Chemical</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>15</t>
                                        </td>
                                        <td>
                                            <t>Smoke</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>16</t>
                                        </td>
                                        <td>
                                            <t>Vapors</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>17</t>
                                        </td>
                                        <td>
                                            <t>Drug</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>18</t>
                                        </td>
                                        <td>
                                            <t>Device</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>19</t>
                                        </td>
                                        <td>
                                            <t>Drone</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>20</t>
                                        </td>
                                        <td>
                                            <t>Car</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>21</t>
                                        </td>
                                        <td>
                                            <t>Truck</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>22</t>
                                        </td>
                                        <td>
                                            <t>Vehicle</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>23</t>
                                        </td>
                                        <td>
                                            <t>Bird</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>24</t>
                                        </td>
                                        <td>
                                            <t>Storm</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>25</t>
                                        </td>
                                        <td>
                                            <t>HighTemperature</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>26</t>
                                        </td>
                                        <td>
                                            <t>Artifact</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>27</t>
                                        </td>
                                        <td>
                                            <t>Autonomous System</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>28</t>
                                        </td>
                                        <td>
                                            <t>Directory</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>29</t>
                                        </td>
                                        <td>
                                            <t>Domain Name</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>30</t>
                                        </td>
                                        <td>
                                            <t>Email Address</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>31</t>
                                        </td>
                                        <td>
                                            <t>Email Message</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>32</t>
                                        </td>
                                        <td>
                                            <t>File</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>33</t>
                                        </td>
                                        <td>
                                            <t>IPv4 Address</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>34</t>
                                        </td>
                                        <td>
                                            <t>IPv6 Address</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>35</t>
                                        </td>
                                        <td>
                                            <t>Mutex</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>36</t>
                                        </td>
                                        <td>
                                            <t>Network Traffic</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>37</t>
                                        </td>
                                        <td>
                                            <t>Process</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>38</t>
                                        </td>
                                        <td>
                                            <t>URL</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>39</t>
                                        </td>
                                        <td>
                                            <t>User Account</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>40</t>
                                        </td>
                                        <td>
                                            <t>Windows Registry Key</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>41</t>
                                        </td>
                                        <td>
                                            <t>X509 Certificate</t>
                                        </td>
                                        <td>
                                        </td>
                                    </tr>
                                    <tr>
                                        <td>
                                            <t>42</t>
                                        </td>
                                        <td>
                                            <t>ext-value</t>
                                        </td>
                                        <td>
                                            <t>A value used to indicate that this attribute is extended and the actual value is provided using the corresponding ext-* attribute. (see <xref target="private-extension-enum"/>)</t>
                                        </td>
                                    </tr>
                                </tbody>
                        </table>
                    </dd>
                
                    <dt>ext-Category</dt>
                    <dd>
                        <t>Optional.
                            A means by which to extend the Category attribute.  (see <xref target="private-extension-enum"/>)</t>
                    </dd>
                
                    <dt>Name</dt>
                    <dd>
                        <t>Optional. Name of the detected vector or "Unknown".</t>
                        <t>Please note that this name does not need to be unique
                            across vectors.</t>
                    </dd>
                
                    <dt>Note</dt>
                    <dd>
                        <t>Optional. Free text human-readable additional note for this vector.</t>
                    </dd>
                
                    <dt>TI</dt>
                    <dd>
                        <t>Optional. Threat Intelligence data about the vector.</t>
                        <t>Values in this list MUST use the format "attribute:origin",
                            where "attribute" refers to the attribute inside this vector
                            found inside a Threat Intelligence database, and "origin"
                            contains a short identifier for the Threat Intelligence database.
                            E.g. "Name:FBI-Wanted".</t>
                        <t>Please note that the same attribute may appear multiple times
                            inside the list (because a match was found in multiple
                            Threat Intelligence databases).</t>
                    </dd>
                
                    <dt>GeoLocation</dt>
                    <dd>
                        <t>Optional. GPS coordinates for the vector.</t>
                    </dd>
                
                    <dt>GeoRadius</dt>
                    <dd>
                        <t>Optional. Estimated radius around the provided geolocation in meters.</t>
                        <t>This attribute can be interpreted as an error margin related to
                            the detection of this vector.</t>
                    </dd>
                
                    <dt>UnLocation</dt>
                    <dd>
                        <t>Optional. Standard UN/Locode for the vector.</t>
                    </dd>
                
                    <dt>Location</dt>
                    <dd>
                        <t>Optional. Internal name for the location of the vector.</t>
                    </dd>
                
                    <dt>Attachment</dt>
                    <dd>
                        <t>Optional. Identifiers for attachments related to this vector.</t>
                        <t>Each identifier listed here MUST match the "Name" attribute for one
                            of the attachments described using the <xref target="class_attachment">Attachment class</xref>.</t>
                    </dd>
                </dl>
      </section>
      <section anchor="class_attachment">
        <name>The Attachment Class</name>
        <t>The Attachment class contains additional data which was captured
                in relation with the event.</t>
        <figure anchor="class_attachment_diagram">
          <name>The Attachment class</name>
          <artwork type="ascii-art" align="center">+----------------------------+
|         Attachment         |
+----------------------------+
| ID         Name            |
| STRING     FileName        |
| HASH[]     Hash            |
| INT        Size            |
| URI[]      Ref             |
| URI[]      ExternalURI     |
| STRING     Note            |
| MEDIATYPE  ContentType     |
| STRING     ContentEncoding |
| STRING     Content         |
+----------------------------+</artwork>
        </figure>
        <t>The Attachment class has the following attributes:</t>
        <dl newline="true">
                    <dt>Name</dt>
                    <dd>
                        <t>Mandatory. A unique identifier among attachments that can be used
                            to reference this attachment from other classes using the
                            "Attachment" attribute.</t>
                    </dd>
                
                    <dt>FileName</dt>
                    <dd>
                        <t>Optional. Attachment filename.</t>
                        <t>This will usually be the original name of the captured file
                            or the name of the file containing the captured content
                            (e.g. a packet capture file).</t>
                    </dd>
                
                    <dt>Hash</dt>
                    <dd>
                        <t>Optional. A list of hash results for the attachment's Content.</t>
                        <t>The values in this list are computed by taking the raw value
                            of the attachment's "Content" attribute.
                            The hash result is computed before any other transformation
                            (e.g. Base64 encoding) is applied to the content, so that a
                            receiving IDMEF system may reverse the transformation, apply
                            the same hashing function and obtain the same hash result.
                            See also the definition for the "ContentEncoding" attribute below.</t>
                        <t>It is RECOMMENDED that compatible implementations use one of
                            the hashing functions from the SHA-2 <xref target="RFC6234"/> or
                            SHA-3 <xref target="NIST.FIPS.202"/> families to compute the hash
                            results in this list.</t>
                    </dd>
                
                    <dt>Size</dt>
                    <dd>
                        <t>Optional. Length of the content (in bytes).</t>
                        <t>This value MUST be a non-negative integer.</t>
                    </dd>
                
                    <dt>Ref</dt>
                    <dd>
                        <t>Optional.
                            References to sources of information related to the alert and/or
                            vulnerability, and specific to this attachment.</t>
                    </dd>
                
                    <dt>ExternalURI</dt>
                    <dd>
                        <t>Optional. If the attachment's content is available and/or recognizable
                            from an external resource, this is the URI (usually a URL) to that resource.</t>
                        <t>This MAY also be a URN in a registered or unregistered ad-hoc namespace
                            bearing reasonable information value and uniqueness, such as
                            "urn:mhr:55eaf7effadc07f866d1eaed9c64e7ee49fe081a" or
                            "magnet:?xt=urn:sha1:YNCKHTQCWBTRNJIV4WNAE52SJUQCZO5C".</t>
                    </dd>
                
                    <dt>Note</dt>
                    <dd>
                        <t>Optional. Free text human-readable additional note for this attachment.</t>
                    </dd>
                
                    <dt>ContentType</dt>
                    <dd>
                        <t>Optional. Internet Media Type of the attachment.</t>
                        <t>For compatibility reasons, implementations SHOULD prefer one of the
                            well-known media types registered in IANA .</t>
                    </dd>
                
                    <dt>ContentEncoding</dt>
                    <dd>
                        <t>Optional. Content encoding.</t>
                        <t>The following encodings are defined in this version of the specification:</t>
                        <ul>
                            <li>
                                <t>"json": The content refers to a JSON object which has been serialized
                                    to a string using the serialization procedure defined in <xref target="RFC8259"/>.</t>
                            </li>
                            <li>
                                <t>"base64": The content has been serialized using the Base64 encoding
                                    defined in <xref target="RFC4648"/>.</t>
                            </li>
                        </ul>
                        <t>The "base64" encoding SHOULD be used when the content contains binary data.
                            If omitted, the "json" encoding MUST be assumed.</t>
                    </dd>
                
                    <dt>Content</dt>
                    <dd>
                        <t>Optional. The attachment's content, in case it is directly embedded
                            inside the message.</t>
                        <t>For large attachments, it is RECOMMENDED that implementations make use
                            of the "ExternalURI" attribute to refererence a copy of the content saved
                            in an external storage mechanism.</t>
                    </dd>
                </dl>
      </section>
      <section anchor="json-sm">
        <name>The JavaScript Object Notation Serialization Method</name>
        <t>This serialization method aims to convert IDMEFv2 messages to a
                format that is easy to parse and process, both by software/hardware
                processors, as well as humans. It relies on the the JavaScript
                Object Notation (JSON) Data Interchange Format defined in [RFC8259].</t>
        <t>Conforming implementations MUST implement all the requirements
                specified in [RFC8259].</t>
        <t>In addition, the following rules MUST be observed when serializing an
                IDMEFv2 message:</t>
        <ul>
                <li>
                    <t>The top-level Alert class (Section 4.2) is represented as a JSON
                        object ([RFC8259]). This JSON object is returned to the calling
                        process at the end of the serialization process.</t>
                </li>
                <li>
                    <t>Aggregate classes are represented as JSON objects and stored as
                        members of the top-level JSON object, using the same name as in
                        the IDMEF data model. E.g. the appears under the name "Analyzer"
                        inside the top-level JSON object.</t>
                </li>
                <li>
                    <t>Attributes are stored as members of the JSON object representing
                        the class they belong to, using the same name as in the IDMEF data
                        model. E.g. the "Version" attribute from the is stored under the
                        name "Version" inside the top-level JSON object.</t>
                </li>
                <li>
                    <t>Lists from the IDMEF data model are represented as JSON arrays
                        ([RFC8259]). This also applies to aggregate classes where a list
                        is expected. E.g. the "Sensor" member inside the top-level JSON
                        object contains a list of objects, where each object represents an
                        instance of the .</t>
                </li>
                <li>
                    <t>The various string-based data types listed in Section 3 are
                        represented as JSON strings ([RFC8259]). Please note that the
                        issues outlined in [RFC8259] regarding strings processing also
                        apply here.</t>
                </li>
                <li>
                    <t>IDMEF attributes with the "NUMBER" data type are represented as
                        JSON numbers ([RFC8259]).</t>
                </li>
            </ul>
      </section>
      <section>
        <name>Attributes completeness</name>
        <t>The next table shows when each attributes is required depending on it's Type:
                physical, cyber or availability.</t>
        <t>Legend:</t>
        <ul>
                <li>
                    <t>R: REQUIRED</t>
                </li>
                <li>
                    <t>r: Recommanded</t>
                </li>
                <li>
                    <t>o: Optional</t>
                </li>
                <li>
                    <t>NA: Not Applicable</t>
                </li>
            </ul>
        <table><name>Attributes completness - Alert</name>
                
                <thead>
                        <tr>
                            <th>
                                <t>Attributes</t>
                            </th>
                            <th>
                                <t>Type</t>
                            </th>
                            <th>
                                <t>Phy</t>
                            </th>
                            <th>
                                <t>Cyb</t>
                            </th>
                            <th>
                                <t>Avail</t>
                            </th>
                        </tr>
                        <tr>
                            <th>
                                <t>Alert</t>
                            </th>
                            <th>
                            </th>
                            <th>
                            </th>
                            <th>
                            </th>
                            <th>
                            </th>
                        </tr>
                    </thead><tbody>
                        <tr>
                            <td>
                                <t>Version</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>ID</t>
                            </td>
                            <td>
                                <t>UUID</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Entity</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Category</t>
                            </td>
                            <td>
                                <t>Array of ENUM</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Cause</t>
                            </td>
                            <td>
                                <t>ENUM</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Description</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Status</t>
                            </td>
                            <td>
                                <t>ENUM</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Priority</t>
                            </td>
                            <td>
                                <t>ENUM</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Confidence</t>
                            </td>
                            <td>
                                <t>Number</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Note</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>CreateTime</t>
                            </td>
                            <td>
                                <t>Timestamp</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>StartTime</t>
                            </td>
                            <td>
                                <t>Timestamp</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>CeaseTime</t>
                            </td>
                            <td>
                                <t>Timestamp</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>DeleteTime</t>
                            </td>
                            <td>
                                <t>Timestamp</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>AltNames</t>
                            </td>
                            <td>
                                <t>Array of String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>AltCategory</t>
                            </td>
                            <td>
                                <t>Array of String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Ref</t>
                            </td>
                            <td>
                                <t>Array of URI</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>CorrelID</t>
                            </td>
                            <td>
                                <t>Array of UUID</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>AggrCondition</t>
                            </td>
                            <td>
                                <t>Array of String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>PredID</t>
                            </td>
                            <td>
                                <t>Array of UUID</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>RelID</t>
                            </td>
                            <td>
                                <t>Array of UUID</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                    </tbody>
            </table>
        <table><name>Attributes completness - Analyzer</name>
                
                <thead>
                        <tr>
                            <th>
                                <t>Attributes</t>
                            </th>
                            <th>
                                <t>Type</t>
                            </th>
                            <th>
                                <t>Phy</t>
                            </th>
                            <th>
                                <t>Cyb</t>
                            </th>
                            <th>
                                <t>Avail</t>
                            </th>
                        </tr>
                        <tr>
                            <th>
                                <t>Analyzer</t>
                            </th>
                            <th>
                                <t>Class</t>
                            </th>
                            <th>
                                <t>R</t>
                            </th>
                            <th>
                                <t>R</t>
                            </th>
                            <th>
                                <t>R</t>
                            </th>
                        </tr>
                    </thead><tbody>
                        <tr>
                            <td>
                                <t>IP</t>
                            </td>
                            <td>
                                <t>IPAddress</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Name</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Hostname</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Type</t>
                            </td>
                            <td>
                                <t>ENUM</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Model</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Category</t>
                            </td>
                            <td>
                                <t>Array of ENUM</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Data</t>
                            </td>
                            <td>
                                <t>Array of ENUM</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Method</t>
                            </td>
                            <td>
                                <t>Array of ENUM</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>GeoLocation</t>
                            </td>
                            <td>
                                <t>GeoLocation</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>UnLocation</t>
                            </td>
                            <td>
                                <t>UN/LOCODE</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Location</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                    </tbody>
            </table>
        <table><name>Attributes completness - Sensor</name>
                
                <thead>
                        <tr>
                            <th>
                                <t>Attributes</t>
                            </th>
                            <th>
                                <t>Type</t>
                            </th>
                            <th>
                                <t>Phy</t>
                            </th>
                            <th>
                                <t>Cyb</t>
                            </th>
                            <th>
                                <t>Avail</t>
                            </th>
                        </tr>
                        <tr>
                            <th>
                                <t>Sensor</t>
                            </th>
                            <th>
                                <t>Array of Class</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                        </tr>
                    </thead><tbody>
                        <tr>
                            <td>
                                <t>IP</t>
                            </td>
                            <td>
                                <t>IPAddress</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Name</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Hostname</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Model</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>UnLocation</t>
                            </td>
                            <td>
                                <t>UN/LOCODE</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Location</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>CaptureZone</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                    </tbody>
            </table>
        <table><name>Attributes completness - Source</name>
                
                <thead>
                        <tr>
                            <th>
                                <t>Attributes</t>
                            </th>
                            <th>
                                <t>Type</t>
                            </th>
                            <th>
                                <t>Phy</t>
                            </th>
                            <th>
                                <t>Cyb</t>
                            </th>
                            <th>
                                <t>Avail</t>
                            </th>
                        </tr>
                        <tr>
                            <th>
                                <t>Source</t>
                            </th>
                            <th>
                                <t>Array of Class</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                        </tr>
                    </thead><tbody>
                        <tr>
                            <td>
                                <t>UnLocation</t>
                            </td>
                            <td>
                                <t>UN/LOCODE</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Location</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>GeoLocation</t>
                            </td>
                            <td>
                                <t>GeoLocation</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Note</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>TI</t>
                            </td>
                            <td>
                                <t>Array of String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>IP</t>
                            </td>
                            <td>
                                <t>IPAddress</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Hostname</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>User</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Email</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Protocol</t>
                            </td>
                            <td>
                                <t>Array of ProtocolName</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Port</t>
                            </td>
                            <td>
                                <t>Array of Port</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Attachment</t>
                            </td>
                            <td>
                                <t>Array of AttachmentName</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                    </tbody>
            </table>
        <table><name>Attributes completness - Target</name>
                
                <thead>
                        <tr>
                            <th>
                                <t>Attributes</t>
                            </th>
                            <th>
                                <t>Type</t>
                            </th>
                            <th>
                                <t>Phy</t>
                            </th>
                            <th>
                                <t>Cyb</t>
                            </th>
                            <th>
                                <t>Avail</t>
                            </th>
                        </tr>
                        <tr>
                            <th>
                                <t>Target</t>
                            </th>
                            <th>
                                <t>Array of Class</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>R</t>
                            </th>
                            <th>
                                <t>R</t>
                            </th>
                        </tr>
                    </thead><tbody>
                        <tr>
                            <td>
                                <t>UnLocation</t>
                            </td>
                            <td>
                                <t>UN/LOCODE</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Location</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>GeoLocation</t>
                            </td>
                            <td>
                                <t>GeoLocation</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Note</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>IP</t>
                            </td>
                            <td>
                                <t>IPAddress</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Hostname</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Service</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>User</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Email</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Port</t>
                            </td>
                            <td>
                                <t>Array of Port</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Attachment</t>
                            </td>
                            <td>
                                <t>Array of AttachmentName</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                    </tbody>
            </table>
        <table><name>Attributes completness - Vector</name>
                
                <thead>
                        <tr>
                            <th>
                                <t>Attributes</t>
                            </th>
                            <th>
                                <t>Type</t>
                            </th>
                            <th>
                                <t>Phy</t>
                            </th>
                            <th>
                                <t>Cyb</t>
                            </th>
                            <th>
                                <t>Avail</t>
                            </th>
                        </tr>
                        <tr>
                            <th>
                                <t>Vector</t>
                            </th>
                            <th>
                                <t>Array of Class</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                        </tr>
                    </thead><tbody>
                        <tr>
                            <td>
                                <t>Category</t>
                            </td>
                            <td>
                                <t>Array of ENUM</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>TI</t>
                            </td>
                            <td>
                                <t>Array of String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Name</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Size</t>
                            </td>
                            <td>
                                <t>ENUM</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>UnLocation</t>
                            </td>
                            <td>
                                <t>UN/LOCODE</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>GeoLocation</t>
                            </td>
                            <td>
                                <t>GeoLocation</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>GeoRadius</t>
                            </td>
                            <td>
                                <t>Number</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Location</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Note</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                            <td>
                                <t>NA</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Attachment</t>
                            </td>
                            <td>
                                <t>Array of AttachmentName</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                    </tbody>
            </table>
        <table><name>Attributes completness - Attachment</name>
                
                <thead>
                        <tr>
                            <th>
                                <t>Attributes</t>
                            </th>
                            <th>
                                <t>Type</t>
                            </th>
                            <th>
                                <t>Phy</t>
                            </th>
                            <th>
                                <t>Cyb</t>
                            </th>
                            <th>
                                <t>Avail</t>
                            </th>
                        </tr>
                        <tr>
                            <th>
                                <t>Attachment</t>
                            </th>
                            <th>
                                <t>Array of Class</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                            <th>
                                <t>o</t>
                            </th>
                        </tr>
                    </thead><tbody>
                        <tr>
                            <td>
                                <t>Name</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>FileName</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Hash</t>
                            </td>
                            <td>
                                <t>Array of Hashes</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Size</t>
                            </td>
                            <td>
                                <t>Number</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Ref</t>
                            </td>
                            <td>
                                <t>Array of URI</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>ExternalURI</t>
                            </td>
                            <td>
                                <t>Array of URI</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Note</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>ContentType</t>
                            </td>
                            <td>
                                <t>MediaType</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>ContentEncoding</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Content</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                            <td>
                                <t>o</t>
                            </td>
                        </tr>
                    </tbody>
            </table>
        <table><name>Attributes completness</name>
                
                <thead>
                        <tr>
                            <th>
                                <t>Attributes</t>
                            </th>
                            <th>
                                <t>Type</t>
                            </th>
                            <th>
                                <t>Phy</t>
                            </th>
                            <th>
                                <t>Cyb</t>
                            </th>
                            <th>
                                <t>Avail</t>
                            </th>
                        </tr>
                        <tr>
                            <th>
                                <t>Name</t>
                            </th>
                            <th>
                                <t>String</t>
                            </th>
                            <th>
                                <t>R</t>
                            </th>
                            <th>
                                <t>R</t>
                            </th>
                            <th>
                                <t>R</t>
                            </th>
                        </tr>
                    </thead><tbody>
                        <tr>
                            <td>
                                <t>Reference</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                            <td>
                                <t>r</t>
                            </td>
                        </tr>
                        <tr>
                            <td>
                                <t>Content</t>
                            </td>
                            <td>
                                <t>String</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                            <td>
                                <t>R</t>
                            </td>
                        </tr>
                    </tbody>
            </table>
      </section>
    </section>
    <section>
      <name>Security Considerations</name>
      <t>This document describes a data representation for exchanging security-related
            information between incident detection system implementations.  Although there
            are no security concerns directly applicable to the format of this data, the
            data itself may contain security-sensitive information whose confidentiality,
            integrity, and/or availability may need to be protected.</t>
      <t>This suggests that the systems used to collect, transmit, process, and store
            this data should be protected against unauthorized use and that the data itself
            should be protected against unauthorized access.</t>
      <t>The underlying messaging format and protocol used to exchange instances of the
            IDMEF MUST provide appropriate guarantees of confidentiality, integrity, and
            authenticity. The use of a standardized security protocol is encouraged.</t>
      <t>The draft-lehmann-idmefv2-https-transport-01.txt document defines the transportation of IDMEF over HTTPs that provides such
            security.</t>
    </section>
    <section>
      <name>IANA Considerations</name>
      <t>This document creates 10 identically structured registries to be
            managed by IANA:</t>
      <ul>
            <li>
                <t>Name of the parent registry: "Incident Detection Message Exchange Format v2 (IDMEF)"</t>
            </li>
            <li>
                <t>URL of the registry: &lt;http://www.iana.org/assignments/idmef2&gt;</t>
            </li>
            <li>
                <t>Namespace format: A registry entry consists of:</t>
                <ul>
                    <li>
                        <t>Value.  A value for a given IDMEF attribute.  It MUST conform
                            to the formatting specified by the IDMEF "ENUM" data type
                            (<xref target="data-types-enums"/>).</t>
                    </li>
                    <li>
                        <t>Description. A short description of the enumerated value.</t>
                    </li>
                    <li>
                        <t>Reference. An optional list of URIs to further describe the value.</t>
                    </li>
                </ul>
            </li>
            <li>
                <t>Allocation policy: Expert Review per <xref target="RFC8126"/>.
                    This reviewer will ensure that the requested registry entry conforms
                    to the prescribed formatting. The reviewer will also ensure that the
                    entry is an appropriate value for the attribute per the information
                    model (<xref target="model"/>).</t>
            </li>
        </ul>
      <t>The registries to be created are named in the "Registry Name" column
            of <xref target="iana-registries"/>. Each registry is initially populated
            with values and descriptions that come from an attribute specified
            in the IDMEF model (<xref target="model"/>).
            The initial values for the Value and Description fields of a given
            registry are listed in "Initial Values".
            The "Initial Values" column points to a table in this document that
            lists and describes each enumerated value. Each enumerated value
            in the table gets a corresponding entry in a given registry.
            The initial value of the Reference field of every registry entry
            described below should be this document.</t>
      <table anchor="iana-registries"><name>IANA Enumerated Value Registries</name>
            
            <thead>
                    <tr>
                        <th>
                            <t>Registry Name</t>
                        </th>
                        <th>
                            <t>Initial Values</t>
                        </th>
                    </tr>
                </thead><tbody>
                    <tr>
                        <td>
                            <t>Alert-Category</t>
                        </td>
                        <td>
                            <t><xref target="enum-alert-category"/> (<xref target="class_alert">Alert class</xref>)</t>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <t>Alert-Cause</t>
                        </td>
                        <td>
                            <t><xref target="enum-alert-cause"/> (<xref target="class_alert">Alert class</xref>)</t>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <t>Alert-Priority</t>
                        </td>
                        <td>
                            <t><xref target="enum-alert-priority"/> (<xref target="class_alert">Alert class</xref>)</t>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <t>Alert-Status</t>
                        </td>
                        <td>
                            <t><xref target="enum-alert-status"/> (<xref target="class_alert">Alert class</xref>)</t>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <t>Analyzer-Category</t>
                        </td>
                        <td>
                            <t><xref target="enum-analyzer-category"/> (<xref target="class_alert">Alert class</xref>)</t>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <t>Analyzer-Data</t>
                        </td>
                        <td>
                            <t><xref target="enum-analyzer-data"/> (<xref target="class_analyzer">Analyzer class</xref>)</t>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <t>Analayzer-Method</t>
                        </td>
                        <td>
                            <t><xref target="enum-analyzer-method"/> (<xref target="class_analyzer">Analyzer class</xref>)</t>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <t>Analyzer-Type</t>
                        </td>
                        <td>
                            <t><xref target="enum-analyzer-type"/> (<xref target="class_analyzer">Analyzer class</xref>)</t>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <t>Vector-Category</t>
                        </td>
                        <td>
                            <t><xref target="enum-vector-category"/> (<xref target="class_vector">Vector</xref>)</t>
                        </td>
                    </tr>
                </tbody>
        </table>
    </section>
    <section>
      <name>Acknowledgement</name>
      <t>The following groups and individuals contributed to the creation of this document and should be recognized for their efforts.</t>
      <ul>
            <li>
                <t>The former Prelude SIEM team :
                    Thomas Andrejak &amp; François Poirotte (Co-authors of the first version of this document),
                    Antoine Luong, Song Tran, Selim Menouar and Camille Gardet</t>
            </li>
            <li>
                <t>The core members of the SECEF (SECurity Exchange Format) consortium :
                    Herve Debar (Author of RFC 4765 - IDMEFv1), Guillaume Hiet and François Dechelle</t>
            </li>
            <li>
                <t>The H2020 7SHIELD project (Safety and Security Standards of Space Systems, ground Segments
                    and Satellite data assets , via prevention, detection, response and mitigation of physical
                    and cyber threats) who implemented in real scale first versions of IDMEFv2 on five pilots
                    around Europe helping greatly to improve it.</t>
            </li>
            <li>
                <t>The CESNET team for their work on the [IDEA0] format (based on IDMEFv1) which inspired
                    multiples concepts to IDMEFv2.</t>
            </li>
            <li>
                <t>The [ENISA-RIST] Reference Security Incident Taxonomy Working Group</t>
            </li>
        </ul>
    </section>
  </middle>
  <back>
    <references title="Normative References">
      <reference anchor="RFC5321" target="https://www.rfc-editor.org/info/rfc5321">
  <front>
    <title>Simple Mail Transfer Protocol</title>
    <author fullname="J. Klensin" initials="J." surname="Klensin"/>
    <date month="October" year="2008"/>
    <abstract>
      <t>This document is a specification of the basic protocol for Internet electronic mail transport. It consolidates, updates, and clarifies several previous documents, making all or parts of most of them obsolete. It covers the SMTP extension mechanisms and best practices for the contemporary Internet, but does not provide details about particular extensions. Although SMTP was designed as a mail transport and delivery protocol, this specification also contains information that is important to its use as a "mail submission" protocol for "split-UA" (User Agent) mail reading systems and mobile environments. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="5321"/>
  <seriesInfo name="DOI" value="10.17487/RFC5321"/>
</reference>
      <reference anchor="RFC2046" target="https://www.rfc-editor.org/info/rfc2046">
  <front>
    <title>Multipurpose Internet Mail Extensions (MIME) Part Two: Media Types</title>
    <author fullname="N. Freed" initials="N." surname="Freed"/>
    <author fullname="N. Borenstein" initials="N." surname="Borenstein"/>
    <date month="November" year="1996"/>
    <abstract>
      <t>This second document defines the general structure of the MIME media typing system and defines an initial set of media types. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="2046"/>
  <seriesInfo name="DOI" value="10.17487/RFC2046"/>
</reference>
      <reference anchor="RFC2119" target="https://www.rfc-editor.org/info/rfc2119">
  <front>
    <title>Key words for use in RFCs to Indicate Requirement Levels</title>
    <author fullname="S. Bradner" initials="S." surname="Bradner"/>
    <date month="March" year="1997"/>
    <abstract>
      <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="14"/>
  <seriesInfo name="RFC" value="2119"/>
  <seriesInfo name="DOI" value="10.17487/RFC2119"/>
</reference>
      <reference anchor="RFC5322" target="https://www.rfc-editor.org/info/rfc5322">
  <front>
    <title>Internet Message Format</title>
    <author fullname="P. Resnick" initials="P." role="editor" surname="Resnick"/>
    <date month="October" year="2008"/>
    <abstract>
      <t>This document specifies the Internet Message Format (IMF), a syntax for text messages that are sent between computer users, within the framework of "electronic mail" messages. This specification is a revision of Request For Comments (RFC) 2822, which itself superseded Request For Comments (RFC) 822, "Standard for the Format of ARPA Internet Text Messages", updating it to reflect current practice and incorporating incremental changes that were specified in other RFCs. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="5322"/>
  <seriesInfo name="DOI" value="10.17487/RFC5322"/>
</reference>
      <reference anchor="RFC3339" target="https://www.rfc-editor.org/info/rfc3339">
  <front>
    <title>Date and Time on the Internet: Timestamps</title>
    <author fullname="G. Klyne" initials="G." surname="Klyne"/>
    <author fullname="C. Newman" initials="C." surname="Newman"/>
    <date month="July" year="2002"/>
    <abstract>
      <t>This document defines a date and time format for use in Internet protocols that is a profile of the ISO 8601 standard for representation of dates and times using the Gregorian calendar.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="3339"/>
  <seriesInfo name="DOI" value="10.17487/RFC3339"/>
</reference>
      <reference anchor="RFC3986" target="https://www.rfc-editor.org/info/rfc3986">
  <front>
    <title>Uniform Resource Identifier (URI): Generic Syntax</title>
    <author fullname="T. Berners-Lee" initials="T." surname="Berners-Lee"/>
    <author fullname="R. Fielding" initials="R." surname="Fielding"/>
    <author fullname="L. Masinter" initials="L." surname="Masinter"/>
    <date month="January" year="2005"/>
    <abstract>
      <t>A Uniform Resource Identifier (URI) is a compact sequence of characters that identifies an abstract or physical resource. This specification defines the generic URI syntax and a process for resolving URI references that might be in relative form, along with guidelines and security considerations for the use of URIs on the Internet. The URI syntax defines a grammar that is a superset of all valid URIs, allowing an implementation to parse the common components of a URI reference without knowing the scheme-specific requirements of every possible identifier. This specification does not define a generative grammar for URIs; that task is performed by the individual specifications of each URI scheme. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="66"/>
  <seriesInfo name="RFC" value="3986"/>
  <seriesInfo name="DOI" value="10.17487/RFC3986"/>
</reference>
      <reference anchor="RFC4122" target="https://www.rfc-editor.org/info/rfc4122">
  <front>
    <title>A Universally Unique IDentifier (UUID) URN Namespace</title>
    <author fullname="P. Leach" initials="P." surname="Leach"/>
    <author fullname="M. Mealling" initials="M." surname="Mealling"/>
    <author fullname="R. Salz" initials="R." surname="Salz"/>
    <date month="July" year="2005"/>
    <abstract>
      <t>This specification defines a Uniform Resource Name namespace for UUIDs (Universally Unique IDentifier), also known as GUIDs (Globally Unique IDentifier). A UUID is 128 bits long, and can guarantee uniqueness across space and time. UUIDs were originally used in the Apollo Network Computing System and later in the Open Software Foundation\'s (OSF) Distributed Computing Environment (DCE), and then in Microsoft Windows platforms.</t>
      <t>This specification is derived from the DCE specification with the kind permission of the OSF (now known as The Open Group). Information from earlier versions of the DCE specification have been incorporated into this document. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4122"/>
  <seriesInfo name="DOI" value="10.17487/RFC4122"/>
</reference>
      <reference anchor="RFC4291" target="https://www.rfc-editor.org/info/rfc4291">
  <front>
    <title>IP Version 6 Addressing Architecture</title>
    <author fullname="R. Hinden" initials="R." surname="Hinden"/>
    <author fullname="S. Deering" initials="S." surname="Deering"/>
    <date month="February" year="2006"/>
    <abstract>
      <t>This specification defines the addressing architecture of the IP Version 6 (IPv6) protocol. The document includes the IPv6 addressing model, text representations of IPv6 addresses, definition of IPv6 unicast addresses, anycast addresses, and multicast addresses, and an IPv6 node's required addresses.</t>
      <t>This document obsoletes RFC 3513, "IP Version 6 Addressing Architecture". [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4291"/>
  <seriesInfo name="DOI" value="10.17487/RFC4291"/>
</reference>
      <reference anchor="RFC4648" target="https://www.rfc-editor.org/info/rfc4648">
  <front>
    <title>The Base16, Base32, and Base64 Data Encodings</title>
    <author fullname="S. Josefsson" initials="S." surname="Josefsson"/>
    <date month="October" year="2006"/>
    <abstract>
      <t>This document describes the commonly used base 64, base 32, and base 16 encoding schemes. It also discusses the use of line-feeds in encoded data, use of padding in encoded data, use of non-alphabet characters in encoded data, use of different encoding alphabets, and canonical encodings. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4648"/>
  <seriesInfo name="DOI" value="10.17487/RFC4648"/>
</reference>
      <reference anchor="RFC5234" target="https://www.rfc-editor.org/info/rfc5234">
  <front>
    <title>Augmented BNF for Syntax Specifications: ABNF</title>
    <author fullname="D. Crocker" initials="D." role="editor" surname="Crocker"/>
    <author fullname="P. Overell" initials="P." surname="Overell"/>
    <date month="January" year="2008"/>
    <abstract>
      <t>Internet technical specifications often need to define a formal syntax. Over the years, a modified version of Backus-Naur Form (BNF), called Augmented BNF (ABNF), has been popular among many Internet specifications. The current specification documents ABNF. It balances compactness and simplicity with reasonable representational power. The differences between standard BNF and ABNF involve naming rules, repetition, alternatives, order-independence, and value ranges. This specification also supplies additional rule definitions and encoding for a core lexical analyzer of the type common to several Internet specifications. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="68"/>
  <seriesInfo name="RFC" value="5234"/>
  <seriesInfo name="DOI" value="10.17487/RFC5234"/>
</reference>
      <reference anchor="RFC5952" target="https://www.rfc-editor.org/info/rfc5952">
  <front>
    <title>A Recommendation for IPv6 Address Text Representation</title>
    <author fullname="S. Kawamura" initials="S." surname="Kawamura"/>
    <author fullname="M. Kawashima" initials="M." surname="Kawashima"/>
    <date month="August" year="2010"/>
    <abstract>
      <t>As IPv6 deployment increases, there will be a dramatic increase in the need to use IPv6 addresses in text. While the IPv6 address architecture in Section 2.2 of RFC 4291 describes a flexible model for text representation of an IPv6 address, this flexibility has been causing problems for operators, system engineers, and users. This document defines a canonical textual representation format. It does not define a format for internal storage, such as within an application or database. It is expected that the canonical format will be followed by humans and systems when representing IPv6 addresses as text, but all implementations must accept and be able to handle any legitimate RFC 4291 format. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="5952"/>
  <seriesInfo name="DOI" value="10.17487/RFC5952"/>
</reference>
      <reference anchor="RFC8259" target="https://www.rfc-editor.org/info/rfc8259">
  <front>
    <title>The JavaScript Object Notation (JSON) Data Interchange Format</title>
    <author fullname="T. Bray" initials="T." role="editor" surname="Bray"/>
    <date month="December" year="2017"/>
    <abstract>
      <t>JavaScript Object Notation (JSON) is a lightweight, text-based, language-independent data interchange format. It was derived from the ECMAScript Programming Language Standard. JSON defines a small set of formatting rules for the portable representation of structured data.</t>
      <t>This document removes inconsistencies with other specifications of JSON, repairs specification errors, and offers experience-based interoperability guidance.</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="90"/>
  <seriesInfo name="RFC" value="8259"/>
  <seriesInfo name="DOI" value="10.17487/RFC8259"/>
</reference>
      <reference target="https://www.unicode.org/versions/Unicode14.0.0/" anchor="UNICODE">
        <front>
          <title>Unicode Standard</title>
          <author>
            <organization>Unicode Consortium</organization>
          </author>
          <date day="14" month="September" year="2021"/>
        </front>
        <seriesInfo name="version" value="14.0.0"/>
      </reference>
      <reference target="https://github.com/enisaeu/Reference-Security-Incident-Taxonomy-Task-Force/blob/master/working_copy/humanv1.md" anchor="ENISA-RIST">
        <front>
          <title>Reference Incident Classification Taxonomy</title>
          <author>
            <organization abbrev="ENISA">European Union Agency for Cybersecurity</organization>
          </author>
          <date day="26" month="January" year="2018"/>
        </front>
      </reference>
      <reference anchor="IANA_media_types" target="http://www.iana.org/assignments/media-types">
  <front>
    <title>Media Types</title>
    <author>
      <organization>IANA</organization>
    </author>
  </front>
</reference>
      <reference anchor="IANA_hash_function_text_names" target="http://www.iana.org/assignments/hash-function-text-names">
  <front>
    <title>Hash Function Textual Names</title>
    <author>
      <organization>IANA</organization>
    </author>
  </front>
</reference>
      <reference target="https://unece.org/trade/cefact/unlocode-code-list-country-and-territory" anchor="UN-LOCODE">
        <front>
          <title abbrev="UN/LOCODE">UN/LOCODE Code List by Country and Territory</title>
          <author>
            <organization abbrev="UNECE">United Nations Economic Commission for Europe</organization>
          </author>
          <date day="6" month="July" year="2021"/>
        </front>
      </reference>
    </references>
    <references title="Informative References">
      <reference anchor="RFC4765" target="https://www.rfc-editor.org/info/rfc4765">
  <front>
    <title>The Intrusion Detection Message Exchange Format (IDMEF)</title>
    <author fullname="H. Debar" initials="H." surname="Debar"/>
    <author fullname="D. Curry" initials="D." surname="Curry"/>
    <author fullname="B. Feinstein" initials="B." surname="Feinstein"/>
    <date month="March" year="2007"/>
    <abstract>
      <t>The purpose of the Intrusion Detection Message Exchange Format (IDMEF) is to define data formats and exchange procedures for sharing information of interest to intrusion detection and response systems and to the management systems that may need to interact with them.</t>
      <t>This document describes a data model to represent information exported by intrusion detection systems and explains the rationale for using this model. An implementation of the data model in the Extensible Markup Language (XML) is presented, an XML Document Type Definition is developed, and examples are provided. This memo defines an Experimental Protocol for the Internet community.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4765"/>
  <seriesInfo name="DOI" value="10.17487/RFC4765"/>
</reference>
      <reference anchor="RFC8126" target="https://www.rfc-editor.org/info/rfc8126">
  <front>
    <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
    <author fullname="M. Cotton" initials="M." surname="Cotton"/>
    <author fullname="B. Leiba" initials="B." surname="Leiba"/>
    <author fullname="T. Narten" initials="T." surname="Narten"/>
    <date month="June" year="2017"/>
    <abstract>
      <t>Many protocols make use of points of extensibility that use constants to identify various protocol parameters. To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper. For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
      <t>To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed. This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
      <t>This is the third edition of this document; it obsoletes RFC 5226.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="26"/>
  <seriesInfo name="RFC" value="8126"/>
  <seriesInfo name="DOI" value="10.17487/RFC8126"/>
</reference>
      <reference anchor="RFC6234" target="https://www.rfc-editor.org/info/rfc6234">
  <front>
    <title>US Secure Hash Algorithms (SHA and SHA-based HMAC and HKDF)</title>
    <author fullname="D. Eastlake 3rd" initials="D." surname="Eastlake 3rd"/>
    <author fullname="T. Hansen" initials="T." surname="Hansen"/>
    <date month="May" year="2011"/>
    <abstract>
      <t>Federal Information Processing Standard, FIPS</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6234"/>
  <seriesInfo name="DOI" value="10.17487/RFC6234"/>
</reference>
      <reference anchor="NIST.FIPS.202" target="https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.202.pdf">
<front>
<title>SHA-3 Standard: Permutation-Based Hash and Extendable-Output Functions</title>
<author initials="Morris J." surname="Dworkin" fullname="Morris J. Dworkin">
<organization>Information Technology Laboratory</organization>
</author>
<date year="2015" month="July"/>
</front>
<seriesInfo name="NIST" value="NIST FIPS 202"/>
<seriesInfo name="DOI" value="10.6028/NIST.FIPS.202"/>
</reference>
      <reference target="https://apps.dtic.mil/sti/pdfs/ADA280358.pdf" anchor="WGS84">
        <front>
          <title>Department of Defense World Geodetic System 1984: Its Definition and Relationships with Local Geodetic Systems</title>
          <author>
            <organization>National Imagery and Mapping Agency</organization>
          </author>
          <date year="1984"/>
        </front>
        <seriesInfo name="Third" value="Edition"/>
      </reference>
      <reference target="https://idea.cesnet.cz/en/definition" anchor="IDEA0">
        <front>
          <title>Intrusion Detection Extensible Alert version 0</title>
          <author>
            <organization>CESNET</organization>
          </author>
          <date day="25" month="September" year="2015"/>
        </front>
      </reference>
    </references>
    <section>
      <name>Examples</name>
      <t>This section contains several examples of events/incidents which may be
            described using the IDMEF Data Model defined in.</t>
      <t>For each example, the serialization method listed in Section 5 was used on the
            original IDMEF message to produce a JSON representation.</t>
      <section>
        <name>Physical intrusion</name>
        <t>Listing 1 describes an incident where an unidentified man was detected on
                company premises near the building where server room A is located.</t>
        <sourcecode type="none">{
  "Version": "2.0",
  "ID": "819df7bc-35ef-40d8-bbee-1901117370b1",
  "Description": "Potential intruder detected",
  "Priority": "Low",
  "Status": "Incident",
  "Cause": "Malicious",
  "CreateTime": "2021-05-10T16:52:13.075994+00:00",
  "StartTime": "2021-05-10T16:52:13+00:00",
  "Category": [
    "Intrusion.Burglary"
  ],
  "Analyzer": {
    "Name": "BigBrother",
    "Hostname": "bb.acme.com",
    "Type": "Physical",
    "Model": "Big Brother v42",
    "Category": [
      "HAR",
      "FRC"
    ],
    "Data": [
      "Images"
    ],
    "Method": [
      "Movement",
      "Biometric",
      "AI"
    ],
    "IP": "192.0.2.1"
  },
  "Sensor": [
    {
      "IP": "192.0.2.2",
      "Name": "Camera #23",
      "Model": "SuperDuper Camera v1",
      "Location": "Hallway to server room A1"
    }
  ],
  "Source": [
    {
      "Note": "Black Organization, aka. APT 4869"
    }
  ],
  "Vector": [
    {
      "Category": ["Man"],
      "TI": ["Name:FBI-Wanted"],
      "Name": "John Doe",
      "Note": "Codename Vodka, known henchman for APT 4869",
      "Location": "Hallway to server room A1",
      "Attachment": ["pic01", "wanted"]
    }
  ],
  "Attachment": [
    {
      "Name": "wanted",
      "FileName": "fbi-wanted-poster.jpg",
      "Size": 1234567,
      "Ref": ["https://www.fbi.gov/wanted/topten"],
      "ContentType": "image/jpg",
      "ContentEncoding": "base64",
      "Content": "..."
    },
    {
      "Name": "pic01",
      "Note": "Hi-res picture showing John Doe near server room A1",
      "ExternalURI": ["ftps://192.0.2.1/cam23/20210510165211.jpg"],
      "ContentType": "image/jpg"
    }
  ]
}</sourcecode>
      </section>
      <section>
        <name>Cyberattack</name>
        <t>Listing 2 describes an incident related to a potential bruteforce attack
                against the "root" user account of the server at 192.0.2.2 and 2001:db8::/32.</t>
        <sourcecode type="none">{
  "Version": "2.0",
  "ID": "819df7bc-35ef-40d8-bbee-1901117370b2",
  "Description": "Potential bruteforce attack on root user account",
  "Priority": "Medium",
  "CreateTime": "2021-05-10T16:55:29.196408+00:00",
  "StartTime": "2021-05-10T16:55:29+00:00",
  "Category": [
    "Attempt.Login"
  ],
  "Analyzer": {
    "Name": "SIEM",
    "Hostname": "siem.acme.com",
    "Type": "Cyber",
    "Model": "Concerto SIEM 5.2",
    "Category": [
      "SIEM",
      "LOG"
    ],
    "Data": [
      "Log"
    ],
    "Method": [
      "Monitor",
      "Signature"
    ],
    "IP": "192.0.2.1"
  },
  "Sensor": [
    {
      "IP": "192.0.2.5",
      "Name": "syslog",
      "Hostname": "www.acme.com",
      "Model": "rsyslog 8.2110",
      "Location": "Server room A1, rack 10"
    }
  ],
  "Target": [
    {
      "IP": "192.0.2.2",
      "Hostname": "www.acme.com",
      "Location": "Server room A1, rack 10",
      "User": "root"
    },
    {
      "IP": "2001:db8::/32",
      "Hostname": "www.acme.com",
      "Location": "Server room A1, rack 10",
      "User": "root"
    }
  ]
}</sourcecode>
      </section>
      <section>
        <name>Server outage</name>
        <t>Listing 3 describes an incident where the webserver at "www.example.com"
                encountered some kind of failure condition resulting in an outage.</t>
        <sourcecode type="none">{
  "Version": "2.0",
  "ID": "819df7bc-35ef-40d8-bbee-1901117370b3",
  "Description": "A server did not reply to an ICMP ping request",
  "Priority": "Medium",
  "Status": "Incident",
  "Cause": "Unknown",
  "CreateTime": "2021-05-10T16:59:11.875209+00:00",
  "StartTime": "2021-05-10T16:59:11.875209+00:00",
  "Category": [
    "Availability.Outage"
  ],
  "Analyzer": {
    "Name": "NMS",
    "Hostname": "nms.example.com",
    "Type": "Availability",
    "Model": "Concerto NMS 5.2",
    "Category": [
      "NMS"
    ],
    "Data": [
      "Network"
    ],
    "Method": [
      "Monitor"
    ],
    "IP": "192.0.2.1"
  },
  "Target": [
    {
      "IP": "192.168.1.2",
      "Hostname": "www.acme.com",
      "Service": "website",
      "Location": "Server room A1, rack 10"
    }
  ]
}</sourcecode>
      </section>
      <section>
        <name>Combined incident</name>
        <t>Listing 4 describes a combined incident resulting from the correlation of the
                previous physical, cyber and availability incidents.</t>
        <sourcecode type="none">{
  "Version": "2.0",
  "ID": "819df7bc-35ef-40d8-bbee-1901117370b4",
  "Description": "Intrusion and Sabotage detected",
  "Prioriy": "High",
  "Status": "Incident",
  "Cause": "Malicious",
  "CreateTime": "2021-05-10T16:59:15.075994+00:00",
  "StartTime": "2021-05-10T16:52:11+00:00",
  "Category": [
    "Intrusion.Burglary",
    "Attempt.Login",
    "Intrusion.SysCompromise",
    "Availability.Outage",
    "Availability.Sabotage",
    "Availability.Failure"
  ],
  "CorrelID": [
    "819df7bc-35ef-40d8-bbee-1901117370b1",
    "819df7bc-35ef-40d8-bbee-1901117370b2",
    "819df7bc-35ef-40d8-bbee-1901117370b3"
  ],
  "Analyzer": {
    "Name": "Correlator",
    "Hostname": "correlator.acme.com",
    "Type": "Combined",
    "Model": "Concerto Hybrid Correlator v5.2",
    "Category": [
    ],
    "Data": [
      "Alert"
    ],
    "Method": [
      "Correlation"
    ],
    "IP": "192.0.2.1"
  },
  "Source": [
    {
      "Note": "Black Organization, aka. APT 4869"
    }
  ],
  "Vector": [
    {
      "Category": ["Man"],
      "TI": ["Name:FBI-Wanted"],
      "Name": "John Doe",
      "Note": "Codename Vodka, known henchman for APT 4869",
      "Size": "Medium"
    }
  ],
  "Target": [
    {
      "Location": "Server room A1"
    },
    {
      "IP": "192.0.2.2",
      "Hostname": "www.acme.com",
      "User": "root"
    },
    {
      "IP": "192.0.2.2",
      "Hostname": "www.acme.com",
      "Service": "website"
    }
  ]
}</sourcecode>
      </section>
    </section>
    <section>
      <name>JSON Validation Schema (Non-normative)</name>
      <t>Listing 5 contains a JSON Schema that can be used to validate incoming IDMEF
            messages prior to processing. Please note that extraneous linebreaks have been
            included due to formatting constraints.</t>
      <sourcecode type="none">{
    "description": "JSON schema for the Intrusion Detection Message Exchange Format (IDMEF) version 2 (revision 2.D.V01)",
    "properties": {
        "Version": {
            "description": "The version of the IDMEF format in use by this alert. During the drafts tuning period the version is equal to the draft version. Therefore it is \"2.D.V01\" for Draft V01.",
            "enum": [
                "2.D.V01"
            ]
        },
        "ID": {
            "description": "Unique identifier for the alert.",
            "$ref": "#/definitions/uuidType"
        },
        "Entity": {
            "description": "Tenant ID to support multi-tenancy (e.g. decentralized infrastructure, local agency, subsidiary company, etc.). Should be used when there are multiple sites/locations or multiple tenants (e.g. by Managed Security Services Providers).",
            "type": "string"
        },
        "Category": {
            "description": "The incident's category &amp; subcategory as listed in using the format \"category.subcategory\" (e.g. \"Attempt.Exploit\").",
            "type": "array",
            "items": {
                "$ref": "#/definitions/categoryEnum"
            }
        },
        "ext-Category": {
            "description": "A means by which to extend the Category attribute. (see )",
            "type": "string"
        },
        "Cause": {
            "description": "Alert cause. The cause can be modified by any analyser on the way of the alert and later by the operator and/or the analyst if new investigation reveals and confirms a different cause of the event.",
            "$ref": "#/definitions/causeEnum"
        },
        "Description": {
            "description": "Short free text human-readable description of the event. The description can add detail to the alert classification for easiest/faster comprehension by the operator. Example : * Cryptoware WannaCry blocked on pegasus server * Unknown person entering through east doorway",
            "type": "string"
        },
        "Status": {
            "description": "Event state in the overall event lifecycle.",
            "$ref": "#/definitions/statusEnum"
        },
        "Priority": {
            "description": "Priority of the alert. Priority is defined by conbining impact and urgency. It indicates how fast the incident should be taken care of. Impact defines the enormity of the situation and mostly deals with \u201cHow Many\u201d or \u201chow much\u201d question. It can be in terms of people, finances, systems, etc. How many people and/or systems impacted, how badly are they impacted (is there potential physical impact ?) , how much financial loss, severity of legal liabilities,... Impact could be considered equivalent to \"Severity\". Urgency is associated with time. The time it takes to have the perceived Impact. For example, a high impact incident may have low urgency if the impact will not affect the business until the end of the financial year.",
            "$ref": "#/definitions/priorityEnum"
        },
        "Confidence": {
            "description": "A floating-point value between 0 and 1 indicating the analyzer's confidence in its own reliability of this particular detection, where 0 means that the detection is surely incorrect while 1 means there is no doubt about the detection made.",
            "type": "number"
        },
        "Note": {
            "description": "Free text human-readable additional note, possibly a longer description of the incident if is not already obvious. The Note attribute can be used to store any additional information. It can be additional information about the event and/or about the incident resolution, although the incident resolution information should in principle be stored elsewhere (with a link with the external tool in AltNames)",
            "type": "string"
        },
        "CreateTime": {
            "description": "Timestamp indicating when the message was created.",
            "$ref": "#/definitions/timestampType"
        },
        "StartTime": {
            "description": "Timestamp indicating the deduced start of the event. StartTime can be later than CreateTime in case or Alerts created from forecast information (e.g. Snow Storm in two days staring at 10h00)",
            "$ref": "#/definitions/timestampType"
        },
        "EndTime": {
            "description": "Timestamp indicating the deduced end of the event.",
            "$ref": "#/definitions/timestampType"
        },
        "AltNames": {
            "description": "Alternative identifiers; strings which help pair the event to internal systems' information (for example ticket IDs inside a request tracking systems).",
            "type": "array",
            "items": {
                "type": "string"
            }
        },
        "AltCategory": {
            "description": "Alternate categories from a reference other than (e.g. MISP, MITRE ATT@CK or another proprietary/internal reference).",
            "type": "array",
            "items": {
                "type": "string"
            }
        },
        "Ref": {
            "description": "References to sources of information related to the alert and/or vulnerability, and specific to this alert. This MAY be a URL to additional info, or a URN in a registered or unregistered ad-hoc namespace bearing reasonable information value and uniqueness, such as \"urn:cve:CVE-2013-2266\".",
            "type": "array",
            "items": {
                "type": "string",
                "format": "uri"
            }
        },
        "CorrelID": {
            "description": "Identifiers for the messages which were used as information sources to create this message, in case the message has been created based on correlation/analysis/deduction from other messages.",
            "type": "array",
            "items": {
                "$ref": "#/definitions/uuidType"
            }
        },
        "AggrCondition": {
            "description": "A list of IDMEF fields used to aggregate events. The values for these fields will be the same in all aggregated events. This attribute should mostly be set by intermediary nodes, which detect duplicates, or aggregate events, spanning multiple detection windows, into a longer one. The \"StartTime\" and \"EndTime\" attributes are used in conjunction with this attribute to describe the aggregation window.",
            "type": "array",
            "items": {
                "type": "string"
            }
        },
        "PredID": {
            "description": "A list containing the identifiers of previous messages which are obsoleted by this message. The obsoleted alerts SHOULD NOT be used anymore. This field can be used to \"update\" an alert.",
            "type": "array",
            "items": {
                "$ref": "#/definitions/uuidType"
            }
        },
        "RelID": {
            "description": "A list containing the identifiers of other messages related to this message.",
            "type": "array",
            "items": {
                "$ref": "#/definitions/uuidType"
            }
        },
        "Analyzer": {
            "type": "object",
            "items": {
                "description": "The Analyzer class describes the module that has analyzed the data captured by the sensors, identified an event of interest and decided to create an alert.",
                "properties": {
                    "IP": {
                        "description": "Analyzer IP address.",
                        "$ref": "#/definitions/ipType"
                    },
                    "Name": {
                        "description": "Name of the analyzer, which must be reasonably unique, however still bear some meaningful sense. This attribute usually denotes the hierarchy of organizational units the detector belongs to and its own name. It MAY also be used to distinguish multiple analyzers running with the same IP address.",
                        "type": "string"
                    },
                    "Hostname": {
                        "description": "Hostname of this analyzer. SHOULD be a fully-qualified domain name.",
                        "type": "string"
                    },
                    "Model": {
                        "description": "Analyzer model description (usually its generic name, brand and version).",
                        "type": "string"
                    },
                    "Type": {
                        "description": "Analyzer type.",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/analyzerTypeEnum"
                        }
                    },
                    "Category": {
                        "description": "Analyzer categories.",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/analyzerCategoryEnum"
                        }
                    },
                    "ext-Category": {
                        "description": "A means by which to extend the Category attribute. (see )",
                        "type": "string"
                    },
                    "Data": {
                        "description": "Type of data analyzed during the detection.",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/analyzerDataEnum"
                        }
                    },
                    "ext-Data": {
                        "description": "A means by which to extend the Data attribute. (see )",
                        "type": "string"
                    },
                    "Method": {
                        "description": "Detection method.",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/analyzerMethodEnum"
                        }
                    },
                    "ext-Method": {
                        "description": "A means by which to extend the Method attribute. (see )",
                        "type": "string"
                    },
                    "GeoLocation": {
                        "description": "GPS coordinates for the analyzer.",
                        "$ref": "#/definitions/geolocType"
                    },
                    "UnLocation": {
                        "description": "Standard UN/Locode for the analyzer.",
                        "$ref": "#/definitions/unlocodeType"
                    },
                    "Location": {
                        "description": "Internal name for the location of the analyzer.",
                        "type": "string"
                    }
                },
                "additionalProperties": false,
                "type": "object",
                "required": [
                    "IP",
                    "Name"
                ]
            }
        },
        "Sensor": {
            "type": "array",
            "items": {
                "description": "The Sensor class describes the module that captured the data before sending it to an analyzer. The Sensor may be a subpart of the Analyzer.",
                "properties": {
                    "IP": {
                        "description": "The sensor's IP address.",
                        "$ref": "#/definitions/ipType"
                    },
                    "Name": {
                        "description": "Name of the sensor, which must be reasonably unique, however still bear some meaningful sense. This attribute usually denotes the hierarchy of organizational units the sensor belongs to and its own name. It MAY also be used to distinguish multiple sensors running with the same IP address.",
                        "type": "string"
                    },
                    "Hostname": {
                        "description": "The sensor's hostname. This SHOULD be a fully qualified domain name, but may not conform exactly because values extracted from logs, messages, DNS, etc. may themselves be malformed. An empty string MAY be used to explicitly state that this value was inquired but not found (missing DNS entry).",
                        "type": "string"
                    },
                    "Model": {
                        "description": "The sensor model's description (usually its generic name, brand and version).",
                        "type": "string"
                    },
                    "GeoLocation": {
                        "description": "GPS coordinates for the analyzerr.",
                        "$ref": "#/definitions/geolocType"
                    },
                    "UnLocation": {
                        "description": "Standard UN/Locode for the sensor.",
                        "$ref": "#/definitions/unlocodeType"
                    },
                    "Location": {
                        "description": "Internal name for the location of the sensor.",
                        "type": "string"
                    },
                    "CaptureZone": {
                        "description": "A string that describes the \"capture zone\" of the sensor, as a JSON-serialized string. Depending on the type of sensor, the capture zone may for instance refer to: \n- A JSON object describing a camera's settings (elevation, horizontal and vertical field of view, azimuth, etc.)\n- A description of the IP network where packet capture is taking place.",
                        "type": "string"
                    }
                },
                "additionalProperties": false,
                "type": "object",
                "required": [
                    "IP",
                    "Name"
                ]
            }
        },
        "Source": {
            "type": "array",
            "items": {
                "description": "The Source class describes the origin(s) of the event(s) leading up to the alert.",
                "properties": {
                    "IP": {
                        "description": "Source IP address.",
                        "$ref": "#/definitions/ipType"
                    },
                    "Hostname": {
                        "description": "Hostname of this source. This SHOULD be a fully qualified domain name, but may not conform exactly because values extracted from logs, messages, DNS, etc. may themselves be malformed. An empty string MAY be used to explicitly state that this value was inquired but not found (missing DNS entry).",
                        "type": "string"
                    },
                    "Note": {
                        "description": "Free text human-readable additional note for this source.",
                        "type": "string"
                    },
                    "TI": {
                        "description": "Threat Intelligence data about the source. Values in this list MUST use the format \"attribute:origin\", where \"attribute\" refers to the attribute inside this source found inside a Threat Intelligence database, and \"origin\" contains a short identifier for the Threat Intelligence database. E.g. \"IP:Dshield\". Please note that the same attribute may appear multiple times inside the list (because a match was found in multiple Threat Intelligence databases).",
                        "type": "array",
                        "items": {
                            "type": "string"
                        }
                    },
                    "User": {
                        "description": "User ID or login responsible for the alert.",
                        "type": "string"
                    },
                    "Email": {
                        "description": "Email address responsible for the alert. E.g. the value of the \"Reply-To\" or \"From\" header inside a phishing e-mail.",
                        "type": "string",
                        "format": "email"
                    },
                    "Protocol": {
                        "description": "Protocols related to connections from/to this source. If several protocols are stacked, they MUST be ordered from the lowest (the closest to the medium) to the highest (the closest to the application) according to the ISO/OSI model.",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/protocolType"
                        }
                    },
                    "Port": {
                        "description": "Source ports involved in the alert. Values in this list MUST be integers and MUST be in the range 1-65535.",
                        "type": "array",
                        "items": {
                            "type": "integer"
                        }
                    },
                    "GeoLocation": {
                        "description": "GPS coordinates for the source.",
                        "$ref": "#/definitions/geolocType"
                    },
                    "UnLocation": {
                        "description": "Standard UN/Locode for the source.",
                        "$ref": "#/definitions/unlocodeType"
                    },
                    "Location": {
                        "description": "Internal name for the location of the source.",
                        "type": "string"
                    },
                    "Attachment": {
                        "description": "Identifiers for attachments related to this source. Each identifier listed here MUST match the \"Name\" attribute for one of the attachments described using the Attachment class .",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/attachmentNameType"
                        }
                    }
                },
                "additionalProperties": false,
                "type": "object"
            }
        },
        "Target": {
            "type": "array",
            "items": {
                "description": "The Target class describes the target(s) impacted by the event(s) leading up to the alert.",
                "properties": {
                    "IP": {
                        "description": "Target IP address.",
                        "$ref": "#/definitions/ipType"
                    },
                    "Hostname": {
                        "description": "Hostname of this target. This SHOULD be a fully qualified domain name, but may not conform exactly because values extracted from logs, messages, DNS, etc. may themselves be malformed. An empty string MAY be used to explicitly state that this value was inquired but not found (missing DNS entry).",
                        "type": "string"
                    },
                    "Note": {
                        "description": "Free text human-readable additional note for this target.",
                        "type": "string"
                    },
                    "Service": {
                        "description": "Service or process impacted by the alert.",
                        "type": "string"
                    },
                    "User": {
                        "description": "User ID or login targeted by the alert.",
                        "type": "string"
                    },
                    "Email": {
                        "description": "Email address targeted by the alert. E.g. the value of the \"To\" header inside a phishing e-mail.",
                        "type": "string",
                        "format": "email"
                    },
                    "Port": {
                        "description": "Target ports involved in the alert. Values in this list MUST be integers and MUST be in the range 1-65535.",
                        "type": "array",
                        "items": {
                            "type": "integer"
                        }
                    },
                    "GeoLocation": {
                        "description": "GPS coordinates for the target.",
                        "$ref": "#/definitions/geolocType"
                    },
                    "UnLocation": {
                        "description": "Standard UN/Locode for the target.",
                        "$ref": "#/definitions/unlocodeType"
                    },
                    "Location": {
                        "description": "Internal name for the location of the target.",
                        "type": "string"
                    },
                    "Attachment": {
                        "description": "Identifiers for attachments related to this target. Each identifier listed here MUST match the \"Name\" attribute for one of the attachments described using the Attachment class .",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/attachmentNameType"
                        }
                    }
                },
                "additionalProperties": false,
                "type": "object"
            }
        },
        "Vector": {
            "type": "array",
            "items": {
                "description": "The Vector class describes the vector(s) of the event(s) leading up to the alert. \u2022 Name, location, description, \u2026",
                "properties": {
                    "Category": {
                        "description": "Category for the detected \"vector\".",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/vectorCategoryEnum"
                        }
                    },
                    "ext-Category": {
                        "description": "A means by which to extend the Category attribute. (see )",
                        "type": "string"
                    },
                    "Name": {
                        "description": "Name of the detected vector or \"Unknown\". Please note that this name does not need to be unique across vectors.",
                        "type": "string"
                    },
                    "Note": {
                        "description": "Free text human-readable additional note for this vector.",
                        "type": "string"
                    },
                    "TI": {
                        "description": "Threat Intelligence data about the vector. Values in this list MUST use the format \"attribute:origin\", where \"attribute\" refers to the attribute inside this vector found inside a Threat Intelligence database, and \"origin\" contains a short identifier for the Threat Intelligence database. E.g. \"Name:FBI-Wanted\". Please note that the same attribute may appear multiple times inside the list (because a match was found in multiple Threat Intelligence databases).",
                        "type": "array",
                        "items": {
                            "type": "string"
                        }
                    },
                    "GeoLocation": {
                        "description": "GPS coordinates for the vector.",
                        "$ref": "#/definitions/geolocType"
                    },
                    "GeoRadius": {
                        "description": "Estimated radius around the provided geolocation in meters. This attribute can be interpreted as an error margin related to the detection of this vector.",
                        "type": "number"
                    },
                    "UnLocation": {
                        "description": "Standard UN/Locode for the vector.",
                        "$ref": "#/definitions/unlocodeType"
                    },
                    "Location": {
                        "description": "Internal name for the location of the vector.",
                        "type": "string"
                    },
                    "Attachment": {
                        "description": "Identifiers for attachments related to this vector. Each identifier listed here MUST match the \"Name\" attribute for one of the attachments described using the Attachment class .",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/attachmentNameType"
                        }
                    }
                },
                "additionalProperties": false,
                "type": "object",
                "required": [
                    "Category"
                ]
            }
        },
        "Attachment": {
            "type": "array",
            "items": {
                "description": "The Attachment class contains additional data which was captured in relation with the event.",
                "properties": {
                    "Name": {
                        "description": "A unique identifier among attachments that can be used to reference this attachment from other classes using the \"Attachment\" attribute.",
                        "$ref": "#/definitions/attachmentNameType"
                    },
                    "FileName": {
                        "description": "Attachment filename. This will usually be the original name of the captured file or the name of the file containing the captured content (e.g. a packet capture file).",
                        "type": "string"
                    },
                    "Hash": {
                        "description": "A list of hash results for the attachment's Content. The values in this list are computed by taking the raw value of the attachment's \"Content\" attribute. The hash result is computed before any other transformation (e.g. Base64 encoding) is applied to the content, so that a receiving IDMEF system may reverse the transformation, apply the same hashing function and obtain the same hash result. See also the definition for the \"ContentEncoding\" attribute below. It is RECOMMENDED that compatible implementations use one of the hashing functions from the SHA-2 or SHA-3 families to compute the hash results in this list.",
                        "type": "array",
                        "items": {
                            "$ref": "#/definitions/hashType"
                        }
                    },
                    "Size": {
                        "description": "Length of the content (in bytes). This value MUST be a non-negative integer.",
                        "type": "integer"
                    },
                    "Ref": {
                        "description": "References to sources of information related to the alert and/or vulnerability, and specific to this attachment.",
                        "type": "array",
                        "items": {
                            "type": "string",
                            "format": "uri"
                        }
                    },
                    "ExternalURI": {
                        "description": "If the attachment's content is available and/or recognizable from an external resource, this is the URI (usually a URL) to that resource. This MAY also be a URN in a registered or unregistered ad-hoc namespace bearing reasonable information value and uniqueness, such as \"urn:mhr:55eaf7effadc07f866d1eaed9c64e7ee49fe081a\" or \"magnet:?xt=urn:sha1:YNCKHTQCWBTRNJIV4WNAE52SJUQCZO5C\".",
                        "type": "array",
                        "items": {
                            "type": "string",
                            "format": "uri"
                        }
                    },
                    "Note": {
                        "description": "Free text human-readable additional note for this attachment.",
                        "type": "string"
                    },
                    "ContentType": {
                        "description": "Internet Media Type of the attachment. For compatibility reasons, implementations SHOULD prefer one of the well-known media types registered in IANA .",
                        "$ref": "#/definitions/mediatypeType"
                    },
                    "ContentEncoding": {
                        "description": "Content encoding. The following encodings are defined in this version of the specification: \n- \"json\": The content refers to a JSON object which has been serialized to a string using the serialization procedure defined in .\n- \"base64\": The content has been serialized using the Base64 encoding defined in . The \"base64\" encoding SHOULD be used when the content contains binary data. If omitted, the \"json\" encoding MUST be assumed.",
                        "type": "string"
                    },
                    "Content": {
                        "description": "The attachment's content, in case it is directly embedded inside the message. For large attachments, it is RECOMMENDED that implementations make use of the \"ExternalURI\" attribute to refererence a copy of the content saved in an external storage mechanism.",
                        "type": "string"
                    }
                },
                "additionalProperties": false,
                "type": "object",
                "required": [
                    "Name"
                ]
            }
        }
    },
    "additionalProperties": false,
    "type": "object",
    "required": [
        "Analyzer",
        "Version",
        "ID",
        "CreateTime"
    ],
    "definitions": {
        "categoryEnum": {
            "enum": [
                "Abusive.Spam",
                "Abusive.Harassment",
                "Abusive.Illicit",
                "Malicious.System",
                "Malicious.Botnet",
                "Malicious.Distribution",
                "Malicious.Configuration",
                "Recon.Scanning",
                "Recon.Sniffing",
                "Recon.SocialEngineering",
                "Attempt.Exploit",
                "Attempt.Login",
                "Attempt.NewSignature",
                "Intrusion.AdminCompromise",
                "Intrusion.UserCompromise",
                "Intrusion.AppCompromise",
                "Intrusion.SysCompromise",
                "Intrusion.Burglary",
                "Availability.DoS",
                "Availability.DDoS",
                "Availability.Misconf",
                "Availability.Theft",
                "Availability.Sabotage",
                "Availability.Outage",
                "Availability.Failure",
                "Information. UnauthorizedAccess",
                "Information. UnauthorizedModification",
                "Information.DataLoss",
                "Information.DataLeak",
                "Fraud.UnauthorizedUsage",
                "Fraud.Copyright",
                "Fraud.Masquerade",
                "Fraud.Phishing",
                "Vulnerable.Crypto",
                "Vulnerable.DDoS",
                "Vulnerable.Surface",
                "Vulnerable.Disclosure",
                "Vulnerable.System",
                "Geophysical.Earthquake",
                "Geophysical.MassMovement",
                "Geophysical.Volcanic",
                "Meteorological. Temperature",
                "Meteorological.Fog",
                "Meteorological.Storm",
                "Hydrological.Flood",
                "Hydrological.Landslide",
                "Hydrological.Wave",
                "Climatological.Drought",
                "Climatological. LakeOutburst",
                "Climatological.Wildfire",
                "Biological.Epidemic",
                "Biological.Insect",
                "Biological.Animal",
                "Extraterrestrial.Impact",
                "Extraterrestrial. SpaceWeather",
                "Other.Uncategorised",
                "Other.Undetermined",
                "Test.Test",
                "ext-value"
            ],
            "description": "Possible alert category"
        },
        "causeEnum": {
            "enum": [
                "Normal",
                "Error",
                "Malicious",
                "Malfunction",
                "Hazard",
                "Unknown"
            ],
            "description": "Possible alert cause"
        },
        "statusEnum": {
            "enum": [
                "Event",
                "Incident"
            ],
            "description": "Possible alert status"
        },
        "priorityEnum": {
            "enum": [
                "Unknown",
                "Info",
                "Low",
                "Medium",
                "High"
            ],
            "description": "Possible alert priority"
        },
        "analyzerTypeEnum": {
            "enum": [
                "Cyber",
                "Physical",
                "Availability",
                "Combined"
            ],
            "description": "Possible analyzer type"
        },
        "analyzerCategoryEnum": {
            "enum": [
                "1DLiS",
                "2DLiS",
                "3DLiS",
                "1DLaS",
                "2DLaS",
                "3DLaS",
                "VAD",
                "HAR",
                "FRC",
                "VNIR",
                "SWIR",
                "MWIR",
                "LWIR",
                "ADS",
                "ODC",
                "DDOS",
                "SPAM",
                "AV",
                "EDR",
                "FW",
                "NIDS",
                "HIDS",
                "WIDS",
                "PROX",
                "WAF",
                "HPT",
                "LOG",
                "IAM",
                "VPN",
                "ETL",
                "RASP",
                "BAST",
                "NAC",
                "SIEM",
                "NMS",
                "ext-value"
            ],
            "description": "Possible analyzer category"
        },
        "analyzerDataEnum": {
            "enum": [
                "Light",
                "Noise",
                "Touch",
                "Images",
                "Vibrations",
                "Lidar",
                "Thermic",
                "Seismic",
                "Temperature",
                "Rain",
                "Water",
                "Humidity",
                "Particles",
                "Contact",
                "MagneticField",
                "Acoustics",
                "Fog",
                "External",
                "Reporting",
                "Connection",
                "Datagram",
                "Content",
                "Data",
                "File",
                "Flow",
                "Log",
                "Protocol",
                "Host",
                "Network",
                "Alert",
                "Relay",
                "Auth",
                "SNMP",
                "ext-value"
            ],
            "description": "Possible analyzer data"
        },
        "analyzerMethodEnum": {
            "enum": [
                "Biometric",
                "Policy",
                "Heat",
                "Movement",
                "Blackhole",
                "Signature",
                "Statistical",
                "Heuristic",
                "Integrity",
                "Honeypot",
                "Tarpit",
                "Recon",
                "Correlation",
                "Monitor",
                "AI",
                "Threshold",
                "ext-value"
            ],
            "description": "Possible analyzer method"
        },
        "vectorCategoryEnum": {
            "enum": [
                "Unknown",
                "Face",
                "RunningMan",
                "Human",
                "Man",
                "Woman",
                "Children",
                "Animal",
                "Object",
                "Blast",
                "Fire",
                "Wind",
                "Snow",
                "Rain",
                "Chemical",
                "Smoke",
                "Vapors",
                "Drug",
                "Device",
                "Drone",
                "Car",
                "Truck",
                "Vehicle",
                "Bird",
                "Storm",
                "HighTemperature",
                "Artifact",
                "Autonomous System",
                "Directory",
                "Domain Name",
                "Email Address",
                "Email Message",
                "File",
                "IPv4 Address",
                "IPv6 Address",
                "Mutex",
                "Network Traffic",
                "Process",
                "URL",
                "User Account",
                "Windows Registry Key",
                "X509 Certificate",
                "ext-value"
            ],
            "description": "Possible vector category"
        },
        "attachmentNameType": {
            "description": "A a unique identifier among attachments.",
            "type": "string",
            "pattern": "^[a-zA-Z0-9]+$"
        },
        "portType": {
            "description": "A network port number. The value 0 is excluded from the range because it never appears in an actual network connection.",
            "type": "integer",
            "minimum": 0,
            "maximum": 65535,
            "exclusiveMinimum": true
        },
        "timestampType": {
            "description": "A JSON string containing a timestamp conforming to the format given in section 5.6 of RFC 3339.",
            "type": "string",
            "pattern": "^[0-9]{4}-(0[0-9]|1[012])-([0-2][0-9]|3[01])T([0-1][0-9]|2[0-3]):[0-5][0-9]:([0-5][0-9]|60)(\\.[0-9]+)?(Z|[-+]([0-1][0-9]|2[0-3]):[0-5][0-9])?$"
        },
        "geolocType": {
            "description": "Geolocation coordinates. The format for this type matches the definition for locations inside ISO 6709 (eg. \"+48.75726, +2.299528, +65.1\").",
            "type": "string",
            "pattern": "^[-+]?([0-9]+(\\.[0-9]*)?)(, ?[-+]?([0-9]+(\\.[0-9]*)?)){1,2}$"
        },
        "unlocodeType": {
            "description": "A valid UN/LOCODE location (e.g. \"FR PAR\"). See also the UN/LOCODE Code List 2020-2 at https://unece.org/trade/cefact/unlocode-code-list-country-and-territory.",
            "type": "string",
            "pattern": "^[A-Z]{2} ?[A-Z]{3}$"
        },
        "ipType": {
            "description": "An Internet Protocol address, either version 4 or version 6.",
            "type": "string",
            "pattern": "^(((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)|([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))$"
        },
        "mediatypeType": {
            "description": "A valid media type (e.g. \"text/plain\") conforming to the format defined in section 3.1.1.1 of RFC 7231. See also http://www.iana.org/assignments/media-types/media-types.xhtml.",
            "type": "string",
            "pattern": "^[-!#$%&amp;'*+.^_`|~0-9a-zA-Z]+/[-!#$%&amp;'*+.^_`|~0-9a-zA-Z]+([ \t]*;[ \t]*[-!#$%&amp;'*+.^_`|~0-9a-zA-Z]+=([-!#$%&amp;'*+.^_`|~0-9a-zA-Z]+|\"([]-~\t !#-[\\x80-\\xFF]|\\\\([\t 0-9a-zA-Z\\x80-\\xFF]))*\"))*$"
        },
        "uuidType": {
            "description": "Canonical textual representation for an UUID, as defined in RFC 4122 (e.g. \"e5f9bbae-163e-42f9-a2f2-0daaf78fefb1\")",
            "type": "string",
            "pattern": "^[0-9A-Fa-f]{8}(-[0-9A-Fa-f]{4}){3}-[0-9A-Fa-f]{12}$"
        },
        "protocolType": {
            "description": "A JSON string containing a service or protocol name from the set of permitted values defined in the IANA \"Service Name and Transport Protocol Port Number\" registry (http://www.iana.org/assignments/service-names-port-numbers/service-names-port-numbers.xhtml).",
            "type": "string",
            "pattern": "^[a-zA-Z0-9](-?[a-zA-Z0-9])*$"
        },
        "hashType": {
            "description": "A cryptographic hash acting as a checksum for some content, using the format \"function:hex-value\" (e.g. \"md5:dc89f0b4ff9bd3b061dd66bb66c991b1\").",
            "type": "string",
            "pattern": "^[a-zA-Z0-9-]+:([a-fA-F0-9]{2})+$"
        }
    },
    "$schema": "http://json-schema.org/draft-04/schema#",
    "title": "IDMEF 2.D.V01"
}</sourcecode>
    </section>
  </back>
</rfc>
