Api

Version

mediamosa-21

Class

mediamosa_rest_call_asset_delete

Code

File: /sites/all/modules/mediamosa/modules/asset/mediamosa_asset.rest.inc
<?php

/**
 * URI: /asset/$asset_id/delete
 *
 * Method: POST
 *
 * 1.x: media_management_delete_asset
 */
class mediamosa_rest_call_asset_delete extends mediamosa_rest_call {
  
// ------------------------------------------------------------------ Consts.
  // Rest vars;
  
const ASSET_ID 'asset_id';
  const 
USER_ID 'user_id';
  const 
DELETE 'delete';

  
// ------------------------------------------------------------------ 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_type::TYPE_ASSET_ID,
          
self::VAR_DESCRIPTION => 'The asset ID to delete.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
        ),
        
self::USER_ID => array(
          
self::VAR_TYPE => mediamosa_type::TYPE_USER_ID,
          
self::VAR_DESCRIPTION => 'User ID, must be the owner to delete asset.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
        ),
        
self::DELETE => array(
          
self::VAR_TYPE => mediamosa_type::TYPE_ALPHA,
          
self::VAR_DESCRIPTION => 'Delete mode.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_NO,
          
self::VAR_ALLOWED_VALUES => array('''cascade'),
        ),
      ),
    );

    return 
self::get_var_setup_default($a_var_setup);
  }

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

    
$asset_id $this->get_param_value(self::ASSET_ID);

    
$app_ids $this->get_param_value_app();
    
$app_id reset($app_ids);
    
$is_app_admin $this->get_param_value(self::IS_APP_ADMIN);

    
$asset_id $this->get_param_value(self::ASSET_ID);
    
$user_id $this->get_param_value(self::USER_ID);
    
$delete $this->get_param_value(self::DELETE);

    
// Test webservice.
    
mediamosa_webservice_app::webservice_must_be_active(mediamosa_webservice_app::HANDLE_MEDIA_MANAGEMENT$app_ids);

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

    
// Get asset.
    
$a_asset mediamosa_db::db_query(
      
'SELECT #app_id, #owner_id FROM {#mediamosa_asset} WHERE #asset_id  = :asset_id',
      array(
        
'#app_id' => mediamosa_asset_db::APP_ID,
        
'#owner_id' => mediamosa_asset_db::OWNER_ID,
        
'#mediamosa_asset' => mediamosa_asset_db::TABLE_NAME,
        
'#asset_id' => mediamosa_asset_db::ID,
        
':asset_id' => $asset_id,
      )
    )->
fetchAssoc();

    
// Must be owner / app_admin to delete.
    
mediamosa_aut::owner_check($app_id$user_id$a_asset[mediamosa_asset_db::APP_ID], $a_asset[mediamosa_asset_db::OWNER_ID], $is_app_admin);

    
// Delete the asset (and all other stuff related).
    
mediamosa_asset::delete($asset_id$delete == 'cascade');

    
// All ok.
    
$mediamosa->set_result_okay();
  }
}