Api

Version

mediamosa-22

Class

mediamosa_rest_call_statistics_get_newest_mediafiles

Code

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

/**
 * MediaMosa is Open Source Software to build a Full Featured, Webservice
 * Oriented Media Management and Distribution platform (http://mediamosa.org)
 *
 * Copyright (C) 2010 SURFnet BV (http://www.surfnet.nl) and Kennisnet
 * (http://www.kennisnet.nl)
 *
 * MediaMosa is based on the open source Drupal platform and
 * was originally developed by Madcap BV (http://www.madcap.nl)
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, you can find it at:
 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
 */

/**
 * @file
 * REST calls statistics.
 */

/**
 * URI: /statistics/newestmediafiles
 * Method: GET
 *
 * 1.x: vpx_statistics_get_newest_mediafiles
 *
 */
class mediamosa_rest_call_statistics_get_newest_mediafiles extends mediamosa_rest_call {
  
// ------------------------------------------------------------------ Consts.
  // Rest vars;

  // ------------------------------------------------------------------ Get Var Setup.
  
public function get_var_setup() {
    
$var_setup = array();

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

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

    
$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(
      
'created' => array('column' => 'mf.created'),
      
'owner_id' => array('column' => 'mf.owner_id'),
      
'filename' => array('column' => 'mf.filename'),
      
'mediafile_id' => array('column' => 'mf.mediafile_id'),
      
'app_id' => array('column' => 'a.app_id'),
      
'asset_id' => array('column' => 'a.asset_id'),
      
'container_type' => array('column' => 'mfm.container_type'),
      
'filesize' => array('column' => 'mfm.filesize'),
    );

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

    
$a_query = array();

    
// First query only retrieves the mediafile_ids
    
$a_query[mediamosa_db_query::A_FROM][] = '{mediamosa_asset} AS a';

    
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'a.asset_id';
    
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'a.app_id';
    
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'a.owner_id';
    
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'a.group_id';

    
$a_query[mediamosa_db_query::A_SELECT_EXPR][] = 'mf.mediafile_id';
    
$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("a.app_id IN(%s)"mediamosa_db::escape_string(implode(','$app_ids)));

    
// Only parent assets
    
$a_query[mediamosa_db_query::A_WHERE][mediamosa_db_query::WHERE_AND][] = "a.parent_id IS NULL";

    
// Dont count private assets
    
$a_query[mediamosa_db_query::A_WHERE][mediamosa_db_query::WHERE_AND][] = "a.isprivate = 'FALSE'";

    
// Dont count unappropiate assets
    
$a_query[mediamosa_db_query::A_WHERE][mediamosa_db_query::WHERE_AND][] = "a.is_unappropriate = 'FALSE'";

    
// Join the mediafiles
    
$a_query[mediamosa_db_query::A_JOIN]['mediafile'] = "LEFT JOIN {mediamosa_asset_mediafile} AS mf ON mf.asset_id = a.asset_id";

    
// MF must be original
    
$a_query[mediamosa_db_query::A_WHERE][mediamosa_db_query::WHERE_AND][] = "mf.is_original_file='TRUE'";

    
// 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) {
      
// Join the metadata stuff
      
$mediafile_id $row[mediamosa_asset_mediafile_db::ID];
      
$row[mediamosa_asset_mediafile_metadata::CONTAINER_TYPE] = mediamosa_asset_mediafile_metadata::get_mediafile_metadata_char($mediafile_idmediamosa_asset_mediafile_metadata::CONTAINER_TYPE);
      
$row[mediamosa_asset_mediafile_metadata::FILESIZE] = mediamosa_asset_mediafile_metadata::get_mediafile_metadata_int($mediafile_idmediamosa_asset_mediafile_metadata::FILESIZE);

      
// UTC -> App timezone.
      
$row[mediamosa_asset_mediafile_db::CREATED] = mediamosa::utcdate2appdate($row[mediamosa_asset_mediafile_db::CREATED]);

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