True, 'help' => True, 'view' => True, 'export'=> True, 'touch' => True, 'history' => True, 'edit' => True, 'fileModels'=>True, 'getReturnExecuteForm' => True, 'dir_ls' => True, 'search' => True, 'get_folders_list' => True, 'showUploadboxes' => True, 'createdir' => True, 'removedir' => True, 'uploadModel'=>True ); //keep var $bo; var $vfs_functions; var $t; //template object var $dispath; var $cwd; var $lesspath; var $readable_groups; var $files_array; var $numoffiles; var $dispsep; var $target; var $prefs;//array var $groups_applications; var $current_config; var $dirs; var $to; var $changedir; // for switching dir. var $cdtodir; // for switching dir. var $newfile_or_dir; var $newfile_x; var $createfile_var; var $move_to_x; var $copy_to_x; var $edit_x; var $edit_file; var $edit_preview_x; var $edit_save_x; var $edit_save_done_x; var $edit_cancel_x; // this ones must be checked thorougly; var $fileman = Array(); //var $fileman; var $path; var $file; // FIXME WHERE IS THIS FILLED? var $sortby; var $messages; var $limit; //for paging (paginacao) var $offset; //for paging (paginacao) var $now; function uifilemanager() { $this->messages = &$_SESSION['phpgw_info']['filemanager']['user']['messages']; $GLOBALS['phpgw']->browser = CreateObject('phpgwapi.browser'); $this->now = date('Y-m-d'); $this->bo = CreateObject('filemanager.bofilemanager'); $this->vfs_functions = CreateObject('filemanager.vfs_functions'); $this->t = $GLOBALS['phpgw']->template; $c = CreateObject('phpgwapi.config','filemanager'); $c->read_repository(); $this->current_config = $c->config_data; // here local vars are created from the HTTP vars reset( $_POST ); while(list($name,) = each( $_POST ) ) { $this->$name = $_POST[ $name ]; } reset( $_GET ); while(list($name,) = each( $_GET ) ) { $$name = $_GET[ $name ]; $this -> $name = $_GET[ $name ]; } $to_decode = array ( 'op' => array('op' => ''), 'path' => array('path' => ''), 'filename' => array('filename' => ''), 'file' => array('file' => ''), 'sortby' => array('sortby' => ''), 'messages' => array('messages' => ''), 'show_upload_boxes' => array('show_upload_boxes' => ''), 'from' => array('from' => ''), 'to' => array('to' => '') ); reset($to_decode); while(list($var, $conditions) = each($to_decode)) { while(list($condvar, $condvalue) = each($conditions)) { if(isset($$condvar) && ($condvar == $var || $$condvar == $condvalue)) { $this->$var = stripslashes(base64_decode($$var)); } } } // get appl. and user prefs $pref = CreateObject('phpgwapi.preferences', $this->bo->userinfo['username']); $pref->read_repository(); //$GLOBALS['phpgw']->hooks->single('add_def_pref', $GLOBALS['appname']); $pref->save_repository(True); $pref_array = $pref->read_repository(); $this->prefs = $pref_array[$this->bo->appname]; //FIXME check appname var in _debug_array //always show name $this->prefs[name] =1; if($this->prefs['viewinnewwin']) { $this->target = '_blank'; } /* Check for essential directories admin must be able to disable these tests */ // check if basedir exist $test=$this->bo->vfs->get_real_info(array('string' => $this->bo->basedir, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); if($test[mime_type]!='Directory') { die('Base directory does not exist, Ask adminstrator to check the global configuration.'); } $test=$this->bo->vfs->get_real_info(array('string' => $this->bo->basedir.$this->bo->fakebase, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); if($test[mime_type]!='Directory') { $this->bo->vfs->override_acl = 1; $this->bo->vfs->mkdir(array( 'string' => $this->bo->fakebase, 'relatives' => array(RELATIVE_NONE) )); $this->bo->vfs->override_acl = 0; //test one more time $test=$this->bo->vfs->get_real_info(array('string' => $this->bo->basedir.$this->bo->fakebase, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); if($test[mime_type]!='Directory') { die('Fake Base directory does not exist and could not be created, please ask the administrator to check the global configuration.'); } else { $this->messages[]= lang('Fake Base Dir did not exist, created a new one.'); } } $test=$this->bo->vfs->get_real_info(array('string' => $this->bo->basedir.$this->bo->homedir, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); if($test[mime_type]!='Directory') { $this->bo->vfs->override_acl = 1; $this->bo->vfs->mkdir(array( 'string' => $this->bo->homedir, 'relatives' => array(RELATIVE_NONE) )); $this->bo->vfs->set_quota(array( 'string' => $this->bo->homedir, 'relatives' => array(RELATIVE_NONE), 'new_quota' => $this->current_config['filemanager_quota_size'] )); $this->bo->vfs->override_acl = 0; //test one more time $test=$this->bo->vfs->get_real_info(array('string' => $this->bo->basedir.$this->bo->homedir, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); if($test[mime_type]!='Directory') { die('Your Home Dir does not exist and could not be created, please ask the adminstrator to check the global configuration.'); } else { $this->messages[]= lang('Your Home Dir did not exist, eGroupWare created a new one.'); // FIXME we just created a fresh home dir so we know there nothing in it so we have to remove all existing content } } } function fileModels() { $GLOBALS['phpgw_info']['flags'] = array ( 'currentapp' => 'filemanager', //'noheader' => False, //'nonavbar' => False, 'nofooter' => False, 'noappheader' => False, 'enable_browser_class' => True ); //$GLOBALS['phpgw']->common->phpgw_header(); $this->t->set_file(array('models' => 'fileModels.tpl')); $this->t->set_block('models','header','header'); $this->t->set_block('models','body','body'); $this->t->set_block('models','footer','footer'); $this->t->set_var('url_1', './index.php?menuaction=filemanager.uifilemanager.uploadModel&model=article'); $this->t->set_var('model_1','article'); $this->t->set_var('lang_1',lang('article')); $this->t->set_var('url_2','./index.php?menuaction=filemanager.uifilemanager.uploadModel&model=calendar'); $this->t->set_var('model_2','calendar'); $this->t->set_var('lang_2',lang('calendar')); $this->t->set_var('url_3','./index.php?menuaction=filemanager.uifilemanager.uploadModel&model=todo'); $this->t->set_var('model_3','todo'); $this->t->set_var('lang_3',lang('todo')); $this->t->set_var('url_4','./index.php?menuaction=filemanager.uifilemanager.uploadModel&model=slide'); $this->t->set_var('model_4','slide'); $this->t->set_var('lang_4',lang('slide')); $this->t->set_var('url_5','./index.php?menuaction=filemanager.uifilemanager.uploadModel&model=cards'); $this->t->set_var('model_5','cards'); $this->t->set_var('lang_5',lang('cards')); $this->t->set_var('url_6','./index.php?menuaction=filemanager.uifilemanager.uploadModel&model=resume'); $this->t->set_var('model_6','resume'); $this->t->set_var('lang_6',lang('resume')); $this->t->pparse('out','models'); } function uploadModel(){ $GLOBALS['phpgw_info']['flags'] = array ( 'currentapp' => 'filemanager', //'noheader' => False, //'nonavbar' => False, 'nofooter' => False, 'noappheader' => False, 'enable_browser_class' => True ); //$GLOBALS['phpgw']->common->phpgw_header(); $filename = lang('new')."_".lang($this->model).rand(0,1000).".html"; $this->bo->vfs->cp(array( 'from'=> PHPGW_SERVER_ROOT . '/filemanager/templates/default/'.$this->model.'.html', 'to'=> $filename, 'relatives' => array(RELATIVE_NONE|VFS_REAL, RELATIVE_ALL) )); $this->bo->vfs->set_attributes(array( 'string'=> $filename, 'relatives' => array(RELATIVE_ALL), 'attributes'=> array( 'mime_type' => "text/html", 'comment' => "" ) )); $this->filename = $filename; $this->edit(); } function index() { $GLOBALS['phpgw_info']['flags'] = array ( 'currentapp' => 'filemanager', //'noheader' => False, //'nonavbar' => False, 'nofooter' => False, 'noappheader' => False, 'enable_browser_class' => True ); //$GLOBALS['phpgw']->common->phpgw_header(); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'dftree', 'dftree' ); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'jscode', 'global', 'filemanager' ); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'jscode', 'load_lang', 'filemanager' ); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'jscode', 'main', 'filemanager' ); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'jscode', 'common_functions', 'filemanager' ); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'jscode', 'connector', 'filemanager' ); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'jscode', 'draw_api', 'filemanager' ); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'jscode', 'drag_area', 'filemanager' ); $GLOBALS[ 'phpgw' ] -> js -> validate_file( 'jscode', 'handler', 'filemanager' ); //include('load_lang.php'); # Page to process users # Code is fairly hackish at the beginning, but it gets better # Highly suggest turning wrapping off due to long SQL queries ### # Some hacks to set and display directory paths correctly ### // new method for switching to a new dir. if($this->changedir=='true' && $this->cdtodir || $this->goto_x) { $this->path = $this->cdtodir; } if(!$this->path) { $this->path = $this->bo->vfs->pwd(); if(!$this->path || $this->bo->vfs->pwd(array('full' => False)) == '') { $this->path = $this->bo->homedir; } } $this->bo->vfs->cd(array('string' => False, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); $this->bo->vfs->cd(array('string' => $this->path, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); $pwd = $this->bo->vfs->pwd(); if(!$this->cwd = substr($this->path, strlen($this->bo->homedir) + 1)) { $this->cwd = '/'; } else { $this->cwd = substr($pwd, strrpos($pwd, '/') + 1); } $this->disppath = $this->path; /* This just prevents // in some cases */ if($this->path == '/') { $this->dispsep = ''; } else { $this->dispsep = '/'; } if(!($this->lesspath = substr($this->path, 0, strrpos($this->path, '/')))) { $this->lesspath = '/'; } /*Check permission*/ if($this->bo->vfs->acl_check(array( 'string' => $this->path, 'relatives' => array(RELATIVE_NONE), 'operation' => PHPGW_ACL_READ ))) { $this->can_read = True; } if ($_SESSION['phpgw_info']['user']['filemanager']['flush'] != 'flushed') { /*Flush journal-deleted*/ $this->bo->vfs->flush_journal(array( 'string' => $this->path, 'relatives' => array(RELATIVE_NONE), 'deleteall' => True )); $_SESSION['phpgw_info']['user']['filemanager']['flush'] = 'flushed'; } # if is different path than home and no permission allowed if($this->path != $this->bo->homedir && $this->path != $this->bo->fakebase && $this->path != '/' && !$this->can_read) { $this->messages[] = lang('You do not have access to %1', $this->path); $this->path = $this->homedir; $this->bo->vfs->cd(array('string' => $this->path, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); $GLOBALS['phpgw']->common->phpgw_footer(); $GLOBALS['phpgw']->common->phpgw_exit(); } $this->bo->userinfo['working_id'] = $this->bo->vfs->working_id; $this->bo->userinfo['working_lid'] = $GLOBALS['phpgw']->accounts->id2name($this->bo->userinfo['working_id']); # Verify path is real if($this->path != $this->bo->homedir && $this->path != '/' && $this->path != $this->bo->fakebase) { if(!$this->bo->vfs->file_exists(array( 'string' => $this->path, 'relatives' => array(RELATIVE_NONE) ))) { $this->messages[] = lang('Error:').lang('Directory %1 does not exist', $this->path); $this->path = $this->homedir; $this->bo->vfs->cd(array('string' => $this->path, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); $GLOBALS['phpgw']->common->phpgw_footer(); $GLOBALS['phpgw']->common->phpgw_exit(); } } # Default is to sort by name if(!$this->sortby) { $this->sortby = 'name'; } if($this->newfile_x && $this->newfile_or_dir) // create new textfile { $this->createfile(); } elseif($this->edit_cancel_x) { $this->readFilesInfo(); $this->fileListing(); } elseif($this->edit_x || $this->edit_preview_x || $this->edit_save_x || $this->edit_save_done_x) { $this->edit(); } else { //$this->readFilesInfo(); $this->fileListing(); } } function get_permissions(){ /* get permissions */ if((preg_match('+^'.$this->bo->fakebase.'\/(.*)(\/|$)+U', $this->path, $matches)) && $matches[1] != $this->bo->userinfo['account_lid']) //FIXME matches not defined { $this->bo->vfs->working_id = $GLOBALS['phpgw']->accounts->name2id($matches[1]);//FIXME matches not defined } else { $this->bo->vfs->working_id = $this->bo->userinfo['username']; } # Check available permissions for $this->path, so we can disable unusable operations in user interface $path = explode('/',$this->path); $owner_id = $this->bo->vfs->ownerOf($this->bo->fakebase,$path[2]); $user_id = $GLOBALS['phpgw_info']['user']['account_id']; if ($owner_id == $user_id) { $rights = 31; }else { $acl = CreateObject ('phpgwapi.acl', $owner_id); $acl->account_id = $owner_id; $acl->read_repository(); $rights = $acl->get_rights($user_id); } return $rights; } function dir_ls() { // change dir to this->path $this->bo->vfs->cd(array('string' => $this->path, 'relatives' => array(RELATIVE_NONE), 'relative' => False)); $return['permissions'] = $this->get_permissions(); $return['quota']['usedSpace'] = $this->bo->vfs->get_size(array( 'string' => $this->path, 'relatives' => array(RELATIVE_NONE) )); $return['files_count'] = $this->bo->vfs->count_files(array( 'string' => $this->path, )); $quota = $this->bo->vfs->get_quota(array( 'string' => $this->path )); reset($this->files_array); $this->readFilesInfo(); for($i = 0; $i != $this->numoffiles; $i++) { $files = $this->files_array[$i]; if($files['mime_type'] == "Directory") { continue; } if ($files['size'] == "" && $files['name'] == "") continue; /* small keys to safe bandwidth */ $tuple['name'] = $files['name']; if ($_SESSION['phpgw_info']['user']['preferences']['filemanager']['viewIcons'] == 1){ if ($files['mime_type'] == 'image/png' || $files['mime_type'] == 'image/gif' || $files['mime_type'] == 'image/jpg') { $filename = str_replace('=','',base64_encode($tuple['name'])); $pathname = str_replace('=','',base64_encode($this->path)); $tuple['icon'] = './index.php?menuaction=filemanager.vfs_functions.summary&file='.$filename.'&path='.$pathname; } else $tuple['icon'] = $this->mime_icon($files['mime_type'],64); } else $tuple['icon'] = $this->mime_icon($files['mime_type']); $tuple['type'] = $files['type']; $tuple['created'] = $this->vfs_functions->dateString2timeStamp($files['created']); $tuple['modified'] = $this->vfs_functions->dateString2timeStamp($files['modified']); $tuple['size'] = $files['size']; $tuple['mime_type'] = $files['mime_type']; $tuple['pub'] = $files['type']; $tuple['createdby_id'] = $GLOBALS['phpgw']->accounts->id2name($files['createdby_id']); $tuple['modifiedby_id'] = $files['modifiedby_id']?$GLOBALS['phpgw']->accounts->id2name($files['modifiedby_id']):''; $tuple['owner'] = $GLOBALS['phpgw']->accounts->id2name($files['owner_id']); $tuple['comment'] = $files['comment']; $tuple['version'] = $files['version']; $output[] = $tuple; } $return['files'] = $output; $return['quota']['quotaSize'] = ($quota*1024*1024); echo serialize($return); } function get_folders_list() { $this->update_groups(); $this->groups_applications = array(); $user_groups = $GLOBALS['phpgw']->accounts->membership(); foreach($user_groups as $val){ $account_name = $GLOBALS['phpgw']->accounts->id2name($val['account_id']); $this->readable_groups[$account_name] = array( 'account_id' => $val['account_id'], 'account_name' => $account_name ); } foreach ($this->readable_groups as $value) { $applications = CreateObject('phpgwapi.applications', $value['account_id']); $this->groups_applications[$value['account_name']] = $applications->read_account_specific(); } // selectbox for change/move/and copy to $this->dirs = $this->all_other_directories(); foreach($this->dirs as $dir) $return[] = $dir['directory'] . $dir['name']; echo serialize($return); } function fileListing() { $this->t->set_file(array('filemanager_list_t' => 'main.tpl')); $this->t->set_block('filemanager_list_t','filemanager_header','filemanager_header'); $this->t->set_block('filemanager_list_t','filemanager_footer','filemanager_footer'); $this->t->set_var( 'url', $GLOBALS[ 'phpgw' ] -> link( '/filemanager' ) ); if($this->numoffiles || $this->cwd) { $vars['path']=''; $vars['css']=''; $vars['css'].=''; $vars[preferences]=''; $GLOBALS[ 'phpgw_info' ][ 'flags' ][ 'java_script' ] .= ''; $vars['new_button']=$this->toolButton('new','createfile',lang('New...')); $vars['new_button'].=''; // reload button with this url $vars['refresh_button']=$this->toolButton('reload','reload',lang('reload')); // go up icon when we're not at the top, dont allow to go outside /home = fakebase if($this->path != '/' && $this->path != $this->bo->fakebase) { $vars['tools_button'] = $this->toolButton('tools','tools',lang('tools')); } else $vars['tools_button'] = ""; $vars['toolbar1']=$toolbar; if(count($this->messages)>0) { foreach($this->messages as $msg) { $messages.=''.$msg.''; } } $this->messages = NULL; $vars['messages']=$messages; $this->t->set_var($vars); $this->t->pparse('out','filemanager_header'); } $this->t->set_var($vars); $this->t->pparse('out','filemanager_footer'); $GLOBALS['phpgw']->common->phpgw_footer(); $GLOBALS['phpgw']->common->phpgw_exit(); } function readFilesInfo() { // start files info # Read in file info from database to use in the rest of the script # $fakebase is a special directory. In that directory, we list the user's # home directory and the directories for the groups they're in $this->numoffiles = 0; if($this->path == $this->bo->fakebase) { // FIXME this test can be removed if(!$this->bo->vfs->file_exists(array('string' => $this->bo->homedir, 'relatives' => array(RELATIVE_NONE)))) { $this->bo->vfs->mkdir(array('string' => $this->bo->homedir, 'relatives' => array(RELATIVE_NONE))); } $ls_array = $this->bo->vfs->ls(array( 'string' => $this->bo->homedir, 'relatives' => array(RELATIVE_NONE), 'checksubdirs' => False, 'nofiles' => True )); $this->files_array[] = $ls_array[0]; $this->numoffiles++; reset($this->readable_groups); while(list($num, $group_array) = each($this->readable_groups)) { # If the group doesn't have access to this app, we don't show it /*if(!$this->groups_applications[$group_array['account_name']][$this->bo->appname]['enabled']) { continue; } */ if(!$this->bo->vfs->file_exists(array('string' => $this->bo->fakebase.'/'.$group_array['account_name'],'relatives' => array(RELATIVE_NONE)))) { $this->bo->vfs->override_acl = 1; $this->bo->vfs->mkdir(array( 'string' => $this->bo->fakebase.'/'.$group_array['account_name'], 'relatives' => array(RELATIVE_NONE) )); // FIXME we just created a fresh group dir so we know there nothing in it so we have to remove all existing content $this->bo->vfs->override_acl = 0; $this->bo->vfs->set_attributes(array('string' => $this->bo->fakebase.'/'.$group_array['account_name'],'relatives' => array(RELATIVE_NONE),'attributes' => array('owner_id' => $group_array['account_id'],'createdby_id' => $group_array['account_id']))); } $ls_array = $this->bo->vfs->ls(array('string' => $this->bo->fakebase.'/'.$group_array['account_name'],'relatives' => array(RELATIVE_NONE),'checksubdirs' => False,'nofiles' => True)); $this->files_array[] = $ls_array[0]; $this->numoffiles++; } } else { $ls_array = $this->bo->vfs->ls(array( 'string' => $this->path, 'relatives' => array(RELATIVE_NONE), 'checksubdirs' => False, 'nofiles' => False, 'orderby' => $this->criteria, 'otype' => $this->otype, 'limit' => $this->limit, 'offset' => $this->offset )); while(list($num, $file_array) = each($ls_array)) { $this->numoffiles++; $this->files_array[] = $file_array; } } if(!is_array($this->files_array)) { $this->files_array = array(); } // end file count } function removedir() { require_once(PHPGW_INCLUDE_ROOT.'/phpgwapi/inc/class.rsa.inc.php'); $rsa = new rsa(); $toRemove = $rsa->decode($this->path); if ( $this->bo->vfs->rm(array( 'string' => $toRemove, 'relatives' => array (RELATIVE_NONE) )) ) echo "True"; else echo "False"; } function createdir() { if($this->bo->badchar = $this->bo->bad_chars($this->filename, True, True)) { echo lang('Error:').$this->bo->html_encode(lang('Directory names cannot contain "%1"', $badchar), 1); return; } /* TODO is this right or should it be a single $ ? */ if($this->filename[strlen($this->filename)-1] == ' ' || $this->filename[0] == ' ') { echo lang('Error:').lang('Cannot create directory because it begins or ends in a space'); } $ls_array = $this->bo->vfs->ls(array( 'string' => $this->path . '/' . $this->filename, 'relatives' => array(RELATIVE_NONE), 'checksubdirs' => False, 'nofiles' => True )); $fileinfo = $ls_array[0]; if($fileinfo['name']) { if($fileinfo['mime_type'] != 'Directory') { echo lang('Error:').lang('%1 already exists as a file',$fileinfo['name']); } else { echo lang('Error:').lang('Directory %1 already exists', $fileinfo['name']); } } else { if($this->bo->vfs->mkdir(array('string' => $this->filename))) { echo lang('Created directory %1', $this->disppath.'/'.$this->filename); } else { echo lang('Error:').lang('Could not create %1', $this->disppath.'/'.$this->filename); } } echo lang('Directory created'); } function getReturnExecuteForm(){ $response = $_SESSION['response']; $_SESSION['response'] = null; echo $response; return; } function showUploadboxes() { $GLOBALS['phpgw_info']['flags'] = array ( 'currentapp' => 'filemanager', //'noheader' => True, //'nonavbar' => True, 'nofooter' => True, 'noappheader' => True ); //$GLOBALS['phpgw']->common->phpgw_header(); $this->t->set_file(array('upload' => 'upload.tpl')); $this->t->set_block('upload','upload_header','upload_header'); $this->t->set_block('upload','row','row'); $this->t->set_block('upload','upload_footer','upload_footer'); if($this->path != '/' && $this->path != $this->bo->fakebase) { $vars[max_size]=lang('Note: Uploaded is limited to %1MB',($this->current_config['filemanager_Max_file_size'])); $vars[form_action]=$GLOBALS[phpgw]->link('/filemanager/inc/upload.php'); //$vars[form_action]=$GLOBALS[phpgw]->link('/index.php','menuaction=filemanager.uifilemanager.index'); $vars[path]=$this->path; $vars[lang_file]=lang('File'); $vars[lang_comment]=lang('Comment'); $vars[num_upload_boxes]=1; $this->t->set_var($vars); $this->t->pparse('out','upload_header'); $this->t->set_var('row_tr_color',$tr_color); $this->t->parse('rows','row'); $this->t->pparse('out','row'); $vars[lang_upload]=lang('Upload files'); $vars[change_upload_boxes].=lang('Show') . ' '; $this->t->set_var($vars); $this->t->pparse('out','upload_footer'); } } /* create textfile */ function createfile() { $this->filename=$this->newfile_or_dir; if($this->filename) { if($badchar = $this->bo->bad_chars($this->filename, True, True)) { $this->messages[] = lang('Error:').lang('File names cannot contain "%1"',$badchar); $this->fileListing(); } if($this->bo->vfs->file_exists(array( 'string'=> $this->filename, 'relatives' => array(RELATIVE_ALL) ))) { $this->messages[]= lang('Error:').lang('File %1 already exists. Please edit it or delete it first.', $this->filename); $this->fileListing(); } if($this->bo->vfs->touch(array( 'string' => $this->filename, 'relatives' => array(RELATIVE_ALL) ))) { $this->edit = 1; $this->numoffiles++; $this->edit(); } else { $this->messages[]= lang('Error:').lang('File %1 could not be created.', $this->filename); $this->fileListing(); } } } # Handle Editing files function edit() { if($this->filename) { if (! $this->vfs_functions->verifyLock($this->path.'/'.$this->filename,RELATIVE_NONE)){ $GLOBALS['phpgw']->redirect('/index.php'); } $ls_array = $this->bo->vfs->ls(array( 'string' => $this->path.'/'.$this->filename, 'relatives' => array(RELATIVE_NONE), 'checksubdirs' => False, 'nofiles' => True )); $this->bo->vfs->touch(array( 'string'=> $this->path.'/'.$this->filename, 'relatives' => array(RELATIVE_NONE) )); if($ls_array[0]['mime_type']) { $mime_type = $ls_array[0]['mime_type']; } elseif($this->prefs['viewtextplain']) { $mime_type = 'text/plain'; } $editable = array('','text/plain','text/csv','text/html','text/text','message/rfc822'); if(!in_array($mime_type,$editable)){ $this->messages[] = lang('Error:').lang('Impossible to edit this file'); $this->readFilesInfo(); $this->fileListing(); return; } } $this->readFilesInfo(); if ($mime_type == 'text/html') $this->t->set_file(array('filemanager_edit' => 'edit_html.tpl')); else $this->t->set_file(array('filemanager_edit' => 'edit_file.tpl')); $this->t->set_block('filemanager_edit','row','row'); $vars[refresh_script] = ""; $vars[preview_content]=''; if($this->edit_file) { $this->edit_file_content = stripslashes($this->edit_file_content); } if($this->edit_preview_x) { $content = $this->edit_file_content; $vars[lang_preview_of]=lang('Preview of %1', $this->path.'/'.$edit_file); $vars[preview_content]=nl2br($content); } elseif($this->edit_save_x || $this->edit_save_done_x) { $content = $this->edit_file_content; //die( $content); if($this->bo->vfs->write(array( 'string' => $this->path.'/'.$this->edit_file, 'relatives' => array(RELATIVE_NONE), 'content' => $content ))) { $this->messages[]=lang('Saved %1', $this->path.'/'.$this->edit_file); if($this->edit_save_done_x) { $this->readFilesInfo(); $this->fileListing(); exit; } } else { $this->messages[]=lang('Could not save %1', $this->path.'/'.$this->edit_file); } } # If we're in preview or save mode, we only show the file # being previewed or saved if($this->edit_file &&($this->filename != $this->edit_file)) { continue; } if($this->filename && $this->bo->vfs->file_exists(array( 'string' => $this->filename, 'relatives' => array(RELATIVE_ALL) ))) { if($this->edit_file) { $content = stripslashes($this->edit_file_content); } else { $content = $this->bo->vfs->read(array('string' => $this->filename)); } $vars[form_action]= $GLOBALS['phpgw']->link('/index.php','menuaction=filemanager.uifilemanager.index','path='.$this->path); $vars[edit_file]=$this->filename; # We need to include all of the fileman entries for each file's form, # so we loop through again for($i = 0; $i != $this->numoffiles; $i++) { if($this->filename) $value='value="'.$this->filename.'"'; $vars[filemans_hidden]=''; } $vars[file_content]=$content; $vars[buttonPreview]=$this->inputButton('edit_preview','edit_preview',lang('Preview %1', $this->bo->html_encode($this->fileman[0], 1))); $vars[buttonSave]=$this->inputButton('edit_save','save',lang('Save %1', $this->bo->html_encode($this->filename, 1))); $vars[buttonDone]=$this->inputButton('edit_save_done','ok',lang('Save %1, and go back to file listing ', $this->bo->html_encode($this->filename, 1))); $vars[buttonCancel]=$this->inputButton('edit_cancel','cancel',lang('Cancel editing %1 without saving', $this->bo->html_encode($this->filename, 1))); if ($mime_type == 'text/html'){ $vars[fck_edit] = ' '; } $this->t->set_var($vars); $this->t->parse('rows','row'); $this->t->pparse('out','row'); } } function history() { if($this->file) // FIXME this-file is never defined { $journal_array = $this->bo->vfs->get_journal(array( 'string' => $this->file,//FIXME 'relatives' => array(RELATIVE_ALL) )); if(is_array($journal_array)) { $this->html_table_begin(); $this->html_table_row_begin(); $this->html_table_col_begin(); echo lang('Date'); $this->html_table_col_end(); $this->html_table_col_begin(); echo lang('Version'); $this->html_table_col_end(); $this->html_table_col_begin(); echo lang('Who'); $this->html_table_col_end(); $this->html_table_col_begin(); echo lang('Operation'); $this->html_table_col_end(); $this->html_table_row_end(); while(list($num, $journal_entry) = each($journal_array)) { $this->html_table_row_begin(); $this->html_table_col_begin(); $this->bo->html_text($journal_entry['created'] . ' '); $this->html_table_col_end(); $this->html_table_col_begin(); $this->bo->html_text($journal_entry['version'] . ' ' ); $this->html_table_col_end(); $this->html_table_col_begin(); $this->bo->html_text($GLOBALS['phpgw']->accounts->id2name($journal_entry['owner_id']) . ' '); $this->html_table_col_end(); $this->html_table_col_begin(); $this->bo->html_text($journal_entry['comment']); $this->html_table_col_end(); } $this->html_table_end(); $GLOBALS['phpgw']->common->phpgw_footer(); $GLOBALS['phpgw']->common->phpgw_exit(); } else { echo lang('No version history for this file/directory'); } } } function view() { if (!$this->bo->vfs->acl_check(array( 'string' => $this->path, 'relatives' => array(RELATIVE_NONE), 'operation' => PHPGW_ACL_READ ))) { $this->messages[] = lang("You have no permission to access this file"); header('Location:'.$this->encode_href('inc/index.php?menuaction=filemanager.uifilemanager.index','&path='.base64_encode($this->bo->homedir))); return; } if($this->file) //FIXME { $ls_array = $this->bo->vfs->ls(array( 'string' => $this->path.'/'.$this->file,//FIXME 'relatives' => array(RELATIVE_NONE), 'checksubdirs' => False, 'nofiles' => True )); if($ls_array[0]['mime_type']) { $mime_type = $ls_array[0]['mime_type']; } elseif($this->prefs['viewtextplain']) { $mime_type = 'text/plain'; } $viewable = array('','text/plain','text/csv','text/html', 'text/text','image/jpeg','image/png','image/gif', 'audio/mpeg','video/mpeg'); if(in_array($mime_type,$viewable)) { /*Note: if you put application/octet-stream you force download */ header('Content-type: ' . $mime_type); header('Content-disposition: filename="' . addslashes($this->file) . '"'); Header("Pragma: public"); } else { $GLOBALS['phpgw']->browser->content_header($this->file,$mime_type,$ls_array[0]['size']); } if ($ls_array[0]['size'] < 10240) { echo $this->bo->vfs->read(array( 'string' => $this->path.'/'.$this->file,//FIXME 'relatives' => array(RELATIVE_NONE) )); } else { $this->bo->vfs->print_content(array( 'string' => $this->path.'/'.$this->file, 'relatives' => array(RELATIVE_NONE) ) ); } $GLOBALS['phpgw']->common->phpgw_exit(); } } function export(){ if($this->file) { $ls_array = $this->bo->vfs->ls(array( 'string' => $this->path.'/'.$this->file, 'relatives' => array(RELATIVE_NONE), 'checksubdirs' => False, 'nofiles' => True )); /*$timestamp = $this->vfs_functions->dateString2timeStamp($ls_array[0]['modified']); if (time() - $timestamp < 60 && $ls_array[0]['modifiedby_id'] != $GLOBALS['phpgw_info']['user']['account_id']); { // recently than last minute: someone is editing }*/ $mime_type = $ls_array[0]['mime_type']; $formats = array('text/html'); if(!in_array($mime_type,$formats)){ echo lang('Impossible to export this file'); return False; } $content = $this->bo->vfs->read(array('string' => $this->path.'/'.$this->file, 'relatives' => array(RELATIVE_NONE) )); include_once('filemanager/tp/dompdf/dompdf_config.inc.php'); $dompdf = new DOMPDF(); $dompdf->load_html($content); $dompdf->set_paper($this->prefs['pdf_paper_type'], $this->prefs['pdf_type']); /* Would be nice to implement 'Title','Subject','Author','Creator','CreationDate'*/ $dompdf->render(); $dompdf->stream(strtok($this->file,'.').".pdf"); $GLOBALS['phpgw']->common->phpgw_exit(); } } //give back an array with all directories except current and dirs that are not accessable function all_other_directories() { # First we get the directories in their home directory $dirs = array(); $dirs[] = array('directory' => $this->bo->fakebase, 'name' => $this->bo->userinfo['account_lid']); $tmp_arr=array( 'string' => $this->bo->homedir, 'relatives' => array(RELATIVE_NONE), 'checksubdirs' => True, 'mime_type' => 'Directory' ); $ls_array = $this->bo->vfs->ls($tmp_arr); while(list($num, $dir) = each($ls_array)) { $dirs[] = $dir; } # Then we get the directories in their readable groups' home directories reset($this->readable_groups); while(list($num, $group_array) = each($this->readable_groups)) { // Don't list directories for groups that don't exists $test=$this->bo->vfs->get_real_info(array('string' => $this->bo->fakebase.'/'.$group_array['account_name'], 'relatives' => array(RELATIVE_NONE), 'relative' => False)); if($test[mime_type]!='Directory') { continue; } $dirs[] = array('directory' => $this->bo->fakebase, 'name' => $group_array['account_name']); $tmp_arr=array( 'string' => $this->bo->fakebase.'/'.$group_array['account_name'], 'relatives' => array(RELATIVE_NONE), 'checksubdirs' => True, 'mime_type' => 'Directory' ); $ls_array = $this->bo->vfs->ls($tmp_arr); while(list($num, $dir) = each($ls_array)) { $dirs[] = $dir; } } reset($dirs); while(list($num, $dir) = each($dirs)) { if(!$dir['directory']) { continue; } # So we don't display // if($dir['directory'] != '/') { $dir['directory'] .= '/'; } $return[] = $dir; } return $return; } function update_groups() { # Get their readable groups to be used throughout the script $acl = array(); $groups = array(); $acl = $GLOBALS['phpgw']->acl->get_ids_for_location($GLOBALS['phpgw_info']['user']['account_id'],1,'filemanager'); if (is_array($acl)) foreach($acl as $key => $value){ $info = array(); $info = $GLOBALS['phpgw']->accounts->get_account_data($value); $groups[$key]['account_id'] = $value; $groups[$key]['account_lid'] = $info[$value]['lid']; $groups[$key]['account_name'] = $info[$value]['firstname']; $groups[$key]['account_lastname'] = $info[$value]['lastname']; $groups[$key]['account_fullname'] = $info[$value]['fullname']; } $this->readable_groups = array(); while(list($num, $account) = each($groups)) { if($this->bo->vfs->acl_check(array('owner_id' => $account['account_id'],'operation' => PHPGW_ACL_READ))) { $this->readable_groups[$account['account_lid']] = Array('account_id' => $account['account_id'], 'account_name' => $account['account_lid']); } } } function search() { /* TODO this is a primitive search */ $this->update_groups(); $this->dirs = $this->all_other_directories(); $path = $this->path; if (strlen($this->text) > 3) { $this->text = strtoupper($this->text); foreach($this->dirs as $elem) { $this->path = $elem['directory'].$elem['name']; reset($this->files_array); $this->readFilesInfo(); for($i = 0; $i < count($this->files_array); $i++) { $comment = strtoupper($this->files_array[$i]['comment']); $name = strtoupper($this->files_array[$i]['name']); if (strstr($name,$this->text) || strstr($comment,$this->text) ){ $return[$this->files_array[$i]['directory'].$name] = $this->files_array[$i]; $return[$this->files_array[$i]['directory'].$name]['icon'] = $this->mime_icon($this->files_array[$i]['mime_type']); } } if (count($return) > 50) { $return = array_slice($return,0,50); break; } } } echo serialize(array_values($return)); } /* seek icon for mimetype else return an unknown icon */ function mime_icon($mime_type, $size=16) { if(!$mime_type) $mime_type='unknown'; $mime_type=str_replace ('/','_',$mime_type); $img=$GLOBALS['phpgw']->common->image('filemanager','mime'.$size.'_'.strtolower($mime_type)); if(!$img) $img=$GLOBALS['phpgw']->common->image('filemanager','mime'.$size.'_unknown'); return $img; } function toolButton($link,$img='',$description='') { $image=$GLOBALS['phpgw']->common->image('filemanager','button_'.strtolower($img)); if($img) { return ''.$description.''; } } function inputButton($name,$img='',$description='') { $image=$GLOBALS['phpgw']->common->image('filemanager','button_'.strtolower($img)); if($img) { return '