blob: ebe362fd3592f7d727478dc862f1827014f53c4b [file] [log] [blame]
fahadnaeemkhan71827242017-09-21 15:10:07 -07001/*
2 * Copyright 2016-present Open Networking Foundation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16package org.onosproject.drivers.ciena;
17
18import org.onlab.util.Frequency;
19import org.onosproject.net.DeviceId;
20import org.onosproject.net.OchSignal;
21import org.onosproject.net.PortNumber;
22import org.onosproject.net.driver.DriverHandler;
23import org.onosproject.protocol.rest.RestSBController;
24import org.slf4j.Logger;
25
26import javax.ws.rs.core.MediaType;
27import javax.ws.rs.core.Response;
28import java.io.ByteArrayInputStream;
29import java.io.InputStream;
30import java.nio.charset.StandardCharsets;
31
32import static com.google.common.base.Preconditions.checkNotNull;
33import static org.slf4j.LoggerFactory.getLogger;
34
35public class CienaRestDevice {
36 private DeviceId deviceId;
37 private RestSBController controller;
38
39 private final Logger log = getLogger(getClass());
40 private static final String ENABLED = "enabled";
41 private static final String DISABLED = "disabled";
42 private static final Frequency BASE_FREQUENCY = Frequency.ofGHz(193_950);
fahadnaeemkhan71827242017-09-21 15:10:07 -070043
44 //URIs
45 private static final String PORT_URI = "ws-ptps/ptps/%s";
46 private static final String TRANSMITTER_URI = PORT_URI + "/properties/transmitter";
47 private static final String PORT_STATE_URI = PORT_URI + "/state";
48 private static final String WAVELENGTH_URI = TRANSMITTER_URI + "/wavelength";
49 private static final String FREQUENCY_URI = TRANSMITTER_URI + "/ciena-ws-ptp-modem:frequency";
50 private static final String CHANNEL_URI = TRANSMITTER_URI + "/ciena-ws-ptp-modem:line-system-channel-number";
51
52 public CienaRestDevice(DriverHandler handler) throws NullPointerException {
53 deviceId = handler.data().deviceId();
54 controller = checkNotNull(handler.get(RestSBController.class));
55 }
56
57 private final String genPortStateRequest(String state) {
58 String request = "{\n" +
59 "\"state\": {\n" +
60 "\"admin-state\": \"" + state + "\"\n}\n}";
61 log.debug("generated request: \n{}", request);
62 return request;
63 }
64
65 private String genWavelengthChangeRequest(String wavelength) {
66 String request = "{\n" +
67 "\"wavelength\": {\n" +
68 "\"value\": " + wavelength + "\n" +
69 "}\n" +
70 "}";
71 log.debug("request:\n{}", request);
72 return request;
73
74 }
75
fahadnaeemkhanffc917f2017-10-03 14:04:46 -070076 private String genFrequencyChangeRequest(long frequency) {
fahadnaeemkhan71827242017-09-21 15:10:07 -070077 String request = "{\n" +
78 "\"ciena-ws-ptp-modem:frequency\": {\n" +
fahadnaeemkhanffc917f2017-10-03 14:04:46 -070079 "\"value\": " + Long.toString(frequency) + "\n" +
fahadnaeemkhan71827242017-09-21 15:10:07 -070080 "}\n" +
81 "}";
82 log.debug("request:\n{}", request);
83 return request;
84
85 }
86
87 private String genChannelChangeRequest(int channel) {
88 String request = "{\n" +
89 "\"ciena-ws-ptp-modem:line-system-channel-number\": " +
90 Integer.toString(channel) + "\n}";
91 log.debug("request:\n{}", request);
92 return request;
93
94 }
95
96
97 private final String genUri(String uriFormat, PortNumber port) {
98 return String.format(uriFormat, port.name());
99 }
100
101 private boolean changePortState(PortNumber number, String state) {
102 log.debug("changing the port {} state to {}", number, state);
103 String uri = genUri(PORT_STATE_URI, number);
104 String request = genPortStateRequest(state);
105 return putNoReply(uri, request);
106 }
107
108 public boolean disablePort(PortNumber number) {
109 return changePortState(number, DISABLED);
110 }
111
112 public boolean enablePort(PortNumber number) {
113 return changePortState(number, ENABLED);
114 }
115
116 public final boolean changeFrequency(OchSignal signal, PortNumber outPort) {
117 String uri = genUri(FREQUENCY_URI, outPort);
118 long frequency = toFrequency(signal);
119 String request = genFrequencyChangeRequest(frequency);
120 return putNoReply(uri, request);
121 }
122
123 public final boolean changeChannel(OchSignal signal, PortNumber outPort) {
124 String uri = genUri(CHANNEL_URI, outPort);
fahadnaeemkhanffc917f2017-10-03 14:04:46 -0700125 int channel = signal.spacingMultiplier();
fahadnaeemkhan71827242017-09-21 15:10:07 -0700126 log.debug("channel is {} for port {} on device {}", channel, outPort.name(), deviceId);
127 String request = genChannelChangeRequest(channel);
128 return putNoReply(uri, request);
129 }
130
131 private final long toFrequency(OchSignal signal) {
132 double frequency = BASE_FREQUENCY.asGHz() +
133 (signal.channelSpacing().frequency().asGHz() * (double) signal.slotGranularity());
134 return Double.valueOf(frequency).longValue();
135 }
136
fahadnaeemkhan71827242017-09-21 15:10:07 -0700137 private int put(String uri, String request) {
138 InputStream payload = new ByteArrayInputStream(request.getBytes(StandardCharsets.UTF_8));
139 int response = controller.put(deviceId, uri, payload, MediaType.valueOf(MediaType.APPLICATION_JSON));
140 log.debug("response: {}", response);
141 return response;
142 }
143
144 private boolean putNoReply(String uri, String request) {
145 return put(uri, request) == Response.Status.NO_CONTENT.getStatusCode();
146 }
147
148}