mirror of
https://github.com/Relintai/mourne_rcpp_fw.git
synced 2025-01-21 16:57:16 +01:00
241 lines
6.2 KiB
PHP
241 lines
6.2 KiB
PHP
|
<?php
|
||
|
class Spell_model extends MO_Model
|
||
|
{
|
||
|
function __construct()
|
||
|
{
|
||
|
parent::__construct();
|
||
|
}
|
||
|
|
||
|
function use_spell($spellid, $slotid, $res, $villageid)
|
||
|
{
|
||
|
$this->resources = $res;
|
||
|
|
||
|
//getting spell
|
||
|
$sql = "SELECT spells.*,building_spell_cooldowns.cooldown_end
|
||
|
FROM building_spells
|
||
|
LEFT JOIN spells ON building_spells.spellid=spells.id
|
||
|
LEFT JOIN building_spell_cooldowns
|
||
|
ON (building_spells.spellid=building_spell_cooldowns.spellid
|
||
|
AND building_spell_cooldowns.slotid='$slotid'
|
||
|
AND building_spell_cooldowns.villageid='$villageid')
|
||
|
WHERE building_spells.villageid='$villageid'
|
||
|
AND building_spells.slotid='$slotid'
|
||
|
AND building_spells.spellid='$spellid'";
|
||
|
|
||
|
$q = $this->db->query($sql);
|
||
|
|
||
|
if (!$q->num_rows())
|
||
|
return 1;
|
||
|
|
||
|
$spell = $q->row_array();
|
||
|
|
||
|
if ($spell['cooldown_end'])
|
||
|
return 2;
|
||
|
|
||
|
if (!$this->check_resources($res, $spell))
|
||
|
return 3;
|
||
|
|
||
|
//everything is fine
|
||
|
//substracting cost
|
||
|
$this->substract_resources($spell, $villageid);
|
||
|
|
||
|
//addign modofiers
|
||
|
$this->add_modifiers($spell['id'], $villageid, 'spell');
|
||
|
|
||
|
$this->write_resources();
|
||
|
|
||
|
if ($spell['weather_change_to'])
|
||
|
{
|
||
|
$sql = "UPDATE villages
|
||
|
SET weather_change_to='" . $spell['weather_change_to'] . "'
|
||
|
WHERE id='$villageid'";
|
||
|
|
||
|
$this->db->query($sql);
|
||
|
}
|
||
|
|
||
|
//do spelleffects here
|
||
|
|
||
|
|
||
|
//adding cooldown
|
||
|
$cd = $spell['cooldown'] + time();
|
||
|
|
||
|
$sql = "INSERT INTO building_spell_cooldowns
|
||
|
VALUES(default, '$villageid', '$slotid',
|
||
|
'" . $spell['id'] . "', '$cd')";
|
||
|
$this->db->query($sql);
|
||
|
|
||
|
//adding spell_effect_end to events
|
||
|
$ev['type'] = 3;
|
||
|
$ev['villageid'] = $villageid;
|
||
|
$ev['slotid'] = $slotid;
|
||
|
$ev['time'] = $spell['duration'];
|
||
|
$ev['data1'] = $spell['id'];
|
||
|
|
||
|
$this->add_event($ev);
|
||
|
}
|
||
|
|
||
|
function get_spells($slotid, $villageid)
|
||
|
{
|
||
|
$this->update_spells($slotid, $villageid);
|
||
|
|
||
|
$sql = "SELECT spells.*,building_spell_cooldowns.cooldown_end
|
||
|
FROM building_spells
|
||
|
LEFT JOIN spells ON building_spells.spellid=spells.id
|
||
|
LEFT JOIN building_spell_cooldowns
|
||
|
ON (building_spells.spellid=building_spell_cooldowns.spellid
|
||
|
AND building_spell_cooldowns.slotid='$slotid'
|
||
|
AND building_spell_cooldowns.villageid='$villageid')
|
||
|
WHERE building_spells.villageid='$villageid'
|
||
|
AND building_spells.slotid='$slotid'";
|
||
|
|
||
|
$q = $this->db->query($sql);
|
||
|
|
||
|
return $q->result_array();
|
||
|
}
|
||
|
|
||
|
function update_spells($slotid, $villageid)
|
||
|
{
|
||
|
$sql = "SELECT * FROM building_spell_cooldowns
|
||
|
WHERE slotid='$slotid'
|
||
|
AND villageid='$villageid'";
|
||
|
|
||
|
$q = $this->db->query($sql);
|
||
|
|
||
|
if (!$q->num_rows())
|
||
|
return;
|
||
|
|
||
|
$spells = $q->result_array();
|
||
|
$time = time();
|
||
|
|
||
|
foreach ($spells as $row)
|
||
|
{
|
||
|
if ($row['cooldown_end'] <= $time)
|
||
|
{
|
||
|
$sql = "DELETE FROM building_spell_cooldowns
|
||
|
WHERE id='" . $row['id'] . "'";
|
||
|
$this->db->query($sql);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function get_spell_mod_drop_admin()
|
||
|
{
|
||
|
//STUB
|
||
|
$data = array('0' => 'Nothing');
|
||
|
return $data;
|
||
|
}
|
||
|
|
||
|
function list_spells_admin()
|
||
|
{
|
||
|
$sql = "SELECT * FROM spells";
|
||
|
$q = $this->db->query($sql);
|
||
|
|
||
|
return $q->result_array();
|
||
|
}
|
||
|
|
||
|
function get_spell_list_drop_admin()
|
||
|
{
|
||
|
$sql = "SELECT * FROM spells";
|
||
|
$q = $this->db->query($sql);
|
||
|
$res = $q->result_array();
|
||
|
|
||
|
$data[0] = 'No Spell';
|
||
|
|
||
|
foreach ($res as $row)
|
||
|
{
|
||
|
$data[$row['id']] = $row['description_admin'];
|
||
|
}
|
||
|
|
||
|
return $data;
|
||
|
}
|
||
|
|
||
|
function get_spell_admin($id)
|
||
|
{
|
||
|
$sql = "SELECT * FROM spells WHERE id='$id'";
|
||
|
$q = $this->db->query($sql);
|
||
|
|
||
|
return $q->row_array();
|
||
|
}
|
||
|
|
||
|
function edit_spell_admin($data)
|
||
|
{
|
||
|
|
||
|
$sql = "UPDATE spells
|
||
|
SET effect='" . $data['effect'] . "',
|
||
|
duration='" . $data['duration'] . "',
|
||
|
cooldown='" . $data['cooldown'] . "',
|
||
|
description='" . $data['description'] . "',
|
||
|
description_admin='" . $data['description_admin'] . "',
|
||
|
weather_change_to='" . $data['weather_change_to'] . "',
|
||
|
cost_food='" . $data['cost_food'] . "',
|
||
|
cost_wood='" . $data['cost_wood'] . "',
|
||
|
cost_stone='" . $data['cost_stone'] . "',
|
||
|
cost_iron='" . $data['cost_iron'] . "',
|
||
|
cost_mana='" . $data['cost_mana'] . "',
|
||
|
mod_max_food='" . $data['mod_max_food'] . "',
|
||
|
mod_max_wood='" . $data['mod_max_wood'] . "',
|
||
|
mod_max_stone='" . $data['mod_max_stone'] . "',
|
||
|
mod_max_iron='" . $data['mod_max_iron'] . "',
|
||
|
mod_max_mana='" . $data['mod_max_mana'] . "',
|
||
|
mod_rate_food='" . $data['mod_rate_food'] . "',
|
||
|
mod_rate_wood='" . $data['mod_rate_wood'] . "',
|
||
|
mod_rate_stone='" . $data['mod_rate_stone'] . "',
|
||
|
mod_rate_iron='" . $data['mod_rate_iron'] . "',
|
||
|
mod_rate_mana='" . $data['mod_rate_mana'] . "',
|
||
|
mod_percent_food='" . $data['mod_percent_food'] . "',
|
||
|
mod_percent_wood='" . $data['mod_percent_wood'] . "',
|
||
|
mod_percent_stone='" . $data['mod_percent_stone'] . "',
|
||
|
mod_percent_iron='" . $data['mod_percent_iron'] . "',
|
||
|
mod_percent_mana='" . $data['mod_percent_mana'] . "'
|
||
|
WHERE id='" . $data['id'] . "'";
|
||
|
|
||
|
$this->db->query($sql);
|
||
|
|
||
|
$this->_create_sql($sql);
|
||
|
}
|
||
|
|
||
|
function add_spell_admin($data)
|
||
|
{
|
||
|
$sql = "INSERT INTO spells VALUES(default,
|
||
|
'" . $data['effect'] . "',
|
||
|
'" . $data['duration'] . "',
|
||
|
'" . $data['cooldown'] . "',
|
||
|
'" . $data['description'] . "',
|
||
|
'" . $data['description_admin'] . "',
|
||
|
'" . $data['weather_change_to'] . "',
|
||
|
'" . $data['cost_food'] . "',
|
||
|
'" . $data['cost_wood'] . "',
|
||
|
'" . $data['cost_stone'] . "',
|
||
|
'" . $data['cost_iron'] . "',
|
||
|
'" . $data['cost_mana'] . "',
|
||
|
'" . $data['mod_max_food'] . "',
|
||
|
'" . $data['mod_max_wood'] . "',
|
||
|
'" . $data['mod_max_stone'] . "',
|
||
|
'" . $data['mod_max_iron'] . "',
|
||
|
'" . $data['mod_max_mana'] . "',
|
||
|
'" . $data['mod_rate_food'] . "',
|
||
|
'" . $data['mod_rate_wood'] . "',
|
||
|
'" . $data['mod_rate_stone'] . "',
|
||
|
'" . $data['mod_rate_iron'] . "',
|
||
|
'" . $data['mod_rate_mana'] . "',
|
||
|
'" . $data['mod_percent_food'] . "',
|
||
|
'" . $data['mod_percent_wood'] . "',
|
||
|
'" . $data['mod_percent_stone'] . "',
|
||
|
'" . $data['mod_percent_iron'] . "',
|
||
|
'" . $data['mod_percent_mana'] . "')";
|
||
|
|
||
|
$this->db->query($sql);
|
||
|
|
||
|
$this->_create_sql($sql);
|
||
|
}
|
||
|
|
||
|
function get_spell_effects_admin()
|
||
|
{
|
||
|
//STUB!
|
||
|
$data = array('0' => 'No Effect');
|
||
|
|
||
|
return $data;
|
||
|
}
|
||
|
}
|
||
|
//nowhitesp
|