freenetis-github/application/models/phone_invoice_user.php @ c2bceaad
8baed187 | Michal Kliment | <?php defined('SYSPATH') or die('No direct script access.');
|
|
/*
|
|||
* This file is part of open source system FreenetIS
|
|||
* and it is released under GPLv3 licence.
|
|||
*
|
|||
* More info about licence can be found:
|
|||
* http://www.gnu.org/licenses/gpl-3.0.html
|
|||
*
|
|||
* More info about project can be found:
|
|||
* http://www.freenetis.org/
|
|||
*
|
|||
*/
|
|||
/**
|
|||
* Descriptions of Phone_invoice_user_Model
|
|||
*
|
|||
* @author Ondřej Fibich
|
|||
* @package Model
|
|||
*
|
|||
* @property integer $id
|
|||
* @property integer $user_id
|
|||
* @property User_Model $user
|
|||
* @property integer $phone_invoice_id
|
|||
* @property Phone_invoice_Model $phone_invoice
|
|||
* @property integer $transfer_id
|
|||
* @property Transfer_Model $transfer
|
|||
* @property string $phone_number
|
|||
* @property boolean $locked
|
|||
* @property ORM_Iterator $phone_connections
|
|||
* @property ORM_Iterator $phone_calls
|
|||
* @property ORM_Iterator $phone_fixed_calls
|
|||
* @property ORM_Iterator $phone_pays
|
|||
* @property ORM_Iterator $phone_roaming_sms_messages
|
|||
* @property ORM_Iterator $phone_sms_messages
|
|||
* @property ORM_Iterator $phone_vpn_calls
|
|||
*/
|
|||
class Phone_invoice_user_Model extends ORM
|
|||
{
|
|||
protected $belongs_to = array('user', 'phone_invoice', 'transfer');
|
|||
protected $has_many = array
|
|||
(
|
|||
'phone_connections', 'phone_calls', 'phone_fixed_calls', 'phone_pays',
|
|||
'phone_roaming_sms_messages', 'phone_sms_messages', 'phone_vpn_calls'
|
|||
);
|
|||
/**
|
|||
* Get sum of all users phone invoices separated to cells price_company and price_private
|
|||
* @param integer $user_id
|
|||
* @return Mysql_Result
|
|||
*/
|
|||
public function get_total_prices($user_id)
|
|||
{
|
|||
$result = $this->db->query("
|
|||
SELECT id FROM phone_invoice_users WHERE user_id = ?
|
|||
", array($user_id));
|
|||
$id_array = array();
|
|||
foreach ($result as $p)
|
|||
{
|
|||
$id_array[] = $p->id;
|
|||
}
|
|||
$ids = implode(",", $id_array);
|
|||
if (empty($ids))
|
|||
{
|
|||
return $this->db->query("
|
|||
SELECT '0' AS price_company, '0' AS price_private
|
|||
")->current();
|
|||
}
|
|||
return $this->db->query("
|
|||
SELECT ((
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=0
|
|||
)) AS price_company,
|
|||
((
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id IN (" . $ids . ") AND private=1
|
|||
)) AS price_private
|
|||
")->current();
|
|||
}
|
|||
/**
|
|||
* Gets all users phone invoices
|
|||
* @param integer $user_id
|
|||
* @return Mysql_Result
|
|||
*/
|
|||
public function get_phone_invoices_of_user($user_id)
|
|||
{
|
|||
return $this->db->query("
|
|||
SELECT p.id, pi.locked, p.locked AS filled,
|
|||
pi.billing_period_from,
|
|||
pi.billing_period_to, p.user_id, p.transfer_id, t.amount,
|
|||
p.phone_number AS number,
|
|||
((
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id=p.id AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id=p.id AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id=p.id AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id=p.id AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id=p.id AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id=p.id AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id=p.id AND private=0
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id=p.id AND private=0
|
|||
)) AS price_company,
|
|||
((
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id=p.id AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id=p.id AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id=p.id AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id=p.id AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id=p.id AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id=p.id AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id=p.id AND private=1
|
|||
) + (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id=p.id AND private=1
|
|||
)) AS price_private
|
|||
FROM phone_invoice_users p
|
|||
LEFT JOIN transfers t ON p.transfer_id = t.id
|
|||
LEFT JOIN phone_invoices pi ON p.phone_invoice_id = pi.id
|
|||
WHERE p.user_id = ?
|
|||
", $user_id);
|
|||
}
|
|||
/**
|
|||
* Gets info about each number in invoice.
|
|||
* Calculates total price for each number.
|
|||
* @param integer $invoice_id
|
|||
* @return Mysql_Result
|
|||
*/
|
|||
public function get_all_invoice_users($invoice_id)
|
|||
{
|
|||
// madness query to calculate price for each user invoicee
|
|||
return $this->db->query("
|
|||
SELECT p.tax_rate, piu.id, piu.locked AS filled,
|
|||
piu.user_id, piu.phone_number , piu.transfer_id, t.amount,
|
|||
CONCAT( users.surname, ' ', users.name ) AS name,
|
|||
(
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 0)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 0)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 0)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 0)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 0)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 0)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 0)
|
|||
) * (1 + p.tax_rate / 100) AS price_company,
|
|||
(
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 1)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 1)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 1)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 1)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 1)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 1)
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id =piu.id AND private = 1)
|
|||
) * (1 + p.tax_rate / 100) AS price_private
|
|||
FROM phone_invoice_users piu
|
|||
LEFT JOIN phone_invoices p ON p.id = piu.phone_invoice_id
|
|||
LEFT JOIN users ON piu.user_id = users.id
|
|||
LEFT JOIN transfers t ON piu.transfer_id = t.id
|
|||
WHERE piu.phone_invoice_id = ?;
|
|||
", array($invoice_id));
|
|||
}
|
|||
/**
|
|||
* Return price of current user phone invoice
|
|||
* @return double
|
|||
*/
|
|||
public function get_price()
|
|||
{
|
|||
$result = $this->db->query("
|
|||
SELECT ((SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id =" . $this->id . ")
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id =" . $this->id . ")
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id =" . $this->id . ")
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id =" . $this->id . ")
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id =" . $this->id . ")
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id =" . $this->id . ")
|
|||
+
|
|||
(SELECT IFNULL(SUM( price ), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id =" . $this->id . ")) AS price"
|
|||
);
|
|||
return ($result) ? $result->current()->price : 0.0;
|
|||
}
|
|||
/**
|
|||
* Vat and Out of tax price of each service
|
|||
* @return Database_Result
|
|||
*/
|
|||
public function get_prices()
|
|||
{
|
|||
return $this->db->query("
|
|||
SELECT (
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=0
|
|||
) AS phone_calls_company,(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_calls
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=1
|
|||
) AS phone_calls_private,
|
|||
(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=0
|
|||
) AS phone_fixed_calls_company,(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_fixed_calls
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=1
|
|||
) AS phone_fixed_calls_private,
|
|||
(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=0
|
|||
) AS phone_vpn_calls_company,(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_vpn_calls
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=1
|
|||
) AS phone_vpn_calls_private,
|
|||
(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=0
|
|||
) AS phone_pays_company,(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_pays
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=1
|
|||
) AS phone_pays_private,
|
|||
(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=0
|
|||
) AS phone_connections_company,(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_connections
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=1
|
|||
) AS phone_connections_private,
|
|||
(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=0
|
|||
) AS phone_roaming_sms_message_company,(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=1
|
|||
) AS phone_roaming_sms_messages_private,
|
|||
(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=0
|
|||
) AS phone_sms_messages_company,(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_sms_messages
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=1
|
|||
) AS phone_sms_messages_private,
|
|||
(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=0
|
|||
) AS phone_roaming_sms_messages_company,(
|
|||
SELECT IFNULL(SUM(price), 0)
|
|||
FROM phone_roaming_sms_messages
|
|||
WHERE phone_invoice_user_id=" . $this->id . " AND private=1
|
|||
) AS phone_roaming_sms_messages_private
|
|||
")->current();
|
|||
}
|
|||
/**
|
|||
* Search for user with specific phone number
|
|||
* @param string $phone_number Number with prefix
|
|||
* @return integer ID or zero if cannot find nuber in database
|
|||
*/
|
|||
public function get_user_id($phone_number)
|
|||
{
|
|||
static $country = NULL;
|
|||
if ($country == NULL)
|
|||
{
|
|||
$country = new Country_Model();
|
|||
}
|
|||
$country_code = $country->find_phone_country_code($phone_number);
|
|||
$query = $this->db->query("
|
|||
SELECT u.user_id FROM users_contacts u
|
|||
LEFT JOIN contacts c ON c.id = u.contact_id
|
|||
WHERE type = ? AND value = ?;
|
|||
", array(Contact_Model::TYPE_PHONE, substr($phone_number, mb_strlen($country_code))));
|
|||
return ($query->count() > 0) ? $query->current()->user_id : 0;
|
|||
}
|
|||
}
|