Adding nemo engine.
[nemo.git] / nemo-impl / src / main / java / org / opendaylight / nemo / user / vnspacemanager / structurestyle / deleteintent / DeleteNode.java
1 /*\r
2  * Copyright (c) 2015 Huawei, Inc. and others. All rights reserved.\r
3  *\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
7  */\r
8 package org.opendaylight.nemo.user.vnspacemanager.structurestyle.deleteintent;\r
9 \r
10 import org.opendaylight.controller.md.sal.binding.api.DataBroker;\r
11 import org.opendaylight.nemo.user.tenantmanager.TenantManage;\r
12 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.common.rev151010.NodeId;\r
13 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.common.rev151010.UserId;\r
14 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.Users;\r
15 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.Objects;\r
16 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.objects.Node;\r
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.objects.NodeKey;\r
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.User;\r
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.UserKey;\r
20 import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;\r
21 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;\r
22 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;\r
23 import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException;\r
24 import com.google.common.util.concurrent.CheckedFuture;\r
25 import com.google.common.util.concurrent.FutureCallback;\r
26 import com.google.common.util.concurrent.Futures;\r
27 import org.slf4j.Logger;\r
28 import org.slf4j.LoggerFactory;\r
29 \r
30 import java.util.List;\r
31 \r
32 /**\r
33  * Created by z00293636 on 2015/9/2.\r
34  */\r
35 public class DeleteNode {\r
36 \r
37     private DataBroker dataBroker;\r
38     private TenantManage tenantManage;\r
39     private static final Logger LOG = LoggerFactory.getLogger(DeleteNode.class);\r
40 \r
41     public DeleteNode(DataBroker dataBroker, TenantManage tenantManage)\r
42     {\r
43         this.dataBroker = dataBroker;\r
44         this.tenantManage = tenantManage;\r
45     }\r
46 \r
47     public String DeleNodeHandling(UserId userId,NodeId nodeId)\r
48     {\r
49         String errorInfo = null;\r
50         Boolean NodeInstanceExist = false;\r
51 \r
52         tenantManage.fetchVNSpace(userId);\r
53 \r
54         User user = tenantManage.getUser();\r
55         if (user != null)\r
56         {\r
57             if (user.getObjects() != null)\r
58             {\r
59                 if (user.getObjects().getNode() != null)\r
60                 {\r
61                     List<Node> nodeList = tenantManage.getUser().getObjects().getNode();\r
62 \r
63                     for (Node node : nodeList)\r
64                     {\r
65                         if (node.getNodeId().equals(nodeId))\r
66                         {\r
67                             NodeInstanceExist = true;\r
68                             break;\r
69                         }\r
70                     }\r
71                     if (NodeInstanceExist)\r
72                     {\r
73                         DeleteNodeInstance(userId,nodeId);\r
74                     }\r
75                     else\r
76                     {\r
77                         errorInfo = "The node instance" +nodeId.toString()+"is not exist.Could not be deleted";\r
78                     }\r
79                 }\r
80                 else\r
81                 {\r
82                     errorInfo = "There are no nodes instances in data store.";\r
83                 }\r
84             }\r
85         }\r
86         else\r
87         {\r
88             errorInfo = "There are no user in data store.";\r
89         }\r
90 \r
91         return errorInfo;\r
92     }\r
93 \r
94     private void DeleteNodeInstance(UserId userId,NodeId nodeId)\r
95     {\r
96         WriteTransaction t = dataBroker.newWriteOnlyTransaction();\r
97         UserKey userKey = new UserKey(userId);\r
98         NodeKey nodeKey = new NodeKey(nodeId);\r
99 \r
100         InstanceIdentifier<Node> nodeid = InstanceIdentifier.builder(Users.class).child(User.class, userKey).child(Objects.class).child(Node.class,nodeKey).build();\r
101         t.delete(LogicalDatastoreType.CONFIGURATION, nodeid);\r
102         CheckedFuture<Void, TransactionCommitFailedException> f = t.submit();\r
103         Futures.addCallback(f, new FutureCallback<Void>() {\r
104             @Override\r
105             public void onFailure(Throwable t) {\r
106                 LOG.error("Could not write endpoint base container", t);\r
107             }\r
108 \r
109             @Override\r
110             public void onSuccess(Void result) {\r
111             }\r
112         });\r
113     }\r
114 }\r