Page MenuHomec4science

Reader.java
No OneTemporary

File Metadata

Created
Tue, Jan 21, 19:31

Reader.java

package io.clinicalfactor;
import java.awt.Color;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.math.BigInteger;
import java.sql.SQLException;
import java.util.Date;
import java.util.HashMap;
import javax.swing.JTextPane;
import javax.swing.text.BadLocationException;
import javax.swing.text.SimpleAttributeSet;
import javax.swing.text.StyleConstants;
import javax.swing.text.StyledDocument;
import crypto.CryptoException;
import crypto.paillier.PaillierScheme;
import database.DBconnector_client;
import database.DBconnector_server;
public class Reader implements Runnable {
private String path;
private DBconnector_client conn_mu;
private DBconnector_server conn_s;
private File input_f;
private BufferedReader br;
private BigInteger[] pbk;
private int id_p;
private PaillierScheme cryptoScheme;
private JTextPane tp;
private StyledDocument doc;
private String[] tokens;
private String line;
private HashMap<String, Integer> attributes;
private String test;
private BigInteger plain;
private BigInteger[] cipher;
public Reader(String csv_file_path, JTextPane txp, String tst){
path = csv_file_path;
conn_mu = new DBconnector_client();
conn_s = new DBconnector_server();
tp = txp;
doc = tp.getStyledDocument();
attributes = new HashMap<>();
test = tst;
}
@Override
public void run() {
try{
//check extension file
String[] pathCheck = path.split("\\.");
if(!pathCheck[pathCheck.length-1].equalsIgnoreCase("csv")) {
throw new IOException("Wrong Format for CSV File!");
}
input_f = new File(path);
br = new BufferedReader(new FileReader(input_f));
conn_s.openConnection();
conn_mu.openConnection();
SimpleAttributeSet attribute = new SimpleAttributeSet();
StyleConstants.setForeground(attribute, Color.BLACK);
long start = System.currentTimeMillis();
switch(test){
case "Coronary Artery Disease":
int i = 0;
while((line = br.readLine()) != null ){
i++;
tokens = line.split(";");
if(i == 1){
for(int j = 0; j<tokens.length;j++){
attributes.put(tokens[j],j);
}
}else{
id_p = Integer.parseInt(tokens[0]);
try {
doc.insertString(doc.getLength(), "Encrypting clinical factors for patient " + id_p + "\n", attribute);
} catch (BadLocationException e1) {
e1.printStackTrace();
}
pbk = conn_s.getPublicKey(id_p);
cryptoScheme = new PaillierScheme(pbk[0], pbk[1], pbk[2]);
//Current Smoking
plain = new BigInteger(tokens[attributes.get("SMOKE")]);
cipher = cryptoScheme.encrypt(plain);
conn_s.insertEncryptedCF(id_p, conn_mu.getCF("Current smoking"), cipher[0], cipher[1], null, null);
//Age
String birthdate = tokens[attributes.get("BIRTHDATE")];
String[] date = birthdate.split("/");
Date today = new Date();
plain = BigInteger.valueOf(1900 + today.getYear() - Integer.parseInt(date[2]));
cipher = cryptoScheme.encrypt(plain);
conn_s.insertEncryptedCF(id_p, conn_mu.getCF("Age"), cipher[0], cipher[1], null, null);
//Family history of CAD
String value = tokens[attributes.get("CV_POS_FAMILY")];
if(Integer.parseInt(value) == 0)
plain = BigInteger.ZERO;
else
plain = BigInteger.ONE;
cipher = cryptoScheme.encrypt(plain);
conn_s.insertEncryptedCF(id_p, conn_mu.getCF("Family history of CAD"), cipher[0], cipher[1], null, null);
//Past Smoking
if(tokens[attributes.get("PAST_SMOKE")].equals("1"))
plain = BigInteger.ONE;
else
plain = BigInteger.ZERO;
cipher = cryptoScheme.encrypt(plain);
conn_s.insertEncryptedCF(id_p, conn_mu.getCF("Past smoking"), cipher[0], cipher[1], null, null);
//Hyper-cholesterolemia
double chol = Double.parseDouble(tokens[attributes.get("CHOL")]);
if(chol > 6.2d)
plain = BigInteger.ONE;
else
plain = BigInteger.ZERO;
cipher = cryptoScheme.encrypt(plain);
conn_s.insertEncryptedCF(id_p, conn_mu.getCF("Hyper-cholesterolemia"), cipher[0], cipher[1], null, null);
//Hypertension
int diastolic = Integer.parseInt(tokens[attributes.get("DIASTOLIC")]);
int systolic = Integer.parseInt(tokens[attributes.get("SYSTOLIC")]);
if(diastolic >= 90 || systolic >= 140 || !tokens[attributes.get("CURRENT_ART")].equals(""))
plain = BigInteger.ONE;
else
plain = BigInteger.ZERO;
cipher = cryptoScheme.encrypt(plain);
conn_s.insertEncryptedCF(id_p, conn_mu.getCF("Hypertension"), cipher[0], cipher[1], null, null);
}
}
break;
}
long end = System.currentTimeMillis();
try {
doc.insertString(doc.getLength(), "Parsing CSV File and encryption, completed!" + "\n", attribute);
doc.insertString(doc.getLength(), (end-start) + " ms\n", attribute);
} catch (BadLocationException e1) {
e1.printStackTrace();
}
}catch(IOException | CryptoException | NullPointerException e ){
e.printStackTrace();
SimpleAttributeSet error = new SimpleAttributeSet();
StyleConstants.setForeground(error, Color.RED);
try {
doc.insertString(doc.getLength(), e.getMessage() + "\n", error);
} catch (BadLocationException e1) {
e1.printStackTrace();
}
} catch (SQLException e) {
e.printStackTrace();
SimpleAttributeSet error = new SimpleAttributeSet();
StyleConstants.setForeground(error, Color.RED);
try {
doc.insertString(doc.getLength(), "No Connection with the Server" + "\n", error);
} catch (BadLocationException e1) {
e1.printStackTrace();
}
}
}
}

Event Timeline