2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.controller.sal.core.api.data;
10 import java.util.EventListener;
11 import java.util.concurrent.Future;
13 import org.opendaylight.controller.md.sal.common.api.TransactionStatus;
14 import org.opendaylight.controller.md.sal.common.api.data.DataModification;
15 import org.opendaylight.yangtools.concepts.ListenerRegistration;
16 import org.opendaylight.yangtools.yang.common.RpcResult;
17 import org.opendaylight.yangtools.yang.data.api.CompositeNode;
18 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
22 * @deprecated Replaced by more specific
23 * {@link org.opendaylight.controller.md.sal.dom.api.DOMDataWriteTransaction}
25 * {@link org.opendaylight.controller.md.sal.dom.api.DOMDataReadTransaction}
26 * or {@link org.opendaylight.controller.md.sal.dom.api.DOMDataReadWriteTransaction}
30 public interface DataModificationTransaction extends DataModification<YangInstanceIdentifier, CompositeNode> {
33 * Returns transaction identifier
35 * @return Transaction identifier
38 Object getIdentifier();
41 TransactionStatus getStatus();
44 * Commits transaction to be stored in global data repository.
47 * @return Future object which returns RpcResult with TransactionStatus when
48 * transaction is processed by store.
51 Future<RpcResult<TransactionStatus>> commit();
53 ListenerRegistration<DataTransactionListener> registerListener(DataTransactionListener listener);
55 public interface DataTransactionListener extends EventListener {
56 void onStatusUpdated(DataModificationTransaction transaction, TransactionStatus status);