Api

Version

mediamosa-30

Class

mediamosa_rest_call_create_mediafile

Code

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

/**
 * URI: /asset/$asset_id/mediafile/create
 * Method: POST
 */
class mediamosa_rest_call_create_mediafile extends mediamosa_rest_call {
  
// ------------------------------------------------------------------ Consts.
  // Rest vars;
  
const ASSET_ID 'asset_id';
  const 
MEDIAFILE_ID 'mediafile_id';
  const 
GROUP_ID 'group_id';
  const 
USER_ID 'user_id';
  const 
URI 'uri';
  const 
IS_DOWNLOADABLE 'is_downloadable';
  const 
SANNAS_MOUNT_POINT 'sannas_mount_point';
  const 
IS_ORIGINAL_FILE 'is_original_file';
  const 
MEDIAFILE_ID_SOURCE 'mediafile_id_source';
  const 
FILENAME 'filename';
  const 
TAG 'tag';

  
// ------------------------------------------------------------------ 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 parent asset.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
        ),
        
self::USER_ID => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_USER_ID,
          
self::VAR_DESCRIPTION => 'The owner ID to match.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
        ),
        
self::GROUP_ID => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_GROUP_ID,
          
self::VAR_DESCRIPTION => 'The group ID.',
          
self::VAR_RANGE_END => mediamosa_user_group_db::GROUP_ID_LENGTH,
        ),
        
self::URI => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_URI,
          
self::VAR_DESCRIPTION => 'The stream URI.',
        ),
        
self::IS_DOWNLOADABLE => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_BOOL,
          
self::VAR_DESCRIPTION => 'Mediafile can be downloaded.',
          
self::VAR_DEFAULT_VALUE => 'FALSE',
        ),
        
self::IS_ORIGINAL_FILE => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_BOOL,
          
self::VAR_DESCRIPTION => 'Mark mediafile as original.',
          
self::VAR_DEFAULT_VALUE => 'TRUE',
          
self::VAR_IS_INTERNAL_ONLY => self::VAR_IS_INTERNAL_ONLY_YES,
        ),
        
self::MEDIAFILE_ID_SOURCE => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_MEDIAFILE_ID,
          
self::VAR_DESCRIPTION => 'The ID of the mediafile of the original.',
          
self::VAR_IS_INTERNAL_ONLY => self::VAR_IS_INTERNAL_ONLY_YES,
        ),
        
self::FILENAME => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_FILENAME,
          
self::VAR_DESCRIPTION => 'Filename of the mediafile, can not be combined with URI.',
          
self::VAR_IS_INTERNAL_ONLY => self::VAR_IS_INTERNAL_ONLY_YES,
        ),
        
self::SANNAS_MOUNT_POINT => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_STRING,
          
self::VAR_DESCRIPTION => 'The location path of the file.',
          
self::VAR_IS_INTERNAL_ONLY => self::VAR_IS_INTERNAL_ONLY_YES,
        ),
        
self::MEDIAFILE_ID => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_MEDIAFILE_ID,
          
self::VAR_DESCRIPTION => 'The mediafile ID.',
          
self::VAR_IS_INTERNAL_ONLY => self::VAR_IS_INTERNAL_ONLY_YES,
        ),
        
self::TAG => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_STRING,
          
self::VAR_DESCRIPTION => 'User specified 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() {
    
$o_mediamosa mediamosa::get();

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

    
$app_id reset($app_ids);
    
$is_app_admin $this->get_param_value(self::IS_APP_ADMIN);
    
$is_original_file $this->get_param_value(self::IS_ORIGINAL_FILE);
    
$asset_id $this->get_param_value(self::ASSET_ID);
    
$user_id $this->get_param_value(self::USER_ID);

    
// Must be enabled.
    
mediamosa_webservice_app::webservice_must_be_active(mediamosa_webservice_app::HANDLE_MEDIA_MANAGEMENT$app_ids);

    
// Make sure we dont mix URI and Filename.
    
if (!$this->empty_param(self::URI) && (!$this->empty_param(self::FILENAME) || $this->get_param_value(self::IS_DOWNLOADABLE))) {
      throw new 
mediamosa_exception_error(mediamosa_error::ERRORCODE_MIX_OF_URI_AND_FILE);
    }

    
// URI set? Unset the mount point.
    
if ($this->isset_param(self::URI)) {
      
$this->unset_param(self::SANNAS_MOUNT_POINT);
    }

    
// Set mediafile ID to something if not present.
    
if ($this->empty_param(self::MEDIAFILE_ID)) {
      
$this->set_param_value(self::MEDIAFILE_IDmediamosa_db::uuid($app_id));
    }

    
// Must exists.
    
$a_asset mediamosa_asset::must_exists($asset_id);

    
// Check owner of parent asset, need ownership.
    
mediamosa_acl::owner_check($app_id$user_id$a_asset[mediamosa_asset_db::APP_ID], $a_asset[mediamosa_asset_db::OWNER_ID], $is_app_admin);

    
// Want to copy these fields to new mediafile.
    
$params = array(
      
self::GROUP_ID => mediamosa_asset_mediafile_db::GROUP_ID,
      
self::IS_DOWNLOADABLE => mediamosa_asset_mediafile_db::IS_DOWNLOADABLE,
      
self::IS_ORIGINAL_FILE => mediamosa_asset_mediafile_db::IS_ORIGINAL_FILE,
      
self::SANNAS_MOUNT_POINT => mediamosa_asset_mediafile_db::SANNAS_MOUNT_POINT,
      
self::FILENAME => mediamosa_asset_mediafile_db::FILENAME,
      
self::URI => mediamosa_asset_mediafile_db::URI,
      
self::MEDIAFILE_ID_SOURCE => mediamosa_asset_mediafile_db::MEDIAFILE_ID_SOURCE,
      
self::TAG => mediamosa_asset_mediafile_db::TAG,
    );

    
// Fields to insert.
    
$fields = array();

    
// Now create the data to insert.
    
foreach ($params as $param => $field_name) {
      if (
$this->isset_param($param)) {
        
$value $this->get_param_value($paramTRUE);

        
$fields[$field_name] = is_bool($value) ? ($value 'TRUE' 'FALSE') : $value;
      }
    }

    
// Get mediafile ID.
    
$mediafile_id $this->get_param_value(self::MEDIAFILE_ID);

    
// Insert the mediafile.
    
$mediafile_id mediamosa_asset_mediafile::create($mediafile_id$app_id$asset_id$user_id$fields);

    
// Ok add to output.
    
$o_mediamosa->add_item(array('mediafile_id' => $mediafile_id));

    
// Done.
  
}
}