Api
Version
mediamosa-21Class
mediamosa_rest_call_statistics_get_most_popular_mediafilesCode
File: /sites/all/modules/mediamosa/modules/statistics/mediamosa_statistics.rest.inc
<?php
/**
* URI: /statistics/popularmediafiles
* Method: GET
*
* 1.x: vpx_statistics_get_most_popular_mediafiles
*
*/
class mediamosa_rest_call_statistics_get_most_popular_mediafiles extends mediamosa_rest_call {
// ------------------------------------------------------------------ Consts.
// Rest vars;
// ------------------------------------------------------------------ Get Var Setup.
public function get_var_setup() {
$a_var_setup = array();
// Enrich with limit, offset.
$a_var_setup = self::get_var_setup_range($a_var_setup, mediamosa_settings::LIMIT_MAX, mediamosa_settings::LIMIT_DEFAULT_STATISTICS);
// Enrich with order by.
$a_var_setup = self::get_var_setup_order_by($a_var_setup, '', array(), mediamosa_type::ORDER_DIRECTION_DESC);
// Enrich with required REST vars.
return self::get_var_setup_default($a_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();
// Allowed Order By List
$a_order_by = array(
'count' => array('column' => 'count'),
'owner_id' => array('column' => 'ssr.owner_id'),
'group_id' => array('column' => 'ssr.group_id'),
'filesize' => array('column' => 'ssr.filesize'),
'container_type' => array('column' => 'ssr.container_type'),
'app_id' => array('column' => 'ssr.app_id'),
'created' => array('column' => 'mf.created'),
'filename' => array('column' => 'mf.filename'),
'asset_id' => array('column' => 'ssr.asset_id'),
'mediafile_id' => array('column' => 'ssr.mediafile_id'),
);
if (!isset($a_order_by[$order_by])) {
$order_by = 'count';
}
$a_query = array();
$a_query[mediamosa_db_query::A_FROM][] = '{mediamosa_statistics_stream_request} AS ssr';
// Join the mediafiles
$a_query[mediamosa_db_query::A_JOIN]['mediafile'] = "LEFT JOIN {mediamosa_asset_mediafile} AS mf USING(mediafile_id)";
// Select these....
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'ssr.mediafile_id';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'ssr.asset_id';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'ssr.app_id';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'ssr.owner_id';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'ssr.group_id';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'ssr.container_type';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'ssr.filesize';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'COUNT(ssr.mediafile_id) AS count';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'mf.filename';
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'mf.created';
// App_id.
$a_query[mediamosa_db_query::A_WHERE][mediamosa_db_query::WHERE_AND][] = sprintf('ssr.app_id IN(%s)', mediamosa_db::escape_string(implode(',', $app_ids)));
// Group by.
$a_query[mediamosa_db_query::A_GROUP_BY][] = 'ssr.mediafile_id';
// 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) {
$o_mediamosa->add_item($row);
}
}
}