1{
2    "$id": "http://redfish.dmtf.org/schemas/v1/EventDestination.v1_15_0.json",
3    "$ref": "#/definitions/EventDestination",
4    "$schema": "http://redfish.dmtf.org/schemas/v1/redfish-schema-v1.json",
5    "copyright": "Copyright 2014-2024 DMTF. For the full DMTF copyright policy, see http://www.dmtf.org/about/policies/copyright",
6    "definitions": {
7        "Actions": {
8            "additionalProperties": false,
9            "description": "The available actions for this resource.",
10            "longDescription": "This type shall contain the available actions for this resource.",
11            "patternProperties": {
12                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
13                    "description": "This property shall specify a valid odata or Redfish property.",
14                    "type": [
15                        "array",
16                        "boolean",
17                        "integer",
18                        "number",
19                        "null",
20                        "object",
21                        "string"
22                    ]
23                }
24            },
25            "properties": {
26                "#EventDestination.ResumeSubscription": {
27                    "$ref": "#/definitions/ResumeSubscription"
28                },
29                "#EventDestination.SuspendSubscription": {
30                    "$ref": "#/definitions/SuspendSubscription"
31                },
32                "Oem": {
33                    "$ref": "#/definitions/OemActions",
34                    "description": "The available OEM-specific actions for this resource.",
35                    "longDescription": "This property shall contain the available OEM-specific actions for this resource.",
36                    "versionAdded": "v1_2_0"
37                }
38            },
39            "type": "object"
40        },
41        "DeliveryRetryPolicy": {
42            "enum": [
43                "TerminateAfterRetries",
44                "SuspendRetries",
45                "RetryForever",
46                "RetryForeverWithBackoff"
47            ],
48            "enumDescriptions": {
49                "RetryForever": "The subscription is not suspended or terminated, and attempts at delivery of future events continues regardless of the number of retries.",
50                "RetryForeverWithBackoff": "The subscription is not suspended or terminated, and attempts at delivery of future events continues regardless of the number of retries, but issued over time according to a service-defined backoff algorithm.",
51                "SuspendRetries": "The subscription is suspended after the maximum number of retries is reached.",
52                "TerminateAfterRetries": "The subscription is terminated after the maximum number of retries is reached."
53            },
54            "enumLongDescriptions": {
55                "RetryForever": "This value shall indicate the subscription is not suspended or terminated, and attempts at delivery of future events shall continue regardless of the number of retries.  The interval between retries remains constant and is specified by the `DeliveryRetryIntervalSeconds` property in the event service.",
56                "RetryForeverWithBackoff": "This value shall indicate the subscription is not suspended or terminated, and attempts at delivery of future events shall continue regardless of the number of retries.  Retry attempts are issued over time according to a service-defined backoff algorithm.  The backoff algorithm may insert an increasing amount of delay between retry attempts and may reach a maximum.",
57                "SuspendRetries": "This value shall indicate the subscription is suspended after the maximum number of retries is reached, specified by the `DeliveryRetryAttempts` property in the event service.  The value of the `State` property within `Status` shall contain `Disabled` for a suspended subscription.",
58                "TerminateAfterRetries": "This value shall indicate the subscription is terminated after the maximum number of retries is reached, specified by the `DeliveryRetryAttempts` property in the event service."
59            },
60            "enumVersionAdded": {
61                "RetryForeverWithBackoff": "v1_10_0"
62            },
63            "type": "string"
64        },
65        "EventDestination": {
66            "additionalProperties": false,
67            "description": "The `EventDestination` schema defines the target of an event subscription, including the event types and context to provide to the target in the event payload.",
68            "longDescription": "This resource shall represent the target of an event subscription, including the event types and context to provide to the target in the event payload.",
69            "patternProperties": {
70                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
71                    "description": "This property shall specify a valid odata or Redfish property.",
72                    "type": [
73                        "array",
74                        "boolean",
75                        "integer",
76                        "number",
77                        "null",
78                        "object",
79                        "string"
80                    ]
81                }
82            },
83            "properties": {
84                "@odata.context": {
85                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/context"
86                },
87                "@odata.etag": {
88                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/etag"
89                },
90                "@odata.id": {
91                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/id"
92                },
93                "@odata.type": {
94                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/type"
95                },
96                "Actions": {
97                    "$ref": "#/definitions/Actions",
98                    "description": "The available actions for this resource.",
99                    "longDescription": "This property shall contain the available actions for this resource.",
100                    "versionAdded": "v1_2_0"
101                },
102                "BackupDestinations": {
103                    "description": "The backup destination URIs for this event receiver.  Events are sent to these URIs, in array order, when the destination URI is unreachable or returns an error.",
104                    "format": "uri-reference",
105                    "items": {
106                        "type": [
107                            "string",
108                            "null"
109                        ]
110                    },
111                    "longDescription": "This property shall contain an array of URIs to destination where events are sent if the event receiver specified by `Destination` is unreachable or returns an error.  Events are sent to each of the backup destinations, in array order, until a destination has been reached.  An empty array shall indicate that the service supports backup event receivers, but none have been specified by the user.",
112                    "readonly": false,
113                    "type": "array",
114                    "versionAdded": "v1_15_0"
115                },
116                "Certificates": {
117                    "$ref": "http://redfish.dmtf.org/schemas/v1/CertificateCollection.json#/definitions/CertificateCollection",
118                    "description": "The link to a collection of server certificates for the server referenced by the `Destination` property.",
119                    "longDescription": "This property shall contain a link to a resource collection of type `CertificateCollection` that represent the server certificates for the server referenced by the `Destination` property.  If `VerifyCertificate` is `true`, services shall compare the certificates in this collection with the certificate obtained during handshaking with the event destination in order to verify the identity of the event destination prior to sending an event.  If the server cannot be verified, the service shall not send the event.  If `VerifyCertificate` is `false`, the service shall not perform certificate verification with certificates in this collection.  Regardless of the contents of this collection, services may perform additional verification based on other factors, such as the configuration of the SecurityPolicy resource.",
120                    "readonly": true,
121                    "versionAdded": "v1_9_0"
122                },
123                "ClientCertificates": {
124                    "$ref": "http://redfish.dmtf.org/schemas/v1/CertificateCollection.json#/definitions/CertificateCollection",
125                    "description": "The link to a collection of client identity certificates provided to the server referenced by the `Destination` property.",
126                    "longDescription": "This property shall contain a link to a resource collection of type `CertificateCollection` that represents the client identity certificates that are provided to the server referenced by the `Destination` property as part of TLS handshaking.",
127                    "readonly": true,
128                    "versionAdded": "v1_11_0"
129                },
130                "Context": {
131                    "description": "A client-supplied string that is stored with the event destination subscription.",
132                    "longDescription": "This property shall contain a client-supplied context that remains with the connection through the connection's lifetime.",
133                    "readonly": false,
134                    "type": [
135                        "string",
136                        "null"
137                    ]
138                },
139                "DeliveryRetryPolicy": {
140                    "anyOf": [
141                        {
142                            "$ref": "#/definitions/DeliveryRetryPolicy"
143                        },
144                        {
145                            "type": "null"
146                        }
147                    ],
148                    "description": "The subscription delivery retry policy for events, where the subscription type is `RedfishEvent`.",
149                    "longDescription": "This property shall indicate the subscription delivery retry policy for events where the subscription type is `RedfishEvent`.",
150                    "readonly": false,
151                    "versionAdded": "v1_6_0"
152                },
153                "Description": {
154                    "anyOf": [
155                        {
156                            "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Description"
157                        },
158                        {
159                            "type": "null"
160                        }
161                    ],
162                    "readonly": true
163                },
164                "Destination": {
165                    "description": "The URI of the destination event receiver.",
166                    "format": "uri-reference",
167                    "longDescription": "This property shall contain a URI to the destination where the events are sent.  If `Protocol` is `SMTP`, the URI shall follow the RFC6068-described format.  SNMP URIs shall be consistent with RFC4088.  Specifically, for SNMPv3, if a username is specified in the SNMP URI, the SNMPv3 authentication and encryption configuration associated with that user shall be utilized in the SNMPv3 traps.  Syslog URIs shall be consistent with RFC3986 and contain the scheme `syslog://`.  Server-sent event destinations shall be in the form `redfish-sse://ip:port` where `ip` and `port` are the IP address and the port of the client with the open SSE connection.  For other URIs, such as HTTP or HTTPS, they shall be consistent with RFC3986.",
168                    "readonly": true,
169                    "type": "string"
170                },
171                "EventFormatType": {
172                    "anyOf": [
173                        {
174                            "$ref": "http://redfish.dmtf.org/schemas/v1/EventDestination.json#/definitions/EventFormatType"
175                        },
176                        {
177                            "type": "null"
178                        }
179                    ],
180                    "description": "The content types of the message that are sent to the `EventDestination`.",
181                    "longDescription": "This property shall indicate the content types of the message that this service sends to the `EventDestination`.  If this property is not present, the `EventFormatType` shall be assumed to be Event.",
182                    "readonly": true,
183                    "versionAdded": "v1_4_0"
184                },
185                "EventTypes": {
186                    "deprecated": "This property has been deprecated.  Starting with Redfish Specification v1.6 (Event v1.3), subscriptions are based on the `RegistryPrefix` and `ResourceType` properties and not on the `EventType` property.  Use `EventFormatType` to create subscriptions for metric reports.  If the subscription does not include this property, the service shall use a single element with a default of `Other`.",
187                    "description": "The types of events that are sent to the destination.",
188                    "items": {
189                        "$ref": "http://redfish.dmtf.org/schemas/v1/Event.json#/definitions/EventType"
190                    },
191                    "longDescription": "This property shall contain an array that contains the types of events that shall be sent to the destination.  To specify that a client is subscribing for metric reports, the `EventTypes` property should include 'MetricReport'.  If the subscription does not include this property, the service shall use a single element with a default of `Other`.",
192                    "readonly": true,
193                    "type": "array",
194                    "versionDeprecated": "v1_5_0"
195                },
196                "ExcludeMessageIds": {
197                    "description": "The list of `MessageId` values that are not sent to this event destination.",
198                    "items": {
199                        "type": [
200                            "string",
201                            "null"
202                        ]
203                    },
204                    "longDescription": "This property shall contain an array of excluded `MessageId` values that are not allowed values for the `MessageId` property within an event sent to the subscriber.  The `MessageId` shall be in the `MessageRegistryPrefix.MessageKey` format.  If included, the `MessageId` major and minor version details should be ignored.  Events with a `MessageId` that is contained in this array shall not be sent to the subscriber.  If this property is an empty array or is absent, no exclusive filtering based upon the `MessageId` of an event is performed.",
205                    "readonly": true,
206                    "type": "array",
207                    "versionAdded": "v1_12_0"
208                },
209                "ExcludeRegistryPrefixes": {
210                    "description": "The list of prefixes for the message registries that contain the `MessageId` values that are not sent to this event destination.",
211                    "items": {
212                        "type": [
213                            "string",
214                            "null"
215                        ]
216                    },
217                    "longDescription": "This property shall contain an array of prefixes of excluded message registries that contain the `MessageId` values that are not allowed values for the `MessageId` property within an event sent to the subscriber.  Events with a `MessageId` that is from a message registry contained in this array shall not be sent to the subscriber.  If this property is an empty array or is absent, no exclusive filtering based upon message registry of the `MessageId` of an event is performed.",
218                    "readonly": true,
219                    "type": "array",
220                    "versionAdded": "v1_12_0"
221                },
222                "HeartbeatIntervalMinutes": {
223                    "description": "Interval for sending heartbeat events to the destination in minutes.",
224                    "longDescription": "This property shall indicate the interval for sending periodic heartbeat events to the subscriber.  The value shall be the interval, in minutes, between each periodic event.  This property shall not be present if the `SendHeartbeat` property is not present.",
225                    "maximum": 65535,
226                    "minimum": 1,
227                    "readonly": true,
228                    "type": [
229                        "integer",
230                        "null"
231                    ],
232                    "versionAdded": "v1_11_0"
233                },
234                "HttpHeaders": {
235                    "description": "An array of settings for HTTP headers, such as authorization information.  This array is `null` or an empty array in responses.  An empty array is the preferred return value on read operations.",
236                    "items": {
237                        "$ref": "#/definitions/HttpHeaderProperty"
238                    },
239                    "longDescription": "This property shall contain an array of objects consisting of the names and values of the HTTP headers to include with every event `POST` to the event destination.  This object shall be `null` or an empty array in responses.  An empty array is the preferred return value in responses.",
240                    "type": "array"
241                },
242                "Id": {
243                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Id",
244                    "readonly": true
245                },
246                "IncludeOriginOfCondition": {
247                    "description": "An indication of whether the events subscribed to will also include the entire resource or object referenced by the `OriginOfCondition` property in the event payload.",
248                    "longDescription": "This property shall indicate whether the event payload sent to the subscription destination will expand the `OriginOfCondition` property to include the resource or object referenced by the `OriginOfCondition` property.",
249                    "readonly": true,
250                    "type": [
251                        "boolean",
252                        "null"
253                    ],
254                    "versionAdded": "v1_8_0"
255                },
256                "MessageIds": {
257                    "description": "The list of `MessageId` values that are sent to this event destination.",
258                    "items": {
259                        "type": [
260                            "string",
261                            "null"
262                        ]
263                    },
264                    "longDescription": "This property shall contain an array of `MessageId` values that are the allowable values for the `MessageId` property within an event sent to the subscriber.  The `MessageId` should be in the `MessageRegistryPrefix.MessageKey` format.  If included, the `MessageId` major and minor version details should be ignored.  Events with a `MessageId` that is not contained in this array and is not from a message registry contained in RegistryPrefixes shall not be sent to the subscriber.  If this property is an empty array or is absent, no inclusive filtering based upon the `MessageId` of an event is performed.",
265                    "readonly": true,
266                    "type": "array",
267                    "versionAdded": "v1_1_0"
268                },
269                "MetricReportDefinitions": {
270                    "description": "A list of metric report definitions for which the service only sends related metric reports.  If this property is absent or the array is empty, metric reports that originate from any metric report definition are sent to the subscriber.",
271                    "items": {
272                        "$ref": "http://redfish.dmtf.org/schemas/v1/MetricReportDefinition.json#/definitions/MetricReportDefinition"
273                    },
274                    "longDescription": "This property shall specify an array of metric report definitions that are the only allowable generators of metric reports for this subscription.  Metric reports originating from metric report definitions not contained in this array shall not be sent to the subscriber.  If this property is absent or the array is empty, the service shall send metric reports originating from any metric report definition to the subscriber.",
275                    "readonly": true,
276                    "type": "array",
277                    "versionAdded": "v1_6_0"
278                },
279                "MetricReportDefinitions@odata.count": {
280                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
281                },
282                "Name": {
283                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Name",
284                    "readonly": true
285                },
286                "OEMProtocol": {
287                    "description": "The OEM-defined protocol type of the event connection.",
288                    "longDescription": "This property shall contain the protocol type that the event uses to send the event to the destination.  This property shall be present if `Protocol` is `OEM`.",
289                    "readonly": true,
290                    "type": "string",
291                    "versionAdded": "v1_9_0"
292                },
293                "OEMSubscriptionType": {
294                    "description": "The OEM-defined subscription type for events.",
295                    "longDescription": "This property shall indicate the OEM-defined type of subscription for events.  This property shall be present if `SubscriptionType` is `OEM`.",
296                    "readonly": true,
297                    "type": "string",
298                    "versionAdded": "v1_9_0"
299                },
300                "Oem": {
301                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Oem",
302                    "description": "The OEM extension property.",
303                    "longDescription": "This property shall contain the OEM extensions.  All values for properties that this object contains shall conform to the Redfish Specification-described requirements."
304                },
305                "OriginResources": {
306                    "description": "The array of resources for which the service sends only related events.",
307                    "items": {
308                        "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/idRef"
309                    },
310                    "longDescription": "This property shall specify an array of resources, resource collections, or referenceable members that are the only allowable values for the `OriginOfCondition` property within an event that the service sends to the subscriber.  Events with an `OriginOfCondition` that is not contained in this array, and is not subordinate to members of this array if `SubordinateResources` contains the value `true`, shall not be sent to the subscriber.  If this property is an empty array or is absent, no filtering based upon the URI of the `OriginOfCondition` of an event is performed.",
311                    "readonly": true,
312                    "type": "array",
313                    "versionAdded": "v1_1_0"
314                },
315                "OriginResources@odata.count": {
316                    "$ref": "http://redfish.dmtf.org/schemas/v1/odata-v4.json#/definitions/count"
317                },
318                "Protocol": {
319                    "$ref": "#/definitions/EventDestinationProtocol",
320                    "description": "The protocol type of the event connection.",
321                    "longDescription": "This property shall contain the protocol type that the event uses to send the event to the destination.  A `Redfish` value shall indicate that the event type shall adhere to the type defined in the Redfish Specification.",
322                    "readonly": true
323                },
324                "RegistryPrefixes": {
325                    "description": "The list of prefixes for the message registries that contain the `MessageId` values that are sent to this event destination.",
326                    "items": {
327                        "type": [
328                            "string",
329                            "null"
330                        ]
331                    },
332                    "longDescription": "This property shall contain an array the prefixes of message registries that contain the `MessageId` values that are the allowable values for the `MessageId` property within an event sent to the subscriber.  Events with a `MessageId` that is not from a message registry contained in this array and is not contained by `MessageIds` shall not be sent to the subscriber.  If this property is an empty array or is absent, no inclusive filtering based upon message registry of the `MessageId` of an event is performed.",
333                    "readonly": true,
334                    "type": "array",
335                    "versionAdded": "v1_4_0"
336                },
337                "ResourceTypes": {
338                    "description": "The list of resource type values (schema names) that correspond to the `OriginOfCondition`.  The version and full namespace should not be specified.",
339                    "items": {
340                        "type": [
341                            "string",
342                            "null"
343                        ]
344                    },
345                    "longDescription": "This property shall specify an array of resource type values that contain the allowable resource types for the resource referenced by the `OriginOfCondition` property.  Events with the resource type of the resource referenced by the `OriginOfCondition` property that is not contained in this array shall not be sent to the subscriber.  If this property is an empty array or is absent, no filtering based upon the resource type of the `OriginOfCondition` of an event is performed.  This property shall contain only the general namespace for the type and not the versioned value.  For example, it shall not contain `Task.v1_2_0.Task` and instead shall contain `Task`.  To specify that a client is subscribing to metric reports, the `EventTypes` property should include `MetricReport`.",
346                    "readonly": true,
347                    "type": "array",
348                    "versionAdded": "v1_4_0"
349                },
350                "SNMP": {
351                    "$ref": "#/definitions/SNMPSettings",
352                    "description": "Settings for an SNMP event destination.",
353                    "longDescription": "This property shall contain the settings for an SNMP event destination.",
354                    "versionAdded": "v1_7_0"
355                },
356                "SendHeartbeat": {
357                    "description": "Send a heartbeat event periodically to the destination.",
358                    "longDescription": "This property shall indicate that the service shall periodically send the `RedfishServiceFunctional` message defined in the Heartbeat Event Message Registry to the subscriber.  If this property is not present, no periodic event shall be sent.  This property shall not apply to event destinations if the `SubscriptionType` property contains the value `SSE`.",
359                    "readonly": true,
360                    "type": [
361                        "boolean",
362                        "null"
363                    ],
364                    "versionAdded": "v1_11_0"
365                },
366                "Severities": {
367                    "description": "The list of severities that are sent to this event destination.",
368                    "items": {
369                        "anyOf": [
370                            {
371                                "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Health"
372                            },
373                            {
374                                "type": "null"
375                            }
376                        ]
377                    },
378                    "longDescription": "This property shall contain an array of severities that are the allowable values for the `MessageSeverity` property within an event sent to the subscriber.  If this property is an empty array or is absent, no filtering based upon the `MessageSeverity` of an event is performed.",
379                    "readonly": true,
380                    "type": "array",
381                    "versionAdded": "v1_13_0"
382                },
383                "Status": {
384                    "$ref": "http://redfish.dmtf.org/schemas/v1/Resource.json#/definitions/Status",
385                    "description": "The status and health of the resource and its subordinate or dependent resources.",
386                    "longDescription": "This property shall contain any status or health properties of the resource.",
387                    "versionAdded": "v1_6_0"
388                },
389                "SubordinateResources": {
390                    "description": "An indication of whether the subscription is for events in the `OriginResources` array and its subordinate resources.  If `true` and the `OriginResources` array is specified, the subscription is for events in the `OriginResources` array and its subordinate resources.  Note that resources associated through the Links section are not considered subordinate.  If `false` and the `OriginResources` array is specified, the subscription is for events in the `OriginResources` array only.  If the `OriginResources` array is not present, this property has no relevance.",
391                    "longDescription": "This property shall indicate whether the subscription is for events in the `OriginResources` array and its subordinate resources.  If `true` and the `OriginResources` array is specified, the subscription is for events in the `OriginResources` array and its subordinate resources.  Note that resources associated through the Links section are not considered subordinate.  If `false` and the `OriginResources` array is specified, the subscription shall be for events in the `OriginResources` array only.  If the `OriginResources` array is not present, this property shall have no relevance.",
392                    "readonly": true,
393                    "type": [
394                        "boolean",
395                        "null"
396                    ],
397                    "versionAdded": "v1_4_0"
398                },
399                "SubscriptionType": {
400                    "anyOf": [
401                        {
402                            "$ref": "#/definitions/SubscriptionType"
403                        },
404                        {
405                            "type": "null"
406                        }
407                    ],
408                    "description": "The subscription type for events.",
409                    "longDescription": "This property shall indicate the type of subscription for events.  If this property is not present, the `SubscriptionType` shall be assumed to be `RedfishEvent`.",
410                    "readonly": true,
411                    "versionAdded": "v1_3_0"
412                },
413                "SyslogFilters": {
414                    "description": "A list of filters applied to syslog messages before sending to a remote syslog server.  An empty list indicates all syslog messages are sent.",
415                    "items": {
416                        "anyOf": [
417                            {
418                                "$ref": "#/definitions/SyslogFilter"
419                            },
420                            {
421                                "type": "null"
422                            }
423                        ]
424                    },
425                    "longDescription": "This property shall describe all desired syslog messages to send to a remote syslog server.  If this property contains an empty array or is absent, all messages shall be sent.",
426                    "type": "array",
427                    "versionAdded": "v1_9_0"
428                },
429                "VerifyCertificate": {
430                    "description": "An indication of whether the service will verify the certificate of the server referenced by the `Destination` property prior to sending the event.",
431                    "longDescription": "This property shall indicate whether the service will verify the certificate of the server referenced by the `Destination` property prior to sending the event with the certificates found in the collection referenced by the `Certificates` property.  If this property is not supported by the service or specified by the client in the create request, it shall be assumed to be `false`.  Regardless of the value of this property, services may perform additional verification based on other factors, such as the configuration of the SecurityPolicy resource.",
432                    "readonly": false,
433                    "type": [
434                        "boolean",
435                        "null"
436                    ],
437                    "versionAdded": "v1_9_0"
438                }
439            },
440            "required": [
441                "Context",
442                "@odata.id",
443                "@odata.type",
444                "Id",
445                "Name",
446                "SubscriptionType"
447            ],
448            "requiredOnCreate": [
449                "Destination",
450                "Protocol"
451            ],
452            "type": "object"
453        },
454        "EventDestinationProtocol": {
455            "enum": [
456                "Redfish",
457                "Kafka",
458                "SNMPv1",
459                "SNMPv2c",
460                "SNMPv3",
461                "SMTP",
462                "SyslogTLS",
463                "SyslogTCP",
464                "SyslogUDP",
465                "SyslogRELP",
466                "OEM"
467            ],
468            "enumDescriptions": {
469                "Kafka": "The destination follows the Kafka protocol for event notifications.",
470                "OEM": "The destination follows an OEM protocol for event notifications.",
471                "Redfish": "The destination follows the Redfish Specification for event notifications.",
472                "SMTP": "The destination follows the SMTP specification for event notifications.",
473                "SNMPv1": "The destination follows the SNMPv1 protocol for event notifications.",
474                "SNMPv2c": "The destination follows the SNMPv2c protocol for event notifications.",
475                "SNMPv3": "The destination follows the SNMPv3 protocol for event notifications.",
476                "SyslogRELP": "The destination follows syslog RELP for event notifications.",
477                "SyslogTCP": "The destination follows syslog TCP-based transport for event notifications.",
478                "SyslogTLS": "The destination follows syslog TLS-based transport for event notifications.",
479                "SyslogUDP": "The destination follows syslog UDP-based transport for event notifications."
480            },
481            "enumLongDescriptions": {
482                "Kafka": "This value shall indicate the destination follows the Apache-defined Kafka protocol as defined by the Kafka Protocol Guide.  The `Context` property shall contain the Kafka topic of the destination broker.",
483                "OEM": "This value shall indicate an OEM-specific protocol.  The `OEMProtocol` property shall contain the specific OEM event destination protocol.",
484                "Redfish": "This value shall indicate the destination follows the Redfish Specification for event notifications.  Destinations requesting `EventFormatType` of `Event` shall receive a Redfish resource of type `Event`.  Destinations requesting `EventFormatType` of `MetricReport` shall receive a Redfish resource of type `MetricReport`.",
485                "SMTP": "This value shall indicate the destination follows the RFC5321-defined SMTP specification.",
486                "SNMPv1": "This value shall indicate the destination follows the RFC1157-defined SNMPv1 protocol.",
487                "SNMPv2c": "This value shall indicate the destination follows the SNMPv2c protocol as defined by RFC1441 and RFC1452.",
488                "SNMPv3": "This value shall indicate the destination follows the SNMPv3 protocol as defined by RFC3411 and RFC3418.",
489                "SyslogRELP": "This value shall indicate the destination follows the Reliable Event Logging Protocol (RELP) transport for syslog as defined by www.rsyslog.com.",
490                "SyslogTCP": "This value shall indicate the destination follows the TCP-based transport for syslog as defined in RFC6587.",
491                "SyslogTLS": "This value shall indicate the destination follows the TLS-based transport for syslog as defined in RFC5424.",
492                "SyslogUDP": "This value shall indicate the destination follows the UDP-based transport for syslog as defined in RFC5424."
493            },
494            "enumVersionAdded": {
495                "Kafka": "v1_13_0",
496                "OEM": "v1_9_0",
497                "SMTP": "v1_7_0",
498                "SNMPv1": "v1_7_0",
499                "SNMPv2c": "v1_7_0",
500                "SNMPv3": "v1_7_0",
501                "SyslogRELP": "v1_9_0",
502                "SyslogTCP": "v1_9_0",
503                "SyslogTLS": "v1_9_0",
504                "SyslogUDP": "v1_9_0"
505            },
506            "type": "string"
507        },
508        "HttpHeaderProperty": {
509            "additionalProperties": false,
510            "description": "The HTTP header value is the property value.  The header name is the property name.",
511            "longDescription": "This type shall contain the HTTP header name and value to include with every event `POST` to the event destination.",
512            "patternProperties": {
513                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
514                    "description": "This property shall specify a valid odata or Redfish property.",
515                    "type": [
516                        "array",
517                        "boolean",
518                        "integer",
519                        "number",
520                        "null",
521                        "object",
522                        "string"
523                    ]
524                },
525                "^[^:\\\\s]+$": {
526                    "type": "string"
527                }
528            },
529            "properties": {},
530            "type": "object"
531        },
532        "OemActions": {
533            "additionalProperties": true,
534            "description": "The available OEM-specific actions for this resource.",
535            "longDescription": "This type shall contain the available OEM-specific actions for this resource.",
536            "patternProperties": {
537                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
538                    "description": "This property shall specify a valid odata or Redfish property.",
539                    "type": [
540                        "array",
541                        "boolean",
542                        "integer",
543                        "number",
544                        "null",
545                        "object",
546                        "string"
547                    ]
548                }
549            },
550            "properties": {},
551            "type": "object"
552        },
553        "ResumeSubscription": {
554            "additionalProperties": false,
555            "description": "This action resumes a suspended event subscription.",
556            "longDescription": "This action shall resume a suspended event subscription, which affects the subscription status.  The service may deliver buffered events when the subscription is resumed.",
557            "parameters": {
558                "DeliverBufferedEventDuration": {
559                    "description": "The maximum age of buffered events that should be delivered when resuming the subscription.",
560                    "longDescription": "This parameter shall indicate the event age of any buffered or otherwise undelivered events that shall be delivered to this event destination when the subscription is resumed.  The service shall deliver any available, previously undelivered event that was created within the duration specified.  A value that equates to zero time, such as `PT0S`, shall indicate that no previously undelivered events shall be sent.  If undelivered events within the duration may have been discarded due to a lack of buffer space, the service should send the `EventBufferExceeded` message from the Base Message Registry.  If the client does not provide this parameter, the service shall apply an implementation-specific duration.",
561                    "pattern": "^P(\\d+D)?(T(\\d+H)?(\\d+M)?(\\d+(.\\d+)?S)?)?$",
562                    "type": "string",
563                    "versionAdded": "v1_12_0"
564                }
565            },
566            "patternProperties": {
567                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
568                    "description": "This property shall specify a valid odata or Redfish property.",
569                    "type": [
570                        "array",
571                        "boolean",
572                        "integer",
573                        "number",
574                        "null",
575                        "object",
576                        "string"
577                    ]
578                }
579            },
580            "properties": {
581                "target": {
582                    "description": "Link to invoke action",
583                    "format": "uri-reference",
584                    "type": "string"
585                },
586                "title": {
587                    "description": "Friendly action name",
588                    "type": "string"
589                }
590            },
591            "type": "object"
592        },
593        "SNMPAuthenticationProtocols": {
594            "enum": [
595                "None",
596                "CommunityString",
597                "HMAC_MD5",
598                "HMAC_SHA96",
599                "HMAC128_SHA224",
600                "HMAC192_SHA256",
601                "HMAC256_SHA384",
602                "HMAC384_SHA512"
603            ],
604            "enumDescriptions": {
605                "CommunityString": "Trap community string authentication.",
606                "HMAC128_SHA224": "HMAC-128-SHA-224 authentication.",
607                "HMAC192_SHA256": "HMAC-192-SHA-256 authentication.",
608                "HMAC256_SHA384": "HMAC-256-SHA-384 authentication.",
609                "HMAC384_SHA512": "HMAC-384-SHA-512 authentication.",
610                "HMAC_MD5": "HMAC-MD5-96 authentication.",
611                "HMAC_SHA96": "HMAC-SHA-96 authentication.",
612                "None": "No authentication."
613            },
614            "enumLongDescriptions": {
615                "CommunityString": "This value shall indicate authentication using SNMP community strings and the value of TrapCommunity.",
616                "HMAC128_SHA224": "This value shall indicate authentication for SNMPv3 access conforms to the RFC7860-defined usmHMAC128SHA224AuthProtocol.",
617                "HMAC192_SHA256": "This value shall indicate authentication for SNMPv3 access conforms to the RFC7860-defined usmHMAC192SHA256AuthProtocol.",
618                "HMAC256_SHA384": "This value shall indicate authentication for SNMPv3 access conforms to the RFC7860-defined usmHMAC256SHA384AuthProtocol.",
619                "HMAC384_SHA512": "This value shall indicate authentication for SNMPv3 access conforms to the RFC7860-defined usmHMAC384SHA512AuthProtocol.",
620                "HMAC_MD5": "This value shall indicate authentication conforms to the RFC3414-defined HMAC-MD5-96 authentication protocol.",
621                "HMAC_SHA96": "This value shall indicate authentication conforms to the RFC3414-defined HMAC-SHA-96 authentication protocol.",
622                "None": "This value shall indicate authentication is not required."
623            },
624            "enumVersionAdded": {
625                "HMAC128_SHA224": "v1_10_0",
626                "HMAC192_SHA256": "v1_10_0",
627                "HMAC256_SHA384": "v1_10_0",
628                "HMAC384_SHA512": "v1_10_0"
629            },
630            "type": "string"
631        },
632        "SNMPEncryptionProtocols": {
633            "enum": [
634                "None",
635                "CBC_DES",
636                "CFB128_AES128",
637                "CFB128_AES192",
638                "CFB128_AES256"
639            ],
640            "enumDescriptions": {
641                "CBC_DES": "CBC-DES encryption.",
642                "CFB128_AES128": "CFB128-AES-128 encryption.",
643                "CFB128_AES192": "CFB128-AES-192 encryption.",
644                "CFB128_AES256": "CFB128-AES-256 encryption.",
645                "None": "No encryption."
646            },
647            "enumLongDescriptions": {
648                "CBC_DES": "This value shall indicate encryption conforms to the RFC3414-defined CBC-DES encryption protocol.",
649                "CFB128_AES128": "This value shall indicate encryption conforms to the RFC3826-defined CFB128-AES-128 encryption protocol.",
650                "CFB128_AES192": "This value shall indicate encryption conforms to the CFB128-AES-192 encryption protocol, extended from RFC3826.",
651                "CFB128_AES256": "This value shall indicate encryption conforms to the CFB128-AES-256 encryption protocol, extended from RFC3826.",
652                "None": "This value shall indicate there is no encryption."
653            },
654            "enumVersionAdded": {
655                "CFB128_AES192": "v1_14_0",
656                "CFB128_AES256": "v1_14_0"
657            },
658            "type": "string"
659        },
660        "SNMPSettings": {
661            "additionalProperties": false,
662            "description": "Settings for an SNMP event destination.",
663            "longDescription": "This type shall contain the settings for an SNMP event destination.",
664            "patternProperties": {
665                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
666                    "description": "This property shall specify a valid odata or Redfish property.",
667                    "type": [
668                        "array",
669                        "boolean",
670                        "integer",
671                        "number",
672                        "null",
673                        "object",
674                        "string"
675                    ]
676                }
677            },
678            "properties": {
679                "AuthenticationKey": {
680                    "description": "The secret authentication key for SNMPv3.",
681                    "longDescription": "This property shall contain the key for SNMPv3 authentication.  The value shall be `null` in responses.  This property accepts a passphrase or a hex-encoded key.  If the string starts with `Passphrase:`, the remainder of the string shall be the passphrase and shall be converted to the key as described in the 'Password to Key Algorithm' section of RFC3414.  If the string starts with `Hex:`, then the remainder of the string shall be the key encoded in hexadecimal notation.  If the string starts with neither, the full string shall be a passphrase and shall be converted to the key as described in the 'Password to Key Algorithm' section of RFC3414.",
682                    "pattern": "(^[ -~]+$)|(^Passphrase:[ -~]+$)|(^Hex:[0-9A-Fa-f]{24,96}$)|(^\\*+$)",
683                    "readonly": false,
684                    "type": [
685                        "string",
686                        "null"
687                    ],
688                    "versionAdded": "v1_7_0",
689                    "writeOnly": true
690                },
691                "AuthenticationKeySet": {
692                    "description": "Indicates if the `AuthenticationKey` property is set.",
693                    "longDescription": "This property shall contain `true` if a valid value was provided for the `AuthenticationKey` property.  Otherwise, the property shall contain `false`.",
694                    "readonly": true,
695                    "type": "boolean",
696                    "versionAdded": "v1_10_0"
697                },
698                "AuthenticationProtocol": {
699                    "anyOf": [
700                        {
701                            "$ref": "#/definitions/SNMPAuthenticationProtocols"
702                        },
703                        {
704                            "type": "null"
705                        }
706                    ],
707                    "description": "The authentication protocol for SNMPv3.",
708                    "longDescription": "This property shall contain the SNMPv3 authentication protocol.",
709                    "readonly": false,
710                    "versionAdded": "v1_7_0"
711                },
712                "EncryptionKey": {
713                    "description": "The secret authentication key for SNMPv3.",
714                    "longDescription": "This property shall contain the key for SNMPv3 encryption.  The value shall be `null` in responses.  This property accepts a passphrase or a hex-encoded key.  If the string starts with `Passphrase:`, the remainder of the string shall be the passphrase and shall be converted to the key as described in the 'Password to Key Algorithm' section of RFC3414.  If the string starts with `Hex:`, then the remainder of the string shall be the key encoded in hexadecimal notation.  If the string starts with neither, the full string shall be a passphrase and shall be converted to the key as described in the 'Password to Key Algorithm' section of RFC3414.",
715                    "pattern": "(^[ -~]+$)|(^Passphrase:[ -~]+$)|(^Hex:[0-9A-Fa-f]{16,64}$)|(^\\*+$)",
716                    "readonly": false,
717                    "type": [
718                        "string",
719                        "null"
720                    ],
721                    "versionAdded": "v1_7_0",
722                    "writeOnly": true
723                },
724                "EncryptionKeySet": {
725                    "description": "Indicates if the `EncryptionKey` property is set.",
726                    "longDescription": "This property shall contain `true` if a valid value was provided for the `EncryptionKey` property.  Otherwise, the property shall contain `false`.",
727                    "readonly": true,
728                    "type": "boolean",
729                    "versionAdded": "v1_10_0"
730                },
731                "EncryptionProtocol": {
732                    "anyOf": [
733                        {
734                            "$ref": "#/definitions/SNMPEncryptionProtocols"
735                        },
736                        {
737                            "type": "null"
738                        }
739                    ],
740                    "description": "The encryption protocol for SNMPv3.",
741                    "longDescription": "This property shall contain the SNMPv3 encryption protocol.",
742                    "readonly": false,
743                    "versionAdded": "v1_7_0"
744                },
745                "TrapCommunity": {
746                    "description": "The SNMP trap community string.",
747                    "longDescription": "This property shall contain the SNMP trap community string.  The value shall be `null` in responses.",
748                    "readonly": false,
749                    "type": [
750                        "string",
751                        "null"
752                    ],
753                    "versionAdded": "v1_7_0",
754                    "writeOnly": true
755                }
756            },
757            "type": "object"
758        },
759        "SubscriptionType": {
760            "enum": [
761                "RedfishEvent",
762                "SSE",
763                "SNMPTrap",
764                "SNMPInform",
765                "Syslog",
766                "OEM"
767            ],
768            "enumDescriptions": {
769                "OEM": "The subscription is an OEM subscription.",
770                "RedfishEvent": "The subscription follows the Redfish Specification for event notifications.  To send an event notification, a service sends an HTTP `POST` to the subscriber's destination URI.",
771                "SNMPInform": "The subscription follows versions 2 and 3 of SNMP Inform for event notifications.",
772                "SNMPTrap": "The subscription follows the various versions of SNMP Traps for event notifications.",
773                "SSE": "The subscription follows the HTML5 server-sent event definition for event notifications.",
774                "Syslog": "The subscription sends syslog messages for event notifications."
775            },
776            "enumLongDescriptions": {
777                "OEM": "This value shall indicate an OEM subscription type.  The `OEMSubscriptionType` property shall contain the specific OEM subscription type.",
778                "SNMPInform": "This value shall indicate the subscription follows versions 2 and 3 of SNMP Inform for event notifications.  `Protocol` shall specify the appropriate version of SNMP.",
779                "SNMPTrap": "This value shall indicate the subscription follows the various versions of SNMP Traps for event notifications.  `Protocol` shall specify the appropriate version of SNMP.",
780                "Syslog": "This value shall indicate the subscription forwards syslog messages to the event destination.  `Protocol` shall specify the appropriate syslog protocol."
781            },
782            "enumVersionAdded": {
783                "OEM": "v1_9_0",
784                "SNMPInform": "v1_7_0",
785                "SNMPTrap": "v1_7_0",
786                "Syslog": "v1_9_0"
787            },
788            "type": "string"
789        },
790        "SuspendSubscription": {
791            "additionalProperties": false,
792            "description": "This action suspends an event subscription.",
793            "longDescription": "This action shall suspend an event subscription.  No events shall be sent to the event destination until invocation of the `ResumeSubscription` action.  The value of the `State` property within `Status` shall contain `Disabled` for a suspended subscription.  The service may buffer events while the subscription is suspended.",
794            "parameters": {},
795            "patternProperties": {
796                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
797                    "description": "This property shall specify a valid odata or Redfish property.",
798                    "type": [
799                        "array",
800                        "boolean",
801                        "integer",
802                        "number",
803                        "null",
804                        "object",
805                        "string"
806                    ]
807                }
808            },
809            "properties": {
810                "target": {
811                    "description": "Link to invoke action",
812                    "format": "uri-reference",
813                    "type": "string"
814                },
815                "title": {
816                    "description": "Friendly action name",
817                    "type": "string"
818                }
819            },
820            "type": "object",
821            "versionAdded": "v1_12_0"
822        },
823        "SyslogFacility": {
824            "description": "The syslog facility code is an enumeration of program types.",
825            "enum": [
826                "Kern",
827                "User",
828                "Mail",
829                "Daemon",
830                "Auth",
831                "Syslog",
832                "LPR",
833                "News",
834                "UUCP",
835                "Cron",
836                "Authpriv",
837                "FTP",
838                "NTP",
839                "Security",
840                "Console",
841                "SolarisCron",
842                "Local0",
843                "Local1",
844                "Local2",
845                "Local3",
846                "Local4",
847                "Local5",
848                "Local6",
849                "Local7"
850            ],
851            "enumDescriptions": {
852                "Auth": "Security/authentication messages.",
853                "Authpriv": "Security/authentication messages.",
854                "Console": "Log alert.",
855                "Cron": "Clock daemon.",
856                "Daemon": "System daemons.",
857                "FTP": "FTP daemon.",
858                "Kern": "Kernel messages.",
859                "LPR": "Line printer subsystem.",
860                "Local0": "Locally used facility 0.",
861                "Local1": "Locally used facility 1.",
862                "Local2": "Locally used facility 2.",
863                "Local3": "Locally used facility 3.",
864                "Local4": "Locally used facility 4.",
865                "Local5": "Locally used facility 5.",
866                "Local6": "Locally used facility 6.",
867                "Local7": "Locally used facility 7.",
868                "Mail": "Mail system.",
869                "NTP": "NTP subsystem.",
870                "News": "Network news subsystem.",
871                "Security": "Log audit.",
872                "SolarisCron": "Scheduling daemon.",
873                "Syslog": "Messages generated internally by syslogd.",
874                "UUCP": "UUCP subsystem.",
875                "User": "User-level messages."
876            },
877            "longDescription": "This type shall specify the syslog facility codes as program types.  Facility values are described in the RFC5424.",
878            "type": "string"
879        },
880        "SyslogFilter": {
881            "additionalProperties": false,
882            "description": "A syslog filter.",
883            "longDescription": "This type shall contain the filter for a syslog message.  The filter shall describe the desired syslog message to forward to a remote syslog server.",
884            "patternProperties": {
885                "^([a-zA-Z_][a-zA-Z0-9_]*)?@(odata|Redfish|Message)\\.[a-zA-Z_][a-zA-Z0-9_]*$": {
886                    "description": "This property shall specify a valid odata or Redfish property.",
887                    "type": [
888                        "array",
889                        "boolean",
890                        "integer",
891                        "number",
892                        "null",
893                        "object",
894                        "string"
895                    ]
896                }
897            },
898            "properties": {
899                "LogFacilities": {
900                    "description": "The types of programs that can log messages.",
901                    "items": {
902                        "anyOf": [
903                            {
904                                "$ref": "#/definitions/SyslogFacility"
905                            },
906                            {
907                                "type": "null"
908                            }
909                        ]
910                    },
911                    "longDescription": "This property shall contain the types of programs that can log messages.  If this property contains an empty array or is absent, all facilities shall be indicated.",
912                    "readonly": false,
913                    "type": "array",
914                    "versionAdded": "v1_9_0"
915                },
916                "LowestSeverity": {
917                    "anyOf": [
918                        {
919                            "$ref": "#/definitions/SyslogSeverity"
920                        },
921                        {
922                            "type": "null"
923                        }
924                    ],
925                    "description": "The lowest severity level message that will be forwarded.",
926                    "longDescription": "This property shall contain the lowest syslog severity level that will be forwarded.  The service shall forward all messages equal to or greater than the value in this property.  The value `All` shall indicate all severities.",
927                    "readonly": false,
928                    "versionAdded": "v1_9_0"
929                }
930            },
931            "type": "object"
932        },
933        "SyslogSeverity": {
934            "description": "The syslog severity is an application-specific rating used to describe the urgency of the message.",
935            "enum": [
936                "Emergency",
937                "Alert",
938                "Critical",
939                "Error",
940                "Warning",
941                "Notice",
942                "Informational",
943                "Debug",
944                "All"
945            ],
946            "enumDescriptions": {
947                "Alert": "A condition that should be corrected immediately, such as a corrupted system database.",
948                "All": "A message of any severity.",
949                "Critical": "Hard device errors.",
950                "Debug": "Messages that contain information normally of use only when debugging a program.",
951                "Emergency": "A panic condition.",
952                "Error": "An Error.",
953                "Informational": "Informational only.",
954                "Notice": "Conditions that are not error conditions, but that might require special handling.",
955                "Warning": "A Warning."
956            },
957            "longDescription": "This type shall specify the syslog severity levels as an application-specific rating used to describe the urgency of the message.  `Emergency` should be reserved for messages indicating the system is unusable and `Debug` should only be used when debugging a program.  Severity values are described in RFC5424.",
958            "type": "string"
959        }
960    },
961    "language": "en",
962    "owningEntity": "DMTF",
963    "release": "2024.3",
964    "title": "#EventDestination.v1_15_0.EventDestination"
965}