6 Commits

18 changed files with 753 additions and 254 deletions

View File

@ -1,5 +1,6 @@
package at.reisinger; package at.reisinger;
import at.reisinger.server.helper.EnumHelper;
import com.fasterxml.jackson.annotation.*; import com.fasterxml.jackson.annotation.*;
/** /**
@ -15,6 +16,8 @@ public class Card {
private ElementTyp elementTyp; private ElementTyp elementTyp;
@JsonProperty @JsonProperty
private CardType cardType; private CardType cardType;
@JsonProperty
private boolean locked;
/** /**
* Erstellt eine neue at.reisinger.Card mit gegebenen Eigenschaften * Erstellt eine neue at.reisinger.Card mit gegebenen Eigenschaften
@ -39,11 +42,11 @@ public class Card {
*/ */
@JsonCreator @JsonCreator
public Card(@JsonProperty("Id") String name, @JsonProperty("Name") String elementCardTyp, @JsonProperty("Damage") double damage){ public Card(@JsonProperty("Id") String name, @JsonProperty("Name") String elementCardTyp, @JsonProperty("Damage") double damage){
ElementTyp tmpElement = stringToElementType(elementCardTyp); ElementTyp tmpElement = EnumHelper.stringToElementType(elementCardTyp);
if(tmpElement == null){ if(tmpElement == null){
tmpElement = ElementTyp.UNDEF; tmpElement = ElementTyp.UNDEF;
} }
CardType tmpCard = stringToCardType(elementCardTyp); CardType tmpCard = EnumHelper.stringToCardType(elementCardTyp);
if(tmpCard == null){ if(tmpCard == null){
tmpCard = CardType.UNDEF; tmpCard = CardType.UNDEF;
} }
@ -54,51 +57,19 @@ public class Card {
} }
/** /**
* Wenn ein String als ElementType vorhanden ist, dann gibt er den passenden ElementType zurück * Prüft ob die Karte gesperrt ist
* @param elementTypeString elementType als String * @return True wenn die Karte gesperrt ist
* @return Passender Element Type oder null falls nicht gefunden
*/ */
private ElementTyp stringToElementType(String elementTypeString){ public boolean isLocked() {
for (ElementTyp e : ElementTyp.values()) { return locked;
System.out.println(e.toString().toLowerCase());
System.out.println(elementTypeString.toLowerCase().contains(e.name().toLowerCase()));
if (elementTypeString.toLowerCase().contains(e.name().toLowerCase())) {
System.out.println("\n\n\n");
System.out.println("####Element####, me.name() : elementTypeString");
System.out.println(e.name().toLowerCase());
System.out.print(" : ");
System.out.println(elementTypeString.toLowerCase());
System.out.println("\n\n\n");
return e;
}
}
return null;
} }
/** /**
* Wenn ein String als cardType vorhanden ist, dann gibt er den passenden cardType zurück * Setzt die sperre der Karte
* @param cardTypeString cardType als String * @param locked True bedeuted gesperrt
* @return Passender Card Type oder null falls nicht gefunden
*/ */
private CardType stringToCardType(String cardTypeString){ public void setLocked(boolean locked) {
System.out.println("\n\n\n"); this.locked = locked;
System.out.println("###CARD###, me.name() : cardTypeString\n");
for (CardType me : CardType.values()) {
System.out.println("\n\n\n");
System.out.print(me.name().toLowerCase());
System.out.print(" : ");
System.out.println(cardTypeString.toLowerCase());
System.out.println("\n\n\n");
if (cardTypeString.toLowerCase().contains(me.toString().toLowerCase())) {
System.out.println("\n\n\n");
System.out.print(me.name().toLowerCase());
System.out.print(" : ");
System.out.println(cardTypeString.toLowerCase());
System.out.println("\n\n\n");
return me;
}
}
return null;
} }
/** /**

View File

@ -1,5 +1,5 @@
package at.reisinger; package at.reisinger;
public enum CardType { public enum CardType {
MONSTER, SPELL, UNDEF, GOBLIN, TROLL, ELF, KNIGHT MONSTER, SPELL, UNDEF, GOBLIN, TROLL, ELF, KNIGHT, DRAGON, WIZZARD, ORK, KRAKEN, FIREELVES
} }

View File

@ -1,19 +1,25 @@
package at.reisinger; package at.reisinger;
import com.fasterxml.jackson.annotation.*;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicBoolean;
/** /**
* Verwaltet eine Liste vo at.reisinger.Cards * Verwaltet eine Liste vo at.reisinger.Cards
*/ */
@JsonAutoDetect
public class Cards { public class Cards {
@JsonDeserialize(as = ArrayList.class, contentAs = Card.class)
private ArrayList<Card> cards; private ArrayList<Card> cards;
/** /**
* Erstellt ein nues obj mit gegebenen Karten * Erstellt ein nues obj mit gegebenen Karten
* @param cardsArrayList Die at.reisinger.Cards zum erstellen des Obj * @param cardsArrayList Die at.reisinger.Cards zum erstellen des Obj
*/ */
public Cards(ArrayList<Card> cardsArrayList) { @JsonCreator
public Cards(@JsonProperty("cards") ArrayList<Card> cardsArrayList) {
this.cards = cardsArrayList; this.cards = cardsArrayList;
} }
@ -23,6 +29,7 @@ public class Cards {
* Fügt eine neue at.reisinger.Card hinzu * Fügt eine neue at.reisinger.Card hinzu
* @param newCard neue at.reisinger.Card * @param newCard neue at.reisinger.Card
*/ */
@JsonSetter
public void addCard(Card newCard) { public void addCard(Card newCard) {
this.cards.add(newCard); this.cards.add(newCard);
} }
@ -31,6 +38,7 @@ public class Cards {
* Holt alle at.reisinger.Cards * Holt alle at.reisinger.Cards
* @return Alle at.reisinger.Cards * @return Alle at.reisinger.Cards
*/ */
@JsonGetter
public ArrayList<Card> getCards() { public ArrayList<Card> getCards() {
return this.cards; return this.cards;
} }
@ -48,10 +56,10 @@ public class Cards {
* @param toCeck at.reisinger.Card nach der in den at.reisinger.Cards gesucht werden soll * @param toCeck at.reisinger.Card nach der in den at.reisinger.Cards gesucht werden soll
* @return True wenn die at.reisinger.Card in den at.reisinger.Cards ist * @return True wenn die at.reisinger.Card in den at.reisinger.Cards ist
*/ */
public boolean containsCard(Card toCeck){ public boolean containsCard(String toCeck){
AtomicBoolean returnval = new AtomicBoolean(false); AtomicBoolean returnval = new AtomicBoolean(false);
this.cards.forEach(item -> { this.cards.forEach(item -> {
if(item.getElementTyp().equals(toCeck.getElementTyp()) && item.getCardType().equals(toCeck.getCardType()) && item.getName().equals(toCeck.getName()) && item.getDamage() == toCeck.getDamage()){ if(item.getName().equals(toCeck)){
returnval.set(true); returnval.set(true);
}else{ }else{
returnval.set(false); returnval.set(false);

View File

@ -4,14 +4,16 @@ import at.reisinger.server.helper.PostgresHelper;
import java.sql.*; import java.sql.*;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/** /**
* Stellt die Verbindung zur "Datenbank" her * Stellt die Verbindung zur "Datenbank" her
* Die "Datenbank" sind hier nur beispieldaten. * Die "Datenbank" sind hier nur beispieldaten.
*/ */
public class DBConnection { public class DBConnection {
private ArrayList<TradingDeal> tradingDeals; //private ArrayList<TradingDeal> tradingDeals;
private ArrayList<Package> packages; //private ArrayList<Package> packages;
private Connection c; private Connection c;
private Statement stmt; private Statement stmt;
@ -28,13 +30,161 @@ public class DBConnection {
* Erstellt alle Tabellen die für den Betrieb der Software bennötigt werden * Erstellt alle Tabellen die für den Betrieb der Software bennötigt werden
*/ */
public void init() { public void init() {
PostgresHelper.executeUpdateMessage("CREATE TABLE IF NOT EXISTS USERS (username TEXT PRIMARY KEY NOT NULL, nachname TEXT NOT NULL, email TEXT NOT NULL, password TEXT NOT NULL)", "User Table created"); PostgresHelper.executeUpdateMessage("CREATE TABLE IF NOT EXISTS USERS (username TEXT PRIMARY KEY NOT NULL, nachname TEXT NOT NULL, email TEXT NOT NULL, password TEXT NOT NULL, bio TEXT, image TEXT, coins integer default 20 not null)", "User Table created");
PostgresHelper.executeUpdate("CREATE TABLE IF NOT EXISTS CARD(NAME TEXT not null,DAMAGE FLOAT not null,ELEMENTTYP TEXT not null,CARDTYPE TEXT not null, PRIMARY KEY (\"name\"));"); PostgresHelper.executeUpdate("CREATE TABLE IF NOT EXISTS CARD(NAME TEXT not null,DAMAGE FLOAT not null,ELEMENTTYP TEXT not null,CARDTYPE TEXT not null, PRIMARY KEY (\"name\"));");
PostgresHelper.executeUpdateMessage("create unique index IF NOT EXISTS card_name_uindex on CARD (NAME);", "Card Table created"); PostgresHelper.executeUpdateMessage("create unique index IF NOT EXISTS card_name_uindex on CARD (NAME);", "Card Table created");
PostgresHelper.executeUpdateMessage("create table IF NOT EXISTS package(\"ID\" varchar(255) not null,name varchar(255) not null constraint name references card, i serial not null constraint package_i primary key );", "Package Table created"); PostgresHelper.executeUpdateMessage("create table IF NOT EXISTS package(\"ID\" varchar(255) not null,name varchar(255) not null constraint name references card, i serial not null constraint package_i primary key );", "Package Table created");
PostgresHelper.executeUpdateMessage("create table IF NOT EXISTS user_cards(username TEXT not null constraint user_cards_users_username_fk references users,name text not null, gesperrt boolean not null);", "UserCards Table created"); PostgresHelper.executeUpdateMessage("create table IF NOT EXISTS user_cards(username TEXT not null constraint user_cards_users_username_fk references users,name text not null, gesperrt boolean not null);", "UserCards Table created");
PostgresHelper.executeUpdateMessage("create table IF NOT EXISTS user_deck(username text not null constraint user_deck_users_username_fk references users,cardname text not null);", "UserDeck Table created");
PostgresHelper.executeUpdateMessage("create table IF NOT EXISTS trading(username text not null constraint trading_users_username_fk references users,id text not null constraint trading_pk primary key, cardtotrade text not null constraint trading_card_name_fk references card, mindamage float not null,reqcardtype text not null,reqelement text not null);", "Trading Table created");
} }
/**
* Updated den Lock einer user card
* @param name Name der Card
* @param lock Zustand des Locks
* @return true bei erfolg, sonst false
*/
public boolean updateCardLock(String name, boolean lock){
System.out.println("Update user_cards set gesperrt = " + lock + " where name = \'" + name + "\';");
return PostgresHelper.executeUpdate("Update user_cards set gesperrt = " + lock + " where name = \'" + name + "\';");
}
/**
* Fügt der DB einen Trading deal hinzu
* @param username User der den Trade hinzufügt
* @param id Id des Trades
* @param mindamage Min damage der für den trade benötigt wird
* @param reqcardtype Req Card Type der für den trade benötigt wird
* @param reqelement Req Element Typ der für den trade benötigt wird
* @param cardtotrade Card die zum Traden ist
* @return True bei erfolg, sonst false
*/
public boolean addTradingdeal(String username, String id, double mindamage, String reqcardtype, String reqelement, String cardtotrade){
if(PostgresHelper.executeUpdate("INSERT INTO public.trading (username, id, cardtotrade, mindamage, reqcardtype, reqelement) VALUES (\'" + username + "\',\'" + id + "\',\'" + cardtotrade + "\',\'"+ mindamage + "\',\'" + reqcardtype + "\',\'" + reqelement + "\');")){
return true;
}else{
return false;
}
}
/**
* Holt alle Trading Deals aus der DB
* @return Null bei error
*/
public ArrayList<TradingDeal> getAllTradingDeals(){
this.c = PostgresHelper.con();
ArrayList<TradingDeal> tradingDeals = new ArrayList<TradingDeal>();
try {
stmt = this.c.createStatement();
ResultSet rs = stmt.executeQuery("select * from trading;");
while (rs.next()) {
String username, id, cardtotrade, reqcardtype, reqelement;
int mindamage;
username = rs.getString("username");
id = rs.getString("id");
cardtotrade = rs.getString("cardtotrade");
reqcardtype = rs.getString("reqcardtype");
reqelement = rs.getString("reqelement");
mindamage = rs.getInt("mindamage");
Card card = new DBConnection().getCardFromID(cardtotrade);
if(card != null){
TradingDeal tmp = new TradingDeal(id, card, mindamage, reqcardtype +reqelement, username);
if (tmp != null){
tradingDeals.add(tmp);
System.out.println("Pulled TradingDeal");
}else{
return null;
}
}else{
return null;
}
}
rs.close();
stmt.close();
this.c.close();
} catch (Exception e) {
System.err.println(e.getClass().getName() + ": " + e.getMessage());
return null;
}
System.out.println("Trading Deals pulled successfully");
return tradingDeals;
}
/**
* Setzt das Deck eines Users
* @param username Username von dem das Deck gesetzt werden soll
* @param deck Die ID´s des Decks in der Form einer ArrayList<String>
* @return True bei erfolg, sonst false
*/
public boolean setDeck(String username, List<String> deck){
if (!delDeck(username)){
return false;
}
Cards allCards = getCards(username);
Cards deckCards = new Cards(new ArrayList<Card>());
int count = 0;
if(allCards != null){
for (String st : deck) {
for (Card ca: allCards.getCards()) {
System.out.println("Count : " + count);
System.out.println("CA: " + ca.getName() + " st: " + st);
if(ca.getName().equals(st) && count < 4){
deckCards.addCard(ca);
if(!PostgresHelper.executeUpdateMessage("INSERT INTO public.user_deck (username, cardname) VALUES (\'"+username+"\', \'"+st+"\');", "Card #"+count+" added to Deck")){
return false;
}
}
}
count++;
}
return true;
}
return false;
}
/**
* Holt alle Card namen aus dem Deck eines Users
* @param username user von dem die Deck namen geholt werden soll
* @return null bedeuted error
*/
public ArrayList<String> getDeck(String username){
this.c = PostgresHelper.con();
String cardname = "";
Cards allCards = new Cards(new ArrayList<Card>());
ArrayList<String> cardnamenarray = new ArrayList<String>();
try {
stmt = this.c.createStatement();
ResultSet rs = stmt.executeQuery("select * from user_deck where username = \'" + username + "\';");
while (rs.next()) {
cardname = rs.getString("cardname");
cardnamenarray.add(cardname);
System.out.println("cardname = " + cardname);
}
rs.close();
stmt.close();
this.c.close();
} catch (Exception e) {
System.err.println(e.getClass().getName() + ": " + e.getMessage());
return null;
}
System.out.println("Deck names pulled successfully");
return cardnamenarray;
}
/**
* Löscht den gesammten inhalt des Decks eines users
* @param username Username von dem das Deck gelöscht werden soll
* @return True bei erfolg, sonst false
*/
public boolean delDeck(String username){
return PostgresHelper.executeUpdateMessage("delete from user_deck where username = \'" + username + "\';", "User Deck: " + username + ", deleted");
}
/** /**
* Holt ein Random package aus dem Shop * Holt ein Random package aus dem Shop
* *
@ -42,13 +192,11 @@ public class DBConnection {
* @return Das Package aus dem Shop, null falls ein Fehler auftritt * @return Das Package aus dem Shop, null falls ein Fehler auftritt
*/ */
public Package userAcquirePackage(String username) { public Package userAcquirePackage(String username) {
System.out.println("Vor den coins");
int coins = checkCoins(username); int coins = checkCoins(username);
if (!(coins - 5 >= 0)) { if (!(coins - 5 >= 0)) {
return null; return null;
} }
updateCoins(coins - 5, username); updateCoins(coins - 5, username);
System.out.println("nach den soins");
this.c = PostgresHelper.con(); this.c = PostgresHelper.con();
String id = ""; String id = "";
@ -57,8 +205,6 @@ public class DBConnection {
ResultSet rs = stmt.executeQuery("select \"ID\" as id from package LIMIT 1;"); ResultSet rs = stmt.executeQuery("select \"ID\" as id from package LIMIT 1;");
while (rs.next()) { while (rs.next()) {
id = rs.getString("id"); id = rs.getString("id");
System.out.println("id = " + id);
System.out.println();
} }
rs.close(); rs.close();
stmt.close(); stmt.close();
@ -87,12 +233,10 @@ public class DBConnection {
damage = rs.getInt("damage"); damage = rs.getInt("damage");
Card newCard = new Card(cardname, elementtyp + cardtype, damage); Card newCard = new Card(cardname, elementtyp + cardtype, damage);
cards.addCard(newCard); cards.addCard(newCard);
System.out.println();
Connection b = PostgresHelper.con(); Connection b = PostgresHelper.con();
try { try {
stmt = b.createStatement(); stmt = b.createStatement();
String sql = "INSERT INTO public.user_cards (username, name, gesperrt) VALUES ( \'" + username + "\',\'" + newCard.getName() + "\', \'false\');"; String sql = "INSERT INTO public.user_cards (username, name, gesperrt) VALUES ( \'" + username + "\',\'" + newCard.getName() + "\', \'false\');";
System.out.println(sql);
stmt.executeUpdate(sql); stmt.executeUpdate(sql);
stmt.close(); stmt.close();
b.close(); b.close();
@ -154,8 +298,6 @@ public class DBConnection {
ResultSet rs = stmt.executeQuery("Select coins from users where username = \'" + username + "\';"); ResultSet rs = stmt.executeQuery("Select coins from users where username = \'" + username + "\';");
while (rs.next()) { while (rs.next()) {
coins = rs.getInt("coins"); coins = rs.getInt("coins");
System.out.println("Count: ");
System.out.print(coins);
} }
rs.close(); rs.close();
stmt.close(); stmt.close();
@ -183,8 +325,6 @@ public class DBConnection {
ResultSet rs = stmt.executeQuery("select count(*) from card where name = \'" + name + "\';"); ResultSet rs = stmt.executeQuery("select count(*) from card where name = \'" + name + "\';");
while (rs.next()) { while (rs.next()) {
count = rs.getInt("count"); count = rs.getInt("count");
System.out.println("Count: ");
System.out.print(count);
} }
rs.close(); rs.close();
stmt.close(); stmt.close();
@ -234,8 +374,6 @@ public class DBConnection {
System.err.println(e.getClass().getName() + ": " + e.getMessage()); System.err.println(e.getClass().getName() + ": " + e.getMessage());
return 0; return 0;
} }
System.out.println("Package Next id is: ");
System.out.print(id);
return Integer.parseInt(id) + 1; return Integer.parseInt(id) + 1;
} }
@ -270,8 +408,25 @@ public class DBConnection {
* @param email Email des Users * @param email Email des Users
* @return True wenn alles erfolgreich war, false wenn es nicht erfolgreich war * @return True wenn alles erfolgreich war, false wenn es nicht erfolgreich war
*/ */
public boolean addUser(String username, String password, String nachname, String email) { public boolean addUser(String username, String password, String nachname, String email, String bio, String image) {
return PostgresHelper.executeUpdateMessage("INSERT INTO users (username, nachname, email, password) values (\'" + username + "\',\'" + nachname + "\',\'" + email + "\',\'" + password + "\')", "User added"); return PostgresHelper.executeUpdateMessage("INSERT INTO users (username, nachname, email, password, bio, image) values (\'" + username + "\',\'" + nachname + "\',\'" + email + "\',\'" + password + "\',\'" + bio + "\',\'" + image + "\')", "User added");
}
/**
* Updated den Nachnamen, Bio und das Image eines Users mit gegebenen usernamen
* @param username User der geändert werden soll
* @param bio Neue BIO
* @param image Neues Image
* @param name Neuer Nachname
* @return True bei erfolg, sonst false
*/
public boolean updateUser(String username, String bio, String image, String name){
System.out.println("UPDATE public.users SET nachname = \'"+ name+"\', bio = \'"+bio+"\', image = \'"+image+"\' WHERE username LIKE \'"+username+"\' ESCAPE \'#\'");
return PostgresHelper.executeUpdate("UPDATE public.users SET nachname = \'"+ name+"\', bio = \'"+bio+"\', image = \'"+image+"\' WHERE username LIKE \'"+username+"\' ESCAPE \'#\'");
}
/**
private boolean updateUser(String username, String name, String bio, String image){
return PostgresHelper.executeUpdate("UPDATE public.users SET nachname = \'"+ name +"\', bio = \'"+bio+"\', image = \'"+image+"\' WHERE username LIKE \'"+username+"\' ESCAPE \'#\'");
} }
/** /**
@ -279,12 +434,12 @@ public class DBConnection {
* Gibt ein User Objekt zurück * Gibt ein User Objekt zurück
* *
* @param uname Username der zu suchen ist * @param uname Username der zu suchen ist
* @return User als User Objekt * @return User als User Objekt, null bei fehler
* @throws SQLException Fehler bei der Suche in der DB * @throws SQLException Fehler bei der Suche in der DB
*/ */
public User getUser(String uname) throws SQLException { public User getUser(String uname) throws SQLException {
this.c = PostgresHelper.con(); this.c = PostgresHelper.con();
String username = "", password = "", email = "", nachname = ""; String username = "", password = "", email = "", nachname = "", bio="", image="";
try { try {
stmt = this.c.createStatement(); stmt = this.c.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM users where username = \'" + uname + "\';"); ResultSet rs = stmt.executeQuery("SELECT * FROM users where username = \'" + uname + "\';");
@ -293,28 +448,128 @@ public class DBConnection {
nachname = rs.getString("nachname"); nachname = rs.getString("nachname");
email = rs.getString("email"); email = rs.getString("email");
password = rs.getString("password"); password = rs.getString("password");
System.out.println("username = " + username); bio = rs.getString("bio");
System.out.println("nachname = " + nachname); image = rs.getString("image");
System.out.println("email = " + email);
System.out.println("password = " + password);
System.out.println();
} }
rs.close(); rs.close();
stmt.close(); stmt.close();
this.c.close(); this.c.close();
} catch (Exception e) { } catch (Exception e) {
System.err.println(e.getClass().getName() + ": " + e.getMessage()); System.err.println(e.getClass().getName() + ": " + e.getMessage());
System.exit(0); return null;
} }
System.out.println("Operation done successfully"); System.out.println("User pulled successfully");
return new User(new Credentials(username, password), username, username, email, new Coins(20)); return new User(new Credentials(username, password), username, username, email, new Coins(20), bio, image);
}
/**
* Holt eine Card aus der DB, anhand der gegebenen Card Id
* @param id Id der Card die geholt werden soll
* @return Null bei error
*/
public Card getCardFromID(String id){
System.out.println(id);
Connection b = PostgresHelper.con();
Card toreturn = null;
try {
stmt = b.createStatement();
ResultSet rs = stmt.executeQuery("select * from card where NAME = \'" + id + "\';");
while (rs.next()) {
int damage =rs.getInt("damage");
String elementtyp =rs.getString("elementtyp");
String cardtype=rs.getString("cardtype");
System.out.println("damage = " + damage);
System.out.println("elementtyp = " + elementtyp);
System.out.println("cardtype = " + cardtype);
System.out.println();
toreturn = new Card(id, elementtyp+cardtype, damage);
}
rs.close();
stmt.close();
b.close();
} catch (Exception e) {
System.err.println(e.getClass().getName() + ": " + e.getMessage());
return null;
}
if (toreturn != null){
System.out.println("Card pulled successfully");
return toreturn;
}else {
System.out.println("Card NOT pulled");
return null;
}
}
/**
* Holt alle Carten einer gegebenen Card ID List
* @param cardnamenarray Card IDs in einer Liste
* @return Falls null, dann war ein error
*/
public Cards getCardsFromIDList(List<String> cardnamenarray){
Cards allCards = new Cards(new ArrayList<Card>());
for (String st : cardnamenarray) {
Connection b = PostgresHelper.con();
try {
stmt = b.createStatement();
ResultSet rs = stmt.executeQuery("select * from card where NAME = \'" + st + "\';");
while (rs.next()) {
int damage =rs.getInt("damage");
String elementtyp =rs.getString("elementtyp");
String cardtype=rs.getString("cardtype");
System.out.println("damage = " + damage);
System.out.println("elementtyp = " + elementtyp);
System.out.println("cardtype = " + cardtype);
System.out.println();
allCards.addCard(new Card(st, elementtyp+cardtype, damage));
}
rs.close();
stmt.close();
b.close();
} catch (Exception e) {
System.err.println(e.getClass().getName() + ": " + e.getMessage());
return null;
}
System.out.println("Card pulled successfully");
}
return allCards;
}
/**
* Holt alle Karten eines Users
* @param username Username des Users
* @return Cards Object, falls es null ist, war ein fehler
*/
public Cards getCards(String username){
this.c = PostgresHelper.con();
String cardname = "";
boolean locked;
Cards allCards = new Cards(new ArrayList<Card>());
ArrayList<String> cardnamenarray = new ArrayList<String>();
try {
stmt = this.c.createStatement();
ResultSet rs = stmt.executeQuery("select * from user_cards where username = \'" + username + "\';");
while (rs.next()) {
cardname = rs.getString("name");
locked = rs.getBoolean("gesperrt");
cardnamenarray.add(cardname);
System.out.println("cardname = " + cardname);
}
rs.close();
stmt.close();
this.c.close();
} catch (Exception e) {
System.err.println(e.getClass().getName() + ": " + e.getMessage());
return null;
}
System.out.println("Card Namen pulled successfully");
return getCardsFromIDList(cardnamenarray);
} }
/** /**
* Holt alle verfügbaren TradingDeals * Holt alle verfügbaren TradingDeals
* *
* @return Alle Trading Deals * @return Alle Trading Deals
*/
public ArrayList<TradingDeal> getAllTradingDeals() { public ArrayList<TradingDeal> getAllTradingDeals() {
return this.tradingDeals; return this.tradingDeals;
} }
@ -323,9 +578,9 @@ public class DBConnection {
* Fügt einen neuen Tradingdeal zum at.reisinger.Store hinzu * Fügt einen neuen Tradingdeal zum at.reisinger.Store hinzu
* *
* @param tradingDeal Der neue Deal * @param tradingDeal Der neue Deal
*/
public void addTradingDeal(TradingDeal tradingDeal) { public void addTradingDeal(TradingDeal tradingDeal) {
this.tradingDeals.add(tradingDeal); this.tradingDeals.add(tradingDeal);
} }
*/
} }

View File

@ -1,5 +1,5 @@
package at.reisinger; package at.reisinger;
public enum ElementTyp { public enum ElementTyp {
WATER, FIRE, NORMAL, UNDEF, REGULAR, GOBLIN, KNIGHT WATER, FIRE, NORMAL, UNDEF, REGULAR, GOBLIN, TROLL, ELF, KNIGHT, DRAGON, WIZZARD, ORK, KRAKEN, FIREELVES
} }

View File

@ -1,43 +1,99 @@
package at.reisinger; package at.reisinger;
import at.reisinger.server.helper.EnumHelper;
import com.fasterxml.jackson.annotation.*;
/** /**
* Ein einzelner Trading deal wird hier verwaltet. * Ein einzelner Trading deal wird hier verwaltet.
*/ */
@JsonAutoDetect
public class TradingDeal { public class TradingDeal {
//private User tradingUser; @JsonProperty
private String id, username;
@JsonProperty
private Card cardToTrade; private Card cardToTrade;
@JsonProperty
private ElementTyp requiredElementType; private ElementTyp requiredElementType;
@JsonProperty
private double requiredMinDamage; private double requiredMinDamage;
@JsonProperty
private CardType requiredCardType; private CardType requiredCardType;
/** /**
* Ein at.reisinger.TradingDeal wird erstellt * Ein TradingDeal wird erstellt
* @param user at.reisinger.User des Deals * @param id Id des Trading deals
* @param cardToTrade at.reisinger.Card die getauscht werden soll * @param cardToTrade at.reisinger.Card die getauscht werden soll
* @param requiredElementType Req ElementType für den Tausch * @param requiredElementType Req ElementType für den Tausch
* @param requiredMinDamage Req min damage für den Tausch * @param requiredMinDamage Req min damage für den Tausch
* @param requiredCardType Req at.reisinger.Card Type für den Tausch * @param requiredCardType Req at.reisinger.Card Type für den Tausch
*/ */
public TradingDeal(User user, Card cardToTrade, ElementTyp requiredElementType, double requiredMinDamage, CardType requiredCardType) { public TradingDeal(String id, Card cardToTrade, ElementTyp requiredElementType, double requiredMinDamage, CardType requiredCardType, String username) {
//this.tradingUser = user; this.id = id;
this.cardToTrade = cardToTrade; this.cardToTrade = cardToTrade;
if(requiredElementType == null){
requiredElementType = ElementTyp.UNDEF;
}
if(requiredCardType == null) {
requiredCardType = CardType.UNDEF;
}
this.requiredElementType = requiredElementType; this.requiredElementType = requiredElementType;
this.requiredMinDamage = requiredMinDamage; this.requiredMinDamage = requiredMinDamage;
this.requiredCardType = requiredCardType; this.requiredCardType = requiredCardType;
this.username = username;
} }
/** /**
* Holt den Trading at.reisinger.User * Ein TradingDeal wird erstellt, anhand des type werden der ElementType und der CardType automatisch bestimmt
* @return at.reisinger.User der den Trade erstellt hat * @param id Id des Trading deals
* @param cardToTrade at.reisinger.Card die getauscht werden soll
public User getTradingUser() { * @param type ElementTyp und CardType in einem String. Beide Enums werden durch diesen String gewählt.
return this.tradingUser; * Wird kein passender Typ gefunden, dann bleibt diese Eigenschaft auf null
*/
@JsonCreator
public TradingDeal(@JsonProperty("Id") String id, @JsonProperty("CardToTrade") Card cardToTrade, @JsonProperty("MinimumDamage") double requiredMinDamage, @JsonProperty("Type") String type, String username) {
this(id, cardToTrade, EnumHelper.stringToElementType(type), requiredMinDamage, EnumHelper.stringToCardType(type), username);
} }
*/
/**
* Holt die ID des Trading deals
* @return Id des Trading Deals
*/
public String getId() {
return id;
}
/**
* Setzt die id des TradingDeals
* @param id Id des TradingDeals
*/
public void setId(String id) {
this.id = id;
}
/**
* Holt den usernamen
* @return Der username als String
*/
@JsonGetter
public String getUsername() {
return username;
}
/**
* Setzt den usernamen
* @param username Der username als String
*/
@JsonSetter
public void setUsername(String username) {
this.username = username;
}
/** /**
* at.reisinger.Card die getraded werden soll * at.reisinger.Card die getraded werden soll
* @return at.reisinger.Card die getradet werden soll * @return at.reisinger.Card die getradet werden soll
*/ */
@JsonGetter
public Card getCardToTrade() { public Card getCardToTrade() {
return this.cardToTrade; return this.cardToTrade;
} }
@ -46,6 +102,7 @@ public class TradingDeal {
* Req Element type holen * Req Element type holen
* @return Req Element Type * @return Req Element Type
*/ */
@JsonGetter
public ElementTyp getRequiredElementType() { public ElementTyp getRequiredElementType() {
return this.requiredElementType; return this.requiredElementType;
} }
@ -54,6 +111,7 @@ public class TradingDeal {
* Req min damage holen * Req min damage holen
* @return Req min damage * @return Req min damage
*/ */
@JsonGetter
public double getRequiredMinDamage() { public double getRequiredMinDamage() {
return this.requiredMinDamage; return this.requiredMinDamage;
} }
@ -62,6 +120,7 @@ public class TradingDeal {
* Hole req cardtype * Hole req cardtype
* @return Req at.reisinger.CardType * @return Req at.reisinger.CardType
*/ */
@JsonGetter
public CardType getRequiredCardType() { public CardType getRequiredCardType() {
return this.requiredCardType; return this.requiredCardType;
} }
@ -78,6 +137,7 @@ public class TradingDeal {
* Setzt die Karte die Getradet werden soll * Setzt die Karte die Getradet werden soll
* @param cardToTrade at.reisinger.Card zum tauschen * @param cardToTrade at.reisinger.Card zum tauschen
*/ */
@JsonSetter
public void setCardToTrade(Card cardToTrade) { public void setCardToTrade(Card cardToTrade) {
this.cardToTrade = cardToTrade; this.cardToTrade = cardToTrade;
} }
@ -86,6 +146,7 @@ public class TradingDeal {
* Setzt req elementType * Setzt req elementType
* @param requiredElementType Der Req elementType * @param requiredElementType Der Req elementType
*/ */
@JsonSetter
public void setRequiredElementType(ElementTyp requiredElementType) { public void setRequiredElementType(ElementTyp requiredElementType) {
this.requiredElementType = requiredElementType; this.requiredElementType = requiredElementType;
} }
@ -94,6 +155,7 @@ public class TradingDeal {
* Setzt die req Min damage * Setzt die req Min damage
* @param requiredMinDamage Die req min gamage * @param requiredMinDamage Die req min gamage
*/ */
@JsonSetter
public void setRequiredMinDamage(double requiredMinDamage) { public void setRequiredMinDamage(double requiredMinDamage) {
this.requiredMinDamage = requiredMinDamage; this.requiredMinDamage = requiredMinDamage;
} }
@ -102,6 +164,7 @@ public class TradingDeal {
* Setzt req cardType * Setzt req cardType
* @param requiredCardType Der Req at.reisinger.CardType * @param requiredCardType Der Req at.reisinger.CardType
*/ */
@JsonSetter
public void setRequiredCardType(CardType requiredCardType) { public void setRequiredCardType(CardType requiredCardType) {
this.requiredCardType = requiredCardType; this.requiredCardType = requiredCardType;
} }

View File

@ -8,9 +8,9 @@ import java.util.ArrayList;
* at.reisinger.User & at.reisinger.Store Logik * at.reisinger.User & at.reisinger.Store Logik
*/ */
@JsonAutoDetect @JsonAutoDetect
public class User implements Store{ public class User{
@JsonProperty @JsonProperty
private String name, nachname, email; private String name, nachname, email, bio, image;
/* /*
@JsonProperty @JsonProperty
private Stack stack; private Stack stack;
@ -42,16 +42,54 @@ public class User implements Store{
} }
*/ */
@JsonCreator @JsonCreator
public User(@JsonProperty Credentials credentials,@JsonProperty String name,@JsonProperty String nachname,@JsonProperty String email,@JsonProperty Coins coins) { public User(@JsonProperty Credentials credentials,@JsonProperty String name,@JsonProperty String nachname,@JsonProperty String email,@JsonProperty Coins coins, @JsonProperty String bio, @JsonProperty String image) {
this.credentials = credentials; this.credentials = credentials;
this.name = name; this.name = name;
this.nachname = nachname; this.nachname = nachname;
this.email = email; this.email = email;
//this.stack = null; //this.stack = null;
this.coins = coins; this.coins = coins;
this.bio = bio;
this.image = image;
//this.db = new at.reisinger.DBConnection(); //this.db = new at.reisinger.DBConnection();
} }
/**
* Holt die Bio vom User
* @return Bio des Users
*/
@JsonGetter
public String getBio() {
return bio;
}
/**
* Setzt die Bio vom User
* @param bio Bio des Users
*/
@JsonSetter
public void setBio(String bio) {
this.bio = bio;
}
/**
* Holt das image vom user
* @return Image vom user
*/
@JsonGetter
public String getImage() {
return image;
}
/**
* Setzt das image vom user
* @param image Image vom user
*/
@JsonSetter
public void setImage(String image) {
this.image = image;
}
/** /**
* Holt den at.reisinger.Stack des Users * Holt den at.reisinger.Stack des Users
* @return at.reisinger.Stack des Users * @return at.reisinger.Stack des Users
@ -199,15 +237,16 @@ public class User implements Store{
/** /**
* Fügt dem at.reisinger.Store einen neuen Tradingdeal hinzu * Fügt dem at.reisinger.Store einen neuen Tradingdeal hinzu
* @param tradingDeal Der neue Tradingdeal * @param tradingDeal Der neue Tradingdeal
*/ *
public void addTradingDeal(TradingDeal tradingDeal) { public void addTradingDeal(TradingDeal tradingDeal) {
new DBConnection().addTradingDeal(tradingDeal); new DBConnection().addTradingDeal(tradingDeal);
} }
/** /**
* Holt alle verfügbaren Tradingdeals * Holt alle verfügbaren Tradingdeals
* @return Alle verfügbaren Deals * @return Alle verfügbaren Deals
*/ *
public ArrayList<TradingDeal> getTradingDeals() { public ArrayList<TradingDeal> getTradingDeals() {
return new DBConnection().getAllTradingDeals(); return new DBConnection().getAllTradingDeals();
} }
@ -237,7 +276,7 @@ public class User implements Store{
* Gibt alle Möglichen Trading Deals zurück * Gibt alle Möglichen Trading Deals zurück
* @param toTrade Prüft nach diesem Deal * @param toTrade Prüft nach diesem Deal
* @return * @return
*/ *
@Override @Override
public ArrayList<TradingDeal> getPossibleTradingDeals(Card toTrade) { public ArrayList<TradingDeal> getPossibleTradingDeals(Card toTrade) {
ArrayList<TradingDeal> storeList = new DBConnection().getAllTradingDeals(); ArrayList<TradingDeal> storeList = new DBConnection().getAllTradingDeals();
@ -251,6 +290,7 @@ public class User implements Store{
return possible; return possible;
} }
*/
/** /**
* Checkt ob es sich um den selben at.reisinger.User handelt * Checkt ob es sich um den selben at.reisinger.User handelt
* @param toCheck Mit diesem at.reisinger.User wird verglichen * @param toCheck Mit diesem at.reisinger.User wird verglichen

View File

@ -1,7 +1,6 @@
package at.reisinger.server; package at.reisinger.server;
import at.reisinger.DBConnection; import at.reisinger.DBConnection;
import at.reisinger.server.msg.MsgHandler;
import at.reisinger.server.objects.Request; import at.reisinger.server.objects.Request;
import at.reisinger.server.objects.Response; import at.reisinger.server.objects.Response;
@ -17,7 +16,6 @@ public class Main {
static final int port = 80; static final int port = 80;
private Socket socket; private Socket socket;
private int id; private int id;
private MsgHandler msgHandler;
/** /**
* Initial Start * Initial Start

View File

@ -0,0 +1,38 @@
package at.reisinger.server.helper;
import at.reisinger.CardType;
import at.reisinger.ElementTyp;
/**
* Hilft beim manipulieren von enums
*/
public class EnumHelper {
/**
* Wenn ein String als ElementType vorhanden ist, dann gibt er den passenden ElementType zurück
* @param elementTypeString elementType als String
* @return Passender Element Type oder null falls nicht gefunden
*/
public static ElementTyp stringToElementType(String elementTypeString){
for (ElementTyp e : ElementTyp.values()) {
if (elementTypeString.toLowerCase().contains(e.name().toLowerCase())) {
return e;
}
}
return null;
}
/**
* Wenn ein String als cardType vorhanden ist, dann gibt er den passenden cardType zurück
* @param cardTypeString cardType als String
* @return Passender Card Type oder null falls nicht gefunden
*/
public static CardType stringToCardType(String cardTypeString){
for (CardType me : CardType.values()) {
if (cardTypeString.toLowerCase().contains(me.toString().toLowerCase())) {
return me;
}
}
return null;
}
}

View File

@ -3,11 +3,13 @@ package at.reisinger.server.helper;
import at.reisinger.Card; import at.reisinger.Card;
import at.reisinger.Cards; import at.reisinger.Cards;
import at.reisinger.Package; import at.reisinger.Package;
import at.reisinger.User;
import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference; import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List;
import java.util.Map; import java.util.Map;
/** /**
@ -23,21 +25,21 @@ public class JsonHelper {
*/ */
public static String packageListToJson(ArrayList<Card> listCards, String name){ public static String packageListToJson(ArrayList<Card> listCards, String name){
Package packageCards = new Package(new Cards(listCards),name, 5); Package packageCards = new Package(new Cards(listCards),name, 5);
return packageToJson(packageCards); return objToJson(packageCards);
} }
/** /**
* Wandelt ein Package Objekt in ein Json um * Wandelt ein Package Objekt in ein Json um
* @param packageCards Package Objekt das in ein Json umgewandelt werden soll * @param obj Objekt das in ein Json umgewandelt werden soll
* @return Json String des Packages * @return Json String des Packages
*/ */
public static String packageToJson(Package packageCards){ public static String objToJson(Object obj){
ObjectMapper objectMapper = new ObjectMapper(); ObjectMapper objectMapper = new ObjectMapper();
objectMapper = new ObjectMapper(); objectMapper = new ObjectMapper();
String packageJson = ""; String packageJson = "";
if(packageCards != null) { if(obj != null) {
try { try {
packageJson += objectMapper.writeValueAsString(packageCards); packageJson += objectMapper.writeValueAsString(obj);
} catch (JsonProcessingException e) { } catch (JsonProcessingException e) {
packageJson = "Error: JsonProcessingException -> " + e.getMessage(); packageJson = "Error: JsonProcessingException -> " + e.getMessage();
} }
@ -47,7 +49,50 @@ public class JsonHelper {
} }
} }
public static Map<String, Object> jsonPayload2ToMap(String payload){ /**
* Json wird in ein Card Objekt umgewandelt
* @param json Json das umgewandelt werden soll
* @return Null bei JsonProcessingException
*/
public static Card jsonToCard(String json){
ObjectMapper objectMapper = new ObjectMapper();
Card card = null;
try {
card = objectMapper.readValue(json, Card.class);
if(card != null) {
return card;
}else{
return null;
}
} catch (JsonProcessingException e) {
e.printStackTrace();
return null;
}
}
/**
* Json zu List
* @param payload Json String
* @return List aus dem json, bei einer JsonProcessingException null
*/
public static List<String> jsonPayloadToList(String payload){
ObjectMapper objectMapper = new ObjectMapper();
try {
return objectMapper.readValue(payload, new TypeReference<List<String>>(){});
} catch (JsonProcessingException e) {
e.printStackTrace();
return null;
}
}
/**
* Json zu Map
* @param payload Json String
* @return Map aus dem json, bei einer JsonProcessingException null
*/
public static Map<String, Object> jsonPayloadToMap(String payload){
ObjectMapper objectMapper = new ObjectMapper(); ObjectMapper objectMapper = new ObjectMapper();
try { try {
return objectMapper.readValue(payload, new TypeReference<Map<String,Object>>(){}); return objectMapper.readValue(payload, new TypeReference<Map<String,Object>>(){});
@ -57,4 +102,9 @@ public class JsonHelper {
} }
} }
@Deprecated
public static String userToJson(User user){
return objToJson(user);
}
} }

View File

@ -34,9 +34,8 @@ public class PostgresHelper {
* @return True bei erfolg, sonst false * @return True bei erfolg, sonst false
*/ */
public static boolean executeUpdateMessage(String sql, String message){ public static boolean executeUpdateMessage(String sql, String message){
boolean tmp = executeUpdate(sql);
System.out.println(message); System.out.println(message);
return tmp; return executeUpdate(sql);
} }
/** /**

View File

@ -1,89 +0,0 @@
package at.reisinger.server.msg;
import at.reisinger.server.objects.Msg;
import java.util.HashMap;
/**
* Der Speicher der Nachrichten
* Mit hilfe einer HashMap werden die MsgId und die Msg selbst gespeichert
* @author Georg Reisinger
*/
public class MsgHandler {
private HashMap<Integer , String> msgHashMap;
private int lastID;
/**
* Erstellt den MsgHandler mit standart Test Messages
*/
public MsgHandler(){
msgHashMap = new HashMap<Integer, String>();
addMsg("Hallo");
addMsg("Wie");
addMsg("Geht");
addMsg("Es");
addMsg("Dir?");
}
/**
* Ermitelt die nächste freie Id
* @return Next ID
*/
private int nextId(){
return this.lastID + 1;
}
/**
* Msg hinzufügen
* @param msg Message Text
*/
public int addMsg(String msg){
int id = nextId();
msgHashMap.put(id, msg);
this.lastID = id;
return id;
}
/**
* Msg löschen
* @param id Message Id
*/
public String delMsg(int id){
return msgHashMap.remove(id);
}
/**
* Msg bearbeiten
* @param id Message Id
* @param msg Message Text
*/
public String editMsg(int id, String msg){
return msgHashMap.replace(id, msg);
}
/**
* Msg als Objekt holen
* @param id Message Id
* @return Message als Msg Objekt
*/
public Msg getMsg(int id){
return new Msg(id, msgHashMap.get(id));
}
/**
* Alle Nachrichten werden in den Format Key, Value besorgt
* bsp: key: 1 value: Nachricht
* @return Alle nachrichten in einem String
*/
public String getAllMsg(){
String returnStr = "";
// Print keys and values
for (Integer i : msgHashMap.keySet()) {
String item = "key: " + i + " value: " + msgHashMap.get(i) + "\n";
returnStr += item;
}
System.out.println(returnStr);
return returnStr;
}
}

View File

@ -65,10 +65,13 @@ public class Request {
headers.add(header); headers.add(header);
} }
int authIndex = headers.toString().indexOf("Authorization"); int authIndex = headers.toString().indexOf("Authorization: Basic");
String authString = headers.toString().substring(authIndex + 21); String authString = headers.toString().substring(authIndex + 21);
System.out.println("AUTH STRING: " + authString);
int authIndexEnd = authString.indexOf(','); int authIndexEnd = authString.indexOf(',');
System.out.println("INDEX OF: " + authIndexEnd);
authString = authString.substring(0, authIndexEnd); authString = authString.substring(0, authIndexEnd);
System.out.println("AUTH STRING: " + authString);
this.authString = authString; this.authString = authString;

View File

@ -3,7 +3,7 @@ package at.reisinger.server.objects;
import at.reisinger.*; import at.reisinger.*;
import at.reisinger.Package; import at.reisinger.Package;
import at.reisinger.server.helper.JsonHelper; import at.reisinger.server.helper.JsonHelper;
import at.reisinger.server.msg.MsgHandler; import at.reisinger.server.helper.PostgresHelper;
import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference; import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
@ -47,10 +47,13 @@ public class Response {
this.cmd = cmd; this.cmd = cmd;
this.out = out; this.out = out;
this.payload = payload; this.payload = payload;
System.out.println(cmd);
if (this.url != null) { if (this.url != null) {
if (this.cmd.equals("GET")) { if (this.cmd.equals("GET")) {
getMethodes(); if(login()) {
getMethodes();
}else{
sendError("401");
}
}else if (this.cmd.equals("POST")){ }else if (this.cmd.equals("POST")){
try { try {
postMethodes(); postMethodes();
@ -58,18 +61,88 @@ public class Response {
e.printStackTrace(); e.printStackTrace();
} }
}else if (this.cmd.equals("PUT")){ }else if (this.cmd.equals("PUT")){
putMethodes(); if(login()) {
putMethodes();
}else{
sendError("401");
}
}else if (this.cmd.equals("DELETE")){ }else if (this.cmd.equals("DELETE")){
deleteMethodes(); if(login()) {
deleteMethodes();
}else{
sendError("401");
}
}else{ }else{
sendError("405"); sendError("405");
} }
} }
} }
/**
* Alle Get Methoden
* Nur für angemeldete user erreichbar
*/
private void getMethodes(){ private void getMethodes(){
if (this.url.startsWith("/messages")) { if (this.url.startsWith("/users")) {
} else if (this.url.startsWith("/")) { String username = this.url.substring(this.url.lastIndexOf('/') + 1);
System.out.println("Username in /users/{username}: " + username);
User user = null;
try {
user = new DBConnection().getUser(username);
} catch (SQLException throwables) {
throwables.printStackTrace();
sendError("401");
}
if (user != null){
String userJson = JsonHelper.userToJson(user);
if(userJson != null && !userJson.isEmpty()){
sendResponse(userJson, "200");
}
}else{
sendError("500");
}
} else if (this.url.startsWith("/cards")) {
String username = basicAuthGetUsername(this.authString);
Cards allCards = new DBConnection().getCards(username);
String jsonCards = JsonHelper.objToJson(allCards);
if (jsonCards != null && !jsonCards.isEmpty()){
sendResponse(jsonCards, "200");
}else{
sendError("500");
}
}else if(this.url.startsWith("/deck")) {
String format = this.url.substring(this.url.lastIndexOf('?') + 1);
System.out.println("Format in /deck?{format=plain}: " + format);
String username = basicAuthGetUsername(this.authString);
ArrayList<String> allCards = new DBConnection().getDeck(username);
Cards deck = null;
Object tmp = null;
if(format.startsWith("format=plain")){
tmp = allCards;
}else{
deck = new DBConnection().getCardsFromIDList(allCards);
tmp = deck;
}
String jsonCards = JsonHelper.objToJson(tmp);
if (jsonCards != null && !jsonCards.isEmpty()) {
sendResponse(jsonCards, "200");
} else {
sendError("500");
}
}else if(this.url.startsWith("/tradings")) {
ArrayList<TradingDeal> allDeals = new DBConnection().getAllTradingDeals();
if(allDeals != null && !allDeals.isEmpty()){
String json = JsonHelper.objToJson(allDeals);
if(json != null && json != ""){
sendResponse(json, "200");
}else{
sendError("500");
}
}else{
sendError("500");
}
}else{
sendError("204");
} }
} }
@ -96,10 +169,8 @@ public class Response {
*/ */
private String basicAuthBase64(String username, String password){ private String basicAuthBase64(String username, String password){
String authString = username + ":" + password; String authString = username + ":" + password;
//System.out.println("auth string: " + authString);
byte[] authEncBytes = Base64.getEncoder().encode(authString.getBytes()); byte[] authEncBytes = Base64.getEncoder().encode(authString.getBytes());
String authStringEnc = new String(authEncBytes); String authStringEnc = new String(authEncBytes);
//System.out.println("Base64 encoded auth string: " + authStringEnc);
return authStringEnc; return authStringEnc;
} }
@ -110,13 +181,10 @@ public class Response {
*/ */
private String basicAuthGetUsername(String authString) { private String basicAuthGetUsername(String authString) {
String[] values; String[] values;
System.out.println("auth To username");
if (authString != null) { if (authString != null) {
byte[] credDecoded = Base64.getDecoder().decode(authString); byte[] credDecoded = Base64.getDecoder().decode(authString);
String credentials = new String(credDecoded); String credentials = new String(credDecoded);
values = credentials.split(":", 2); values = credentials.split(":", 2);
System.out.println("credentials: ");
System.out.println(values[0]);
}else{ }else{
values = null; values = null;
} }
@ -125,36 +193,30 @@ public class Response {
/** /**
* Alle Post Methoden, siehe API beschreibung für genauere details * Alle Post Methoden, siehe API beschreibung für genauere details
*
* Kann auch von nicht angemeldeten usern erreicht werden.
* login() wird hier verwendet
* @throws JsonProcessingException Fehler beim de-/serialisieren * @throws JsonProcessingException Fehler beim de-/serialisieren
*/ */
private void postMethodes() throws JsonProcessingException { private void postMethodes() throws JsonProcessingException {
if (this.url.startsWith("/users")) { if (this.url.startsWith("/users")) {
Map<String, Object> map = JsonHelper.jsonPayload2ToMap(this.payload); Map<String, Object> map = JsonHelper.jsonPayloadToMap(this.payload);
String username = (String) map.get("Username"); String username = (String) map.get("Username");
String password = (String) map.get("Password"); String password = (String) map.get("Password");
User newUser = new User(new Credentials(username, password), username, username, "not implemented", new Coins(20)); User newUser = new User(new Credentials(username, password), username, username, "not implemented", new Coins(20), "BIO", "IMAGE");
System.out.println("CON DB"); System.out.println("CON DB");
DBConnection con = new DBConnection(); DBConnection con = new DBConnection();
if(!con.addUser(username, password, username, "not implemented")){ if(!con.addUser(newUser.getCredentials().getUsername(), newUser.getCredentials().getPasswort(), newUser.getCredentials().getUsername(), newUser.getEmail(), newUser.getBio(), newUser.getImage())){
sendError("409"); sendError("409");
} }
String userJson = JsonHelper.userToJson(newUser);;
//User to json if(userJson != null) {
ObjectMapper objectMapper = new ObjectMapper();
objectMapper = new ObjectMapper();
String userJson = "";
if(newUser != null) {
try {
userJson += objectMapper.writeValueAsString(newUser);
} catch (JsonProcessingException e) {
userJson = "Error: JsonProcessingException -> " + e.getMessage();
}
sendResponse(userJson, "201"); sendResponse(userJson, "201");
}else{ }else{
sendError("500"); sendError("500");
} }
}else if (this.url.startsWith("/sessions")) { }else if (this.url.startsWith("/sessions")) {
Map<String, Object> map = JsonHelper.jsonPayload2ToMap(this.payload); Map<String, Object> map = JsonHelper.jsonPayloadToMap(this.payload);
String username = (String) map.get("Username"); String username = (String) map.get("Username");
String password = (String) map.get("Password"); String password = (String) map.get("Password");
User user = null; User user = null;
@ -173,36 +235,86 @@ public class Response {
sendError("401"); sendError("401");
} }
}else if (this.url.startsWith("/packages")) { }else if (this.url.startsWith("/packages")) {
if(basicAuth("admin", "admin", this.authString)){ if (basicAuth("admin", "istrator", this.authString)) {
ObjectMapper objectMapper = new ObjectMapper(); ObjectMapper objectMapper = new ObjectMapper();
ArrayList<Card> listCards = objectMapper.readValue(this.payload, new TypeReference<ArrayList<Card>>(){}); ArrayList<Card> listCards = objectMapper.readValue(this.payload, new TypeReference<ArrayList<Card>>() {
Package packageCards = new Package(new Cards(listCards), new DBConnection().nextPackageId()+"", 5); });
if(!new DBConnection().addPackage(packageCards)){ Package packageCards = new Package(new Cards(listCards), new DBConnection().nextPackageId() + "", 5);
if (!new DBConnection().addPackage(packageCards)) {
sendError("500"); sendError("500");
}else{ } else {
String packageJson = JsonHelper.packageToJson(packageCards); String packageJson = JsonHelper.objToJson(packageCards);
if(packageJson != null) { if (packageJson != null) {
sendResponse(packageJson, "201"); sendResponse(packageJson, "201");
}else{ } else {
sendError("500"); sendError("500");
} }
} }
} else {
sendError("401");
}
}else if (this.url.startsWith("/transactions/packages")) {
if (login()) {
DBConnection db = new DBConnection();
Package newPackage = db.userAcquirePackage(basicAuthGetUsername(this.authString));
if (newPackage == null) {
sendError("500");
} else {
String packageJson = JsonHelper.objToJson(newPackage);
if (packageJson == null) {
sendError("500");
} else {
sendResponse(packageJson, "200");
}
}
}else{ }else{
sendError("401"); sendError("401");
} }
}else if (this.url.startsWith("/transactions/packages")) { }else if (this.url.startsWith("/tradings")) {
if(login()){ if(login()){
DBConnection db = new DBConnection(); Map<String, Object> map = JsonHelper.jsonPayloadToMap(this.payload);
Package newPackage = db.userAcquirePackage(basicAuthGetUsername(this.authString)); String id = (String)map.get("Id");
if (newPackage == null){ String cardtotrade = (String)map.get("CardToTrade");
sendError("500"); String type = (String)map.get("Type");
}else{ double mindamage = Double.parseDouble(map.get("MinimumDamage") + "");
String packageJson = JsonHelper.packageToJson(newPackage); String username = basicAuthGetUsername(this.authString);
if(packageJson == null){ if (username != null) {
Card cardtoTradeC = new DBConnection().getCardFromID(cardtotrade);
System.out.println("CARD TO TRAD: " + cardtoTradeC.getName());
if (cardtoTradeC != null) {
TradingDeal tradingDeal = new TradingDeal(id, cardtoTradeC, mindamage, type, username);
if (tradingDeal != null) {
String tradingJson = JsonHelper.objToJson(tradingDeal);
if (tradingDeal != null) {
ArrayList<String> deckCards = new DBConnection().getDeck(username);
if (deckCards != null) {
if (deckCards.contains(cardtotrade)) {
new DBConnection().delDeck(username);
}
if(new DBConnection().addTradingdeal(tradingDeal.getUsername(), tradingDeal.getId(), tradingDeal.getRequiredMinDamage(), tradingDeal.getRequiredCardType().name(), tradingDeal.getRequiredElementType().name(), tradingDeal.getCardToTrade().getName())){
if(new DBConnection().updateCardLock(tradingDeal.getCardToTrade().getName(), true)){
sendResponse(JsonHelper.objToJson(tradingDeal), "201");
}else{
sendError("500");
}
}else{
sendError("500");
}
} else {
sendError("500");
}
sendResponse(tradingJson, "201");
} else {
sendError("500");
}
} else {
sendError("500");
}
} else {
sendError("500"); sendError("500");
}else {
sendResponse(packageJson, "200");
} }
}else{
sendError("500");
} }
}else{ }else{
sendError("401"); sendError("401");
@ -232,20 +344,69 @@ public class Response {
} }
/** /**
* Alle Put Methoden, siehe API beschreibung für genauere details * Alle Put Methoden
* Nur für angemeldete user erreichbar
* @throws JsonProcessingException Fehler beim de-/serialisieren * @throws JsonProcessingException Fehler beim de-/serialisieren
*/ */
private void putMethodes(){ private void putMethodes(){
if (this.url.startsWith("/messages")) { if (this.url.startsWith("/users")) {
String username = this.url.substring(this.url.lastIndexOf('/') + 1);
System.out.println("Username in /users/{username}: " + username);
User user = null;
try {
user = new DBConnection().getUser(username);
} catch (SQLException throwables) {
throwables.printStackTrace();
sendError("401");
}
if(user != null) {
Map<String, Object> map = JsonHelper.jsonPayloadToMap(this.payload);
String bio = (String) map.get("Bio");
String image = (String) map.get("Image");
String name = (String) map.get("Name");
System.out.println("Request /users:");
System.out.println("Bio: " + bio + "\nImage: " + image + "\nName: " + name);
user.setBio(bio);
user.setImage(image);
user.setNachname(name);
if (new DBConnection().updateUser(username, user.getBio(), user.getImage(), user.getNachname())) {
sendResponse(JsonHelper.userToJson(user), "200");
} else {
sendError("500");
}
}else{
sendError("500");
}
}else if(this.url.startsWith("/deck")) {
List<String> deckIds = JsonHelper.jsonPayloadToList(this.payload);
if (deckIds != null){
if (new DBConnection().setDeck(basicAuthGetUsername(this.authString), deckIds)){
Cards deck = new DBConnection().getCardsFromIDList(deckIds);
String deckJson = JsonHelper.objToJson(deck);
if (deck != null && deckJson != null){
sendResponse(deckJson, "200");
}else {
sendError("500");
}
}else {
sendError("500");
}
}else{
sendError("500");
}
} }
} }
/** /**
* Alle Delete Methoden, siehe API beschreibung für genauere details * Alle Delete Methoden, siehe API beschreibung für genauere details
* Nur für angemeldete user erreichbar
* @throws JsonProcessingException Fehler beim de-/serialisieren * @throws JsonProcessingException Fehler beim de-/serialisieren
*/ */
private void deleteMethodes(){ private void deleteMethodes(){
if (this.url.startsWith("/messages")) { if (this.url.startsWith("/messages")) {
} }
} }

View File

@ -52,12 +52,12 @@ public class CardsTest {
@Test @Test
void test_contains() { void test_contains() {
assertTrue(cards2.containsCard(card)); assertTrue(cards2.containsCard(card.getName()));
} }
@Test @Test
void test_contains2() { void test_contains2() {
assertFalse(cards.containsCard(newCard)); assertFalse(cards.containsCard(newCard.getName()));
} }
@Test @Test

View File

@ -36,18 +36,18 @@ public class StoreTest {
Coins coins = new Coins(10); Coins coins = new Coins(10);
//at.reisinger.User //at.reisinger.User
Credentials credentials = new Credentials("username", "passwort"); Credentials credentials = new Credentials("username", "passwort");
user = new User(credentials, "name", "nachname", "email", coins); user = new User(credentials, "name", "nachname", "email", coins, "BIO", "IMAGE");
userNew = new User(credentials, "nameNew", "nachnameNew", "emailNew", coins); userNew = new User(credentials, "nameNew", "nachnameNew", "emailNew", coins, "BIO", "IMAGE");
//Trading Deal //Trading Deal
Card cardToTrade = card; Card cardToTrade = card;
ElementTyp requiredElementType = ElementTyp.FIRE; ElementTyp requiredElementType = ElementTyp.FIRE;
double requiredMinDamage = 100; double requiredMinDamage = 100;
CardType requiredCardType = CardType.MONSTER; CardType requiredCardType = CardType.MONSTER;
tradingDeal = new TradingDeal(user, cardToTrade, requiredElementType, requiredMinDamage, requiredCardType); tradingDeal = new TradingDeal("ID", cardToTrade, requiredElementType, requiredMinDamage, requiredCardType, "NAME");
} }
/*
@Test @Test
void test_addTradingDeal() { void test_addTradingDeal() {
@ -66,7 +66,7 @@ public class StoreTest {
stackArrList.add(c5); stackArrList.add(c5);
Cards deck = new Cards(deckArrList); Cards deck = new Cards(deckArrList);
Cards stack = new Cards(stackArrList); Cards stack = new Cards(stackArrList);
User user = new User(new Credentials("username", "passwort"), "Name", "Nachname", "Email", new Coins(1000)); User user = new User(new Credentials("username", "passwort"), "Name", "Nachname", "Email", new Coins(1000), "BIO", "IMAGE");
ArrayList<TradingDeal> tradingDeals = new ArrayList<TradingDeal>(); ArrayList<TradingDeal> tradingDeals = new ArrayList<TradingDeal>();
ArrayList<Package> packages = new ArrayList<at.reisinger.Package>(); ArrayList<Package> packages = new ArrayList<at.reisinger.Package>();
tradingDeals.add(new TradingDeal(user, c1, ElementTyp.FIRE, 10, CardType.MONSTER)); tradingDeals.add(new TradingDeal(user, c1, ElementTyp.FIRE, 10, CardType.MONSTER));
@ -108,7 +108,7 @@ public class StoreTest {
stackArrList.add(c5); stackArrList.add(c5);
Cards deck = new Cards(deckArrList); Cards deck = new Cards(deckArrList);
Cards stack = new Cards(stackArrList); Cards stack = new Cards(stackArrList);
User user = new User(new Credentials("username", "passwort"), "Name", "Nachname", "Email", new Coins(1000)); User user = new User(new Credentials("username", "passwort"), "Name", "Nachname", "Email", new Coins(1000), "BIO", "IMAGE");
ArrayList<TradingDeal> tradingDeals = new ArrayList<TradingDeal>(); ArrayList<TradingDeal> tradingDeals = new ArrayList<TradingDeal>();
ArrayList<at.reisinger.Package> packages = new ArrayList<at.reisinger.Package>(); ArrayList<at.reisinger.Package> packages = new ArrayList<at.reisinger.Package>();
tradingDeals.add(new TradingDeal(user, c1, ElementTyp.FIRE, 10, CardType.MONSTER)); tradingDeals.add(new TradingDeal(user, c1, ElementTyp.FIRE, 10, CardType.MONSTER));
@ -136,10 +136,12 @@ public class StoreTest {
stackArrList.add(c5); stackArrList.add(c5);
Cards deck = new Cards(deckArrList); Cards deck = new Cards(deckArrList);
Cards stack = new Cards(stackArrList); Cards stack = new Cards(stackArrList);
TradingDeal vonDB = new TradingDeal(new User(new Credentials("username", "passwort"), "DerName", "Nachname", "Email", new Coins(1000)), c1, ElementTyp.FIRE, 10, CardType.SPELL); TradingDeal vonDB = new TradingDeal(new User(new Credentials("username", "passwort"), "DerName", "Nachname", "Email", new Coins(1000), "BIO", "IMAGE"), c1, ElementTyp.FIRE, 10, CardType.SPELL);
expected.add(vonDB); expected.add(vonDB);
System.out.println(result.get(0).getCardToTrade().getName()); System.out.println(result.get(0).getCardToTrade().getName());
System.out.println(expected.get(0).getCardToTrade().getName()); System.out.println(expected.get(0).getCardToTrade().getName());
assertTrue(result.get(0).getCardToTrade().equals(expected.get(0).getCardToTrade())); assertTrue(result.get(0).getCardToTrade().equals(expected.get(0).getCardToTrade()));
} }
*/
} }

View File

@ -36,15 +36,15 @@ public class TradingDealTest {
//at.reisinger.User //at.reisinger.User
Credentials credentials = new Credentials("username", "passwort"); Credentials credentials = new Credentials("username", "passwort");
Credentials newCredentials = new Credentials("usernamenew", "passwortnew"); Credentials newCredentials = new Credentials("usernamenew", "passwortnew");
user = new User(credentials, "name", "nachname", "email", coins); user = new User(credentials, "name", "nachname", "email", coins, "BIO", "IMAGE");
userNew = new User(newCredentials, "nameNew", "nachnameNew", "emailNew", coins); userNew = new User(newCredentials, "nameNew", "nachnameNew", "emailNew", coins, "BIO", "IMAGE");
//Trading Deal //Trading Deal
Card cardToTrade = card; Card cardToTrade = card;
ElementTyp requiredElementType = ElementTyp.FIRE; ElementTyp requiredElementType = ElementTyp.FIRE;
double requiredMinDamage = 100; double requiredMinDamage = 100;
CardType requiredCardType = CardType.MONSTER; CardType requiredCardType = CardType.MONSTER;
tradingDeal = new TradingDeal(user, cardToTrade, requiredElementType, requiredMinDamage, requiredCardType); tradingDeal = new TradingDeal("ID", cardToTrade, requiredElementType, requiredMinDamage, requiredCardType, "NAME");
} }
/* /*

View File

@ -38,7 +38,7 @@ public class UserTest {
Coins coins = new Coins(10); Coins coins = new Coins(10);
//at.reisinger.User //at.reisinger.User
Credentials credentials = new Credentials("username", "pw"); Credentials credentials = new Credentials("username", "pw");
user = new User(credentials, "name", "nachname", "email", coins); user = new User(credentials, "name", "nachname", "email", coins, "BIO", "IMAGE");
} }
@Test @Test
public void test_getName() { public void test_getName() {