True ); var $so; var $vfs; var $rootdir; var $fakebase; var $appname; var $settings; var $filesdir; var $hostname; var $userinfo = Array(); var $homedir; var $file_attributes; var $help_info; var $errors; var $rename; var $delete; var $go; var $copy; var $move; var $download; var $createdir; var $newdir; var $createfile; var $newfile; var $fileman = Array(); var $op; var $file; var $help_name; var $path; var $disppath; var $dispsep; var $sortby = 'name'; var $messages = Array(); var $renamefiles; var $comment_files = Array(); var $show_upload_boxes = 5; var $memberships; var $now; var $matches; // var $debug = True; var $debug = False; function bophpwebhosting() { $this->vfs = CreateObject('phpgwapi.vfs'); $to_decode = Array( /* Decode 'var' when 'avar' == 'value' or 'var' when 'var' is set */ 'errors', 'op', 'path', 'file', 'todir', 'sortby', 'fileman', 'messages', 'help_name', 'renamefiles', 'comment_files', 'show_upload_boxes', 'submit', 'rename', 'delete', 'go', 'copy', 'move', 'download', 'newfile', 'createfile', 'newdir', 'createdir' ); $c_to_decode = count($to_decode); for($i=0;$i<$c_to_decode;$i++) { $this->initialize_vars($to_decode[$i]); } $this->rootdir = $this->vfs->basedir; $this->fakebase = $this->vfs->fakebase; $this->appname = $GLOBALS['phpgw_info']['flags']['currentapp']; $this->settings = $GLOBALS['phpgw_info']['user']['preferences'][$this->appname]; if(stristr($this->rootdir,PHPGW_SERVER_ROOT)) { $this->filesdir = substr($this->rootdir,strlen(PHPGW_SERVER_ROOT)); } else { $this->filesdir = ''; } $this->hostname = $GLOBALS['phpgw_info']['server']['webserver_url'].$this->filesdir; $this->userinfo['username'] = $GLOBALS['phpgw_info']['user']['account_id']; $this->userinfo['account_lid'] = $GLOBALS['phpgw']->accounts->id2name($this->userinfo['username']); $this->userinfo['hdspace'] = 10000000000; $this->homedir = $this->fakebase.SEP.$this->userinfo['account_lid']; if(!defined('NULL')) { define('NULL',''); } $this->so = CreateObject('phpwebhosting.sophpwebhosting'); $this->file_attributes = Array( 'name' => 'Filename', 'deletable' => 'Deletable', 'mime_type' => 'MIME Type', 'size' => 'Size', 'created' => 'Created', 'modified' => 'Modified', 'owner' => 'Owner', 'createdby_id' => 'Created by', 'modifiedby_id' => 'Modified by', 'app' => 'Application', 'comment' => 'Comment', 'version' => 'Version' ); if($this->go) { $this->path = $this->todir; } if($this->debug) { echo 'DEBUG: bo.bophpwebhosting: PATH = '.$this->path.'
'."\n"; } if(!$this->path) { $this->path = $this->vfs->pwd(); if (!$this->path || $this->vfs->pwd(False) == '') { $this->path = $this->homedir; } } $this->vfs->cd(False,False,Array(RELATIVE_NONE)); $this->vfs->cd($this->path,False,Array(RELATIVE_NONE)); $this->pwd = $this->vfs->pwd(); if (!$this->cwd = substr($this->path,strlen($this->homedir) + 1)) { $this->cwd = '/'; } else { $this->cwd = substr($this->pwd,strrpos($this->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 = '/'; } $this->now = date('Y-m-d'); if($this->debug) { echo 'PHPWebHosting debug:
' . 'path: '.$this->path.'
' . 'disppath: '.$this->disppath.'
' . 'cwd: '.$this->cwd.'
' . 'lesspath: '.$this->lesspath.'
' . 'fakebase: '.$this->fakebase.'
' . 'homedir: '.$this->homedir.'

' . 'phpGW debug:
' . 'real getabsolutepath: '.$this->vfs->getabsolutepath(False, False, False).'
' . 'fake getabsolutepath: '.$this->vfs->getabsolutepath(False).'
' . 'appsession: '.$GLOBALS['phpgw']->session->appsession('vfs','').'
' . 'pwd: '.$this->vfs->pwd().'
'; } ### # Get their memberships to be used throughout the script ### $this->memberships = $GLOBALS['phpgw']->accounts->membership($this->userinfo['username']); if(!is_array($this->memberships)) { settype($this->memberships,'array'); $this->memberships = Array(); } $group_applications = CreateObject('phpgwapi.applications'); while(list($num,$group_array) = each($this->memberships)) { $group_applications->account_id = get_account_id($GLOBALS['phpgw']->accounts->name2id($group_array['account_name'])); $this->membership_applications[$group_array['account_name']] = $group_applications->read_account_specific(); } ### # We determine if they're in their home directory or a group's directory, # and set the VFS working_id appropriately ### if((preg_match('+^'.$this->fakebase.'\/(.*)(\/|$)+U',$this->path,$this->matches)) && $this->matches[1] != $this->userinfo['account_lid']) { $this->vfs->working_id = $GLOBALS['phpgw']->accounts->name2id($matches[1]); } else { $this->vfs->working_id = $this->userinfo['username']; } } function initialize_vars($name) { $var = get_var($name,Array('GET','POST')); if($this->debug) { echo ''."\n"; } if(is_array($this->$name) && $var) { $temp = Array(); while(list($varkey,$varvalue) = each($var)) { if(is_int($varkey)) { $temp[$varkey] = urldecode($varvalue); } else { $temp[urldecode($varkey)] = $varvalue; } } } elseif($var) { $temp = urldecode($var); } if(isset($temp)) { $this->$name = $temp; } } function load_files() { ### # 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 ### if ($this->path == $this->fakebase) { if (!$this->vfs->file_exists($this->homedir,Array(RELATIVE_NONE))) { $this->vfs->mkdir($this->homedir,Array(RELATIVE_NONE)); } $ls_array = $this->vfs->ls($this->homedir,Array(RELATIVE_NONE),False,False,True); $this->files_array[] = $ls_array[0]; reset ($this->memberships); while(list($num, $group_array) = each($this->memberships)) { ### # If the group doesn't have access to this app, we don't show it ### if (!$this->membership_applications[$group_array['account_name']][$GLOBALS['appname']]['enabled']) { continue; } if (!$this->vfs->file_exists($this->fakebase.'/'.$group_array['account_name'],Array(RELATIVE_NONE))) { $this->vfs->mkdir($this->fakebase.'/'.$group_array['account_name'],Array(RELATIVE_NONE)); $this->vfs->set_attributes($this->fakebase.'/'.$group_array['account_name'],Array(RELATIVE_NONE),Array('owner_id' => $group_array['account_id'], 'createdby_id' => $group_array['account_id'])); } $ls_array = $this->vfs->ls($this->fakebase.'/'.$group_array['account_name'],Array(RELATIVE_NONE),False,False,True); $this->files_array[] = $ls_array[0]; } } else { $ls_array = $this->vfs->ls($this->path,Array(RELATIVE_NONE),False,False,False,$this->sortby); if ($this->debug) { echo '# of files found in "'.$this->path.'" : '.count($ls_array).'
'."\n"; } while(list($num,$file_array) = each($ls_array)) { $this->files_array[] = $file_array; if ($this->debug) { echo 'Filename: '.$file_array['name'].'
'."\n"; } } } if(!is_array($this->files_array)) { $this->files_array = Array(); } return $this->files_array; } function convert_date($data) { if($data && $data != '0000-00-00') { $year = substr($data,0,4); $month = substr($data,5,2); $day = substr($data,8,2); $datetime = mktime(0,0,0,$month,$day,$year); $data = date($GLOBALS['phpgw_info']['user']['preferences']['common']['dateformat'],$datetime); } else { $data = ' '; } return $data; } function f_go() { $this->path = $this->todir; } function f_delete() { $numoffiles = count($this->fileman); for($i=0;$i!=$numoffiles;$i++) { if($this->fileman[$i]) { $ls_array = $this->vfs->ls($this->path.SEP.$this->fileman[$i],Array(RELATIVE_NONE),False,False,True); $fileinfo = $ls_array[0]; if($fileinfo) { if($fileinfo['mime_type'] == 'Directory') { $mime_type = $fileinfo['mime_type']; } else { $mime_type = 'File'; } if($this->vfs->delete($this->path.SEP.$this->fileman[$i],Array(RELATIVE_USER_NONE))) { $errors[] = ''.$mime_type.' Deleted: '.$this->path.SEP.$this->fileman[$i].''; } else { $errors[] = 'Could not delete '.$this->path.SEP.$this->fileman[$i].''; } } else { $errors[] = ''.$this->path.SEP.$this->fileman[$i].' does not exist!'; } } } return $errors; } function f_copy() { $numoffiles = count($this->fileman); for($i=0;$i!=$numoffiles;$i++) { if($this->fileman[$i]) { if($this->vfs->cp($this->path.SEP.$this->fileman[$i],$this->todir.SEP.$this->fileman[$i],Array(RELATIVE_NONE,RELATIVE_NONE))) { $errors[] = 'File copied: '.$this->path.SEP.$this->fileman[$i].' to '.$this->todir.SEP.$this->fileman[$i].''; } else { $errors[] = 'Could not copy '.$this->path.SEP.$this->fileman[$i].' to '.$this->todir.SEP.$this->fileman[$i].''; } } } return $errors; } function f_move() { $numoffiles = count($this->fileman); for($i=0;$i!=$numoffiles;$i++) { if($this->fileman[$i]) { if($this->vfs->mv($this->path.SEP.$this->fileman[$i],$this->todir.SEP.$this->fileman[$i],Array(RELATIVE_NONE,RELATIVE_NONE))) { $errors[] = 'File moved: '.$this->path.SEP.$this->fileman[$i].' to '.$this->todir.SEP.$this->fileman[$i].''; } else { $errors[] = 'Could not move '.$this->path.SEP.$this->fileman[$i].' to '.$this->todir.SEP.$this->fileman[$i].''; } } } return $errors; } function f_download() { $numoffiles = count($this->fileman); for($i=0;$i!=$numoffiles;$i++) { if($this->fileman[$i] && $this->vfs->file_exists($this->bo->path.SEP.$this->bo->fileman[$i],Array(RELATIVE_NONE))) { execmethod($this->appname.'.ui'.$this->appname.'.view_file', Array( 'path' => $this->path, 'file' => $this->fileman[$i] ) ); $errors[] = 'File downloaded: '.$this->path.SEP.$this->fileman[$i].''; } else { $errors[] = 'File does not exist: '.$this->path.SEP.$this->fileman[$i].''; } } return $errors; } function f_newdir() { if ($this->newdir && $this->createdir) { if ($badchar = $this->bad_chars($this->createdir,True,True)) { $errors[] = 'Directory names cannot contain "'.$badchar.'"'; return $errors; } if (substr($this->createdir,strlen($this->createdir)-1,1) == ' ' || substr($this->createdir,0,1) == ' ') { $errors[] = 'Cannot create directory because it begins or ends in a space'; return $errors; } $ls_array = $this->vfs->ls($this->path.SEP.$this->createdir,Array(RELATIVE_NONE),False,False,True); $fileinfo = $ls_array[0]; if ($fileinfo['name']) { if ($fileinfo['mime_type'] != 'Directory') { $errors[] = ''.$fileinfo['name'].' already exists as a file'; } else { $errors[] = 'Directory '.$fileinfo['name'].' already exists.'; } } else { if ($this->vfs->mkdir($this->path.SEP.$this->createdir,Array(RELATIVE_NONE))) { $errors[] = 'Created directory '.$this->path.SEP.$this->createdir.''; // $this->path = $this->path.SEP.$this->createdir; } else { $errors[] = 'Could not create '.$this->path.SEP.$this->createdir.''; } } } return $errors; } function f_newfile() { if ($this->newfile && $this->createfile) { if($badchar = $this->bad_chars($this->createfile,True,True)) { $errors[] = 'Filenames cannot contain "'.$badchar.'"'; return $errors; } if($this->vfs->file_exists($this->path.SEP.$this->createfile,Array(RELATIVE_NONE))) { $errors[] = 'File '.$this->path.SEP.$this->createfile.' already exists. Please edit it or delete it first.'; return $errors; } if(!$this->vfs->touch($this->path.SEP.$this->createfile,Array(RELATIVE_NONE))) { $errors[] = 'File '.$this->path.SEP.$this->createfile.' could not be created.'; } } else { $errors[] = 'Filename not provided!'; } return $errors; } function load_help_info() { $this->help_info = Array( array ("up", "The Up button takes you to the directory above the current directory. For example, if you're in /home/jdoe/mydir, the Up button would take you to /home/jdoe."), array ("directory_name", "The name of the directory you're currently in."), array ("home", "The Home button takes you to your personal home directory."), array ("sort_by", "Click on any of the column headers to sort the list by that column."), array ("filename", "The name of the file or directory."), array ("mime_type", "The MIME-type of the file. Examples include text/plain, text/html, image/jpeg. The special MIME-type Directory is used for directories."), array ("size", "The size of the file or directory in the most convenient units: bytes (B), kilobytes (KB), megabytes (MB), gigabytes (GB). Sizes for directories include subfiles and subdirectories."), array ("created", "When the file or directory was created."), array ("modified", "When the file or directory was last modified."), array ("owner", "The owner of the file or directory. This can be a user or group name."), array ("created_by", "Displays who created the file or directory."), array ("modified_by", "Displays who last modified the file or directory."), array ("application", "The application associated with the file or directory. Usually the application used to create it. A blank application field is ok."), array ("comment", "The comment for the file or directory. Comments can be set when creating the file or directory, and created or edited any time thereafter."), array ("version", "The current version for the file or directory. Clicking on the version number will display a list of changes made to the file or directory."), array ("edit", "Edit the text of the selected file(s). You can select more than one file; this is useful when you want to copy part of one file into another. Clicking Preview will show you a preview of the file. Click Save to save your changes."), array ("rename", "Rename the selected file(s). You can select as many files or directories as you want. You are presented with a text field to enter the new name of each file or directory."), array ("delete", "Delete the selected file(s). You can select as many files or directories as you want. When deleting directories, the entire directory and all of its contents are deleted. You will not be prompted to make sure you want to delete the file(s); make sure you really want to delete them before clicking Delete."), array ("edit_comments", "Create a comment for a file or directory, or edit an existing comment. You can select as many files or directories as you want."), array ("go_to", "The Go to button takes you to the directory selected in the drop down [directory_list|Directory List]."), array ("copy_to", "This will copy all selected files and directories to the directory selected in the drop down [directory_list|Directory List]."), array ("move_to", "This will move all selected files and directories to the directory selected in the drop down [directory_list|Directory List]."), array ("directory_list", "The Directory List contains a list of all directories you have (at least) read access to. Selecting a directory and clicking one of the [go_to|Go to]/[copy_to|Copy to]/[move_to|Move to] buttons will perform the selected action on that directory. For example, if you select \"/home/somegroup/reports\" from the Directory List, and click the \"[copy_to|Copy to]\" button, all selected files and directories will be copied to \"/home/somegroup/reports\"."), array ("download", "Download the first selected file to your local computer. You can only download one file at a time. Directories cannot be downloaded, only files."), array ("create_folder", "Creates a directory (folder == directory). The name of the directory is specified in the text box next to the Create Folder button."), array ("create_file", "Creates a file in the current directory. The name of the file is specified in the text box next to the Create File button. After clicking the Create File button you will be presented with the [edit|Edit] screen, where you may edit the file you just created. If you do not with to make any changes to the file at this time, simply click the Save button and the file will be saved as an empty file."), array ("command_line", "Enter a Unix-style command line here, which will be executed when the [execute|Execute] button is pressed. If you don't know what this is, you probably should turn the option off in the Preferences."), array ("execute", "Clicking the Execute button will execute the Unix-style [command_line|command line] specified in the text box above. If you don't know what this is, you probably should turn the option off in the Preferences."), array ("update", "Sync the database with the filesystem for the current directory. This is useful if you use another interface to access the same files. Any new files or directories in the current directory will be read in, and the attributes for the other files will be updated to reflect any changes to the filesystem. Update is run automatically every few page loads (currently every 20 page loads as of this writing, but that may have changed by now)."), array ("file_stats", "Various statistics on the number and size of the files in the current directory. In some situations, these reflect different statistics. For example, when in / or the base directory."), array ("upload_file", "The full path of the local file to upload. You can type it in or use the Browse.. button to select it. The file will be uploaded to the current directory. You cannot upload directories, only files."), array ("upload_comment", "The inital comment to use for the newly uploaded file. Totally optional and completely arbitrary. You can [edit_comments|create or edit the comment] at any time in the future."), array ("upload_files", "This will upload the files listed in the input boxes above, and store them in the current directory."), array ("show_upload_fields", "This setting determines how many [upload_files|upload fields] will be shown at once. You can change the default number that will be shown in the preferences.") ); } function borkb ($size,$enclosed = NULL,$return = 0) { if(!$size) { $size = 0; } if($enclosed) { $left = '('; $right = ')'; } if($size<1024) { return $left.$size.' B  '.$right; } else { return $left.round($size/1024).' KB'.$right; } } ### # Check for and return the first unwanted character ### function bad_chars($string,$all = True,$return = 0) { if($all) { if (preg_match("-([\\/<>\'\"\&])-", $string, $badchars)) { $rstring = $badchars[1]; } } else { if (preg_match("-([\\/<>])-", $string, $badchars)) { $rstring = $badchars[1]; } } return $rstring; } ### # Match character in string using ord (). ### function ord_match($string, $charnum) { for ($i=0;$ihostname,$string)) { $rstring = ereg_replace('^'.$this->hostname.'/','',$string); $rstring = preg_replace("/(.*)(\/|$)/Ue","rawurlencode (base64_encode ('\\1')).'\\2'",$rstring); $rstring = $this->hostname.'/'.$rstring; } else { $rstring = rawurlencode($string); /* Terrible hack, decodes all /'s back to normal */ $rstring = preg_replace("/%2F/",'/',$rstring); } return($this->eor($rstring,$return)); } function string_decode($string,$return = False) { $rstring = rawurldecode($string); return($this->eor($rstring,$return)); } ### # HTML encode a string # This should be used with anything in an HTML tag that might contain < or > ### function html_encode($string, $return) { return($this->eor(htmlspecialchars($string),$return)); } function translate ($text) { return($GLOBALS['phpgw']->lang($text)); } } ?>