Implement nemo language style RPC.
[nemo.git] / nemo-impl / src / main / java / org / opendaylight / nemo / user / vnspacemanager / structurestyle / deleteintent / DeleteConnection.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.ConnectionId;\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.Connection;\r
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.objects.ConnectionKey;\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 DeleteConnection {\r
36 \r
37     private DataBroker dataBroker;\r
38     private TenantManage tenantManage;\r
39     private static final Logger LOG = LoggerFactory.getLogger(DeleteConnection.class);\r
40 \r
41     public DeleteConnection(DataBroker dataBroker, TenantManage tenantManage){\r
42         this.dataBroker = dataBroker;\r
43         this.tenantManage = tenantManage;\r
44     }\r
45 \r
46     public String DeleteConnectionHandling(UserId userId, ConnectionId connectionId){\r
47         Boolean ConnInstanceExist = false;\r
48         String errorInfo = null;\r
49         tenantManage.fetchVNSpace(userId);\r
50         User user = tenantManage.getUser();\r
51 \r
52         if (user != null){\r
53             if (user.getObjects() != null){\r
54                 if (user.getObjects().getConnection() != null){\r
55                     List<Connection> connectionList = tenantManage.getUser().getObjects().getConnection();\r
56 \r
57                     for (Connection connection : connectionList){\r
58                         if (connection.getConnectionId().equals(connectionId)){\r
59                             ConnInstanceExist = true;\r
60                             break;\r
61                         }\r
62                     }\r
63                     if (ConnInstanceExist){\r
64                         DeleteConnInstance(userId, connectionId);\r
65                     }\r
66                     else{\r
67                         errorInfo = "The connection instance "+connectionId.getValue()+ " is not exit. Could not be deleted.";\r
68                     }\r
69                 }\r
70                 else{\r
71                     errorInfo = "There are no connection instances in data store.";\r
72                 }\r
73             }\r
74         }\r
75         else{\r
76             errorInfo = "There are no connection instances in data store.";\r
77         }\r
78 \r
79         return errorInfo;\r
80     }\r
81 \r
82     private void DeleteConnInstance(UserId userId, ConnectionId connectionId){\r
83         WriteTransaction t = dataBroker.newWriteOnlyTransaction();\r
84         UserKey userKey = new UserKey(userId);\r
85         ConnectionKey connectionKey = new ConnectionKey(connectionId);\r
86 \r
87         InstanceIdentifier<Connection> connectionid = InstanceIdentifier.builder(Users.class).child(User.class, userKey).child(Objects.class).child(Connection.class,connectionKey).build();\r
88         t.delete(LogicalDatastoreType.CONFIGURATION, connectionid);\r
89         CheckedFuture<Void, TransactionCommitFailedException> f = t.submit();\r
90         Futures.addCallback(f, new FutureCallback<Void>() {\r
91             @Override\r
92             public void onFailure(Throwable t) {\r
93                 LOG.error("Could not write endpoint base container", t);\r
94             }\r
95 \r
96             @Override\r
97             public void onSuccess(Void result) {\r
98             }\r
99         });\r
100     }\r
101 }\r