2 * Copyright (c) 2015 Huawei, Inc. and others. All rights reserved.
\r
4 * This program and the accompanying materials are made available under the
\r
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
\r
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
\r
8 package org.opendaylight.nemo.user.vnspacemanager.structurestyle.updateintent;
\r
10 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
\r
11 import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
\r
12 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
\r
13 import org.opendaylight.nemo.user.tenantmanager.TenantManage;
\r
14 import org.opendaylight.nemo.user.vnspacemanager.instancecheck.NodeInstanceCheck;
\r
15 import org.opendaylight.nemo.user.vnspacemanager.syntaxcheck.NodeDefinitionCheck;
\r
16 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.common.rev151010.UserId;
\r
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.Users;
\r
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.Objects;
\r
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.objects.Node;
\r
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.objects.NodeBuilder;
\r
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.objects.NodeKey;
\r
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.User;
\r
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.UserKey;
\r
24 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
\r
25 import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException;
\r
26 import com.google.common.util.concurrent.CheckedFuture;
\r
27 import com.google.common.util.concurrent.FutureCallback;
\r
28 import com.google.common.util.concurrent.Futures;
\r
29 import org.slf4j.Logger;
\r
30 import org.slf4j.LoggerFactory;
\r
33 * Created by z00293636 on 2015/8/31.
\r
35 public class UpdateNode {
\r
37 private DataBroker dataBroker;
\r
38 private NodeDefinitionCheck nodeCheck;
\r
39 private NodeInstanceCheck nodeInstanceCheck;
\r
40 private static final Logger LOG = LoggerFactory.getLogger(UpdateNode.class);
\r
42 public UpdateNode(DataBroker dataBroker,TenantManage tenantManage)
\r
44 this.dataBroker = dataBroker;
\r
45 nodeCheck = new NodeDefinitionCheck(dataBroker);
\r
46 nodeInstanceCheck = new NodeInstanceCheck(tenantManage);
\r
49 public String NodeHandling(UserId userId,Node node)
\r
51 String errorDefinition = nodeCheck.CheckNodeDefinition(node);
\r
52 String errorInstance = nodeInstanceCheck.checkNodeInstance(userId,node);
\r
54 if (errorDefinition != null)
\r
56 return errorDefinition;
\r
58 if (errorInstance != null)
\r
60 return errorInstance;
\r
64 WriteTransaction t = dataBroker.newWriteOnlyTransaction();
\r
65 if (userId != null && node.getNodeId() !=null)
\r
67 // NodeBuilder nodeBuilder = new NodeBuilder();
\r
68 // nodeBuilder.setNodeId(node.getNodeId());
\r
69 // nodeBuilder.setNodeId(node.getNodeId());
\r
70 // nodeBuilder.setNodeName(node.getNodeName());
\r
71 // nodeBuilder.setSubNode(node.getSubNode());
\r
72 // nodeBuilder.setProperty(node.getProperty());
\r
73 // Node node1 = nodeBuilder.build();
\r
75 Node node1 = new NodeBuilder(node).build();
\r
76 NodeKey nodeKey = new NodeKey(node.getKey());
\r
78 UserKey userKey = new UserKey(userId);
\r
80 InstanceIdentifier<Node> nodeid = InstanceIdentifier.builder(Users.class).child(User.class, userKey).child(Objects.class).child(Node.class,nodeKey).build();
\r
81 t.put(LogicalDatastoreType.CONFIGURATION, nodeid, node1,true);
\r
82 CheckedFuture<Void, TransactionCommitFailedException> f = t.submit();
\r
83 Futures.addCallback(f, new FutureCallback<Void>() {
\r
85 public void onFailure(Throwable t) {
\r
86 LOG.error("Could not write endpoint base container", t);
\r
90 public void onSuccess(Void result) {
\r