Phaneendra Manda
Committed by Gerrit Code Review

[ONOS-3114] Vtn codec registrator added

Change-Id: I500e8a9c5f67603cb287d8deab33cddf2e93cbaa
1 +/*
2 + * Copyright 2014-2015 Open Networking Laboratory
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 + */
16 +package org.onosproject.vtnweb.web;
17 +
18 +import org.apache.felix.scr.annotations.Activate;
19 +import org.apache.felix.scr.annotations.Component;
20 +import org.apache.felix.scr.annotations.Deactivate;
21 +import org.apache.felix.scr.annotations.Reference;
22 +import org.apache.felix.scr.annotations.ReferenceCardinality;
23 +import org.onosproject.codec.CodecService;
24 +import org.onosproject.vtnrsc.FlowClassifier;
25 +import org.onosproject.vtnrsc.PortChain;
26 +import org.onosproject.vtnrsc.PortPair;
27 +import org.onosproject.vtnrsc.PortPairGroup;
28 +import org.slf4j.Logger;
29 +import org.slf4j.LoggerFactory;
30 +
31 +/**
32 + * Implementation of the JSON codec brokering service for VTN app.
33 + */
34 +@Component(immediate = true)
35 +public class VtnCodecRegistrator {
36 +
37 + private static Logger log = LoggerFactory.getLogger(VtnCodecRegistrator.class);
38 +
39 + @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
40 + protected CodecService codecService;
41 +
42 + @Activate
43 + public void activate() {
44 + codecService.registerCodec(PortPair.class, new PortPairCodec());
45 + codecService.registerCodec(PortPairGroup.class, new PortPairGroupCodec());
46 + codecService.registerCodec(FlowClassifier.class, new FlowClassifierCodec());
47 + codecService.registerCodec(PortChain.class, new PortChainCodec());
48 +
49 + log.info("Started");
50 + }
51 +
52 + @Deactivate
53 + public void deactivate() {
54 + log.info("Stopped");
55 + }
56 +}
...@@ -15,15 +15,10 @@ ...@@ -15,15 +15,10 @@
15 */ 15 */
16 package org.onosproject.vtnweb.web; 16 package org.onosproject.vtnweb.web;
17 17
18 -import java.util.Map;
19 -import java.util.concurrent.ConcurrentHashMap;
20 -
21 import org.onosproject.codec.CodecContext; 18 import org.onosproject.codec.CodecContext;
19 +import org.onosproject.codec.CodecService;
22 import org.onosproject.codec.JsonCodec; 20 import org.onosproject.codec.JsonCodec;
23 -import org.onosproject.vtnrsc.FlowClassifier; 21 +import org.onosproject.codec.impl.CodecManager;
24 -import org.onosproject.vtnrsc.PortChain;
25 -import org.onosproject.vtnrsc.PortPair;
26 -import org.onosproject.vtnrsc.PortPairGroup;
27 22
28 import com.fasterxml.jackson.databind.ObjectMapper; 23 import com.fasterxml.jackson.databind.ObjectMapper;
29 24
...@@ -33,17 +28,16 @@ import com.fasterxml.jackson.databind.ObjectMapper; ...@@ -33,17 +28,16 @@ import com.fasterxml.jackson.databind.ObjectMapper;
33 public class SfcCodecContext implements CodecContext { 28 public class SfcCodecContext implements CodecContext {
34 29
35 private final ObjectMapper mapper = new ObjectMapper(); 30 private final ObjectMapper mapper = new ObjectMapper();
36 - private final Map<Class<?>, JsonCodec> codecs = new ConcurrentHashMap<>(); 31 + private final CodecManager codecManager = new CodecManager();
32 + private final VtnCodecRegistrator manager = new VtnCodecRegistrator();
37 33
38 /** 34 /**
39 * Constructs a new mock codec context. 35 * Constructs a new mock codec context.
40 */ 36 */
41 public SfcCodecContext() { 37 public SfcCodecContext() {
42 - codecs.clear(); 38 + codecManager.activate();
43 - registerCodec(PortPair.class, new PortPairCodec()); 39 + manager.codecService = codecManager;
44 - registerCodec(PortChain.class, new PortChainCodec()); 40 + manager.activate();
45 - registerCodec(PortPairGroup.class, new PortPairGroupCodec());
46 - registerCodec(FlowClassifier.class, new FlowClassifierCodec());
47 } 41 }
48 42
49 @Override 43 @Override
...@@ -58,20 +52,17 @@ public class SfcCodecContext implements CodecContext { ...@@ -58,20 +52,17 @@ public class SfcCodecContext implements CodecContext {
58 return null; 52 return null;
59 } 53 }
60 54
55 + @Override
56 + public <T> JsonCodec<T> codec(Class<T> entityClass) {
57 + return codecManager.getCodec(entityClass);
58 + }
59 +
61 /** 60 /**
62 - * Registers the specified JSON codec for the given entity class. 61 + * Get the codec manager.
63 * 62 *
64 - * @param entityClass entity class 63 + * @return instance of codec manager
65 - * @param codec JSON codec
66 - * @param <T> entity type
67 */ 64 */
68 - public <T> void registerCodec(Class<T> entityClass, JsonCodec<T> codec) { 65 + public CodecService codecManager() {
69 - codecs.putIfAbsent(entityClass, codec); 66 + return codecManager;
70 - }
71 -
72 - @SuppressWarnings("unchecked")
73 - @Override
74 - public <T> JsonCodec<T> codec(Class<T> entityClass) {
75 - return codecs.get(entityClass);
76 } 67 }
77 } 68 }
......