@ -12,69 +12,67 @@ include_once (ROOT_PATH.'/include/defines.inc.php');
defineIfNotDefined('NORMALKAMPF', 1);
defineIfNotDefined('CLANKAMPF', 2);
//Anzahl der Typen die in einem Kampf erlaubt sind
//TODO: sollte überprüft werden, welche typen es eigentlich ingame noch gibt
defineIfNotDefined('KAMPF_SSJ', 1); // SSJ ist eine Art technik die werte mal setzt
defineIfNotDefined('KAMPF_TAUSCH', 1); // Tausch ist eine Art technik die alle werte vertauscht gegner und sich selbst
defineIfNotDefined('KAMPF_HP', 2); // HP ist eine technik die es erlaubt sich zu Heilen
defineIfNotDefined('KAMPF_HPMP', 1); // HPMP ist eine art die HP+MP erhoeht
defineIfNotDefined('KAMPF_SPIRIT', 1); // spirit ist was mit spirit stones
defineIfNotDefined('KAMPF_LOSE', 1); // Lose ist wie Kaioken nur das man werte verliert
defineIfNotDefined('KAMPF_KAIOKEN', 1); // Kaioken ist eine technik die werte gibt
defineIfNotDefined('KAMPF_SUMMON', 1); // spirit2 ist was mit spirit stones
defineIfNotDefined('KAMPF_GIFT', 1); // Lose ist wie Kaioken nur das man werte verliert
defineIfNotDefined('KAMPF_SCHATTEN', 2); // Kaioken ist eine technik die werte gibt
defineIfNotDefined('KAMPF_COPY', 1); // Man Trasfert werte.
defineIfNotDefined('KAMPF_KAIOKEN2', 1); // Man Bekommt sau viel staerke fuer 1runde
defineIfNotDefined('KAMPF_LOSE2', 1); // MP Wegmachen
defineIfNotDefined('KAMPF_MAJIN', 1); // Jemnand als majin machen.
defineIfNotDefined('KAMPF_KONTERHEAL', 2); // Eine Heal-Attacke kontern.
defineIfNotDefined('KAMPF_TAUSCH2', 3); // Attacke Kopieren.
defineIfNotDefined('KAMPF_FRUCHT', 1);
function getCharAttackSet($char_id, $type) {
$qry = null;
// default values (in case the data is not or partially set)
for ($i = 1; $i < 11 ; $ i + + ) {
$set[$i] = -1;
}
//Anzahl der Runden pro Kampf
defineIfNotDefined('KAMPF_RUNDEN', 10);
if(is_numeric($char_id)) {
$qry = mysql_query('SELECT attack_id, round FROM attackenset WHERE char_id = '.$char_id.' AND type = '.$type);
function createAttackSet($char_id, $type) {
if(!is_numeric($char_id) || !is_numeric($type)) {
return false;
}
while ($result = mysql_fetch_assoc($qry)) {
$set[$result['round']] = $result['attack_id'];
for($i = 1; $i < KAMPF_RUNDEN + 1 ; $ i + + ) {
$values .= '('.$char_id.',-1,'.$type.','.$i.')';
if($i < 10 ) {
$values .= ',';
}
}
return $set;
$qry = 'INSERT INTO attackenset VALUES '.$values.';';
return mysql_query($qry);
}
function updateCharAttack($char_id, $att_id,$round, $type) {
$qry = 'UPDATE attackenset SET attack_id = '.$att_id.' WHERE char_id = '.$char_id.' AND type = '.$type.' AND round = '.$round.';';
mysql_query($qry);
function deleteAttackSet($char_id, $type) {
if(!is_numeric($char_id) || !is_numeric($type)) {
return false;
}
$qry = 'DELETE FROM attackenset WHERE char_id = '.$char_id.' AND type = '.$type.';';
return mysql_query($qry);
}
function createCharAttack($char_id, $att_id,$round, $type) {
$qry = 'INSERT INTO attackenset VALUES('.$char_id.','.$att_id.','.$type.','.$round.');';
mysql_query($qry);
function getAttackSet($char_id, $type) {
if(!is_numeric($char_id) || !is_numeric($type)) {
return false;
}
$qry = mysql_query('SELECT attack_id, round FROM attackenset WHERE char_id = '.$char_id.' AND type = '.$type);
while ($result = mysql_fetch_assoc($qry)) {
$set[$result['round']] = $result['attack_id'];
}
return $set;
}
function updateCharAttackSet($char_id, $set, $type) {
$old_set = getCharAttackSet($char_id, $type);
function updateAttackSet($char_id, $type, $newSet) {
if(!is_numeric($char_id) || !is_numeric($type) || !is_array($newSet) || count($newSet) == 0) {
return false;
}
$oldset = getAttackSet($char_id, $type);
for ($i = 1; $i < count ( $ set ) + 1 ; $ i + + ) {
if($old_set[$i] < 0 & & $ set [ $ i ] > 0) {
//insert new value
createCharAttack($char_id, $set[$i], $i, $type);
} elseif($old_set > 0 & & $set[$i] != $old_set[$i]) {
//update old value
updateCharAttack($char_id,$set[$i], $i, $type);
for ($i = 1; $i < KAMPF_RUNDEN + 1 ; $ i + + ) {
if($oldset[$i] != $newSet[$i]) {
$qry = 'UPDATE attackenset SET attack_id = '.$newSet[$i].' WHERE char_id = '.$char_id.' AND type = '.$type.' AND round = '.$i.';';
mysql_query($qry);
}
}
return true;
}
function getAttackNamesFromAttackSet($attset) {
$qry = mysql_query('SELECT l.id,a.name FROM attacken a INNER JOIN lernen l ON a.id=l.at_id WHERE l.id in ('.implode(',', $attset).');');
function getAttackNames($attackSet) {
if(!is_array($attackSet) || count($attackSet) == 0) {
return array();
}
$qry = mysql_query('SELECT l.id,a.name FROM attacken a INNER JOIN lernen l ON a.id=l.at_id WHERE l.id in ('.implode(',', $attackSet).');');
while ($result = mysql_fetch_assoc($qry)) {
$set[$result['id']] = $result['name'];
@ -83,121 +81,64 @@ function getAttackNamesFromAttackSet($attset) {
return $set;
}
function getAttackTypesFromAttackSet($atts et) {
if($attset == NULL || count($atts et) == 0) {
function getAttackTypes($attackS et) {
if(!is_array($attackSet) || count($attackS et) == 0) {
return array();
}
$qry = mysql_query('SELECT l.id,a.type FROM attacken a INNER JOIN lernen l ON a.id=l.at_id WHERE l.id in ('.implode(',', $atts et).');');
$qry = mysql_query('SELECT l.id,a.type,a.options FROM attacken a INNER JOIN lernen l ON a.id=l.at_id WHERE l.id in ('.implode(',', $attackS et).');');
while ($result = mysql_fetch_assoc($qry)) {
$set[$result['id']] = $result['type'];
if($result['type'] == 'generic') {
$options = json_decode($result['options'], true);
$set[$result['id']] = $options['type'];
} else {
$set[$result['id']] = $result['type'];
}
}
return $set;
}
function validateAttackSetTypes($attset) {
//the attset is empty or wasn't even initialised
if($attset == NULL || count($attset) == 0) {
return NULL;
function validateAttackSet($attackSet) {
if(!is_array($attackSet) || count($attackSet) == 0) {
return 'Invalides Attackenset!';
}
//lets check for id's other then -1 (if every id is -1, it means the array is empty!)
$hit = false;
for($i = 1; $i < count ( $ attset ) ; $ i + + ) {
if($attset[$i] != -1) {
$hit = true;
$types = getAttackTypes($attackSet);
//attackentypen im set zählen
$data = array();
for($i = 1; $i < 11 ; $ i + + ) {
if(is_string($types[$attackSet[$i]])) {
$data[$types[$attackSet[$i]]] += 1;
}
}
if(!$hit) {
return NULL;
}
$types = getAttackTypesFromAttackSet($attset);
if(count($types)==0) {
return 'Es wurden garkeine Attacken ausgewählt!';
//Alle Attackentypen auslesen
$qry = mysql_query('SELECT name, anzahl, kategorie FROM attackentyp;');
$types = array();
while ($row = mysql_fetch_assoc($qry)) {
$types[$row['name']] = array('anzahl' => $row['anzahl'], 'kategorie' => $row['kategorie']);
}
foreach ($attset as $att_id) {
if($types[$att_id] == "tausch") { $kampf_tausch_n++;
}elseif($types[$att_id] == "SSJ") { $kampf_ssj_n++;
}elseif($types[$att_id] == "hpmp") { $kampf_hpmp_n++;
}elseif($types[$att_id] == "hp") { $kampf_hp_n++;
}elseif($types[$att_id] == "lose") { $kampf_lose_n++;
}elseif($types[$att_id] == "kaioken") { $kampf_kaioken_n++;
}elseif($types[$att_id] == "summon") { $kampf_summon_n++;
}elseif($types[$att_id] == "gift") { $kampf_gift_n++;
}elseif($types[$att_id] == "schatten") { $kampf_schatten_n++;
}elseif($types[$att_id] == "copy") { $kampf_copy_n++;
}elseif($types[$att_id] == "kaioken2") { $kampf_kaioken2_n++;
}elseif($types[$att_id] == "lose2") { $kampf_lose2_n++;
}elseif($types[$att_id] == "majin") { $kampf_majin_n++;
}elseif($types[$att_id] == "tausch2") { $kampf_tausch2_n++;
}elseif($types[$att_id] == "frucht") { $kampf_frucht_n++;
}elseif($types[$att_id] == "konterhp") { $kampf_konterheal_n++;
}
if($kampf_copy_n > KAMPF_COPY) {
return "Fehler die Technik vom type: Copy darf nur ".KAMPF_COPY." mal benutzt werden.";
}
if($kampf_kaioken2_n > KAMPF_KAIOKEN2) {
return "Fehler die Technik vom type: Kaiaoken2 darf nur ".KAMPF_KAIOKEN2." mal benutzt werden.";
}
if($kampf_lose2_n > KAMPF_LOSE2) {
return "Fehler die Technik vom type: lose2 darf nur ".KAMPF_LOSE2." mal benutzt werden.";
}
if($kampf_majin_n > KAMPF_MAJIN) {
return "Fehler die Technik vom type: Majin darf nur ".KAMPF_MAJIN." mal benutzt werden.";
}
if($kampf_tausch2_n > KAMPF_TAUSCH2) {
return "Fehler die Technik vom type: Tausch darf nur ".KAMPF_TAUSCH2." mal benutzt werden.";
}
if($kampf_summon_n > KAMPF_SUMMON) {
return "Fehler die Technik vom type: Summon darf nur ".KAMPF_SUMMON." mal benutzt werden.";
}
if($kampf_gift_n > KAMPF_GIFT) {
return "Fehler die Technik vom type: Gift darf nur ".KAMPF_GIFT." mal benutzt werden.";
}
if($kampf_schatten_n > KAMPF_SCHATTEN) {
return "Fehler die Technik vom type: Schatten darf nur ".KAMPF_SCHATTEN." mal benutzt werden.";
}
if($kampf_ssj_n AND $kampf_kaioken_n) {
return "Fehler sie dü rfen Techniken vom Type SSJ und Kaioken nicht zusammen nutzen.";
}
if($kampf_tausch_n > KAMPF_TAUSCH) {
return "Fehler die Technik vom type: Kampf darf nur ".KAMPF_TAUSCH." mal benutzt werden.";
}
if($kampf_ssj_n > KAMPF_SSJ) {
return "Fehler die Technik vom type: SSJ darf nur ".KAMPF_SSJ." mal benutzt werden.";
}
if($kampf_hp_n > KAMPF_HP) {
return "Fehler die Technik vom type: HP darf nur ".KAMPF_HP." mal benutzt werden.";
}
if($kampf_hpmp_n > KAMPF_HPMP) {
return "Fehler die Technik vom type: HPMP darf nur ".KAMPF_HPMP." mal benutzt werden.";
}
if($kampf_sprit_n > KAMPF_SPIRIT) {
return "Fehler die Technik vom type:Sprit darf nur ".KAMPF_SPIRIT." mal benutzt werden.";
}
if($kampf_sprit2_n > $kampf_sprit2) {
return "Fehler die Technik vom type: Sprit2 darf nur ".$kampf_sprit2." mal benutzt werden.";
}
if($kampf_lose_n > KAMPF_LOSE) {
return "Fehler die Technik vom type: Lose darf nur ".KAMPF_LOSE." mal benutzt werden.";
}
if($kampf_kaioken_n > KAMPF_KAIOKEN) {
return "Fehler die Technik vom type: Kaiaoken darf nur ".KAMPF_KAIOKEN." mal benutzt werden.";
}
if($kampf_frucht_n > KAMPF_FRUCHT) {
return 'Fehler die Technik vom type: frucht darf nur '.KAMPF_FRUCHT.' mal benutzt werden!';
}
if($kampf_konterheal_n > KAMPF_KONTERHEAL) {
return 'Fehler die Technik vom type: Konterheal darf nur '.KAMPF_KONTERHEAL.' mal benutzt werden!';
}
if($kampf_hp_n >= 1 AND $kampf_hpmp_n >= 1) {
return 'Fehler die Technik vom type: HP darf nicht zusammen mit der Technik vom type: HPMP benutzt werden!';
//hier passieren mehrere sachen, erst wird geschaut ob die anzahl die max. anzahl übersteigt
//danach wird die kategorie ausgewertet indem geschaut wird ob in dem kategorie array mehr als 1 eintrag sind
$kategorie = array();
foreach ($data as $row => $key) {
if($types[$row]['anzahl'] < $key) {
return 'Fehler die Technik vom type '.$row.' darf nur '.$types[$row]['anzahl'].' mal benutzt werden.';
} else {
if(is_string($types[$row]['kategorie'])) {
if($kategorie[$types[$row]['kategorie']] == null) {
$kategorie[$types[$row]['kategorie']] = array($row);
} else {
$kategorie[$types[$row]['kategorie']][] = $row;
}
if(count($kategorie[$types[$row]['kategorie']])> 1) {
return 'Fehler sie dü rfen Techniken vom Type '.$kategorie[$types[$row]['kategorie']][0].' und '.$kategorie[$types[$row]['kategorie']][1].' nicht zusammen nutzen.';
}
}
}
}
return NULL;
}
?>