1
0

create DatabaseConnector and test it

This commit is contained in:
Rémi Heredero 2023-05-17 14:13:27 +02:00
parent cdc5dddb80
commit 7e9ae2e1f1
3 changed files with 67 additions and 8 deletions

View File

@ -1,4 +1,3 @@
URL = https://influx.sdi.hevs.ch URL = https://influx.sdi.hevs.ch
ORG = SIn15 ORG = SIn15
BUCKET = SIn15 BUCKET = SIn15
TOKEN = ${SECRET_TOKEN}

View File

@ -3,14 +3,38 @@ package ch.hevs.isi.db;
import ch.hevs.isi.core.DataPoint; import ch.hevs.isi.core.DataPoint;
import ch.hevs.isi.core.DataPointListener; import ch.hevs.isi.core.DataPointListener;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Properties;
public class DatabaseConnector implements DataPointListener { public class DatabaseConnector implements DataPointListener {
String token = "bW6-s_EkTkZ-rT-Mj0kt1uZQYOPKio5FdEK-OtwWJlxDwYQ5OkH599t1jUz4VV47SrkKonLDHB0jRJ3Eu6OUTA=="; Properties properties = new Properties();
String default_token = System.getenv("SECRET_TOKEN");
String default_url;
String default_org;
String default_bucket;
String fullURL;
URL myURL;
HttpURLConnection con;
private static DatabaseConnector mySelf = null; private static DatabaseConnector mySelf = null;
private DatabaseConnector (){ private DatabaseConnector (){
try (InputStream input = new FileInputStream("src/config.properties")) {
properties.load(input);
} catch (Exception e) {
e.printStackTrace();
}
default_url = properties.getProperty("URL");
default_org = properties.getProperty("ORG");
default_bucket = properties.getProperty("BUCKET");
} }
public static DatabaseConnector getMySelf(){ public static DatabaseConnector getMySelf(){
@ -20,11 +44,39 @@ public class DatabaseConnector implements DataPointListener {
return mySelf; return mySelf;
} }
public void initialize(String url){ public void initialize(String url){
String org = default_org;
String bucket = default_bucket;
fullURL = url + "/api/v2/write?org=" + org + "&bucket=" + bucket;
System.out.println(fullURL);
try{
myURL = new URL(fullURL);
} catch (MalformedURLException e) {
throw new RuntimeException(e);
} catch (IOException e) {
throw new RuntimeException(e);
}
} }
private void pushToDatabase(DataPoint dp){ private void pushToDatabase(DataPoint dp){
System.out.println(dp.toString() + " -> Database"); String data = "measurement " + dp.toString();
try {
HttpURLConnection con = (HttpURLConnection) myURL.openConnection();
con.setRequestMethod("POST");
con.setRequestProperty("Authorization", "Token " + default_token);
con.setRequestProperty("Content-Type", "application/json");
con.setDoOutput(true);
OutputStreamWriter writer = new OutputStreamWriter(con.getOutputStream());
writer.write(data);
writer.flush();
int respondCode = con.getResponseCode();
System.out.println(dp.toString() + " -> Database. Code: " + respondCode);
con.disconnect();
} catch (IOException e) {
e.printStackTrace();
}
} }
@Override @Override

View File

@ -1,8 +1,11 @@
import ch.hevs.isi.core.DataPoint;
import ch.hevs.isi.core.FloatDataPoint;
import ch.hevs.isi.db.DatabaseConnector;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.InputStream; import java.io.InputStream;
import java.util.Properties; import java.util.Properties;
public class Database { public class Database {
public static void main(String[] args) { public static void main(String[] args) {
Properties properties = new Properties(); Properties properties = new Properties();
@ -11,8 +14,13 @@ public class Database {
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
} }
String token = properties.getProperty("TOKEN"); String url = properties.getProperty("URL");
DatabaseConnector db = DatabaseConnector.getMySelf();
db.initialize(url);
FloatDataPoint gridVoltage = new FloatDataPoint("GRID_U_FLOAT", true);
gridVoltage.setValue(500);
System.out.println(token);
} }
} }