class_CopyPasteHandler.inc 11.23 KiB
<?php
/*
  This code is part of FusionDirectory (http://www.fusiondirectory.org/)
  Copyright (C) 2003-2010  Cajus Pollmeier
  Copyright (C) 2011-2016  FusionDirectory
  This program is free software; you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation; either version 2 of the License, or
  (at your option) any later version.
  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.
  You should have received a copy of the GNU General Public License
  along with this program; if not, write to the Free Software
  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
/*!
 * \file class_CopyPasteHandler.inc
 * Source code for class CopyPasteHandle
/*!
 * \brief This class contains all function to copy and paste
class CopyPasteHandler
  var $current;
  /*!
   * \brief This array contains all dns of the currently copyied objects
  var $queue = array();
  /*!
   *  \brief The dn of the last edited object
  var $lastdn = "";
  var $disallowed_objects = array();
  var $objects_to_fix     = array();
  var $clean_objects      = array();
  var $require_update     = FALSE;
  /*!
   * \brief Create CP handler
   * \param string $config
  function __construct()
    $this->current  = NULL;
    $this->queue    = array();
  /*!
   * \brief Entry entry to Copy & Paste queue.
   * A Queue entry is represented as follows.
   *  array['file_name']  - Position on hdd
   *  array['method']     - 'copy' or 'cut'
   *  array['dn']         - the dn of the object added to the queue
   *  array['tab_class']  - Tab object that should be used to initialize the new object
   *  array['tab_object'] - Tab object name used to initialize correct object Type like USERTABS
7172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
* \param String $dn The dn of the object added to the queue * * \param String $action Copy or Cut * * \param String $tab_class Tab object that should be used to initialize the new object * * \param String $tab_object Tab object name used to initialize correct object Type like USERTABS * * \param String $tab_acl_category Tab with acl category * * \param Object $parent the parent to set to the tab object */ function add_to_queue() { global $config; $dn = func_get_arg(0); @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__, $dn, "add_to_queue"); $action = func_get_arg(1); if (!in_array($action, array("cut","copy"))) { trigger_error(sprintf("Specified action '%s' does not exists for copy & paste.", $action)); return FALSE; } $tmp = array(); $tmp['method'] = $action; $tmp['dn'] = $dn; if (func_num_args() == 3) { $type = func_get_arg(2); $tmp['type'] = $type; $infos = objects::infos($type); $tmp['tab_acl_category'] = $infos['aclCategory']; $tmp['parent'] = NULL; } else { // Deprecated $tab_class = func_get_arg(2); $tab_object = func_get_arg(3); $tab_acl_category = func_get_arg(4); $parent = NULL; if (func_num_args() > 5) { $parent = func_get_arg(5); } if (!class_available($tab_class)) { trigger_error(sprintf("Specified class object '%s' does not exists.", $tab_class)); return FALSE; } if (!isset($config->data['TABS'][$tab_object])) { trigger_error(sprintf("Specified tab object '%s' does not exists.", $tab_object)); return FALSE; } $tmp['tab_class'] = $tab_class; $tmp['tab_object'] = $tab_object; $tmp['tab_acl_category'] = $tab_acl_category; $tmp['parent'] = $parent; } $this->queue[] = $tmp; $this->require_update = TRUE; return TRUE; } /*! * \brief This removes all objects from queue. * Remove hdd dumps of current entries too.