Api
Version
mediamosa-30Class
mediamosa_rest_call_statistics_get_used_diskspaceCode
File: /sites/all/modules/mediamosa/modules/statistics/mediamosa_statistics.rest.class.inc
<?php
/**
* URI: /statistics/datausagevideo
* Method: GET
*
* 1.x: vpx_statistics_get_used_diskspace
*
*/
class mediamosa_rest_call_statistics_get_used_diskspace extends mediamosa_rest_call {
// ------------------------------------------------------------------ Consts.
// Rest vars;
const MONTH = 'month';
const YEAR = 'year';
const TYPE = 'type';
// ------------------------------------------------------------------ Get Var Setup.
public function get_var_setup() {
$var_setup = array();
$var_setup = array(
self::VARS => array(
self::MONTH => array(
self::VAR_TYPE => mediamosa_sdk::TYPE_INT,
self::VAR_DESCRIPTION => 'The month of the query.',
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
self::VAR_RANGE_START => 1,
self::VAR_RANGE_END => 12,
),
self::YEAR => array(
self::VAR_TYPE => mediamosa_sdk::TYPE_INT,
self::VAR_DESCRIPTION => 'The year of the query.',
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
self::VAR_RANGE_START => 1970,
self::VAR_RANGE_END => 2099,
),
self::TYPE => array(
self::VAR_TYPE => mediamosa_sdk::TYPE_STRING,
self::VAR_DESCRIPTION => 'The type.',
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
self::VAR_ALLOWED_VALUES => array(
mediamosa_statistics_diskspace_used_db::TYPE_CONTAINER,
mediamosa_statistics_diskspace_used_db::TYPE_GROUP,
mediamosa_statistics_diskspace_used_db::TYPE_USER,
),
),
)
);
// Enrich with limit, offset.
$var_setup = self::get_var_setup_range($var_setup, mediamosa_settings::LIMIT_MAX, mediamosa_settings::LIMIT_DEFAULT_STATISTICS);
// Enrich with order by.
$var_setup = self::get_var_setup_order_by($var_setup, '', array(), mediamosa_type::ORDER_DIRECTION_ASC);
// Enrich with required REST vars.
return self::get_var_setup_default($var_setup);
}
// ------------------------------------------------------------------ Do Call.
public function do_call() {
$o_mediamosa = mediamosa::get();
$app_ids = $this->get_param_value_app();
$app_id = reset($app_ids);
$order_by = $this->get_param_value_order_by();
$order_direction = $this->get_param_value_order_direction();
$limit = $this->get_param_value_limit();
$offset = $this->get_param_value_offset();
$type = $this->get_param_value(self::TYPE);
$month = $this->get_param_value(self::MONTH);
$year = $this->get_param_value(self::YEAR);
// Allowed Order By List
$a_order_by = array(
'diskspace_mb' => array('column' => 'diskspace_mb'),
'type' => array('column' => 'type'),
'app_id' => array('column' => 'app_id'),
'container_type' => array('column' => 'container_type'),
);
if (!isset($a_order_by[$order_by])) {
$order_by = 'app_id';
}
$a_query = array();
$a_query[mediamosa_db_query::A_FROM][] = '{mediamosa_statistics_diskspace_used}';
// Select this.
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'container_type';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = sprintf('keyword AS %s_id', mediamosa_db::escape_string($type));
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'type';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'app_id';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'diskspace AS diskspace_mb';
$a_query[mediamosa_db_query::A_WHERE][mediamosa_db_query::WHERE_AND][] = sprintf("app_id IN(%s)", mediamosa_db::escape_string(implode(",", $app_ids)));
$a_query[mediamosa_db_query::A_WHERE][mediamosa_db_query::WHERE_AND][] = sprintf("type = '%s'", mediamosa_db::escape_string($type));
$a_query[mediamosa_db_query::A_WHERE][mediamosa_db_query::WHERE_AND][] = sprintf("timestamp BETWEEN '%04d-%02d-01' AND '%04d-%02d-01'", $year, $month, ($month == 12 ? $year + 1 : $year), ($month == 12 ? 1 : $month + 1));
// Order by.
$a_query[mediamosa_db_query::A_ORDER_BY][] = $a_order_by[$order_by]['column'] . ' ' . $order_direction;
// Limit.
$a_query[mediamosa_db_query::LIMIT] = $limit;
// Offset.
$a_query[mediamosa_db_query::OFFSET] = $offset;
// Do query.
$query = mediamosa_db_query::query_select($a_query, array(mediamosa_db_query::SQL_CALC_FOUND_ROWS => TRUE));
$result = mediamosa_db::db_query($query);
// Set total.
$o_mediamosa->item_count_total = mediamosa_db_query::found_rows();
// Fill items.
foreach ($result as $row) {
if ($type == 'container') {
unset($row['container_id']);
}
$o_mediamosa->add_item($row);
}
// Total disk usage.
// Data.
$a_query_disk_usage = $a_query;
unset($a_query_disk_usage[mediamosa_db_query::A_SELECT_EXPR]);
$a_query_disk_usage[mediamosa_db_query::A_SELECT_EXPR][] = 'sum(diskspace) as total_disk_usage';
unset($a_query_disk_usage[mediamosa_db_query::A_ORDER_BY]);
unset($a_query_disk_usage[mediamosa_db_query::LIMIT]);
unset($a_query_disk_usage[mediamosa_db_query::OFFSET]);
// Do query.
$query_disk_usage = mediamosa_db_query::query_select($a_query_disk_usage);
$result = mediamosa_db::db_query($query_disk_usage);
// Add data.
$statistics_data = array(
'total_disk_usage_mb' => $result->fetchField(),
);
$o_mediamosa->set_result_header_extra($statistics_data, 'statistics');
}
}