Return a correct timestamp when a folder is empty.

If a folder was empty a zero timestamp was returned. Now it will
return the timestamp of the folder itself.
This commit is contained in:
Klaus Weidenbach 2014-06-29 21:15:37 +02:00
parent 322091cd12
commit aacb293f2e
2 changed files with 50 additions and 36 deletions

View File

@ -356,9 +356,13 @@ class RedDirectory extends DAV\Node implements DAV\ICollection, DAV\IQuota {
} }
/** /**
* @brief Returns the last modification time for the directory, as a unix * @brief Returns the last modification time for the directory, as a UNIX
* timestamp. * timestamp.
* *
* It looks for the last edited file in the folder. If it is an empty folder
* it returns the lastmodified time of the folder itself, to prevent zero
* timestamps.
*
* @return int last modification time in UNIX timestamp * @return int last modification time in UNIX timestamp
*/ */
public function getLastModified() { public function getLastModified() {
@ -366,10 +370,16 @@ class RedDirectory extends DAV\Node implements DAV\ICollection, DAV\IQuota {
dbesc($this->folder_hash), dbesc($this->folder_hash),
intval($this->auth->owner_id) intval($this->auth->owner_id)
); );
if ($r) if (! $r) {
return datetime_convert('UTC', 'UTC', $r[0]['edited'], 'U'); $r = q("SELECT edited FROM attach WHERE hash = '%s' AND uid = %d LIMIT 1",
dbesc($this->folder_hash),
intval($this->auth->owner_id)
);
if (! $r)
return ''; return '';
} }
return datetime_convert('UTC', 'UTC', $r[0]['edited'], 'U');
}
/** /**
* @brief Return quota usage. * @brief Return quota usage.
@ -997,11 +1007,17 @@ class RedBasicAuth extends DAV\Auth\Backend\AbstractBasic {
$this->currentUser = $name; $this->currentUser = $name;
} }
function setBrowserPlugin($browser) { /**
* @brief Set browser plugin.
*
* @see RedBrowser::set_writeable()
* @param DAV\Browser\Plugin $browser
*/
public function setBrowserPlugin($browser) {
$this->browser = $browser; $this->browser = $browser;
} }
// internal? loggin function // internal? logging function
function log() { function log() {
logger('dav: auth: channel_name ' . $this->channel_name, LOGGER_DATA); logger('dav: auth: channel_name ' . $this->channel_name, LOGGER_DATA);
logger('dav: auth: channel_id ' . $this->channel_id, LOGGER_DATA); logger('dav: auth: channel_id ' . $this->channel_id, LOGGER_DATA);
@ -1045,9 +1061,7 @@ class RedBrowser extends DAV\Browser\Plugin {
} }
/** /**
* Creates the directory listing for the given path. * @brief Creates the directory listing for the given path.
*
* @todo Why not use RedDirectory for this?
* *
* @param string $path which should be displayed * @param string $path which should be displayed
*/ */

View File

@ -1,13 +1,16 @@
<?php <?php
/**
* @file mod/cloud.php
* @brief Initialize Red Matrix's cloud (SabreDAV)
*
*/
use Sabre\DAV; use Sabre\DAV;
require_once('vendor/autoload.php'); require_once('vendor/autoload.php');
// workaround for HTTP-auth in CGI mode // workaround for HTTP-auth in CGI mode
if(x($_SERVER,'REDIRECT_REMOTE_USER')) { if(x($_SERVER,'REDIRECT_REMOTE_USER')) {
$userpass = base64_decode(substr($_SERVER["REDIRECT_REMOTE_USER"],6)) ; $userpass = base64_decode(substr($_SERVER["REDIRECT_REMOTE_USER"], 6)) ;
if(strlen($userpass)) { if(strlen($userpass)) {
list($name, $password) = explode(':', $userpass); list($name, $password) = explode(':', $userpass);
$_SERVER['PHP_AUTH_USER'] = $name; $_SERVER['PHP_AUTH_USER'] = $name;
@ -16,7 +19,7 @@
} }
if(x($_SERVER,'HTTP_AUTHORIZATION')) { if(x($_SERVER,'HTTP_AUTHORIZATION')) {
$userpass = base64_decode(substr($_SERVER["HTTP_AUTHORIZATION"],6)) ; $userpass = base64_decode(substr($_SERVER["HTTP_AUTHORIZATION"], 6)) ;
if(strlen($userpass)) { if(strlen($userpass)) {
list($name, $password) = explode(':', $userpass); list($name, $password) = explode(':', $userpass);
$_SERVER['PHP_AUTH_USER'] = $name; $_SERVER['PHP_AUTH_USER'] = $name;
@ -24,10 +27,11 @@
} }
} }
/**
* @brief Fires up the SabreDAV server.
*
* @param App &$a
*/
function cloud_init(&$a) { function cloud_init(&$a) {
require_once('include/reddav.php'); require_once('include/reddav.php');
@ -42,13 +46,10 @@ function cloud_init(&$a) {
$profile = 0; $profile = 0;
$channel = $a->get_channel(); $channel = $a->get_channel();
$a->page['htmlhead'] .= '<link rel="alternate" type="application/atom+xml" href="' . $a->get_baseurl() . '/feed/' . $which .'" />' . "\r\n" ; $a->page['htmlhead'] .= '<link rel="alternate" type="application/atom+xml" href="' . $a->get_baseurl() . '/feed/' . $which . '" />' . "\r\n" ;
if($which) if($which)
profile_load($a,$which,$profile); profile_load($a, $which, $profile);
$auth = new RedBasicAuth(); $auth = new RedBasicAuth();
@ -71,8 +72,6 @@ function cloud_init(&$a) {
if($_GET['davguest']) if($_GET['davguest'])
$_SESSION['davguest'] = true; $_SESSION['davguest'] = true;
$_SERVER['QUERY_STRING'] = str_replace(array('?f=','&f='),array('',''),$_SERVER['QUERY_STRING']); $_SERVER['QUERY_STRING'] = str_replace(array('?f=','&f='),array('',''),$_SERVER['QUERY_STRING']);
$_SERVER['QUERY_STRING'] = strip_zids($_SERVER['QUERY_STRING']); $_SERVER['QUERY_STRING'] = strip_zids($_SERVER['QUERY_STRING']);
$_SERVER['QUERY_STRING'] = preg_replace('/[\?&]davguest=(.*?)([\?&]|$)/ism','',$_SERVER['QUERY_STRING']); $_SERVER['QUERY_STRING'] = preg_replace('/[\?&]davguest=(.*?)([\?&]|$)/ism','',$_SERVER['QUERY_STRING']);
@ -81,8 +80,11 @@ function cloud_init(&$a) {
$_SERVER['REQUEST_URI'] = strip_zids($_SERVER['REQUEST_URI']); $_SERVER['REQUEST_URI'] = strip_zids($_SERVER['REQUEST_URI']);
$_SERVER['REQUEST_URI'] = preg_replace('/[\?&]davguest=(.*?)([\?&]|$)/ism','',$_SERVER['REQUEST_URI']); $_SERVER['REQUEST_URI'] = preg_replace('/[\?&]davguest=(.*?)([\?&]|$)/ism','',$_SERVER['REQUEST_URI']);
$rootDirectory = new RedDirectory('/',$auth); $rootDirectory = new RedDirectory('/', $auth);
// A SabreDAV server-object
$server = new DAV\Server($rootDirectory); $server = new DAV\Server($rootDirectory);
// prevent overwriting changes each other with a lock backend
$lockBackend = new DAV\Locks\Backend\File('store/[data]/locks'); $lockBackend = new DAV\Locks\Backend\File('store/[data]/locks');
$lockPlugin = new DAV\Locks\Plugin($lockBackend); $lockPlugin = new DAV\Locks\Plugin($lockBackend);
@ -95,11 +97,11 @@ function cloud_init(&$a) {
// In order to avoid prompting for passwords for viewing a DIRECTORY, add the URL query parameter 'davguest=1' // In order to avoid prompting for passwords for viewing a DIRECTORY, add the URL query parameter 'davguest=1'
$isapublic_file = false; $isapublic_file = false;
$davguest = ((x($_SESSION,'davguest')) ? true : false); $davguest = ((x($_SESSION, 'davguest')) ? true : false);
if((! $auth->observer) && ($_SERVER['REQUEST_METHOD'] === 'GET')) { if((! $auth->observer) && ($_SERVER['REQUEST_METHOD'] === 'GET')) {
try { try {
$x = RedFileData('/' . $a->cmd,$auth); $x = RedFileData('/' . $a->cmd, $auth);
if($x instanceof RedFile) if($x instanceof RedFile)
$isapublic_file = true; $isapublic_file = true;
} }
@ -114,20 +116,18 @@ function cloud_init(&$a) {
} }
catch ( Exception $e) { catch ( Exception $e) {
logger('mod_cloud: auth exception' . $e->getMessage()); logger('mod_cloud: auth exception' . $e->getMessage());
http_status_exit($e->getHTTPCode(),$e->getMessage()); http_status_exit($e->getHTTPCode(), $e->getMessage());
} }
} }
// $browser = new DAV\Browser\Plugin();
// provide a directory view for the cloud in Red Matrix
$browser = new RedBrowser($auth); $browser = new RedBrowser($auth);
$auth->setBrowserPlugin($browser); $auth->setBrowserPlugin($browser);
$server->addPlugin($browser); $server->addPlugin($browser);
// All we need to do now, is to fire up the server // All we need to do now, is to fire up the server
$server->exec(); $server->exec();