blob: 22bca67273de8e4d117fa6df7f8d4fa4fc4d2ad1 [file] [log] [blame]
Chip Boling6e27b352020-02-14 09:10:01 -06001/*
2 * Copyright (c) 2018 - present. Boling Consulting Solutions (bcsw.net)
Andrea Campanella7167ebb2020-02-24 09:56:38 +01003 * Copyright 2020-present Open Networking Foundation
4
Chip Boling6e27b352020-02-14 09:10:01 -06005 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
Andrea Campanella7167ebb2020-02-24 09:56:38 +01008
Chip Boling6e27b352020-02-14 09:10:01 -06009 * http://www.apache.org/licenses/LICENSE-2.0
Andrea Campanella7167ebb2020-02-24 09:56:38 +010010
Chip Boling6e27b352020-02-14 09:10:01 -060011 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
Chip Boling34ebcb62021-02-02 12:13:58 -060017/*
Chip Boling6e27b352020-02-14 09:10:01 -060018 * NOTE: This file was generated, manual edits will be overwritten!
19 *
20 * Generated by 'goCodeGenerator.py':
21 * https://github.com/cboling/OMCI-parser/README.md
22 */
23
24package generated
25
26import "github.com/deckarep/golang-set"
27
28// EquipmentExtensionPackageClassID is the 16-bit ID for the OMCI
29// Managed entity Equipment extension package
Chip Boling610117d2021-09-09 11:24:34 -050030const EquipmentExtensionPackageClassID = ClassID(160) // 0x00a0
Chip Boling6e27b352020-02-14 09:10:01 -060031
32var equipmentextensionpackageBME *ManagedEntityDefinition
33
Chip Boling610117d2021-09-09 11:24:34 -050034// EquipmentExtensionPackage (Class ID: #160 / 0x00a0)
Chip Boling6e27b352020-02-14 09:10:01 -060035// This ME supports optional extensions to circuit pack MEs. If the circuit pack supports these
36// features, the ONU creates and deletes this ME along with its associated real or virtual circuit
37// pack.
38//
39// Relationships
40// An equipment extension package may be contained by an ONU-G or cardholder.
41//
42// Attributes
43// Managed Entity Id
Chip Boling610117d2021-09-09 11:24:34 -050044// This attribute uniquely identifies each instance of this ME. Through an identical ID, this ME is
45// implicitly linked to an instance of the ONU-G or cardholder. (R) (mandatory) (2-bytes)
Chip Boling6e27b352020-02-14 09:10:01 -060046//
47// Environmental Sense
Chip Boling610117d2021-09-09 11:24:34 -050048// This attribute provisions an ONU that supports external sense points, e.g., physical security
49// detectors at an enclosure. Each pair of bits is defined as follows.
50//
51// 00 Sense point disabled (default)
52//
53// 01 Report contact closure
54//
55// 10 Report contact open
56//
57// 11 Sense point disabled (same as 00)
58//
59// If the byte is represented in binary as 0B hhgg ffee ddcc bbaa, bits hh correspond to sense
60// point 1, while bits aa correspond to sense point 8. (R,-W) (optional) (2-bytes)
61//
Chip Boling6e27b352020-02-14 09:10:01 -060062// NOTE - Some specific sense point applications are already defined on the ONU-G ME. It is the
63// vendor's choice how to configure and report sense points that appear both generically and
64// specifically.
65//
66// Contact Closure Output
Chip Boling610117d2021-09-09 11:24:34 -050067// This attribute provisions an ONU that supports external contact closure outputs, e.g., sump pump
68// or air conditioner activation at an ONU enclosure. A contact point is said to be released when
69// it is not energized. Whether this corresponds to an open or a closed electrical circuit depends
70// on the ONU's wiring options. Upon ONU initialization, all contact points should go to the
71// released state.
72//
73// If the byte is represented in binary as 0B hhgg ffee ddcc bbaa, bits hh correspond to contact
74// output point 1, while bits aa correspond to contact output point 8.
75//
76// On write, the bits of this attribute have the following meaning.
77//
78// 0x No change to contact output point state
79//
80// 10 Release contact output point
81//
82// 11 Operate contact output point
83//
Chip Boling6e27b352020-02-14 09:10:01 -060084// On read, the left bit in each pair should be set to 0 at the ONU and ignored at the OLT. The
85// right bit indicates a released output point with 0 and an operated contact point with 1. (R,-W)
86// (optional) (2-bytes)
87//
88type EquipmentExtensionPackage struct {
89 ManagedEntityDefinition
90 Attributes AttributeValueMap
91}
92
93func init() {
94 equipmentextensionpackageBME = &ManagedEntityDefinition{
95 Name: "EquipmentExtensionPackage",
96 ClassID: 160,
97 MessageTypes: mapset.NewSetWith(
98 Get,
99 Set,
100 ),
101 AllowedAttributeMask: 0xc000,
102 AttributeDefinitions: AttributeDefinitionMap{
103 0: Uint16Field("ManagedEntityId", PointerAttributeType, 0x0000, 0, mapset.NewSetWith(Read), false, false, false, 0),
104 1: Uint16Field("EnvironmentalSense", UnsignedIntegerAttributeType, 0x8000, 0, mapset.NewSetWith(Read, Write), false, true, false, 1),
105 2: Uint16Field("ContactClosureOutput", UnsignedIntegerAttributeType, 0x4000, 0, mapset.NewSetWith(Read, Write), false, true, false, 2),
106 },
107 Access: CreatedByOnu,
108 Support: UnknownSupport,
Chip Boling34ebcb62021-02-02 12:13:58 -0600109 Alarms: AlarmMap{
110 0: "Reserved",
111 1: "Sense point 1",
112 2: "Sense point 2",
113 3: "Sense point 3",
114 4: "Sense point 4",
115 5: "Sense point 5",
116 6: "Sense point 6",
117 7: "Sense point 7",
118 8: "Sense point 8",
119 },
Chip Boling6e27b352020-02-14 09:10:01 -0600120 }
121}
122
123// NewEquipmentExtensionPackage (class ID 160) creates the basic
124// Managed Entity definition that is used to validate an ME of this type that
125// is received from or transmitted to the OMCC.
126func NewEquipmentExtensionPackage(params ...ParamData) (*ManagedEntity, OmciErrors) {
127 return NewManagedEntity(*equipmentextensionpackageBME, params...)
128}