Api

Version

mediamosa-30

Class

mediamosa_rest_call_statistics_get_requested_streams

Code

File: /sites/all/modules/mediamosa/modules/statistics/mediamosa_statistics.rest.class.inc
<?php

/**
 * URI: /statistics/playedstreams
 * Method: GET
 *
 * 1.x: vpx_statistics_get_requested_streams
 *
 */
class mediamosa_rest_call_statistics_get_requested_streams extends mediamosa_rest_call {
  
// ------------------------------------------------------------------ Consts.
  // Rest vars;
  
const MONTH 'month';
  const 
YEAR 'year';
  const 
TYPE 'type';
  const 
OWNER_ID 'owner_id';
  const 
GROUP_ID 'group_id';
  const 
PLAY_TYPE 'play_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 => 2000,
          
self::VAR_RANGE_END => 2099,
        ),
      )
    );

        
// Enrich with limit, offset.
    
$var_setup self::get_var_setup_range($var_setupmediamosa_settings::LIMIT_MAXmediamosa_settings::LIMIT_DEFAULT_STATISTICS_NO_PAGER);

    
// Enrich with order by.
    
$var_setup self::get_var_setup_order_by($var_setup'', array(), mediamosa_type::ORDER_DIRECTION_DESC);

    
// 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();

    
$month $this->get_param_value(self::MONTH);
    
$year $this->get_param_value(self::YEAR);

    
// Allowed Order By List
    
$a_order_by = array(
      
'app_id' => array('column' => 'app_id'),
      
'time' => array('column' => 'time'),
      
'mediafile_id' => array('column' => 'mediafile_id'),
    );

    if (!isset(
$a_order_by[$order_by])) {
      
$order_by 'time';
    }

    
$a_query = array();
    
$a_query[mediamosa_db_query::A_FROM][] = '{mediamosa_statistics_stream_request}';

    
// Select this.
    
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = '*';

    
// Correct app_id(s) if given.
    
$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("time BETWEEN '%04d-%02d-01' AND '%04d-%02d-01'"$year$month, ($month == 12 $year $year), ($month == 12 $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 => FALSE));
    
$result mediamosa_db::db_query($query);

    
// Fill items.
    
foreach ($result as $row) {
      
// UTC -> App timezone.
      
$row[mediamosa_statistics_stream_request_db::TIME] = mediamosa::utcdate2appdate($row[mediamosa_statistics_stream_request_db::TIME]);

      
$o_mediamosa->add_item($row);
    }
  }
}