blob: 19ea562c5966f8a25a930efe92c63bc8165944e2 [file] [log] [blame]
Madan Jampani7e55c662016-02-15 21:13:53 -08001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2016-present Open Networking Foundation
Madan Jampani7e55c662016-02-15 21:13:53 -08003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16package org.onosproject.store.primitives.impl;
17
Madan Jampani3780d4b2016-04-04 18:18:24 -070018import java.util.concurrent.CompletableFuture;
Madan Jampani7e55c662016-02-15 21:13:53 -080019import java.util.concurrent.atomic.AtomicBoolean;
20
Madan Jampani7e55c662016-02-15 21:13:53 -080021import org.onosproject.store.primitives.TransactionId;
Madan Jampani3780d4b2016-04-04 18:18:24 -070022import org.onosproject.store.service.CommitStatus;
Madan Jampani7e55c662016-02-15 21:13:53 -080023import org.onosproject.store.service.Serializer;
24import org.onosproject.store.service.TransactionContext;
25import org.onosproject.store.service.TransactionalMap;
Madan Jampani3780d4b2016-04-04 18:18:24 -070026import org.onosproject.utils.MeteringAgent;
Jordan Halterman03b83182017-05-09 12:11:22 -070027import org.slf4j.Logger;
28import org.slf4j.LoggerFactory;
Madan Jampani7e55c662016-02-15 21:13:53 -080029
Jordan Halterman948d6592017-04-20 17:18:24 -070030import static com.google.common.base.MoreObjects.toStringHelper;
Jordan Halterman03b83182017-05-09 12:11:22 -070031import static com.google.common.base.Preconditions.checkState;
Madan Jampani7e55c662016-02-15 21:13:53 -080032
33/**
34 * Default implementation of transaction context.
35 */
Madan Jampani832686d2016-04-04 21:57:26 -070036public class DefaultTransactionContext implements TransactionContext {
Jordan Halterman03b83182017-05-09 12:11:22 -070037 private final Logger log = LoggerFactory.getLogger(getClass());
Madan Jampani7e55c662016-02-15 21:13:53 -080038 private final AtomicBoolean isOpen = new AtomicBoolean(false);
Madan Jampani7e55c662016-02-15 21:13:53 -080039 private final TransactionId transactionId;
40 private final TransactionCoordinator transactionCoordinator;
Madan Jampani3780d4b2016-04-04 18:18:24 -070041 private final MeteringAgent monitor;
Madan Jampani7e55c662016-02-15 21:13:53 -080042
Jordan Halterman948d6592017-04-20 17:18:24 -070043 public DefaultTransactionContext(TransactionId transactionId, TransactionCoordinator transactionCoordinator) {
Madan Jampani7e55c662016-02-15 21:13:53 -080044 this.transactionId = transactionId;
Madan Jampani7e55c662016-02-15 21:13:53 -080045 this.transactionCoordinator = transactionCoordinator;
Madan Jampani3780d4b2016-04-04 18:18:24 -070046 this.monitor = new MeteringAgent("transactionContext", "*", true);
Madan Jampani7e55c662016-02-15 21:13:53 -080047 }
48
49 @Override
50 public String name() {
51 return transactionId.toString();
52 }
53
54 @Override
55 public TransactionId transactionId() {
56 return transactionId;
57 }
58
59 @Override
60 public boolean isOpen() {
61 return isOpen.get();
62 }
63
64 @Override
65 public void begin() {
Jordan Halterman03b83182017-05-09 12:11:22 -070066 if (isOpen.compareAndSet(false, true)) {
67 log.trace("Opened transaction {}", transactionId);
68 } else {
Madan Jampani7e55c662016-02-15 21:13:53 -080069 throw new IllegalStateException("TransactionContext is already open");
70 }
71 }
72
73 @Override
Madan Jampani3780d4b2016-04-04 18:18:24 -070074 public CompletableFuture<CommitStatus> commit() {
Jordan Halterman03b83182017-05-09 12:11:22 -070075 checkState(isOpen.get(), "Transaction not open");
Madan Jampani3780d4b2016-04-04 18:18:24 -070076 final MeteringAgent.Context timer = monitor.startTimer("commit");
Jordan Halterman03b83182017-05-09 12:11:22 -070077 log.debug("Committing transaction {}", transactionId);
Jordan Halterman948d6592017-04-20 17:18:24 -070078 return transactionCoordinator.commit().whenComplete((r, e) -> timer.stop(e));
Madan Jampani7e55c662016-02-15 21:13:53 -080079 }
80
81 @Override
82 public void abort() {
Jordan Halterman03b83182017-05-09 12:11:22 -070083 if (isOpen.compareAndSet(true, false)) {
84 log.debug("Aborted transaction {}", transactionId);
85 }
Madan Jampani7e55c662016-02-15 21:13:53 -080086 }
87
88 @Override
Jordan Halterman948d6592017-04-20 17:18:24 -070089 public <K, V> TransactionalMap<K, V> getTransactionalMap(String mapName, Serializer serializer) {
90 return transactionCoordinator.getTransactionalMap(mapName, serializer);
91 }
92
93 @Override
94 public String toString() {
95 return toStringHelper(this)
96 .add("transactionId", transactionId)
97 .toString();
Madan Jampani7e55c662016-02-15 21:13:53 -080098 }
99}