Compare commits
128 Commits
Author | SHA1 | Date |
---|---|---|
Selim Eser | 11797b9b73 | |
Selim Eser | af6e9669b4 | |
David Groys | b92c488768 | |
Selim Eser | 7acdaf97a4 | |
Selim Eser | c6a209e27e | |
Selim Eser | 10fb4ac11c | |
Selim Eser | 5215d9b4f7 | |
Selim Eser | e0cd0c376f | |
Selim Eser | 0060368e0a | |
Selim Eser | 9dc98f62e7 | |
Selim Eser | 00a96494e6 | |
David Groys | f9fb48a3f4 | |
David Groys | 606708c904 | |
David Groys | b34b0c82bc | |
David Groys | 5ce975c334 | |
David Groys | 991e0f1d8d | |
David Groys | d08992eba2 | |
David Groys | b670cc38dc | |
David Groys | 1a45bc23ec | |
David Groys | 5eaff1161b | |
David Groys | ed04821220 | |
David Groys | d45465c1ad | |
David Groys | 47e613d109 | |
David Groys | 89961cfca9 | |
David Groys | 109489f0ad | |
David Groys | c182602dfa | |
David Groys | 1028a91a47 | |
David Groys | 0d76243379 | |
David Groys | 89c767f5c9 | |
David Groys | 11db856157 | |
David Groys | 9bdae273d8 | |
David Groys | 316222e8b5 | |
David Groys | d803f6df2a | |
David Groys | 1e7bb5cdfe | |
David Groys | f8c35aca98 | |
David Groys | 8f5211a5ef | |
David Groys | 6090029284 | |
David Groys | 8d83fc784c | |
David Groys | 4a3c4dbcea | |
David Groys | 30d805e17d | |
selim | 751a3c7117 | |
selim | 592a22fbd8 | |
selim | 0f1dea7bec | |
selim | d3a7b96213 | |
selim | c0ac21148f | |
selim | a5d53ac895 | |
Selim Eser | 0c1b1fbe76 | |
Selim Eser | 3bde666802 | |
Selim Eser | a78f0bd47e | |
Selim Eser | c8344e3bf2 | |
Selim Eser | 5da483b279 | |
Selim Eser | 8abc7bda1b | |
Selim Eser | b66b2314d8 | |
Selim Eser | a2e432119e | |
Selim Eser | 7df63b10ed | |
Selim Eser | b71f9c090a | |
Selim Eser | ed2acc0065 | |
Selim Eser | f90eeb6841 | |
Selim Eser | a38c77533a | |
Selim Eser | 31a24b8c9a | |
Selim Eser | a366b27ee3 | |
Selim Eser | d366227c52 | |
Selim Eser | 531407dcf7 | |
Selim Eser | d5408617e1 | |
David Groys | ca8f9a0053 | |
David Groys | 6acdf13340 | |
David Groys | 4335e7f49e | |
David Groys | 9ceffc108d | |
David Groys | a8cac6b067 | |
Selim Eser | 1a8f2bfa74 | |
Selim Eser | 122dfe0b64 | |
Selim Eser | 0cd0be5fe9 | |
Selim Eser | 4a811935d2 | |
Selim Eser | 0e4f7d35b7 | |
Selim Eser | f669e91668 | |
Daniel Zdravkovic | bc8c19bc66 | |
Daniel Zdravkovic | 735c1f38ea | |
Daniel Zdravkovic | cd86769cd0 | |
Daniel Zdravkovic | 675a1bd35e | |
Daniel Zdravkovic | 8bf5c4a0b8 | |
Daniel Zdravkovic | 6252c3d686 | |
Daniel Zdravkovic | 5141d8ec03 | |
Daniel Zdravkovic | 5d087518e9 | |
Daniel Zdravkovic | 33ff251c20 | |
Daniel Zdravkovic | 75b3b597c1 | |
Daniel Zdravkovic | 8016e9848e | |
Daniel Zdravkovic | 0a1482451f | |
Daniel Zdravkovic | 96e7dad23f | |
Daniel Zdravkovic | f5e74fbbe5 | |
Daniel Zdravkovic | 52ed99fc1d | |
Daniel Zdravkovic | 88493290fd | |
Daniel Zdravkovic | 359a88b773 | |
Daniel Zdravkovic | 41676607ad | |
Daniel Zdravkovic | 5120dd94be | |
Daniel Zdravkovic | a41384a116 | |
Selim Eser | 79b145e9f5 | |
Selim Eser | f17f4d1a1c | |
Selim Eser | 4fbcfb4bf5 | |
Selim Eser | e2923ae838 | |
Selim Eser | 1aed134131 | |
Selim Eser | 5a6fe3fc53 | |
Selim Eser | 9c6ed4b889 | |
Selim Eser | 372745939c | |
Selim Eser | 8c2eba6d48 | |
Selim Eser | de917666c7 | |
Selim Eser | 0ac411e9d3 | |
Selim Eser | db04ad8201 | |
Selim Eser | 3b49d9f2e2 | |
Selim Eser | ba7ba72a87 | |
Selim Eser | e3ae9c6599 | |
Selim Eser | 9deda6bf76 | |
Selim Eser | 44b385bf3d | |
Selim Eser | 5413a18435 | |
Selim Eser | 5a5f86db98 | |
Selim Eser | 7439e5159c | |
Selim Eser | 067617e8c0 | |
Selim Eser | 523ff6a4a6 | |
Selim Eser | 39cfdc4d43 | |
Selim Eser | 14f8c38a70 | |
Selim Eser | c43fe4196c | |
Selim Eser | 3455d7b1b7 | |
Selim Eser | ee784a91b2 | |
Selim Eser | 6d96b3ba76 | |
Selim Eser | 671553bd19 | |
Selim Eser | 9db8247e14 | |
Selim Eser | 757e33fc8f | |
Selim Eser | 1be9d7b429 | |
Selim Eser | 5a4cc07d9e |
|
@ -0,0 +1,3 @@
|
||||||
|
Selim Eser 2211482: Selim Eser, Selim
|
||||||
|
David Groys 3012642: David Groys
|
||||||
|
Daniel Zdravkovic 3012893: Daniel Zdravkovic
|
12
pom.xml
12
pom.xml
|
@ -28,6 +28,11 @@
|
||||||
<artifactId>json</artifactId>
|
<artifactId>json</artifactId>
|
||||||
<version>20210307</version>
|
<version>20210307</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>commons-codec</groupId>
|
||||||
|
<artifactId>commons-codec</artifactId>
|
||||||
|
<version>1.17.0</version>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<build>
|
<build>
|
||||||
<resources>
|
<resources>
|
||||||
|
@ -90,11 +95,14 @@
|
||||||
</execution>
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
</plugin>
|
</plugin>
|
||||||
<!-- Static code analysis, cf: target/site/pmd.html
|
<!-- Static code analysis, cf: target/site/pmd.html -->
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-pmd-plugin</artifactId>
|
<artifactId>maven-pmd-plugin</artifactId>
|
||||||
<version>3.22.0</version>
|
<version>3.22.0</version>
|
||||||
|
<configuration>
|
||||||
|
<failOnViolation>false</failOnViolation>
|
||||||
|
</configuration>
|
||||||
<executions>
|
<executions>
|
||||||
<execution>
|
<execution>
|
||||||
<phase>verify</phase>
|
<phase>verify</phase>
|
||||||
|
@ -103,7 +111,7 @@
|
||||||
</goals>
|
</goals>
|
||||||
</execution>
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
</plugin>-->
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
</project>
|
</project>
|
|
@ -0,0 +1,36 @@
|
||||||
|
package de.hs_mannheim.domain;
|
||||||
|
|
||||||
|
public class Destination {
|
||||||
|
|
||||||
|
private String town;
|
||||||
|
private String zip;
|
||||||
|
private double distance_from_user;
|
||||||
|
|
||||||
|
public Destination(String town,String zip, double distance_from_user) {
|
||||||
|
this.town = town;
|
||||||
|
this.zip = zip;
|
||||||
|
this.distance_from_user = distance_from_user;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getTown() {
|
||||||
|
return town;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTown(String town) {
|
||||||
|
this.town = town;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getZip() {
|
||||||
|
return zip;
|
||||||
|
}
|
||||||
|
public void setZip(String zip) {
|
||||||
|
this.zip = zip;
|
||||||
|
}
|
||||||
|
public double getDistance_from_user() {
|
||||||
|
return distance_from_user;
|
||||||
|
}
|
||||||
|
public void setDistance_from_user(double distance_from_user) {
|
||||||
|
this.distance_from_user = distance_from_user;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,97 +1,398 @@
|
||||||
package de.hs_mannheim.domain;
|
package de.hs_mannheim.domain;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.net.http.HttpClient;
|
import java.net.http.HttpClient;
|
||||||
import java.net.http.HttpRequest;
|
import java.net.http.HttpRequest;
|
||||||
import java.net.http.HttpResponse;
|
import java.net.http.HttpResponse;
|
||||||
import java.net.http.HttpResponse.BodyHandlers;
|
import java.net.http.HttpResponse.BodyHandlers;
|
||||||
import java.util.HashSet;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.TreeSet;
|
import java.util.TreeSet;
|
||||||
|
|
||||||
|
import org.apache.commons.codec.binary.Base64;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
|
|
||||||
public class System {
|
public class System {
|
||||||
|
|
||||||
private User current_user = new User();
|
private User current_user = new User();
|
||||||
|
private ArrayList<User> all_user = new ArrayList<>();
|
||||||
private String api_key;
|
private String api_key;
|
||||||
|
private HashMap<String, Destination> all_destinations = new HashMap<String, Destination>();
|
||||||
|
|
||||||
public System(String api_key) {
|
public System(String api_key) {
|
||||||
this.api_key = api_key;
|
this.api_key = api_key;
|
||||||
|
get_all_user();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void set_current_user_zip(String zip){
|
public void set_current_user_zip(String zip) {
|
||||||
this.current_user.setZip(Integer.parseInt(zip));
|
this.current_user.setZip(zip);
|
||||||
}
|
}
|
||||||
|
|
||||||
public HashSet<User> get_all_user(){
|
public void set_current_user_car_l_100km(double car_l_100km) {
|
||||||
return new HashSet<User>();
|
this.current_user.setCar_l_100km(car_l_100km);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean sign_in_user(String username, String password){
|
public void set_current_user_car_avg_kmh(double car_avg_kmh) {
|
||||||
|
this.current_user.setCar_avg_kmh(car_avg_kmh);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void set_current_user_bike_avg_kmh(double bike_avg_kmh) {
|
||||||
|
this.current_user.setBike_avg_kmh(bike_avg_kmh);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String decoding(String string) {
|
||||||
|
byte[] binary_data = new byte[string.length()];
|
||||||
|
for (int i = 0; i < string.length(); i++) {
|
||||||
|
binary_data[i] = (byte) string.charAt(i);
|
||||||
|
}
|
||||||
|
return new String(Base64.decodeBase64(binary_data));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String encoding(String string) {
|
||||||
|
byte[] binary_data = new byte[string.length()];
|
||||||
|
for (int i = 0; i < string.length(); i++) {
|
||||||
|
binary_data[i] = (byte) string.charAt(i);
|
||||||
|
}
|
||||||
|
return Base64.encodeBase64String(binary_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static double parseDouble(String s) throws NumberFormatException {
|
||||||
|
if (s.equals(""))
|
||||||
|
return 0;
|
||||||
|
else
|
||||||
|
return Double.parseDouble(s);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void get_all_user() {
|
||||||
|
String[] fileString = new String[8];
|
||||||
|
|
||||||
|
InputStream inputStream = System.class.getResourceAsStream("/user_data.csv");
|
||||||
|
String path;
|
||||||
|
|
||||||
|
try (BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream))) {
|
||||||
|
while ((path = reader.readLine()) != null) {
|
||||||
|
fileString = path.split(";");
|
||||||
|
fileString[1] = decoding(fileString[1]);
|
||||||
|
this.all_user.add(new User(fileString[0], fileString[1], fileString[2],
|
||||||
|
fileString[3], fileString[4],
|
||||||
|
Double.parseDouble(fileString[5]),
|
||||||
|
Double.parseDouble(fileString[6]),
|
||||||
|
Double.parseDouble(fileString[7])));
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
//
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArrayList<String> all_user_toString() {
|
||||||
|
|
||||||
|
ArrayList<String> result = new ArrayList<>();
|
||||||
|
|
||||||
|
for (User user : this.all_user) {
|
||||||
|
result.add(user.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean sign_in_user(String username, String password) {
|
||||||
|
|
||||||
|
for (User user : this.all_user) {
|
||||||
|
if (user.getUsername().equals(username) && user.getPassword().equals(password)) {
|
||||||
|
current_user = new User(user.getUsername(), user.getPassword(),
|
||||||
|
user.getHometown(), user.getZip(), user.getCar_name(),
|
||||||
|
user.getCar_l_100km(), user.getCar_avg_kmh(), user.getBike_avg_kmh());
|
||||||
|
|
||||||
|
all_distances();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean sign_up_user(String username, String password, String password_authentication, String hometown,
|
||||||
|
String zip,
|
||||||
|
String car_name, String car_l_100kmS, String car_avg_kmhS, String bike_avg_kmhS) {
|
||||||
|
|
||||||
|
double car_l_100km;
|
||||||
|
double car_avg_kmh;
|
||||||
|
double bike_avg_kmh;
|
||||||
|
|
||||||
|
try {
|
||||||
|
car_l_100km = parseDouble(car_l_100kmS);
|
||||||
|
car_avg_kmh = parseDouble(car_avg_kmhS);
|
||||||
|
bike_avg_kmh = parseDouble(bike_avg_kmhS);
|
||||||
|
} catch (NumberFormatException n) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (username.equals("") || password.equals("") || hometown.equals("") || zip.equals(""))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (!password.equals(password_authentication))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
for (User user : this.all_user)
|
||||||
|
if (user.getUsername().equals(username))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
ArrayList<String> mem = search(zip);
|
||||||
|
boolean bool = false;
|
||||||
|
|
||||||
|
for (String line : mem)
|
||||||
|
if (line.split(";")[1].equals(hometown)) {
|
||||||
|
bool = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!bool)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
current_user = new User(username, password, hometown, zip, car_name, car_l_100km, car_avg_kmh, bike_avg_kmh);
|
||||||
|
|
||||||
|
this.all_user.add(current_user);
|
||||||
|
|
||||||
|
write_to_file(all_user_toString(), "src/main/resources/user_data.csv");
|
||||||
|
write_to_file(all_user_toString(), "src/test/resources/user_data.csv");
|
||||||
|
|
||||||
|
all_distances();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean sign_up_user(String username, String password, String hometown, int zip,
|
public boolean change_user_details(String username, String password, String hometown, String zip,
|
||||||
String car_name, double car_co2_km, double car_avg_kmh, double bike_avg_kmh){
|
String car_name, String car_l_100kmS, String car_avg_kmhS, String bike_avg_kmhS) {
|
||||||
|
|
||||||
|
double car_l_100km;
|
||||||
|
double car_avg_kmh;
|
||||||
|
double bike_avg_kmh;
|
||||||
|
|
||||||
|
try {
|
||||||
|
car_l_100km = parseDouble(car_l_100kmS);
|
||||||
|
car_avg_kmh = parseDouble(car_avg_kmhS);
|
||||||
|
bike_avg_kmh = parseDouble(bike_avg_kmhS);
|
||||||
|
} catch (NumberFormatException n) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!current_user.getPassword().equals(password))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (username.equals("") || hometown.equals("") || zip.equals(""))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (!current_user.getUsername().equals(username)) {
|
||||||
|
for (User user : this.all_user)
|
||||||
|
if (user.getUsername().equals(username))
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
ArrayList<String> mem = search(zip);
|
||||||
|
boolean bool = false;
|
||||||
|
|
||||||
|
for (String line : mem)
|
||||||
|
if (line.split(";")[1].equals(hometown)) {
|
||||||
|
bool = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!bool)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
for (int i = 0; i < this.all_user.size(); i++)
|
||||||
|
if (this.all_user.get(i).getUsername().equals(current_user.getUsername()))
|
||||||
|
this.all_user.remove(i);
|
||||||
|
|
||||||
|
write_to_file(all_user_toString(), "src/main/resources/user_data.csv");
|
||||||
|
write_to_file(all_user_toString(), "src/test/resources/user_data.csv");
|
||||||
|
|
||||||
|
this.current_user = new User(username, password, hometown, zip, car_name, car_l_100km, car_avg_kmh,
|
||||||
|
bike_avg_kmh);
|
||||||
|
this.all_user.add(current_user);
|
||||||
|
|
||||||
|
write_to_file(all_user_toString(), "src/main/resources/user_data.csv");
|
||||||
|
write_to_file(all_user_toString(), "src/test/resources/user_data.csv");
|
||||||
|
|
||||||
|
all_distances();
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void sign_out_user(){}
|
public boolean change_user_password(String old_password, String new_password, String new_password_authentication) {
|
||||||
|
if (!this.current_user.getPassword().equals(old_password))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (!new_password.equals(new_password_authentication))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if(old_password.equals(new_password))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
for (int i = 0; i < this.all_user.size(); i++)
|
||||||
|
if (this.all_user.get(i).getUsername().equals(current_user.getUsername()))
|
||||||
|
this.all_user.remove(i);
|
||||||
|
|
||||||
|
write_to_file(all_user_toString(), "src/main/resources/user_data.csv");
|
||||||
|
write_to_file(all_user_toString(), "src/test/resources/user_data.csv");
|
||||||
|
|
||||||
|
this.current_user.setPassword(new_password);
|
||||||
|
this.all_user.add(current_user);
|
||||||
|
|
||||||
|
write_to_file(all_user_toString(), "src/main/resources/user_data.csv");
|
||||||
|
write_to_file(all_user_toString(), "src/test/resources/user_data.csv");
|
||||||
|
|
||||||
public boolean change_user_details(String username, String password, String hometown, int zip,
|
|
||||||
String car_name, double car_co2_km, double car_avg_kmh, double bike_avg_kmh){
|
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public TreeSet<String> search(String hometown_or_zip){
|
public void write_to_file(ArrayList<String> lines, String file) {
|
||||||
return new TreeSet<String>();
|
try (BufferedWriter writer = new BufferedWriter(new FileWriter(file))) {
|
||||||
|
for (int i = 0; i < lines.size() - 1; i++) {
|
||||||
|
writer.write(lines.get(i));
|
||||||
|
writer.newLine();
|
||||||
|
}
|
||||||
|
writer.write(lines.getLast());
|
||||||
|
} catch (IOException e) {
|
||||||
|
//
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public TreeSet<String> random_destinations(){
|
public void sign_out_user() {
|
||||||
return new TreeSet<String>();
|
current_user = new User();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String[] destination_details(String destination_zip){
|
public String[] getDetails() {
|
||||||
return new String[1];
|
return new String[] { current_user.getUsername(), current_user.getHometown(),
|
||||||
|
current_user.getZip(), current_user.getCar_name(),
|
||||||
|
current_user.getCar_l_100km() == 0 ? "" : String.valueOf(current_user.getCar_l_100km()),
|
||||||
|
current_user.getCar_avg_kmh() == 0 ? "" : String.valueOf(current_user.getCar_avg_kmh()),
|
||||||
|
current_user.getBike_avg_kmh() == 0 ? "" : String.valueOf(current_user.getBike_avg_kmh()) };
|
||||||
}
|
}
|
||||||
|
|
||||||
public String current_weather(){
|
public ArrayList<String> search(String hometown_or_zip) {
|
||||||
|
|
||||||
|
TreeSet<String> zip_set = new TreeSet<>();
|
||||||
|
|
||||||
|
InputStream inputStream = System.class.getResourceAsStream("/zip.csv");
|
||||||
|
|
||||||
|
try (BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream))) {
|
||||||
|
String line;
|
||||||
|
while ((line = reader.readLine()) != null && zip_set.size() < 200) {
|
||||||
|
line = line.replace("\"", "");
|
||||||
|
if (line.split(";")[0].toUpperCase().startsWith(hometown_or_zip.toUpperCase())
|
||||||
|
|| line.split(";")[1].toUpperCase().startsWith(hometown_or_zip.toUpperCase()))
|
||||||
|
zip_set.add(line);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
|
return new ArrayList<>(zip_set);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArrayList<String> random_destinations_car() {
|
||||||
|
|
||||||
|
ArrayList<Destination> mem = new ArrayList<>();
|
||||||
|
ArrayList<String> result = new ArrayList<>();
|
||||||
|
int random = 0;
|
||||||
|
|
||||||
|
for (Destination destination : this.all_destinations.values()) {
|
||||||
|
if (destination.getDistance_from_user() > 150)
|
||||||
|
mem.add(destination);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < 3; i++) {
|
||||||
|
random = (int) (Math.random() * mem.size());
|
||||||
|
result.add(mem.get(random).getZip() + ";" + mem.get(random).getTown());
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArrayList<String> random_destinations_bike() {
|
||||||
|
|
||||||
|
ArrayList<Destination> mem = new ArrayList<>();
|
||||||
|
ArrayList<String> result = new ArrayList<>();
|
||||||
|
int random = 0;
|
||||||
|
|
||||||
|
for (Destination destination : this.all_destinations.values()) {
|
||||||
|
if (destination.getDistance_from_user() < 100)
|
||||||
|
mem.add(destination);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < 3; i++) {
|
||||||
|
random = (int) (Math.random() * mem.size());
|
||||||
|
result.add(mem.get(random).getZip() + ";" + mem.get(random).getTown());
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String[] destination_details(String destination_zip) {
|
||||||
|
String[] result = new String[7];
|
||||||
|
|
||||||
|
result[0] = weather_forecast(destination_zip)[0]; // Wettervorhersage für die nächsten 3 Tage
|
||||||
|
result[1] = weather_forecast(destination_zip)[1];
|
||||||
|
result[2] = weather_forecast(destination_zip)[2];
|
||||||
|
result[3] = distance(destination_zip); // Entfernung
|
||||||
|
result[4] = travel_time(destination_zip)[0]; // Reisedauer Auto
|
||||||
|
result[5] = calc_l_consumption(destination_zip); // Kraftstoffverbrauch Auto
|
||||||
|
result[6] = travel_time(destination_zip)[1]; // Reisedauer Fahrrad
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String current_weather() {
|
||||||
|
|
||||||
String weather = "";
|
String weather = "";
|
||||||
double temperature = 1;
|
double temperature = 1;
|
||||||
|
|
||||||
try{
|
try {
|
||||||
HttpClient http_client = HttpClient.newHttpClient();
|
HttpClient http_client = HttpClient.newHttpClient();
|
||||||
|
HttpRequest get_request;
|
||||||
HttpRequest get_request = HttpRequest.newBuilder()
|
|
||||||
.uri(new URI("https://api.openweathermap.org/data/2.5/weather?zip="+current_user.getZip()+",de&appid="+api_key+"&units=metric&lang=de"))
|
if(current_user.getZip().length()<5){
|
||||||
.GET()
|
get_request = HttpRequest.newBuilder()
|
||||||
.build();
|
.uri(new URI("https://api.openweathermap.org/data/2.5/weather?q=" + current_user.getHometown()
|
||||||
|
+ ",de&appid=" + api_key + "&units=metric&lang=de"))
|
||||||
HttpResponse get_response = http_client.send(get_request, BodyHandlers.ofString());
|
.GET()
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
else{
|
||||||
|
get_request = HttpRequest.newBuilder()
|
||||||
|
.uri(new URI("https://api.openweathermap.org/data/2.5/weather?zip=" + current_user.getZip()
|
||||||
|
+ ",de&appid=" + api_key + "&units=metric&lang=de"))
|
||||||
|
.GET()
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
HttpResponse<String> get_response = http_client.send(get_request, BodyHandlers.ofString());
|
||||||
|
|
||||||
JSONObject json = new JSONObject(((String)get_response.body()).substring(0,((String) get_response.body()).length()));
|
JSONObject json = new JSONObject(get_response.body());
|
||||||
weather = json.getJSONArray("weather").getJSONObject(0).getString("description");
|
weather = json.getJSONArray("weather").getJSONObject(0).getString("description");
|
||||||
temperature = json.getJSONObject("main").getDouble("temp");
|
temperature = json.getJSONObject("main").getDouble("temp");
|
||||||
} catch (Exception e){}
|
} catch (Exception e) {
|
||||||
|
//
|
||||||
if(weather.equals(""))
|
}
|
||||||
|
|
||||||
|
if (weather.equals(""))
|
||||||
return "Es ist ein Fehler aufgetreten!";
|
return "Es ist ein Fehler aufgetreten!";
|
||||||
else
|
else
|
||||||
return weather + ": " + temperature + " °C";
|
return weather + " " + temperature + "°C";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String weather_forecast(String destination_zip){
|
public String[] weather_forecast(String destination_zip) {
|
||||||
|
|
||||||
String weather_day_1 = "";
|
String weather_day_1 = "";
|
||||||
String weather_day_2 = "";
|
String weather_day_2 = "";
|
||||||
String weather_day_3 = "";
|
String weather_day_3 = "";
|
||||||
|
String[] result = new String[3];
|
||||||
|
|
||||||
double temperature_day_1_1 = 1;
|
double temperature_day_1_1 = 1;
|
||||||
double temperature_day_1_2 = 1;
|
double temperature_day_1_2 = 1;
|
||||||
double temperature_day_1_3 = 1;
|
double temperature_day_1_3 = 1;
|
||||||
double temperature_day_1_4 = 1;
|
double temperature_day_1_4 = 1;
|
||||||
|
double temperature_day_1_5 = 1;
|
||||||
|
|
||||||
TreeSet<Double> temperature_day_1 = new TreeSet<>();
|
TreeSet<Double> temperature_day_1 = new TreeSet<>();
|
||||||
double temperature_day_1_high = 1;
|
double temperature_day_1_high = 1;
|
||||||
|
@ -101,6 +402,7 @@ public class System {
|
||||||
double temperature_day_2_2 = 1;
|
double temperature_day_2_2 = 1;
|
||||||
double temperature_day_2_3 = 1;
|
double temperature_day_2_3 = 1;
|
||||||
double temperature_day_2_4 = 1;
|
double temperature_day_2_4 = 1;
|
||||||
|
double temperature_day_2_5 = 1;
|
||||||
|
|
||||||
TreeSet<Double> temperature_day_2 = new TreeSet<>();
|
TreeSet<Double> temperature_day_2 = new TreeSet<>();
|
||||||
double temperature_day_2_high = 1;
|
double temperature_day_2_high = 1;
|
||||||
|
@ -110,86 +412,279 @@ public class System {
|
||||||
double temperature_day_3_2 = 1;
|
double temperature_day_3_2 = 1;
|
||||||
double temperature_day_3_3 = 1;
|
double temperature_day_3_3 = 1;
|
||||||
double temperature_day_3_4 = 1;
|
double temperature_day_3_4 = 1;
|
||||||
|
double temperature_day_3_5 = 1;
|
||||||
|
|
||||||
TreeSet<Double> temperature_day_3 = new TreeSet<>();
|
TreeSet<Double> temperature_day_3 = new TreeSet<>();
|
||||||
double temperature_day_3_high = 1;
|
double temperature_day_3_high = 1;
|
||||||
double temperature_day_3_low = 1;
|
double temperature_day_3_low = 1;
|
||||||
|
|
||||||
|
String day1date = "";
|
||||||
|
String day2date = "";
|
||||||
|
String day3date = "";
|
||||||
|
|
||||||
try{
|
try {
|
||||||
HttpClient http_client = HttpClient.newHttpClient();
|
HttpClient http_client = HttpClient.newHttpClient();
|
||||||
|
HttpRequest get_request;
|
||||||
|
|
||||||
HttpRequest get_request = HttpRequest.newBuilder()
|
if(destination_zip.length()<5){
|
||||||
.uri(new URI("https://api.openweathermap.org/data/2.5/forecast?zip="+destination_zip+",de&appid="+api_key+"&units=metric&lang=de"))
|
get_request = HttpRequest.newBuilder()
|
||||||
.GET()
|
.uri(new URI("https://api.openweathermap.org/data/2.5/forecast?q=" + search(destination_zip).get(0).split(";")[1]
|
||||||
.build();
|
+ ",de&appid=" + api_key + "&units=metric&lang=de"))
|
||||||
|
.GET()
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
get_request = HttpRequest.newBuilder()
|
||||||
|
.uri(new URI("https://api.openweathermap.org/data/2.5/forecast?zip=" + destination_zip
|
||||||
|
+ ",de&appid=" + api_key + "&units=metric&lang=de"))
|
||||||
|
.GET()
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
HttpResponse get_response = http_client.send(get_request, BodyHandlers.ofString());
|
HttpResponse<String> get_response = http_client.send(get_request, BodyHandlers.ofString());
|
||||||
|
|
||||||
|
JSONObject json = new JSONObject(get_response.body());
|
||||||
|
|
||||||
|
int day1_1 = 0;
|
||||||
|
int day1_2 = 0;
|
||||||
|
int day1_3 = 0;
|
||||||
|
int day1_4 = 0;
|
||||||
|
int day1_5 = 0;
|
||||||
|
int day2_1 = 0;
|
||||||
|
int day2_2 = 0;
|
||||||
|
int day2_3 = 0;
|
||||||
|
int day2_4 = 0;
|
||||||
|
int day2_5 = 0;
|
||||||
|
int day3_1 = 0;
|
||||||
|
int day3_2 = 0;
|
||||||
|
int day3_3 = 0;
|
||||||
|
int day3_4 = 0;
|
||||||
|
int day3_5 = 0;
|
||||||
|
|
||||||
|
for (int i = 0; i < 40; i++) {
|
||||||
|
|
||||||
|
if (json.getJSONArray("list").getJSONObject(i).getString("dt_txt").split(" ")[1].startsWith("00")) {
|
||||||
|
day1_1 = i + 3; // 9 Uhr
|
||||||
|
day1_2 = day1_1 + 1; // 12 Uhr
|
||||||
|
day1_3 = day1_2 + 1; // 15 Uhr
|
||||||
|
day1_4 = day1_3 + 1; // 18 Uhr
|
||||||
|
day1_5 = day1_4 + 1; // 21 Uhr
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = day1_5; i < 40; i++) {
|
||||||
|
|
||||||
|
if (json.getJSONArray("list").getJSONObject(i).getString("dt_txt").split(" ")[1].startsWith("00")) {
|
||||||
|
day2_1 = i + 3; // 9 Uhr
|
||||||
|
day2_2 = day2_1 + 1; // 12 Uhr
|
||||||
|
day2_3 = day2_2 + 1; // 15 Uhr
|
||||||
|
day2_4 = day2_3 + 1; // 18 Uhr
|
||||||
|
day2_5 = day2_4 + 1; // 21 Uhr
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = day2_5 + 1; i < 40; i++) {
|
||||||
|
|
||||||
|
if (json.getJSONArray("list").getJSONObject(i).getString("dt_txt").split(" ")[1].startsWith("00")) {
|
||||||
|
day3_1 = i + 3; // 9 Uhr
|
||||||
|
day3_2 = day3_1 + 1; // 12 Uhr
|
||||||
|
day3_3 = day3_2 + 1; // 15 Uhr
|
||||||
|
day3_4 = day3_3 + 1; // 18 Uhr
|
||||||
|
day3_5 = day3_4 + 1; // 21 Uhr
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
day1date = json.getJSONArray("list").getJSONObject(day1_1).getString("dt_txt").split(" ")[0];
|
||||||
|
day1date = day1date.split("-")[2] + "." + day1date.split("-")[1] + "." + day1date.split("-")[0];
|
||||||
|
day2date = json.getJSONArray("list").getJSONObject(day2_1).getString("dt_txt").split(" ")[0];
|
||||||
|
day2date = day2date.split("-")[2] + "." + day2date.split("-")[1] + "." + day2date.split("-")[0];
|
||||||
|
day3date = json.getJSONArray("list").getJSONObject(day3_1).getString("dt_txt").split(" ")[0];
|
||||||
|
day3date = day3date.split("-")[2] + "." + day3date.split("-")[1] + "." + day3date.split("-")[0];
|
||||||
|
|
||||||
|
weather_day_1 = json.getJSONArray("list").getJSONObject(day1_3).getJSONArray("weather").getJSONObject(0)
|
||||||
|
.getString("description");
|
||||||
|
weather_day_2 = json.getJSONArray("list").getJSONObject(day2_3).getJSONArray("weather").getJSONObject(0)
|
||||||
|
.getString("description");
|
||||||
|
weather_day_3 = json.getJSONArray("list").getJSONObject(day3_3).getJSONArray("weather").getJSONObject(0)
|
||||||
|
.getString("description");
|
||||||
|
|
||||||
|
temperature_day_1_1 = json.getJSONArray("list").getJSONObject(day1_1).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_1_2 = json.getJSONArray("list").getJSONObject(day1_2).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_1_3 = json.getJSONArray("list").getJSONObject(day1_3).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_1_4 = json.getJSONArray("list").getJSONObject(day1_4).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_1_5 = json.getJSONArray("list").getJSONObject(day1_5).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
|
||||||
|
temperature_day_2_1 = json.getJSONArray("list").getJSONObject(day2_1).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_2_2 = json.getJSONArray("list").getJSONObject(day2_2).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_2_3 = json.getJSONArray("list").getJSONObject(day2_3).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_2_4 = json.getJSONArray("list").getJSONObject(day2_4).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_2_5 = json.getJSONArray("list").getJSONObject(day2_5).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
|
||||||
|
temperature_day_3_1 = json.getJSONArray("list").getJSONObject(day3_1).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_3_2 = json.getJSONArray("list").getJSONObject(day3_2).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_3_3 = json.getJSONArray("list").getJSONObject(day3_3).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_3_4 = json.getJSONArray("list").getJSONObject(day3_4).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
temperature_day_3_5 = json.getJSONArray("list").getJSONObject(day3_5).getJSONObject("main")
|
||||||
|
.getDouble("temp");
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
JSONObject json = new JSONObject(((String)get_response.body()).substring(0,((String) get_response.body()).length()));
|
|
||||||
weather_day_1 = json.getJSONArray("list").getJSONObject(11).getJSONArray("weather").getJSONObject(0).getString("description");
|
|
||||||
weather_day_2 = json.getJSONArray("list").getJSONObject(19).getJSONArray("weather").getJSONObject(0).getString("description");
|
|
||||||
weather_day_3 = json.getJSONArray("list").getJSONObject(27).getJSONArray("weather").getJSONObject(0).getString("description");
|
|
||||||
|
|
||||||
temperature_day_1_1 = json.getJSONArray("list").getJSONObject(8).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_1_2 = json.getJSONArray("list").getJSONObject(10).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_1_3 = json.getJSONArray("list").getJSONObject(12).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_1_4 = json.getJSONArray("list").getJSONObject(14).getJSONObject("main").getDouble("temp");
|
|
||||||
|
|
||||||
temperature_day_2_1 = json.getJSONArray("list").getJSONObject(16).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_2_2 = json.getJSONArray("list").getJSONObject(18).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_2_3 = json.getJSONArray("list").getJSONObject(20).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_2_4 = json.getJSONArray("list").getJSONObject(22).getJSONObject("main").getDouble("temp");
|
|
||||||
|
|
||||||
temperature_day_3_1 = json.getJSONArray("list").getJSONObject(24).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_3_2 = json.getJSONArray("list").getJSONObject(26).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_3_3 = json.getJSONArray("list").getJSONObject(28).getJSONObject("main").getDouble("temp");
|
|
||||||
temperature_day_3_4 = json.getJSONArray("list").getJSONObject(30).getJSONObject("main").getDouble("temp");
|
|
||||||
|
|
||||||
} catch (Exception e){}
|
|
||||||
|
|
||||||
temperature_day_1.add(temperature_day_1_1);
|
temperature_day_1.add(temperature_day_1_1);
|
||||||
temperature_day_1.add(temperature_day_1_2);
|
temperature_day_1.add(temperature_day_1_2);
|
||||||
temperature_day_1.add(temperature_day_1_3);
|
temperature_day_1.add(temperature_day_1_3);
|
||||||
temperature_day_1.add(temperature_day_1_4);
|
temperature_day_1.add(temperature_day_1_4);
|
||||||
|
temperature_day_1.add(temperature_day_1_5);
|
||||||
|
|
||||||
temperature_day_1_high = (double) temperature_day_1.toArray()[temperature_day_1.size()-1];
|
temperature_day_1_high = (double) temperature_day_1.toArray()[temperature_day_1.size() - 1];
|
||||||
temperature_day_1_low = (double) temperature_day_1.toArray()[0];
|
temperature_day_1_low = (double) temperature_day_1.toArray()[0];
|
||||||
|
|
||||||
temperature_day_2.add(temperature_day_2_1);
|
temperature_day_2.add(temperature_day_2_1);
|
||||||
temperature_day_2.add(temperature_day_2_2);
|
temperature_day_2.add(temperature_day_2_2);
|
||||||
temperature_day_2.add(temperature_day_2_3);
|
temperature_day_2.add(temperature_day_2_3);
|
||||||
temperature_day_2.add(temperature_day_2_4);
|
temperature_day_2.add(temperature_day_2_4);
|
||||||
|
temperature_day_2.add(temperature_day_2_5);
|
||||||
|
|
||||||
temperature_day_2_high = (double) temperature_day_2.toArray()[temperature_day_1.size()-1];
|
temperature_day_2_high = (double) temperature_day_2.toArray()[temperature_day_2.size() - 1];
|
||||||
temperature_day_2_low = (double) temperature_day_2.toArray()[0];
|
temperature_day_2_low = (double) temperature_day_2.toArray()[0];
|
||||||
|
|
||||||
temperature_day_3.add(temperature_day_3_1);
|
temperature_day_3.add(temperature_day_3_1);
|
||||||
temperature_day_3.add(temperature_day_3_2);
|
temperature_day_3.add(temperature_day_3_2);
|
||||||
temperature_day_3.add(temperature_day_3_3);
|
temperature_day_3.add(temperature_day_3_3);
|
||||||
temperature_day_3.add(temperature_day_3_4);
|
temperature_day_3.add(temperature_day_3_4);
|
||||||
|
temperature_day_3.add(temperature_day_3_5);
|
||||||
|
|
||||||
temperature_day_3_high = (double) temperature_day_3.toArray()[temperature_day_1.size()-1];
|
temperature_day_3_high = (double) temperature_day_3.toArray()[temperature_day_2.size() - 1];
|
||||||
temperature_day_3_low = (double) temperature_day_3.toArray()[0];
|
temperature_day_3_low = (double) temperature_day_3.toArray()[0];
|
||||||
|
|
||||||
if(weather_day_1.equals("")||weather_day_2.equals("")||weather_day_3.equals(""))
|
if (weather_day_1.equals("") || weather_day_2.equals("") || weather_day_3.equals("")) {
|
||||||
return "Es ist ein Fehler aufgetreten!";
|
result[0] = "Es ist ein Fehler aufgetreten!";
|
||||||
|
result[1] = "Es ist ein Fehler aufgetreten!";
|
||||||
|
result[2] = "Es ist ein Fehler aufgetreten!";
|
||||||
|
} else {
|
||||||
|
result[0] = day1date + ": " + weather_day_1 + " H: " + temperature_day_1_high + "°C" + " T: "
|
||||||
|
+ temperature_day_1_low + "°C";
|
||||||
|
result[1] = day2date + ": " + weather_day_2 + " H: " + temperature_day_2_high + "°C" + " T: "
|
||||||
|
+ temperature_day_2_low + "°C";
|
||||||
|
result[2] = day3date + ": " + weather_day_3 + " H: " + temperature_day_3_high + "°C" + " T: "
|
||||||
|
+ temperature_day_3_low + "°C";
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean all_distances() {
|
||||||
|
|
||||||
|
double lon1 = -1;
|
||||||
|
double lon2 = -1;
|
||||||
|
double lat1 = -1;
|
||||||
|
double lat2 = -1;
|
||||||
|
double dLat;
|
||||||
|
double dLon;
|
||||||
|
double a;
|
||||||
|
double distance;
|
||||||
|
double result;
|
||||||
|
|
||||||
|
InputStream inputStream = System.class.getResourceAsStream("/zip.csv");
|
||||||
|
|
||||||
|
try (BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream))) {
|
||||||
|
String line;
|
||||||
|
while ((line = reader.readLine()) != null) {
|
||||||
|
line = line.replace("\"", "");
|
||||||
|
|
||||||
|
if (line.split(";")[0].equals(current_user.getZip())) {
|
||||||
|
lon1 = Double.parseDouble(line.split(";")[2]);
|
||||||
|
lat1 = Double.parseDouble(line.split(";")[3]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
|
InputStream inputStream2 = System.class.getResourceAsStream("/zip.csv");
|
||||||
|
|
||||||
|
try (BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream2))) {
|
||||||
|
String line;
|
||||||
|
while ((line = reader.readLine()) != null) {
|
||||||
|
line = line.replace("\"", "");
|
||||||
|
|
||||||
|
lon2 = Double.parseDouble(line.split(";")[2]);
|
||||||
|
lat2 = Double.parseDouble(line.split(";")[3]);
|
||||||
|
|
||||||
|
if (lon1 == -1 || lon2 == -1 || lat1 == -1 || lat2 == -1)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
dLat = lat2 - lat1;
|
||||||
|
dLon = lon2 - lon1;
|
||||||
|
|
||||||
|
a = Math.pow(Math.sin(Math.toRadians(dLat / 2.0)), 2)
|
||||||
|
+ Math.pow(Math.sin(Math.toRadians(dLon / 2.0)), 2) * Math.cos(Math.toRadians(lat1))
|
||||||
|
* Math.cos(Math.toRadians(lat2));
|
||||||
|
|
||||||
|
distance = 6378.388 * 2.0 * Math.atan2(Math.sqrt(a), Math.sqrt(1.0 - a));
|
||||||
|
|
||||||
|
result = Math.round(distance * 1.25 * 100) / 100.0;
|
||||||
|
|
||||||
|
this.all_destinations.put(line.split(";")[0],
|
||||||
|
new Destination(line.split(";")[1], line.split(";")[0], result));
|
||||||
|
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String distance(String destination_zip) {
|
||||||
|
|
||||||
|
return "" + this.all_destinations.get(destination_zip).getDistance_from_user() + " km";
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public String[] travel_time(String destination_zip) {
|
||||||
|
|
||||||
|
String[] result = new String[2];
|
||||||
|
|
||||||
|
if (current_user.getCar_avg_kmh() == 0)
|
||||||
|
result[0] = "";
|
||||||
else
|
else
|
||||||
return "Morgen: " + weather_day_1 + ": Minimum: " + temperature_day_1_low + " °C" + "; Maximum: " + temperature_day_1_high + " °C\n"
|
result[0] = "" + (Math.round(Double.parseDouble(distance(destination_zip).replace(" km", ""))
|
||||||
+ "Übermorgen: " + weather_day_2 + ": Minimum: " + temperature_day_2_low + " °C" + "; Maximum: " + temperature_day_2_high + " °C\n"
|
/ current_user.getCar_avg_kmh() * 100) / 100.0) + " h";
|
||||||
+ "Überübermorgen: " + weather_day_3 + ": Minimum: " + temperature_day_3_low + " °C" + "; Maximum: " + temperature_day_3_high + " °C";
|
|
||||||
|
if (current_user.getBike_avg_kmh() == 0)
|
||||||
|
result[1] = "";
|
||||||
|
else
|
||||||
|
result[1] = "" + (Math.round(Double.parseDouble(distance(destination_zip).replace(" km", ""))
|
||||||
|
/ current_user.getBike_avg_kmh() * 100) / 100.0) + " h";
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String distance(String destination_zip){
|
public String calc_l_consumption(String destination_zip) {
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
public String[] travel_time(String destination_zip){
|
if (current_user.getCar_l_100km() == 0)
|
||||||
return new String[1];
|
return "";
|
||||||
}
|
return "" + (Math.round(Double.parseDouble(distance(destination_zip).replace(" km", ""))
|
||||||
|
* current_user.getCar_l_100km() / 100.0 * 100) / 100.0) + " l";
|
||||||
|
|
||||||
public String calc_co2(String destination_zip){
|
|
||||||
return "";
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,11 +5,25 @@ public class User {
|
||||||
private String username = "";
|
private String username = "";
|
||||||
private String password = "";
|
private String password = "";
|
||||||
private String hometown = "";
|
private String hometown = "";
|
||||||
private int zip;
|
private String zip = "";
|
||||||
private String car_name = "";
|
private String car_name = "";
|
||||||
private double car_co2_kmh;
|
private double car_l_100km = 0;
|
||||||
private double car_avg_kmh;
|
private double car_avg_kmh = 0;
|
||||||
private double bike_avg_kmh;
|
private double bike_avg_kmh = 0;
|
||||||
|
|
||||||
|
public User(){}
|
||||||
|
|
||||||
|
public User(String username, String password, String hometown, String zip
|
||||||
|
, String car_name, double car_l_100km, double car_avg_kmh, double bike_avg_kmh){
|
||||||
|
this.username = username;
|
||||||
|
this.password = password;
|
||||||
|
this.hometown = hometown;
|
||||||
|
this.zip = zip;
|
||||||
|
this.car_name = car_name;
|
||||||
|
this.car_l_100km = car_l_100km;
|
||||||
|
this.car_avg_kmh = car_avg_kmh;
|
||||||
|
this.bike_avg_kmh = bike_avg_kmh;
|
||||||
|
}
|
||||||
|
|
||||||
public String getUsername() {
|
public String getUsername() {
|
||||||
return username;
|
return username;
|
||||||
|
@ -35,11 +49,11 @@ public class User {
|
||||||
this.hometown = hometown;
|
this.hometown = hometown;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getZip() {
|
public String getZip() {
|
||||||
return zip;
|
return zip;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setZip(int zip) {
|
public void setZip(String zip) {
|
||||||
this.zip = zip;
|
this.zip = zip;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,14 +65,14 @@ public class User {
|
||||||
this.car_name = car_name;
|
this.car_name = car_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getCar_co2_kmh() {
|
public double getCar_l_100km() {
|
||||||
return car_co2_kmh;
|
return car_l_100km;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCar_co2_kmh(double car_co2_kmh) {
|
public void setCar_l_100km(double car_l_100km) {
|
||||||
this.car_co2_kmh = car_co2_kmh;
|
this.car_l_100km = car_l_100km;
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getCar_avg_kmh() {
|
public double getCar_avg_kmh() {
|
||||||
return car_avg_kmh;
|
return car_avg_kmh;
|
||||||
}
|
}
|
||||||
|
@ -74,4 +88,9 @@ public class User {
|
||||||
public void setBike_avg_kmh(double bike_avg_kmh) {
|
public void setBike_avg_kmh(double bike_avg_kmh) {
|
||||||
this.bike_avg_kmh = bike_avg_kmh;
|
this.bike_avg_kmh = bike_avg_kmh;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String toString(){
|
||||||
|
return this.username + ";" + System.encoding(this.password) + ";" + this.hometown + ";" + this.zip + ";" + this.car_name + ";"
|
||||||
|
+ this.car_l_100km + ";" + this.car_avg_kmh + ";" + this.bike_avg_kmh;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
package de.hs_mannheim.facade;
|
package de.hs_mannheim.facade;
|
||||||
|
|
||||||
import java.util.TreeSet;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import de.hs_mannheim.domain.System;
|
import de.hs_mannheim.domain.System;
|
||||||
|
|
||||||
|
@ -13,35 +13,54 @@ public class Application {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean sign_in_user(String username, String password){
|
public boolean sign_in_user(String username, String password){
|
||||||
return true;
|
return running_system.sign_in_user(username, password);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean sign_up_user(String username, String password, String hometown, int zip,
|
public boolean sign_up_user(String username, String password, String password_authentication, String hometown, String zip,
|
||||||
String car_name, double car_co2_km, double car_avg_kmh, double bike_avg_kmh){
|
String car_name, String car_co2_km, String car_avg_kmh, String bike_avg_kmh){
|
||||||
return true;
|
return running_system.sign_up_user(username, password, password_authentication, hometown, zip, car_name, car_co2_km, car_avg_kmh, bike_avg_kmh);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void sign_out_user(){}
|
public void sign_out_user(){
|
||||||
|
running_system.sign_out_user();
|
||||||
public boolean change_user_details(String username, String password, String hometown, int zip,
|
|
||||||
String car_name, double car_co2_km, double car_avg_kmh, double bike_avg_kmh){
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public TreeSet<String> search(String hometown_or_zip){
|
public boolean change_user_details(String username, String password, String hometown, String zip,
|
||||||
return new TreeSet<String>();
|
String car_name, String car_co2_km, String car_avg_kmh, String bike_avg_kmh){
|
||||||
|
return running_system.change_user_details(username, password, hometown, zip, car_name, car_co2_km, car_avg_kmh, bike_avg_kmh);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TreeSet<String> random_destinations(){
|
public boolean change_user_password(String old_password, String new_password, String new_password_authentication){
|
||||||
return new TreeSet<String>();
|
return running_system.change_user_password(old_password, new_password, new_password_authentication);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArrayList<String> search(String hometown_or_zip){
|
||||||
|
return running_system.search(hometown_or_zip);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArrayList<String> random_destinations_car(){
|
||||||
|
return running_system.random_destinations_car();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArrayList<String> random_destinations_bike(){
|
||||||
|
return running_system.random_destinations_bike();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String[] destination_details(String destination_zip){
|
public String[] destination_details(String destination_zip){
|
||||||
return new String[1];
|
return running_system.destination_details(destination_zip);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String current_weather(){
|
public String current_weather(){
|
||||||
return "";
|
return running_system.current_weather();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String[] getDetails(){
|
||||||
|
return running_system.getDetails();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String distance(String zip){
|
||||||
|
return running_system.distance(zip);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
Binary file not shown.
After Width: | Height: | Size: 12 KiB |
Binary file not shown.
After Width: | Height: | Size: 9.4 KiB |
Binary file not shown.
After Width: | Height: | Size: 12 KiB |
Binary file not shown.
After Width: | Height: | Size: 1.4 KiB |
|
@ -0,0 +1,2 @@
|
||||||
|
Daniel;MTQwMURhbmllbA==;Mannheim;68305;BMW;1.5;50.4;40.2
|
||||||
|
David;MTIzRXNlbA==;Mannheim;68161;AMG;10.0;100.0;20.0
|
|
|
@ -3,26 +3,174 @@ package de.hs_mannheim.domain;
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
import static org.junit.jupiter.api.Assertions.assertNotEquals;
|
import static org.junit.jupiter.api.Assertions.assertNotEquals;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
public class SystemTest {
|
public class SystemTest {
|
||||||
|
|
||||||
|
System current_system = new System("35a75437476f12302f72e55d368485db");
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void weather_forecast(){
|
public void weather_forecast() {
|
||||||
|
|
||||||
System current_system = new System("35a75437476f12302f72e55d368485db");
|
current_system.sign_in_user("David", "123Esel");
|
||||||
|
|
||||||
assertNotEquals("Es ist ein Fehler aufgetreten!",current_system.weather_forecast("68161"));
|
assertNotEquals("Es ist ein Fehler aufgetreten!", current_system.weather_forecast("68161")[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void current_weather(){
|
public void current_weather() {
|
||||||
|
|
||||||
System current_system = new System("35a75437476f12302f72e55d368485db");
|
current_system.sign_in_user("David", "123Esel");
|
||||||
|
|
||||||
current_system.set_current_user_zip("68161");
|
assertNotEquals("Es ist ein Fehler aufgetreten!", current_system.current_weather());
|
||||||
|
|
||||||
assertNotEquals("Es ist ein Fehler aufgetreten!",current_system.current_weather());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
@Test
|
||||||
|
public void search() {
|
||||||
|
|
||||||
|
ArrayList<String> list = current_system.search("Mannheim");
|
||||||
|
|
||||||
|
assertEquals("68159", list.get(0).split(";")[0]);
|
||||||
|
assertEquals("68167", list.get(4).split(";")[0]);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void distance() {
|
||||||
|
|
||||||
|
current_system.sign_in_user("David", "123Esel");
|
||||||
|
|
||||||
|
assertEquals("88.46 km", current_system.distance("60306")); // Frankfurt
|
||||||
|
assertEquals("581.11 km", current_system.distance("20095")); // Hamburg
|
||||||
|
assertEquals("603.61 km", current_system.distance("10115")); // Berlin
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void travel_time() {
|
||||||
|
|
||||||
|
current_system.sign_in_user("David", "123Esel");
|
||||||
|
|
||||||
|
assertEquals("0.88 h", current_system.travel_time("60306")[0]); // Frankfurt mit Auto
|
||||||
|
assertEquals("4.42 h", current_system.travel_time("60306")[1]); // Frankfurt mit Fahrrad
|
||||||
|
|
||||||
|
assertEquals("6.04 h", current_system.travel_time("10115")[0]); // Berlin mit Auto
|
||||||
|
assertEquals("30.18 h", current_system.travel_time("10115")[1]); // Berlin mit Fahrrad
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void calc_l_consumption() {
|
||||||
|
|
||||||
|
current_system.sign_in_user("David", "123Esel");
|
||||||
|
|
||||||
|
assertEquals("8.85 l", current_system.calc_l_consumption("60306")); // Kraftstoffverbrauch nach Frankfurt
|
||||||
|
assertEquals("58.11 l", current_system.calc_l_consumption("20095")); // Kraftstoffverbrauch nach Hamburg
|
||||||
|
assertEquals("60.36 l", current_system.calc_l_consumption("10115")); // Kraftstoffverbrauch nach Berlin
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void random_destinations() {
|
||||||
|
|
||||||
|
current_system.sign_in_user("David", "123Esel");
|
||||||
|
ArrayList<String> random_destination_car = current_system.random_destinations_car();
|
||||||
|
ArrayList<String> random_destination_bike = current_system.random_destinations_bike();
|
||||||
|
|
||||||
|
assertEquals(3, random_destination_car.size()); // random_destinations_car gibt genau 3 destinations zurück
|
||||||
|
assertEquals(3, random_destination_bike.size()); // random destinations_bike gibt genau 3 destinations zurück
|
||||||
|
|
||||||
|
// random_destinations_car gibt nur destinations mit mindestens 150 km
|
||||||
|
// Entfernung zurück
|
||||||
|
assertEquals(true, Double.parseDouble(
|
||||||
|
current_system.distance(random_destination_car.get(0).split(";")[0]).replace(" km", "")) > 150);
|
||||||
|
// random_destinations_bike gibt nur destinations mit maximal 100 km Entfernung
|
||||||
|
// zurück
|
||||||
|
assertEquals(true, Double.parseDouble(
|
||||||
|
current_system.distance(random_destination_bike.get(0).split(";")[0]).replace(" km", "")) < 100);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void encoding() {
|
||||||
|
|
||||||
|
String test_password = "123Esel";
|
||||||
|
|
||||||
|
assertEquals("MTIzRXNlbA==", System.encoding(test_password));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void decoding() {
|
||||||
|
|
||||||
|
String test_password = "MTIzRXNlbA==";
|
||||||
|
|
||||||
|
assertEquals("123Esel", System.decoding(test_password));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void sign_in_user() {
|
||||||
|
|
||||||
|
assertEquals(true, current_system.sign_in_user("Daniel", "1401Daniel"));
|
||||||
|
assertEquals("Daniel", current_system.getDetails()[0]);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void sign_out_user() {
|
||||||
|
|
||||||
|
assertEquals(true, current_system.sign_in_user("David", "123Esel"));
|
||||||
|
assertEquals("David", current_system.getDetails()[0]);
|
||||||
|
current_system.sign_out_user();
|
||||||
|
assertEquals("", current_system.getDetails()[0]);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void sign_up_user() {
|
||||||
|
// Username darf nicht doppelt vorkommen!
|
||||||
|
assertEquals(false, current_system.sign_up_user("David", "123Esel", "123Esel", "Mannheim", "68161", "AMG", "10",
|
||||||
|
"300", "20"));
|
||||||
|
assertEquals(true, current_system.sign_up_user("Selim", "Penis69", "Penis69", "Mannheim", "68161", "AMG", "10",
|
||||||
|
"300", "20"));
|
||||||
|
// PLZ muss mit Stadt übereinstimmen
|
||||||
|
assertEquals(false, current_system.sign_up_user("Lukas", "123Esel", "123Esel", "Mannheim", "11105", "AMG", "10",
|
||||||
|
"300", "20"));
|
||||||
|
assertEquals(true, current_system.sign_up_user("Lukas", "123Esel", "123Esel", "Mannheim", "68305", "AMG", "10",
|
||||||
|
"300", "20"));
|
||||||
|
|
||||||
|
assertEquals("Lukas", current_system.getDetails()[0]);
|
||||||
|
current_system.sign_out_user();
|
||||||
|
assertEquals("", current_system.getDetails()[0]);
|
||||||
|
assertEquals(true, current_system.sign_in_user("Lukas", "123Esel"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void change_user_details() {
|
||||||
|
|
||||||
|
current_system.sign_in_user("David", "123Esel");
|
||||||
|
current_system.change_user_details("Enes", "123Esel", "Mannheim", "68161", "", "", "", "");
|
||||||
|
assertEquals("Enes", current_system.getDetails()[0]);
|
||||||
|
current_system.change_user_details("David", "123Esel", "Mannheim", "68161", "AMG", "10", "100", "20");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void change_user_password() {
|
||||||
|
|
||||||
|
current_system.sign_in_user("David", "123Esel");
|
||||||
|
assertEquals(true, current_system.change_user_password("123Esel", "Pizza69", "Pizza69"));
|
||||||
|
assertEquals(true, current_system.change_user_password("Pizza69", "123Esel", "123Esel"));
|
||||||
|
assertEquals(true, current_system.change_user_details("Enes", "123Esel", "Mannheim", "68161", "", "", "", ""));
|
||||||
|
current_system.change_user_details("David", "123Esel", "Mannheim", "68161", "AMG", "10", "100", "20");
|
||||||
|
|
||||||
|
;
|
||||||
|
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* Tests auf Basis von user_data.csv:
|
||||||
|
* Daniel;MTQwMURhbmllbA==;Mannheim;68305;BMW;1.5;50.4;40.2
|
||||||
|
* David;MTIzRXNlbA==;Mannheim;68161;AMG;10.0;100.0;20.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,2 @@
|
||||||
|
Daniel;MTQwMURhbmllbA==;Mannheim;68305;BMW;1.5;50.4;40.2
|
||||||
|
David;MTIzRXNlbA==;Mannheim;68161;AMG;10.0;100.0;20.0
|
|
Loading…
Reference in New Issue