2 * Copyright (c) 2014 Cisco Systems, Inc. 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
8 package org.opendaylight.netconf.sal.restconf.impl;
10 import java.math.BigInteger;
11 import java.util.concurrent.atomic.AtomicLong;
12 import javax.ws.rs.core.Response;
13 import javax.ws.rs.core.Response.Status;
14 import javax.ws.rs.core.UriInfo;
15 import org.opendaylight.netconf.sal.rest.api.RestconfService;
16 import org.opendaylight.restconf.common.context.NormalizedNodeContext;
18 public class StatisticsRestconfServiceWrapper implements RestconfService {
20 AtomicLong operationalGet = new AtomicLong();
21 AtomicLong configGet = new AtomicLong();
22 AtomicLong rpc = new AtomicLong();
23 AtomicLong configPost = new AtomicLong();
24 AtomicLong configPut = new AtomicLong();
25 AtomicLong configDelete = new AtomicLong();
26 AtomicLong successGetConfig = new AtomicLong();
27 AtomicLong successGetOperational = new AtomicLong();
28 AtomicLong successPost = new AtomicLong();
29 AtomicLong successPut = new AtomicLong();
30 AtomicLong successDelete = new AtomicLong();
31 AtomicLong failureGetConfig = new AtomicLong();
32 AtomicLong failureGetOperational = new AtomicLong();
33 AtomicLong failurePost = new AtomicLong();
34 AtomicLong failurePut = new AtomicLong();
35 AtomicLong failureDelete = new AtomicLong();
37 private static final StatisticsRestconfServiceWrapper INSTANCE =
38 new StatisticsRestconfServiceWrapper(RestconfImpl.getInstance());
40 final RestconfService delegate;
42 private StatisticsRestconfServiceWrapper(final RestconfService delegate) {
43 this.delegate = delegate;
46 public static StatisticsRestconfServiceWrapper getInstance() {
51 public Object getRoot() {
52 return this.delegate.getRoot();
56 public NormalizedNodeContext getModules(final UriInfo uriInfo) {
57 return this.delegate.getModules(uriInfo);
61 public NormalizedNodeContext getModules(final String identifier, final UriInfo uriInfo) {
62 return this.delegate.getModules(identifier, uriInfo);
66 public NormalizedNodeContext getModule(final String identifier, final UriInfo uriInfo) {
67 return this.delegate.getModule(identifier, uriInfo);
71 public NormalizedNodeContext getOperations(final UriInfo uriInfo) {
72 return this.delegate.getOperations(uriInfo);
76 public NormalizedNodeContext getOperations(final String identifier, final UriInfo uriInfo) {
77 return this.delegate.getOperations(identifier, uriInfo);
81 public NormalizedNodeContext invokeRpc(final String identifier, final NormalizedNodeContext payload,
82 final UriInfo uriInfo) {
83 this.rpc.incrementAndGet();
84 return this.delegate.invokeRpc(identifier, payload, uriInfo);
88 public NormalizedNodeContext invokeRpc(final String identifier, final String noPayload, final UriInfo uriInfo) {
89 this.rpc.incrementAndGet();
90 return this.delegate.invokeRpc(identifier, noPayload, uriInfo);
93 @SuppressWarnings("checkstyle:IllegalCatch")
95 public NormalizedNodeContext readConfigurationData(final String identifier, final UriInfo uriInfo) {
96 this.configGet.incrementAndGet();
97 NormalizedNodeContext normalizedNodeContext = null;
99 normalizedNodeContext = this.delegate.readConfigurationData(identifier, uriInfo);
100 if (normalizedNodeContext.getData() != null) {
101 this.successGetConfig.incrementAndGet();
103 this.failureGetConfig.incrementAndGet();
105 } catch (final Exception e) {
106 this.failureGetConfig.incrementAndGet();
109 return normalizedNodeContext;
112 @SuppressWarnings("checkstyle:IllegalCatch")
114 public NormalizedNodeContext readOperationalData(final String identifier, final UriInfo uriInfo) {
115 this.operationalGet.incrementAndGet();
116 NormalizedNodeContext normalizedNodeContext = null;
118 normalizedNodeContext = this.delegate.readOperationalData(identifier, uriInfo);
119 if (normalizedNodeContext.getData() != null) {
120 this.successGetOperational.incrementAndGet();
122 this.failureGetOperational.incrementAndGet();
124 } catch (final Exception e) {
125 this.failureGetOperational.incrementAndGet();
128 return normalizedNodeContext;
131 @SuppressWarnings("checkstyle:IllegalCatch")
133 public Response updateConfigurationData(final String identifier, final NormalizedNodeContext payload,
134 final UriInfo uriInfo) {
135 this.configPut.incrementAndGet();
136 Response response = null;
138 response = this.delegate.updateConfigurationData(identifier, payload, uriInfo);
139 if (response.getStatus() == Status.OK.getStatusCode()) {
140 this.successPut.incrementAndGet();
142 this.failurePut.incrementAndGet();
144 } catch (final Exception e) {
145 this.failurePut.incrementAndGet();
151 @SuppressWarnings("checkstyle:IllegalCatch")
153 public Response createConfigurationData(final String identifier, final NormalizedNodeContext payload,
154 final UriInfo uriInfo) {
155 this.configPost.incrementAndGet();
156 Response response = null;
158 response = this.delegate.createConfigurationData(identifier, payload, uriInfo);
159 if (response.getStatus() == Status.OK.getStatusCode()) {
160 this.successPost.incrementAndGet();
162 this.failurePost.incrementAndGet();
164 } catch (final Exception e) {
165 this.failurePost.incrementAndGet();
171 @SuppressWarnings("checkstyle:IllegalCatch")
173 public Response createConfigurationData(final NormalizedNodeContext payload, final UriInfo uriInfo) {
174 this.configPost.incrementAndGet();
175 Response response = null;
177 response = this.delegate.createConfigurationData(payload, uriInfo);
178 if (response.getStatus() == Status.OK.getStatusCode()) {
179 this.successPost.incrementAndGet();
181 this.failurePost.incrementAndGet();
183 } catch (final Exception e) {
184 this.failurePost.incrementAndGet();
190 @SuppressWarnings("checkstyle:IllegalCatch")
192 public Response deleteConfigurationData(final String identifier) {
193 this.configDelete.incrementAndGet();
194 Response response = null;
196 response = this.delegate.deleteConfigurationData(identifier);
197 if (response.getStatus() == Status.OK.getStatusCode()) {
198 this.successDelete.incrementAndGet();
200 this.failureDelete.incrementAndGet();
202 } catch (final Exception e) {
203 this.failureDelete.incrementAndGet();
210 public NormalizedNodeContext subscribeToStream(final String identifier, final UriInfo uriInfo) {
211 return this.delegate.subscribeToStream(identifier, uriInfo);
215 public NormalizedNodeContext getAvailableStreams(final UriInfo uriInfo) {
216 return this.delegate.getAvailableStreams(uriInfo);
220 public PatchStatusContext patchConfigurationData(final String identifier, final PatchContext payload,
221 final UriInfo uriInfo) {
222 return this.delegate.patchConfigurationData(identifier, payload, uriInfo);
226 public PatchStatusContext patchConfigurationData(final PatchContext payload, final UriInfo uriInfo) {
227 return this.delegate.patchConfigurationData(payload, uriInfo);
230 public BigInteger getConfigDelete() {
231 return BigInteger.valueOf(this.configDelete.get());
234 public BigInteger getConfigGet() {
235 return BigInteger.valueOf(this.configGet.get());
238 public BigInteger getConfigPost() {
239 return BigInteger.valueOf(this.configPost.get());
242 public BigInteger getConfigPut() {
243 return BigInteger.valueOf(this.configPut.get());
246 public BigInteger getOperationalGet() {
247 return BigInteger.valueOf(this.operationalGet.get());
250 public BigInteger getRpc() {
251 return BigInteger.valueOf(this.rpc.get());
254 public BigInteger getSuccessGetConfig() {
255 return BigInteger.valueOf(this.successGetConfig.get());
258 public BigInteger getSuccessGetOperational() {
259 return BigInteger.valueOf(this.successGetOperational.get());
262 public BigInteger getSuccessPost() {
263 return BigInteger.valueOf(this.successPost.get());
266 public BigInteger getSuccessPut() {
267 return BigInteger.valueOf(this.successPut.get());
270 public BigInteger getSuccessDelete() {
271 return BigInteger.valueOf(this.successDelete.get());
274 public BigInteger getFailureGetConfig() {
275 return BigInteger.valueOf(this.failureGetConfig.get());
278 public BigInteger getFailureGetOperational() {
279 return BigInteger.valueOf(this.failureGetOperational.get());
282 public BigInteger getFailurePost() {
283 return BigInteger.valueOf(this.failurePost.get());
286 public BigInteger getFailurePut() {
287 return BigInteger.valueOf(this.failurePut.get());
290 public BigInteger getFailureDelete() {
291 return BigInteger.valueOf(this.failureDelete.get());