Api
Version
mediamosa-30Class
mediamosa_rest_call_create_mediafileCode
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_ID, mediamosa_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($param, TRUE);
$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.
}
}