2 * Copyright © 2017 AT&T and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.transportpce.renderer.openroadminterface;
11 import java.math.BigDecimal;
12 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
13 import org.opendaylight.controller.md.sal.binding.api.MountPointService;
14 import org.opendaylight.yang.gen.v1.http.org.openroadm.common.types.rev161014.PowerDBm;
15 import org.opendaylight.yang.gen.v1.http.org.openroadm.device.rev170206.interfaces.grp.InterfaceBuilder;
16 import org.opendaylight.yang.gen.v1.http.org.openroadm.device.rev170206.interfaces.grp.InterfaceKey;
17 import org.opendaylight.yang.gen.v1.http.org.openroadm.interfaces.rev161014.OpticalChannel;
18 import org.opendaylight.yang.gen.v1.http.org.openroadm.optical.channel.interfaces.rev161014.Interface1;
19 import org.opendaylight.yang.gen.v1.http.org.openroadm.optical.channel.interfaces.rev161014.Interface1Builder;
20 import org.opendaylight.yang.gen.v1.http.org.openroadm.optical.channel.interfaces.rev161014.OchAttributes.ModulationFormat;
21 import org.opendaylight.yang.gen.v1.http.org.openroadm.optical.channel.interfaces.rev161014.RateIdentity;
22 import org.opendaylight.yang.gen.v1.http.org.openroadm.optical.channel.interfaces.rev161014.och.container.OchBuilder;
24 public class OpenRoadmOchInterface extends OpenRoadmInterfaces {
26 public OpenRoadmOchInterface(DataBroker db, MountPointService mps, String nodeId, String logicalConnPoint,
28 super(db, mps, nodeId, logicalConnPoint, serviceName);
32 * This methods creates an OCH interface on the given termination point on
36 * wavelength number of the OCH interface.
38 * @return Name of the interface if successful, otherwise return null.
41 public String createInterface(Long waveNumber) {
43 // Create generic interface
44 InterfaceBuilder ochInterfaceBldr = getIntfBuilder(portMap);
45 ochInterfaceBldr.setType(OpticalChannel.class);
46 ochInterfaceBldr.setName(logicalConnPoint + "-" + waveNumber);
47 ochInterfaceBldr.setKey(new InterfaceKey(logicalConnPoint + "-" + waveNumber));
49 // OCH interface specific data
50 OchBuilder ocIfBuilder = new OchBuilder();
51 ocIfBuilder.setWavelengthNumber(waveNumber);
53 // Add supporting OMS interface
54 if (portMap.getSupportingOms() != null) {
55 ochInterfaceBldr.setSupportingInterface(portMap.getSupportingOms());
57 // Create Interface1 type object required for adding as augmentation
58 Interface1Builder ochIf1Builder = new Interface1Builder();
59 ochInterfaceBldr.addAugmentation(Interface1.class, ochIf1Builder.setOch(ocIfBuilder.build()).build());
61 // Post interface on the device
62 if (postInterface(ochInterfaceBldr)) {
63 return ochInterfaceBldr.getName();
69 public String createInterface(Long waveNumber, Class<? extends RateIdentity> rate, ModulationFormat format) {
71 // Create generic interface
72 InterfaceBuilder ochInterfaceBldr = getIntfBuilder(portMap);
73 ochInterfaceBldr.setType(OpticalChannel.class);
74 ochInterfaceBldr.setName(logicalConnPoint + "-" + waveNumber);
75 ochInterfaceBldr.setKey(new InterfaceKey(logicalConnPoint + "-" + waveNumber));
77 // OCH interface specific data
78 OchBuilder ocIfBuilder = new OchBuilder();
79 ocIfBuilder.setWavelengthNumber(waveNumber);
80 ocIfBuilder.setModulationFormat(format);
81 ocIfBuilder.setRate(rate);
82 ocIfBuilder.setTransmitPower(new PowerDBm(new BigDecimal("-5")));
84 // Create Interface1 type object required for adding as augmentation
85 Interface1Builder ochIf1Builder = new Interface1Builder();
86 ochInterfaceBldr.addAugmentation(Interface1.class, ochIf1Builder.setOch(ocIfBuilder.build()).build());
88 // Post interface on the device
89 if (postInterface(ochInterfaceBldr)) {
90 return ochInterfaceBldr.getName();