Adding nemo engine.
[nemo.git] / nemo-impl / src / main / java / org / opendaylight / nemo / user / vnspacemanager / structurestyle / deleteintent / DeleteOperation.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.OperationId;\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.Operations;\r
16 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.operations.Operation;\r
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.operations.OperationKey;\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 DeleteOperation {\r
36 \r
37     private DataBroker dataBroker;\r
38     private TenantManage tenantManage;\r
39     private static final Logger LOG = LoggerFactory.getLogger(DeleteOperation.class);\r
40 \r
41     public DeleteOperation(DataBroker dataBroker, TenantManage tenantManage)\r
42     {\r
43         this.dataBroker = dataBroker;\r
44         this.tenantManage = tenantManage;\r
45     }\r
46 \r
47     public String DeleteOperationhandling(UserId userId, OperationId operationId)\r
48     {\r
49         Boolean OperationExist = false;\r
50         String errorInfo = null;\r
51         tenantManage.fetchVNSpace(userId);\r
52 \r
53         User user = tenantManage.getUser();\r
54 \r
55         if (user != null)\r
56         {\r
57             if (user.getOperations() != null)\r
58             {\r
59                 if (user.getOperations().getOperation() != null)\r
60                 {\r
61                     List<Operation> operationList = tenantManage.getUser().getOperations().getOperation();\r
62 \r
63                     for (Operation operation : operationList)\r
64                     {\r
65                         if (operation.getOperationId().equals(operationId))\r
66                         {\r
67                             OperationExist = true;\r
68                             break;\r
69                         }\r
70                     }\r
71 \r
72                     if (OperationExist)\r
73                     {\r
74                         DeleteOperationInstance(userId,operationId);\r
75                     }\r
76                     else\r
77                     {\r
78                         errorInfo = "The operation instance" +operationId.toString()+"is not exist. Could not be deleted.";\r
79                     }\r
80                 }\r
81                 else\r
82                 {\r
83                     errorInfo = "There are no operation instances in the data store.";\r
84                 }\r
85             }\r
86         }\r
87         else\r
88         {\r
89             errorInfo = "There are no user in the data store.";\r
90         }\r
91         return errorInfo;\r
92     }\r
93 \r
94     private void DeleteOperationInstance(UserId userId, OperationId operationId)\r
95     {\r
96         WriteTransaction t = dataBroker.newWriteOnlyTransaction();\r
97         UserKey userKey = new UserKey(userId);\r
98         OperationKey operationKey = new OperationKey(operationId);\r
99 \r
100         InstanceIdentifier<Operation> operationid = InstanceIdentifier.builder(Users.class).child(User.class, userKey).child(Operations.class).child(Operation.class,operationKey).build();\r
101         t.delete(LogicalDatastoreType.CONFIGURATION, operationid);\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