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.nemo.user.tenantmanager.TenantManage;
\r
13 import org.opendaylight.nemo.user.vnspacemanager.instancecheck.OperationInstanceCheck;
\r
14 import org.opendaylight.nemo.user.vnspacemanager.syntaxcheck.OperationDefinitionCheck;
\r
15 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.common.rev151010.UserId;
\r
16 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.Users;
\r
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.Operations;
\r
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.operations.Operation;
\r
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.operations.OperationBuilder;
\r
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.user.intent.operations.OperationKey;
\r
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.User;
\r
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.nemo.intent.rev151010.users.UserKey;
\r
23 import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
\r
24 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
\r
25 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
\r
26 import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException;
\r
27 import com.google.common.util.concurrent.CheckedFuture;
\r
28 import com.google.common.util.concurrent.FutureCallback;
\r
29 import com.google.common.util.concurrent.Futures;
\r
30 import org.slf4j.Logger;
\r
31 import org.slf4j.LoggerFactory;
\r
34 * Created by z00293636 on 2015/8/31.
\r
36 public class UpdateOperation {
\r
38 private DataBroker dataBroker;
\r
39 private TenantManage tenantManage;
\r
40 private OperationDefinitionCheck operationDefinitionCheck;
\r
41 private OperationInstanceCheck operationInstanceCheck;
\r
42 private static final Logger LOG = LoggerFactory.getLogger(UpdateOperation.class);
\r
44 public UpdateOperation(DataBroker dataBroker, TenantManage tenantManage)
\r
46 this.dataBroker = dataBroker;
\r
47 this.tenantManage = tenantManage;
\r
48 operationDefinitionCheck = new OperationDefinitionCheck(dataBroker);
\r
49 operationInstanceCheck = new OperationInstanceCheck(tenantManage);
\r
52 public String OperationHandling(UserId userId, Operation operation)
\r
54 String errorDefinition = operationDefinitionCheck.CheckDefinition(operation);
\r
55 String errorInstance = operationInstanceCheck.checkOperationInstance(userId, operation);
\r
57 if (errorDefinition != null)
\r
59 return errorDefinition;
\r
61 if (errorInstance != null)
\r
63 return errorInstance;
\r
67 WriteTransaction t = dataBroker.newWriteOnlyTransaction();
\r
68 if (userId != null && operation.getOperationId() != null)
\r
70 // OperationBuilder operationBuilder = new OperationBuilder();
\r
71 // operationBuilder.setOperationId(operation.getOperationId());
\r
72 // operationBuilder.setOperationName(operation.getOperationName());
\r
73 // operationBuilder.setConditionSegment(operation.getConditionSegment());
\r
74 // operationBuilder.setTargetObject(operationBuilder.getTargetObject());
\r
75 // operationBuilder.setAction(operation.getAction());
\r
76 // operationBuilder.setPriority(operation.getPriority());
\r
78 // Operation operation1 = operationBuilder.build();
\r
79 Operation operation1 = new OperationBuilder(operation).build();
\r
80 OperationKey operationKey = new OperationKey(operation.getOperationId());
\r
82 UserKey userKey = new UserKey(userId);
\r
84 InstanceIdentifier<Operation> operationid = InstanceIdentifier.builder(Users.class).child(User.class, userKey).child(Operations.class).child(Operation.class,operationKey).build();
\r
85 t.put(LogicalDatastoreType.CONFIGURATION, operationid, operation1,true);
\r
86 CheckedFuture<Void, TransactionCommitFailedException> f = t.submit();
\r
87 Futures.addCallback(f, new FutureCallback<Void>() {
\r
89 public void onFailure(Throwable t) {
\r
90 LOG.error("Could not write endpoint base container", t);
\r
94 public void onSuccess(Void result) {
\r