]> git.basschouten.com Git - openhab-addons.git/blob
388aa630eee7f74fa79d7f4f01abc553bea9a0ad
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2023 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
7  * This program and the accompanying materials are made available under the
8  * terms of the Eclipse Public License 2.0 which is available at
9  * http://www.eclipse.org/legal/epl-2.0
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.binding.dbquery.internal.dbimpl.influx2;
14
15 import java.util.ArrayList;
16 import java.util.List;
17 import java.util.concurrent.CompletableFuture;
18 import java.util.concurrent.ExecutorService;
19 import java.util.concurrent.Executors;
20
21 import org.eclipse.jdt.annotation.NonNullByDefault;
22 import org.openhab.binding.dbquery.internal.config.InfluxDB2BridgeConfiguration;
23 import org.openhab.binding.dbquery.internal.domain.Database;
24 import org.openhab.binding.dbquery.internal.domain.Query;
25 import org.openhab.binding.dbquery.internal.domain.QueryFactory;
26 import org.openhab.binding.dbquery.internal.domain.QueryResult;
27 import org.openhab.binding.dbquery.internal.error.DatabaseException;
28 import org.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
30
31 import com.influxdb.query.FluxRecord;
32
33 /**
34  * Influx2 implementation of {@link Database}
35  *
36  * @author Joan Pujol - Initial contribution
37  */
38 @NonNullByDefault
39 public class Influx2Database implements Database {
40     private final Logger logger = LoggerFactory.getLogger(Influx2Database.class);
41     private final ExecutorService executors;
42     private final InfluxDB2BridgeConfiguration config;
43     private final InfluxDBClientFacade client;
44     private final QueryFactory queryFactory;
45
46     public Influx2Database(InfluxDB2BridgeConfiguration config, InfluxDBClientFacade influxDBClientFacade) {
47         this.config = config;
48         this.client = influxDBClientFacade;
49         executors = Executors.newSingleThreadScheduledExecutor();
50         queryFactory = new Influx2QueryFactory();
51     }
52
53     @Override
54     public boolean isConnected() {
55         return client.isConnected();
56     }
57
58     @Override
59     public CompletableFuture<Boolean> connect() {
60         return CompletableFuture.supplyAsync(() -> {
61             synchronized (Influx2Database.this) {
62                 return client.connect();
63             }
64         }, executors);
65     }
66
67     @Override
68     public CompletableFuture<Boolean> disconnect() {
69         return CompletableFuture.supplyAsync(() -> {
70             synchronized (Influx2Database.this) {
71                 return client.disconnect();
72             }
73         }, executors);
74     }
75
76     @Override
77     public QueryFactory queryFactory() throws DatabaseException {
78         return queryFactory;
79     }
80
81     @Override
82     public CompletableFuture<QueryResult> executeQuery(Query query) {
83         try {
84             if (query instanceof Influx2QueryFactory.Influx2Query influxQuery) {
85                 CompletableFuture<QueryResult> asyncResult = new CompletableFuture<>();
86                 List<FluxRecord> records = new ArrayList<>();
87                 client.query(influxQuery.getQuery(), (cancellable, record) -> { // onNext
88                     records.add(record);
89                 }, error -> { // onError
90                     logger.warn("Error executing query {}", query, error);
91                     asyncResult.complete(QueryResult.ofIncorrectResult("Error executing query"));
92                 }, () -> { // onComplete
93                     asyncResult.complete(new Influx2QueryResultExtractor().apply(records));
94                 });
95                 return asyncResult;
96             } else {
97                 return CompletableFuture
98                         .completedFuture(QueryResult.ofIncorrectResult("Unnexpected query type " + query));
99             }
100         } catch (RuntimeException e) {
101             return CompletableFuture.failedFuture(e);
102         }
103     }
104
105     @Override
106     public String toString() {
107         return "Influx2Database{config=" + config + '}';
108     }
109 }