Api

Version

mediamosa-30

Class

mediamosa_rest_call_get_asset_mediafiles

Code

File: /sites/all/modules/mediamosa/modules/asset/mediafile/mediamosa_asset_mediafile.rest.class.inc
<?php

/**
 * URI: /asset/$asset_id/mediafile
 * Method: GET
 */
class mediamosa_rest_call_get_asset_mediafiles extends mediamosa_rest_call {
  
// ------------------------------------------------------------------ Consts.
  // Rest vars;
  
const ASSET_ID 'asset_id';
  const 
TAG 'tag';
  const 
IS_STILL 'is_still';
  const 
IS_OAI 'is_oai';

  
// ------------------------------------------------------------------ Public Functions.
  
public function get_var_setup() {
    
$a_var_setup = array();

    
$a_var_setup = array(
      
self::VARS => array(
        
self::ASSET_ID => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_ASSET_ID,
          
self::VAR_DESCRIPTION => 'The ID of the mediafile to retrieve.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
        ),
        
self::IS_STILL => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_BOOL,
          
self::VAR_DESCRIPTION => 'Include the stills in the output.',
          
self::VAR_DEFAULT_VALUE => 'FALSE'
        
),
        
self::IS_OAI => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_BOOL,
          
self::VAR_DESCRIPTION => 'Include extra information required for OAI output.',
          
self::VAR_DEFAULT_VALUE => 'FALSE'
        
),
        
self::TAG => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_STRING,
          
self::VAR_DESCRIPTION => 'Search on tag.',
          
self::VAR_RANGE_END => mediamosa_asset_mediafile_db::TAG_LENGTH,
        )
      )
    );

    
// Enrich with required REST vars.
    
return self::get_var_setup_default($a_var_setup);
  }

  public function 
do_call() {
    
$mediamosa mediamosa::get();

    
$app_ids $this->get_param_value_app();
    
$app_id reset($app_ids);

    
$asset_id $this->get_param_value(self::ASSET_ID);
    
$tag $this->get_param_value(self::TAG);
    
$is_still $this->get_param_value(self::IS_STILL);
    
$is_oai $this->get_param_value(self::IS_OAI);

    
// Asset must exist.
    
$asset mediamosa_db::db_must_exists(mediamosa_asset_db::TABLE_NAME, array(mediamosa_asset_db::ID => $asset_id));

    
$mediafile_ids mediamosa_asset_mediafile::mediafiles_search($asset_id$tag$is_still, ($asset['app_id'] == $app_id ? array() : $app_ids));

    
// Create output.
    
$items mediamosa_asset_mediafile::enrich_response_mediafile($mediafile_ids$app_ids$is_oai);


    
// Add to response.
    
if (!empty($items['mediafile'])) {
      foreach (
$items['mediafile'] as $item) {
        
$mediamosa->add_item($item);
      }
    }
  }
}