blob: 61b615939c913c27aae549ad0a691fafdbd09ad3 [file] [log] [blame]
hiroki79d5ac32018-05-26 12:21:07 -07001/*
2 * Copyright 2018-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 */
16
17package org.onosproject.odtn.cli.impl;
18
19import java.util.regex.Pattern;
Ray Milkey86ad7bb2018-09-27 12:32:28 -070020import org.apache.karaf.shell.api.action.Command;
Ray Milkey7a2dee52018-09-28 10:58:28 -070021import org.apache.karaf.shell.api.action.lifecycle.Service;
hiroki79d5ac32018-05-26 12:21:07 -070022import org.onlab.util.XmlString;
23import org.onosproject.cli.AbstractShellCommand;
24import org.onosproject.config.DynamicConfigService;
25import org.onosproject.config.Filter;
26import static org.onosproject.odtn.utils.YangToolUtil.toCharSequence;
27import static org.onosproject.odtn.utils.YangToolUtil.toCompositeData;
28import static org.onosproject.odtn.utils.YangToolUtil.toResourceData;
29import static org.onosproject.odtn.utils.YangToolUtil.toXmlCompositeStream;
hiroki96ab3c22018-12-11 14:10:52 -080030import org.onosproject.yang.gen.v1.tapicommon.rev20181210.tapicommon.DefaultContext;
hiroki79d5ac32018-05-26 12:21:07 -070031import org.onosproject.yang.model.DataNode;
32import org.onosproject.yang.model.DefaultModelObjectData;
33import org.onosproject.yang.model.InnerModelObject;
34import org.onosproject.yang.model.ModelConverter;
35import org.onosproject.yang.model.ModelObjectData;
36import org.onosproject.yang.model.ModelObjectId;
37import org.onosproject.yang.model.ResourceData;
38import org.onosproject.yang.model.ResourceId;
39import org.slf4j.Logger;
40import static org.slf4j.LoggerFactory.getLogger;
41
Ray Milkey7a2dee52018-09-28 10:58:28 -070042@Service
hiroki79d5ac32018-05-26 12:21:07 -070043@Command(scope = "onos", name = "odtn-show-tapi-context")
44public class OdtnDcsModelCheckCommand extends AbstractShellCommand {
45
46 private static final Logger log = getLogger(OdtnDcsModelCheckCommand.class);
47 private DynamicConfigService dcs;
48 private ModelConverter modelConverter;
49
50 private void printlog(String format, Object... objs) {
51 print(format.replaceAll(Pattern.quote("{}"), "%s"), objs);
52 log.info(format, objs);
53 }
54
55 @Override
Ray Milkey86ad7bb2018-09-27 12:32:28 -070056 protected void doExecute() {
hiroki79d5ac32018-05-26 12:21:07 -070057 dcs = get(DynamicConfigService.class);
58 modelConverter = get(ModelConverter.class);
59 dumpDcsStore(DefaultContext.class);
60 }
61
62 private ResourceId getResourceId(ModelObjectId modelId) {
63 ModelObjectData data = DefaultModelObjectData.builder()
64 .identifier(modelId)
65 .build();
66 ResourceData rnode = modelConverter.createDataNode(data);
67 return rnode.resourceId();
68 }
69
70 private <T extends InnerModelObject> void dumpDcsStore(Class<T> cls) {
71
72 ModelObjectId mid = ModelObjectId.builder().addChild(cls).build();
73 DataNode all = dcs.readNode(getResourceId(mid), Filter.builder().build());
74
75 ResourceId empty = ResourceId.builder().build();
76 CharSequence strNode = toCharSequence(toXmlCompositeStream(toCompositeData(toResourceData(empty, all))));
77 printlog("XML:\n{}", XmlString.prettifyXml(strNode));
78 }
hirokid8fd7862018-10-09 15:24:24 +090079}