64886e418c142994fdb3a323ecaa8b7484e7ba22
[onosfw.git] /
1 /*
2  * Copyright 2015 Open Networking Laboratory
3  *
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  */
16 package org.onosproject.store.consistent.impl;
17
18 import org.onosproject.store.service.AsyncAtomicCounter;
19 import org.onosproject.store.service.AtomicCounter;
20 import org.onosproject.store.service.StorageException;
21
22 import java.util.concurrent.CompletableFuture;
23 import java.util.concurrent.ExecutionException;
24 import java.util.concurrent.TimeUnit;
25 import java.util.concurrent.TimeoutException;
26
27 /**
28  * Default implementation for a distributed AtomicCounter backed by
29  * partitioned Raft DB.
30  * <p>
31  * The initial value will be zero.
32  */
33 public class DefaultAtomicCounter implements AtomicCounter {
34
35     private static final int OPERATION_TIMEOUT_MILLIS = 5000;
36
37     private final AsyncAtomicCounter asyncCounter;
38
39     public DefaultAtomicCounter(String name,
40                                 Database database,
41                                 boolean meteringEnabled) {
42         asyncCounter = new DefaultAsyncAtomicCounter(name, database, meteringEnabled);
43     }
44
45     @Override
46     public long incrementAndGet() {
47         return complete(asyncCounter.incrementAndGet());
48     }
49
50     @Override
51     public long getAndIncrement() {
52         return complete(asyncCounter.getAndIncrement());
53     }
54
55     @Override
56     public long getAndAdd(long delta) {
57         return complete(asyncCounter.getAndAdd(delta));
58     }
59
60     @Override
61     public long addAndGet(long delta) {
62         return complete(asyncCounter.getAndAdd(delta));
63     }
64
65     @Override
66     public long get() {
67         return complete(asyncCounter.get());
68     }
69
70     private static <T> T complete(CompletableFuture<T> future) {
71         try {
72             return future.get(OPERATION_TIMEOUT_MILLIS, TimeUnit.MILLISECONDS);
73         } catch (InterruptedException e) {
74             Thread.currentThread().interrupt();
75             throw new StorageException.Interrupted();
76         } catch (TimeoutException e) {
77             throw new StorageException.Timeout();
78         } catch (ExecutionException e) {
79             throw new StorageException(e.getCause());
80         }
81     }
82 }