-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathalarms-1-0.yang
723 lines (659 loc) · 23.6 KB
/
alarms-1-0.yang
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
module alarms-1-0 {
yang-version 1.1;
namespace "urn:onf:yang:alarms-1-0";
prefix alarms;
import ietf-yang-types {
prefix yang;
}
import core-model-1-4 {
prefix core-model;
}
organization
"openBackhaul.com proposal to Open Networking Foundation (ONF)";
contact
"WG Web : https://github.com/openBackhaul/Overview
WG List: [email protected]
Editor : Thorsten Heinze
Email : [email protected]";
description
"Copyright 2024 openBackhaul.com
Licensed under the Apache License, Version 2.0 (the 'License');
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an 'AS IS' BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.";
revision 2024-01-22 {
description
"Model for the Transport SDN Introduction at Telefonica Germany.
Please view https://github.com/openBackhaul/alarms/issues for changes.";
reference
"https://github.com/openBackhaul/alarms/tree/tsi: Model definition
https://github.com/openBackhaul/onfCoreIm/tree/tsp: ONF TR-512 Core IM incl. Profile and enhanced Equipment definition";
}
revision 2024-01-02 {
description
"Model for the Transport SDN Introduction at Telefonica Germany.
Please view https://github.com/openBackhaul/alarms/issues for changes.";
reference
"https://github.com/openBackhaul/alarms/tree/tsi: Model definition
https://github.com/openBackhaul/onfCoreIm/tree/tsp: ONF TR-512 Core IM incl. Profile and enhanced Equipment definition";
}
revision 2023-10-05 {
description
"Model for the Transport SDN Introduction at Telefonica Germany.
Please view https://github.com/openBackhaul/alarms/issues for changes.";
reference
"https://github.com/openBackhaul/alarms/tree/tsi: Model definition
https://github.com/openBackhaul/onfCoreIm/tree/tsp: ONF TR-512 Core IM incl. Profile and enhanced Equipment definition";
}
/*********************************************
* grouping statements for complex data types
*******************************************/
identity ALARM_TYPE_ID_TYPE {
description
"none";
}
identity ALARM_TYPE_ID_TYPE_ALL {
base ALARM_TYPE_ID_TYPE;
description
"Exclusively to be used with the AlarmBehaviorType::alarmTypeId attribute. Represents all combinations of alarmTypeId and alarmTypeQualifier that are available on a specific resource.";
}
identity ALARM_TYPE_ID_TYPE_NOT_YET_DEFINED {
base ALARM_TYPE_ID_TYPE;
description
"none";
}
identity ALARM_CATEGORY_TYPE {
description
"none";
}
identity ALARM_CATEGORY_TYPE_OTHER {
base ALARM_CATEGORY_TYPE;
description
"None of the below.";
}
identity ALARM_CATEGORY_TYPE_COMMUNICATIONS_ALARM {
base ALARM_CATEGORY_TYPE;
description
"An alarm of this type is principally associated with the procedures and/or processes required to convey information from one point to another.";
}
identity ALARM_CATEGORY_TYPE_QUALITY_OF_SERVICE_ALARM {
base ALARM_CATEGORY_TYPE;
description
"An alarm of this type is principally associated with a degradation in the quality of a service.";
}
identity ALARM_CATEGORY_TYPE_PROCESSING_ERROR_ALARM {
base ALARM_CATEGORY_TYPE;
description
"An alarm of this type is principally associated with a software or processing fault.";
}
identity ALARM_CATEGORY_TYPE_EQUIPMENT_ALARM {
base ALARM_CATEGORY_TYPE;
description
"An alarm of this type is principally associated with an equipment fault.";
}
identity ALARM_CATEGORY_TYPE_ENVIRONMENTAL_ALARM {
base ALARM_CATEGORY_TYPE;
description
"An alarm of this type is principally associated with a condition relating to an enclosure in which the equipment resides.";
}
identity ALARM_CATEGORY_TYPE_INTEGRITY_VIOLATION {
base ALARM_CATEGORY_TYPE;
description
"An indication that information may have been illegally modified, inserted or deleted.";
}
identity ALARM_CATEGORY_TYPE_OPERATIONAL_VIOLATION {
base ALARM_CATEGORY_TYPE;
description
"An indication that the provision of the requested service was not possible due to the unavailability, malfunction or incorrect invocation of the service.";
}
identity ALARM_CATEGORY_TYPE_PHYSICAL_VIOLATION {
base ALARM_CATEGORY_TYPE;
description
"An indication that a physical resource has been violated in a way that suggests a security attack.";
}
identity ALARM_CATEGORY_TYPE_SECURITY_SERVICE_OR_MECHANISM_VIOLATION {
base ALARM_CATEGORY_TYPE;
description
"An indication that a security attack has been detected by a security service or mechanism.";
}
identity ALARM_CATEGORY_TYPE_TIME_DOMAIN_VIOLATION {
base ALARM_CATEGORY_TYPE;
description
"An indication that an event has occurred at an unexpected or prohibited time.";
}
identity ALARM_CATEGORY_TYPE_NOT_YET_DEFINED {
base ALARM_CATEGORY_TYPE;
description
"none";
}
identity SEVERITY_AND_CLEARED_TYPE {
description
"none";
}
identity SEVERITY_AND_CLEARED_TYPE_INDETERMINATE {
base SEVERITY_AND_CLEARED_TYPE;
description
"Indicates that the severity level could not be determined. This level SHOULD be avoided.";
}
identity SEVERITY_AND_CLEARED_TYPE_WARNING {
base SEVERITY_AND_CLEARED_TYPE;
description
"This severity level indicates the detection of a potential or impending service affecting fault, before any significant effects have been felt. Action should be taken to further diagnose (if necessary) and correct the problem in order to prevent it from becoming a more serious service affecting fault.";
}
identity SEVERITY_AND_CLEARED_TYPE_MINOR {
base SEVERITY_AND_CLEARED_TYPE;
description
"This severity level indicates the existence of a non-service affecting fault condition and that corrective action should be taken in order to prevent a more serious (for example, service affecting) fault. Such a severity can be reported, for example, when the detected alarm condition is not currently degrading the capacity of the resource.";
}
identity SEVERITY_AND_CLEARED_TYPE_MAJOR {
base SEVERITY_AND_CLEARED_TYPE;
description
"This severity level indicates that a service affecting condition has developed and an urgent corrective action is required. Such a severity can be reported, for example, when there is a severe degradation in the capability of the resource and its full capability must be restored.";
}
identity SEVERITY_AND_CLEARED_TYPE_CRITICAL {
base SEVERITY_AND_CLEARED_TYPE;
description
"This severity level indicates that a service affecting condition has occurred and an immediate corrective action is required. Such a severity can be reported, for example, when a resource becomes totally out of service and its capability must be restored.";
}
identity SEVERITY_AND_CLEARED_TYPE_CLEARED {
base SEVERITY_AND_CLEARED_TYPE;
description
"This value indicates that the alarm is no longer active.";
}
identity SEVERITY_AND_CLEARED_TYPE_NOT_YET_DEFINED {
base SEVERITY_AND_CLEARED_TYPE;
description
"none";
}
identity BEHAVIOR_TYPE {
description
"none";
}
identity BEHAVIOR_TYPE_FULLY_FUNCTIONAL {
base BEHAVIOR_TYPE;
description
"An entry is made into the list of current alarms and a notification gets sent, if such kind of alarm is raised or cleared.";
}
identity BEHAVIOR_TYPE_NOT_NOTIFIED {
base BEHAVIOR_TYPE;
description
"An entry is made into the list of current alarms, but no notification gets sent, if such kind of alarm is raised or cleared.";
}
identity BEHAVIOR_TYPE_DISABLED {
base BEHAVIOR_TYPE;
description
"Alarm gets neither listed in current alarms list nor notified.";
}
identity BEHAVIOR_TYPE_NOT_YET_DEFINED {
base BEHAVIOR_TYPE;
description
"none";
}
identity SEVERITY_TYPE {
description
"none";
}
identity SEVERITY_TYPE_INDETERMINATE {
base SEVERITY_TYPE;
description
"Indicates that the severity level could not be determined. This level SHOULD be avoided.";
}
identity SEVERITY_TYPE_WARNING {
base SEVERITY_TYPE;
description
"This severity level indicates the detection of a potential or impending service affecting fault, before any significant effects have been felt. Action should be taken to further diagnose (if necessary) and correct the problem in order to prevent it from becoming a more serious service affecting fault.";
}
identity SEVERITY_TYPE_MINOR {
base SEVERITY_TYPE;
description
"This severity level indicates the existence of a non-service affecting fault condition and that corrective action should be taken in order to prevent a more serious (for example, service affecting) fault. Such a severity can be reported, for example, when the detected alarm condition is not currently degrading the capacity of the resource.";
}
identity SEVERITY_TYPE_MAJOR {
base SEVERITY_TYPE;
description
"This severity level indicates that a service affecting condition has developed and an urgent corrective action is required. Such a severity can be reported, for example, when there is a severe degradation in the capability of the resource and its full capability must be restored.";
}
identity SEVERITY_TYPE_CRITICAL {
base SEVERITY_TYPE;
description
"This severity level indicates that a service affecting condition has occurred and an immediate corrective action is required. Such a severity can be reported, for example, when a resource becomes totally out of service and its capability must be restored.";
}
identity SEVERITY_TYPE_NOT_YET_DEFINED {
base SEVERITY_TYPE;
description
"none";
}
/****************************************
* typedef statements
**************************************/
typedef alarm-type-id-type {
type identityref {
base ALARM_TYPE_ID_TYPE;
}
description
"This identity shall be referenced as a base identity for identities representing individual alarm types as they are supported by the individual device. The additional identities referencing the ALARM_TYPE_ID_TYPE shall be provided by vendors in a separate YANG module.";
}
typedef alarm-category-type {
type identityref {
base ALARM_CATEGORY_TYPE;
}
description
"none";
}
typedef severity-and-cleared-type {
type identityref {
base SEVERITY_AND_CLEARED_TYPE;
}
description
"According to ITU-T M.3160";
}
typedef behavior-type {
type identityref {
base BEHAVIOR_TYPE;
}
description
"none";
}
/****************************************
* package super-types
**************************************/
typedef severity-type {
type identityref {
base SEVERITY_TYPE;
}
description
"According to ITU-T M.3160";
}
grouping alarm-event-notification {
description
"none";
leaf alarm-event-sequence-number {
type uint32;
config false;
mandatory true;
description
"Identifier of the records of raised and cleared alarms.";
}
leaf alarm-type-id {
type alarm-type-id-type;
config false;
mandatory true;
description
"This leaf and the leaf alarm-type-qualifier together provides a unique identification of the alarm type.";
}
leaf alarm-type-qualifier {
type string;
config false;
description
"This leaf is used when the alarm-type-id leaf cannot uniquely identify the alarm type. Normally, this is not the case, and this leaf is the empty string.";
}
leaf resource {
type instance-identifier;
config false;
mandatory true;
description
"Concrete resource causing this alarm notification.";
}
leaf problem-severity {
type severity-and-cleared-type;
default "SEVERITY_AND_CLEARED_TYPE_NOT_YET_DEFINED";
config false;
description
"Severity of the alarm, but also indication about the alarm being cleared.";
}
leaf timestamp {
type yang:date-and-time;
default "2010-11-20T14:00:00+01:00";
config false;
description
"The time-stamp when this alarm event occured.";
}
}
/****************************************
* grouping statements for object classes
**************************************/
grouping alarm-spec {
description
"none";
container alarm-pac {
description
"none";
uses alarm-pac;
}
}
grouping alarm-pac {
description
"none";
container alarm-capability {
config false;
description
"none";
uses alarm-capability;
}
container alarm-configuration {
description
"none";
uses alarm-configuration;
}
container current-alarms {
config false;
description
"none";
uses current-alarms;
}
container alarm-event-records {
config false;
description
"none";
uses alarm-event-records;
}
}
grouping alarm-capability {
description
"none";
list alarm-inventory-list {
key "alarm-type-id alarm-type-qualifier";
config false;
description
"This alarm-inventory list contains all types of alarms, which are available at the device.";
uses alarm-kind-type;
}
}
grouping alarm-configuration {
description
"none";
list severity-configuration-list {
key "severity-configuration-identifier";
description
"This severity-configuration list contains all severity levels, which are currently configured at the device.";
uses severity-configuration-type;
}
list behavior-management-list {
key "alarm-type-id alarm-type-qualifier resource";
description
"The entries generated by the device in this list shall represent the complete set of possible configurations.";
uses alarm-behavior-type;
}
}
grouping current-alarms {
description
"none";
list current-alarm-list {
key "alarm-type-id alarm-type-qualifier resource";
config false;
description
"Number of currently active alarms in the device.";
uses current-alarm-type;
}
leaf number-of-current-alarms {
type int16;
units "alarms";
default "-1";
config false;
description
"This object shows the total number of currently active alarms in the system.";
}
leaf time-of-latest-change {
type yang:date-and-time;
default "2010-11-20T14:00:00+01:00";
config false;
description
"Date and time of the last time an alarm has either been raised or cleared.";
}
}
grouping alarm-event-records {
description
"none";
list alarm-event-record-list {
key "alarm-event-sequence-number";
config false;
description
"This alarm-event list contains all events recorded by the device.";
uses alarm-event-record-type;
}
leaf number-of-alarm-event-records {
type int16;
units "records";
default "-1";
config false;
description
"Number of alarm-events recorded by the device.";
}
leaf time-of-latest-change {
type yang:date-and-time;
default "2010-11-20T14:00:00+01:00";
config false;
description
"Date and time when the last alarm-event has been recorded.";
}
}
grouping alarm-kind-type {
description
"none";
leaf alarm-type-id {
type alarm-type-id-type;
mandatory true;
description
"The statically defined alarm type identifier for this possible alarm.";
}
leaf alarm-type-qualifier {
type string;
mandatory true;
description
"The optionally defined alarm type identifier for this possible alarm.";
}
leaf will-clear {
type boolean;
default "false";
config false;
description
"This attribute tells the operator, whether the alarm will be automatically cleared when the correct corrective action has been taken.";
}
leaf description {
type string;
default "Not yet defined.";
config false;
description
"A description of the possible alarm. It should include information on possible underlying root causes and corrective actions.";
}
leaf alarm-category {
type alarm-category-type;
default "ALARM_CATEGORY_TYPE_NOT_YET_DEFINED";
config false;
description
"The X.733/X.736 event type for this alarm.";
}
leaf probable-cause {
type int16;
default "-1";
config false;
description
"If the value of the alarm-category attribute is chosen from ITU-T X.733, values 1-57 of this attribute have to be applied according to ITU-T X.721 section 14.2. If the value of the alarm-category attribute is chosen from ITU-T X.736, values 1-18 of this attribute have to be applied according to ITU-T X.721 section 14.2. If probable-cause and alarm-category cannot be mapped to those defined in ITU-T X.733 and ITU-T X.736, then the default value shall be represented in this attribute. In such case, the probable-cause-string attribute might be used.";
}
leaf probable-cause-string {
type string;
default "Not yet defined.";
config false;
description
"The user friendly string matching the probable cause integer value. The string should match the X.733 enumeration.";
}
leaf specific-problem {
type string;
default "Not yet defined.";
config false;
description
"This parameter, when present, identifies further refinements to the probable-cause of the alarm. This parameter qualifies the chosen probable-cause and may be used by the managed object class definer to specify a set of identifiers for use in
managed object classes.";
}
}
grouping severity-configuration-type {
description
"This list is used to override the system default alarm severity levels.";
leaf severity-configuration-identifier {
type string;
mandatory true;
description
"Identifier of the data set of a severity configuration.";
}
leaf alarm-type-id {
type alarm-type-id-type;
config false;
mandatory true;
description
"The alarm type identifier to match.";
}
leaf alarm-type-qualifier {
type string;
config false;
description
"The optionally defined alarm type identifier for this possible alarm.";
}
leaf-list resource-list {
type string;
config false;
min-elements 1;
description
"One or several xpath expressions describing individual resources or types of resources that are subject to the severity definition.";
}
leaf resource-group-description {
type string;
default "Not yet defined.";
config false;
description
"Label that describes the group of resources or resource types that are subject to this severity configuration.";
}
leaf-list severity-level-list {
type severity-type;
default "SEVERITY_TYPE_NOT_YET_DEFINED";
description
"Specifies the configured severity level(s) for the matching alarm. If the alarm has several severity levels, the list shall be given in rising severity order. Example: Assume a high-utilization alarm type with two thresholds with the system-default severity levels of threshold1 = warning and threshold2 = minor. Setting this list to (minor, major) will assign the severity levels as threshold1 = minor and threshold2 = major.";
}
}
grouping current-alarm-type {
description
"none";
leaf alarm-type-id {
type alarm-type-id-type;
config false;
mandatory true;
description
"This attribute and the alarm-type-qualifier attribute together provides a unique identification of the alarm type.";
}
leaf alarm-type-qualifier {
type string;
config false;
description
"This attribute is used whenever the alarm-type-id attribute cannot uniquely identify the type of alarm. Usually, this is not required and this leaf is an empty string.";
}
leaf resource {
type instance-identifier;
config false;
mandatory true;
description
"Concrete resource affected by this alarm.";
}
leaf alarm-severity {
type severity-type;
default "SEVERITY_TYPE_NOT_YET_DEFINED";
config false;
description
"Severity of the alarm.";
}
leaf timestamp {
type yang:date-and-time;
default "2010-11-20T14:00:00+01:00";
config false;
description
"Time when this alarm occurred. This represents the first time the alarm appeared; it can also represent that the alarm re-appeared after a purge.";
}
}
grouping alarm-event-record-type {
description
"none";
leaf alarm-event-sequence-number {
type uint32;
mandatory true;
description
"Identifier of the records of raised and cleared alarms.";
}
leaf alarm-type-id {
type alarm-type-id-type;
config false;
mandatory true;
description
"This attribute and the alarm-type-qualifier attribute together provides a unique identification of the alarm type.";
}
leaf alarm-type-qualifier {
type string;
config false;
description
"This attribute is used when the alarm-type-id attribute does not suffice for uniquely identifying the alarm type.";
}
leaf resource {
type instance-identifier;
config false;
mandatory true;
description
"Concrete resource affected by this alarm event.";
}
leaf alarm-severity {
type severity-and-cleared-type;
default "SEVERITY_AND_CLEARED_TYPE_NOT_YET_DEFINED";
config false;
description
"Severity of the alarm, but also indication about the alarm being cleared.";
}
leaf timestamp {
type yang:date-and-time;
default "2010-11-20T14:00:00+01:00";
config false;
description
"The time-stamp when this alarm event occurred.";
}
}
grouping alarm-behavior-type {
description
"none";
leaf alarm-type-id {
type alarm-type-id-type;
mandatory true;
description
"The alarm type identifier to match.";
}
leaf alarm-type-qualifier {
type string;
description
"The optionally defined alarm type identifier for this possible alarm.";
}
leaf resource {
type instance-identifier;
mandatory true;
description
"xpath expression describing an individual resource or type of resource that is subject to the behavior configuration. If the configuration for a specific combination of alarmTypeId and alarmTypeQualifier would apply on all resources, the ControlConstruct would have to be referenced as resource.";
}
leaf behavior {
type behavior-type;
default "BEHAVIOR_TYPE_NOT_YET_DEFINED";
description
"Defines the behavior of the device when the alarm gets raised or cleared.";
}
}
/****************************************
* package notifications
**************************************/
notification alarm-event-notification {
description
"none";
uses alarm-event-notification;
}
augment "/core-model:control-construct" {
description
"none";
uses alarm-spec;
}
}