Api

Version

mediamosa-30

Class

mediamosa_rest_call_collection_delete_relation

Code

File: /sites/all/modules/mediamosa/modules/collection/mediamosa_collection.rest.class.inc
<?php


/**
 * URI: /collection/$coll_id/asset_relation/delete
 * Method: POST
 *
 * 1.x: media_management_delete_collection_relation
 */
class mediamosa_rest_call_collection_delete_relation extends mediamosa_rest_call {
  
// ------------------------------------------------------------------ Consts.
  // Rest vars;
  
const COLL_ID 'coll_id';
  const 
ASSET_ID 'asset_id';
  const 
USER_ID 'user_id';

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

    
$var_setup = array(
      
self::VARS => array(
        
self::COLL_ID => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_COLLECTION_ID,
          
self::VAR_DESCRIPTION => 'The collection ID.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
        ),
        
self::ASSET_ID => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_ASSET_ID,
          
self::VAR_DESCRIPTION => 'The asset ID\'s to be removed from the collection. This parameter accepts an array of assets.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
          
self::VAR_IS_ARRAY => self::VAR_IS_ARRAY_YES,
        ),
        
self::USER_ID => array(
          
self::VAR_TYPE => mediamosa_sdk::TYPE_USER_ID,
          
self::VAR_DESCRIPTION => 'The user ID, must be owner of the collection.',
          
self::VAR_IS_REQUIRED => self::VAR_IS_REQUIRED_YES,
        ),
      ),
    );

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

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

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

    
$coll_id $this->get_param_value(self::COLL_ID);
    
$user_id $this->get_param_value(self::USER_ID);
    
$asset_ids $this->get_param_value(self::ASSET_ID);

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

    
// Collection must exist.
    
$collection mediamosa_collection::must_exists($coll_id);

    
// Get the assets.
    
$a_assets mediamosa_asset::getAllAssoc($asset_ids);

    
// Now go through each asset.
    
foreach ($asset_ids as $asset_id) {

      if (!isset(
$a_assets[$asset_id])) {
        throw new 
mediamosa_exception_error(mediamosa_error::ERRORCODE_ASSET_NOT_FOUND, array('@asset_id' => $asset_id));
      }

      
// Test link of collection to asset.
      
mediamosa_db::db_must_exists(
        
mediamosa_asset_collection_db::TABLE_NAME,
        array(
          
mediamosa_asset_collection_db::ASSET_ID => $asset_id,
          
mediamosa_asset_collection_db::COLL_ID => $coll_id,
        )
      );

      
mediamosa_acl::owner_check_collection_assign($app_id$user_id$a_assets[$asset_id], $collection$is_app_admin);
    }

    
// If we get to this point, then all was passed and we can remove them from the collection.

    // Now go through each asset.
    
foreach ($asset_ids as $asset_id) {
      
// Delete the relation.
      
mediamosa_asset_collection::delete($asset_id$coll_id);

      
// Add deletion to output. (new 2.0).
      
$o_mediamosa->add_item(array('asset_id' => $asset_id'coll_id' => $coll_id));
    }

    
$o_mediamosa->set_result_okay();
  }
}