mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-27 08:19:09 +01:00
139 lines
4.2 KiB
PHP
139 lines
4.2 KiB
PHP
|
<?php
|
||
|
|
||
|
|
||
|
namespace EGroupware\Filemanager\Sharing;
|
||
|
|
||
|
|
||
|
use EGroupware\Api\Vfs;
|
||
|
use EGroupware\Api\Vfs\Sharing;
|
||
|
use EGroupware\Api\Vfs\UploadSharingUi;
|
||
|
|
||
|
class HiddenUpload extends AnonymousList
|
||
|
{
|
||
|
|
||
|
/**
|
||
|
* Get active view - override so it points to this class
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public static function get_view()
|
||
|
{
|
||
|
return array(new HiddenUpload(), 'listview');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Filemanager listview
|
||
|
*
|
||
|
* Override to customize for sharing with a hidden upload directory.
|
||
|
* Everything not in the upload directory is readonly, but we make it look like you can upload.
|
||
|
* The upload directory is not shown.
|
||
|
*
|
||
|
* @param array $content
|
||
|
* @param string $msg
|
||
|
*/
|
||
|
function listview(array $content=null,$msg=null)
|
||
|
{
|
||
|
$this->etemplate = $this->etemplate ? $this->etemplate : new Api\Etemplate(static::LIST_TEMPLATE);
|
||
|
|
||
|
if (isset($GLOBALS['egw']->sharing) && $GLOBALS['egw']->sharing->has_hidden_upload())
|
||
|
{
|
||
|
// Tell client side that the path is actually writable
|
||
|
$content['initial_path_readonly'] = false;
|
||
|
|
||
|
// No new anything
|
||
|
$this->etemplate->disableElement('nm[new]');
|
||
|
$this->etemplate->setElementAttribute('nm[button][createdir]', 'readonly', true);
|
||
|
|
||
|
// Take over upload, change target and conflict strategy
|
||
|
$path = Vfs::concat(self::get_home_dir(), Sharing::HIDDEN_UPLOAD_DIR);
|
||
|
$target = str_replace('\\', '\\\\', __CLASS__);
|
||
|
$this->etemplate->setElementAttribute('nm[upload]', 'onFinishOne', "app.filemanager.upload(ev, 1, '$path', 'rename', '{$target}::ajax_action')");
|
||
|
}
|
||
|
|
||
|
return parent::listview($content, $msg);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Deal with an uploaded file.
|
||
|
* Overridden from the parent to change the message and message type
|
||
|
*
|
||
|
* @param string $action Should be 'upload'
|
||
|
* @param $selected Array of file information
|
||
|
* @param string $dir Target directory
|
||
|
* @param $props
|
||
|
* @param string[] $arr Result
|
||
|
*
|
||
|
* @throws Api\Exception\AssertionFailed
|
||
|
*/
|
||
|
protected static function handle_upload_action(string $action, $selected, $dir, $props, &$arr)
|
||
|
{
|
||
|
Api\Translation::add_app('filemanager');
|
||
|
$vfs = Vfs::mount();
|
||
|
$GLOBALS['egw']->sharing->redo();
|
||
|
parent::handle_upload_action($action, $selected, $dir, $props, $arr);
|
||
|
$arr['msg'] .= "\n" . lang("The uploaded file is only visible to the person sharing these files with you, not to yourself or other people knowing this sharing link.");
|
||
|
$arr['type'] = 'notice';
|
||
|
}
|
||
|
|
||
|
protected function is_hidden_upload_dir($directory)
|
||
|
{
|
||
|
if (!isset($GLOBALS['egw']->sharing)) return false;
|
||
|
// Just hide anything that is 'Upload' mounted where we expect, not just this share, to avoid exposing when
|
||
|
// more than one share is used
|
||
|
$mounts = Vfs::mount();
|
||
|
return Vfs::is_dir($directory) && '/'.Vfs::basename($directory) == Sharing::HIDDEN_UPLOAD_DIR && $mounts[$directory];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Callback to fetch the rows for the nextmatch widget
|
||
|
*
|
||
|
* @param array $query
|
||
|
* @param array &$rows
|
||
|
* @return int
|
||
|
*
|
||
|
* @throws Api\Json\Exception
|
||
|
*/
|
||
|
function get_rows(&$query, &$rows)
|
||
|
{
|
||
|
$hidden_upload = (isset($GLOBALS['egw']->sharing) && $GLOBALS['egw']->sharing->has_hidden_upload());
|
||
|
|
||
|
// Not allowed in hidden upload dir
|
||
|
$check_path = Sharing::HIDDEN_UPLOAD_DIR . (substr($query['path'], -1) == '/' ? '/' : '');
|
||
|
if(($length = strlen($check_path)) && (substr($query['path'], -$length) === $check_path))
|
||
|
{
|
||
|
// only redirect, if it would be to some other location, gives redirect-loop otherwise
|
||
|
if ($query['path'] != ($path = static::get_home_dir()))
|
||
|
{
|
||
|
// we will leave here, since we are not allowed, go back to root
|
||
|
// TODO: Give message about it, redirect to home dir
|
||
|
}
|
||
|
$rows = array();
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
// Get file list from parent
|
||
|
$total = parent::get_rows($query, $rows);
|
||
|
|
||
|
if(! $hidden_upload )
|
||
|
{
|
||
|
return $total;
|
||
|
}
|
||
|
|
||
|
// tell client-side that this directory is writeable - allows upload + button
|
||
|
$response = Api\Json\Response::get();
|
||
|
$response->call('app.filemanager.set_readonly', $query['path'], false);
|
||
|
|
||
|
// Hide the hidden upload directory, mark everything else as readonly
|
||
|
foreach($rows as $key => &$row)
|
||
|
{
|
||
|
if($this->is_hidden_upload_dir($row['path']))
|
||
|
{
|
||
|
unset($rows[$key]);
|
||
|
$total--;
|
||
|
continue;
|
||
|
}
|
||
|
$row['class'] .= 'noEdit noDelete ';
|
||
|
}
|
||
|
return $total;
|
||
|
}
|
||
|
}
|