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;
17 public class StatisticsRestconfServiceWrapper implements RestconfService {
19 AtomicLong operationalGet = new AtomicLong();
20 AtomicLong configGet = new AtomicLong();
21 AtomicLong rpc = new AtomicLong();
22 AtomicLong configPost = new AtomicLong();
23 AtomicLong configPut = new AtomicLong();
24 AtomicLong configDelete = new AtomicLong();
25 AtomicLong successGetConfig = new AtomicLong();
26 AtomicLong successGetOperational = new AtomicLong();
27 AtomicLong successPost = new AtomicLong();
28 AtomicLong successPut = new AtomicLong();
29 AtomicLong successDelete = new AtomicLong();
30 AtomicLong failureGetConfig = new AtomicLong();
31 AtomicLong failureGetOperational = new AtomicLong();
32 AtomicLong failurePost = new AtomicLong();
33 AtomicLong failurePut = new AtomicLong();
34 AtomicLong failureDelete = new AtomicLong();
36 private static final StatisticsRestconfServiceWrapper INSTANCE =
37 new StatisticsRestconfServiceWrapper(RestconfImpl.getInstance());
39 final RestconfService delegate;
41 private StatisticsRestconfServiceWrapper(final RestconfService delegate) {
42 this.delegate = delegate;
45 public static StatisticsRestconfServiceWrapper getInstance() {
50 public Object getRoot() {
51 return this.delegate.getRoot();
55 public NormalizedNodeContext getModules(final UriInfo uriInfo) {
56 return this.delegate.getModules(uriInfo);
60 public NormalizedNodeContext getModules(final String identifier, final UriInfo uriInfo) {
61 return this.delegate.getModules(identifier, uriInfo);
65 public NormalizedNodeContext getModule(final String identifier, final UriInfo uriInfo) {
66 return this.delegate.getModule(identifier, uriInfo);
70 public NormalizedNodeContext getOperations(final UriInfo uriInfo) {
71 return this.delegate.getOperations(uriInfo);
75 public NormalizedNodeContext getOperations(final String identifier, final UriInfo uriInfo) {
76 return this.delegate.getOperations(identifier, uriInfo);
80 public NormalizedNodeContext invokeRpc(final String identifier, final NormalizedNodeContext payload,
81 final UriInfo uriInfo) {
82 this.rpc.incrementAndGet();
83 return this.delegate.invokeRpc(identifier, payload, uriInfo);
87 public NormalizedNodeContext invokeRpc(final String identifier, final String noPayload, final UriInfo uriInfo) {
88 this.rpc.incrementAndGet();
89 return this.delegate.invokeRpc(identifier, noPayload, uriInfo);
93 public NormalizedNodeContext readConfigurationData(final String identifier, final UriInfo uriInfo) {
94 this.configGet.incrementAndGet();
95 NormalizedNodeContext normalizedNodeContext = null;
97 normalizedNodeContext = this.delegate.readConfigurationData(identifier, uriInfo);
98 if (normalizedNodeContext.getData() != null) {
99 this.successGetConfig.incrementAndGet();
102 this.failureGetConfig.incrementAndGet();
104 } catch (final Exception e) {
105 this.failureGetConfig.incrementAndGet();
108 return normalizedNodeContext;
112 public NormalizedNodeContext readOperationalData(final String identifier, final UriInfo uriInfo) {
113 this.operationalGet.incrementAndGet();
114 NormalizedNodeContext normalizedNodeContext = null;
116 normalizedNodeContext = this.delegate.readOperationalData(identifier, uriInfo);
117 if (normalizedNodeContext.getData() != null) {
118 this.successGetOperational.incrementAndGet();
121 this.failureGetOperational.incrementAndGet();
123 } catch (final Exception e) {
124 this.failureGetOperational.incrementAndGet();
127 return normalizedNodeContext;
131 public Response updateConfigurationData(final String identifier, final NormalizedNodeContext payload) {
132 this.configPut.incrementAndGet();
133 Response response = null;
135 response = this.delegate.updateConfigurationData(identifier, payload);
136 if (response.getStatus() == Status.OK.getStatusCode()) {
137 this.successPut.incrementAndGet();
140 this.failurePut.incrementAndGet();
142 } catch (final Exception e) {
143 this.failurePut.incrementAndGet();
150 public Response createConfigurationData(final String identifier, final NormalizedNodeContext payload,
151 final UriInfo uriInfo) {
152 this.configPost.incrementAndGet();
153 Response response = null;
155 response = this.delegate.createConfigurationData(identifier, payload, uriInfo);
156 if (response.getStatus() == Status.OK.getStatusCode()) {
157 this.successPost.incrementAndGet();
160 this.failurePost.incrementAndGet();
162 } catch (final Exception e) {
163 this.failurePost.incrementAndGet();
170 public Response createConfigurationData(final NormalizedNodeContext payload, final UriInfo uriInfo) {
171 this.configPost.incrementAndGet();
172 Response response = null;
174 response = this.delegate.createConfigurationData(payload, uriInfo);
175 if (response.getStatus() == Status.OK.getStatusCode()) {
176 this.successPost.incrementAndGet();
179 this.failurePost.incrementAndGet();
181 }catch (final Exception e) {
182 this.failurePost.incrementAndGet();
189 public Response deleteConfigurationData(final String identifier) {
190 this.configDelete.incrementAndGet();
191 Response response = null;
193 response = this.delegate.deleteConfigurationData(identifier);
194 if (response.getStatus() == Status.OK.getStatusCode()) {
195 this.successDelete.incrementAndGet();
198 this.failureDelete.incrementAndGet();
200 } catch (final Exception e) {
201 this.failureDelete.incrementAndGet();
208 public NormalizedNodeContext subscribeToStream(final String identifier, final UriInfo uriInfo) {
209 return this.delegate.subscribeToStream(identifier, uriInfo);
213 public NormalizedNodeContext getAvailableStreams(final UriInfo uriInfo) {
214 return this.delegate.getAvailableStreams(uriInfo);
218 public PATCHStatusContext patchConfigurationData(final String identifier, final PATCHContext payload,
219 final UriInfo uriInfo) {
220 return this.delegate.patchConfigurationData(identifier, payload, uriInfo);
224 public PATCHStatusContext patchConfigurationData(final PATCHContext payload, final UriInfo uriInfo) {
225 return this.delegate.patchConfigurationData(payload, uriInfo);
228 public BigInteger getConfigDelete() {
229 return BigInteger.valueOf(this.configDelete.get());
232 public BigInteger getConfigGet() {
233 return BigInteger.valueOf(this.configGet.get());
236 public BigInteger getConfigPost() {
237 return BigInteger.valueOf(this.configPost.get());
240 public BigInteger getConfigPut() {
241 return BigInteger.valueOf(this.configPut.get());
244 public BigInteger getOperationalGet() {
245 return BigInteger.valueOf(this.operationalGet.get());
248 public BigInteger getRpc() {
249 return BigInteger.valueOf(this.rpc.get());
252 public BigInteger getSuccessGetConfig() {
253 return BigInteger.valueOf(this.successGetConfig.get());
256 public BigInteger getSuccessGetOperational() {
257 return BigInteger.valueOf(this.successGetOperational.get());
260 public BigInteger getSuccessPost() {
261 return BigInteger.valueOf(this.successPost.get());
264 public BigInteger getSuccessPut() {
265 return BigInteger.valueOf(this.successPut.get());
268 public BigInteger getSuccessDelete() {
269 return BigInteger.valueOf(this.successDelete.get());
272 public BigInteger getFailureGetConfig() {
273 return BigInteger.valueOf(this.failureGetConfig.get());
276 public BigInteger getFailureGetOperational() {
277 return BigInteger.valueOf(this.failureGetOperational.get());
280 public BigInteger getFailurePost() {
281 return BigInteger.valueOf(this.failurePost.get());
284 public BigInteger getFailurePut() {
285 return BigInteger.valueOf(this.failurePut.get());
288 public BigInteger getFailureDelete() {
289 return BigInteger.valueOf(this.failureDelete.get());