Merge remote-tracking branch 'mike/master' into dev
This commit is contained in:
commit
2e9738e204
@ -389,8 +389,12 @@ class Directory extends DAV\Node implements DAV\ICollection, DAV\IQuota, DAV\IMo
|
|||||||
);
|
);
|
||||||
|
|
||||||
if ($r) {
|
if ($r) {
|
||||||
|
|
||||||
|
// When initiated from DAV, set the 'force' flag on attach_mkdir(). This will cause the operation to report success even if the
|
||||||
|
// folder already exists.
|
||||||
|
|
||||||
require_once('include/attach.php');
|
require_once('include/attach.php');
|
||||||
$result = attach_mkdir($r[0], $this->auth->observer, array('filename' => $name, 'folder' => $this->folder_hash));
|
$result = attach_mkdir($r[0], $this->auth->observer, array('filename' => $name, 'folder' => $this->folder_hash, 'force' => true));
|
||||||
|
|
||||||
if($result['success']) {
|
if($result['success']) {
|
||||||
$sync = attach_export_data($r[0],$result['data']['hash']);
|
$sync = attach_export_data($r[0],$result['data']['hash']);
|
||||||
|
@ -2286,33 +2286,22 @@ function attach_move($channel_id, $resource_id, $new_folder_hash) {
|
|||||||
if(! ($c && $resource_id))
|
if(! ($c && $resource_id))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
||||||
|
// find the resource to be moved
|
||||||
|
|
||||||
$r = q("select * from attach where hash = '%s' and uid = %d limit 1",
|
$r = q("select * from attach where hash = '%s' and uid = %d limit 1",
|
||||||
dbesc($resource_id),
|
dbesc($resource_id),
|
||||||
intval($channel_id)
|
intval($channel_id)
|
||||||
);
|
);
|
||||||
if(! $r)
|
if(! $r) {
|
||||||
|
logger('resource_id not found');
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
$oldstorepath = dbunescbin($r[0]['content']);
|
$oldstorepath = dbunescbin($r[0]['content']);
|
||||||
|
|
||||||
if($r[0]['is_dir']) {
|
|
||||||
$move_success = true;
|
|
||||||
$x = q("select hash from attach where folder = '%s' and uid = %d",
|
|
||||||
dbesc($r[0]['hash']),
|
|
||||||
intval($channel_id)
|
|
||||||
);
|
|
||||||
if($x) {
|
|
||||||
foreach($x as $xv) {
|
|
||||||
$rs = attach_move($channel_id,$xv['hash'],$r[0]['hash']);
|
|
||||||
if(! $rs) {
|
|
||||||
$move_success = false;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return $move_success;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
// find the resource we are moving to
|
||||||
|
|
||||||
if($new_folder_hash) {
|
if($new_folder_hash) {
|
||||||
$n = q("select * from attach where hash = '%s' and uid = %d and is_dir = 1 limit 1",
|
$n = q("select * from attach where hash = '%s' and uid = %d and is_dir = 1 limit 1",
|
||||||
@ -2326,6 +2315,10 @@ function attach_move($channel_id, $resource_id, $new_folder_hash) {
|
|||||||
$newstorepath = dbunescbin($n[0]['content']) . '/' . $resource_id;
|
$newstorepath = dbunescbin($n[0]['content']) . '/' . $resource_id;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
||||||
|
// root directory
|
||||||
|
|
||||||
|
$newdirname = EMPTY_STR;
|
||||||
$newstorepath = 'store/' . $c['channel_address'] . '/' . $resource_id;
|
$newstorepath = 'store/' . $c['channel_address'] . '/' . $resource_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2335,6 +2328,10 @@ function attach_move($channel_id, $resource_id, $new_folder_hash) {
|
|||||||
|
|
||||||
$filename = $r[0]['filename'];
|
$filename = $r[0]['filename'];
|
||||||
|
|
||||||
|
// don't do duplicate check unless our parent folder has changed.
|
||||||
|
|
||||||
|
if($r[0]['folder'] !== $new_folder_hash) {
|
||||||
|
|
||||||
$s = q("select filename, id, hash, filesize from attach where filename = '%s' and folder = '%s' ",
|
$s = q("select filename, id, hash, filesize from attach where filename = '%s' and folder = '%s' ",
|
||||||
dbesc($filename),
|
dbesc($filename),
|
||||||
dbesc($new_folder_hash)
|
dbesc($new_folder_hash)
|
||||||
@ -2387,6 +2384,7 @@ function attach_move($channel_id, $resource_id, $new_folder_hash) {
|
|||||||
$filename = $basename . $ext;
|
$filename = $basename . $ext;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$t = q("update attach set content = '%s', folder = '%s', filename = '%s' where id = %d",
|
$t = q("update attach set content = '%s', folder = '%s', filename = '%s' where id = %d",
|
||||||
dbescbin($newstorepath),
|
dbescbin($newstorepath),
|
||||||
@ -2423,6 +2421,24 @@ function attach_move($channel_id, $resource_id, $new_folder_hash) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($r[0]['is_dir']) {
|
||||||
|
$move_success = true;
|
||||||
|
$x = q("select hash from attach where folder = '%s' and uid = %d",
|
||||||
|
dbesc($r[0]['hash']),
|
||||||
|
intval($channel_id)
|
||||||
|
);
|
||||||
|
if($x) {
|
||||||
|
foreach($x as $xv) {
|
||||||
|
$rs = attach_move($channel_id,$xv['hash'],$r[0]['hash']);
|
||||||
|
if(! $rs) {
|
||||||
|
$move_success = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $move_success;
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,12 +85,14 @@ function tryoembed($match) {
|
|||||||
function nakedoembed($match) {
|
function nakedoembed($match) {
|
||||||
$url = ((count($match) == 2) ? $match[1] : $match[2]);
|
$url = ((count($match) == 2) ? $match[1] : $match[2]);
|
||||||
|
|
||||||
$o = oembed_fetch_url($url);
|
$strip_url = strip_escaped_zids($url);
|
||||||
|
|
||||||
|
$o = oembed_fetch_url($strip_url);
|
||||||
|
|
||||||
if ($o['type'] == 'error')
|
if ($o['type'] == 'error')
|
||||||
return $match[0];
|
return str_replace($url,$strip_url,$match[0]);
|
||||||
|
|
||||||
return '[embed]' . $url . '[/embed]';
|
return '[embed]' . $strip_url . '[/embed]';
|
||||||
}
|
}
|
||||||
|
|
||||||
function tryzrlaudio($match) {
|
function tryzrlaudio($match) {
|
||||||
|
@ -3307,6 +3307,7 @@ function cleanup_bbcode($body) {
|
|||||||
* First protect any url inside certain bbcode tags so we don't double link it.
|
* First protect any url inside certain bbcode tags so we don't double link it.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
$body = preg_replace_callback('/\[code(.*?)\[\/(code)\]/ism','\red_escape_codeblock',$body);
|
$body = preg_replace_callback('/\[code(.*?)\[\/(code)\]/ism','\red_escape_codeblock',$body);
|
||||||
$body = preg_replace_callback('/\[url(.*?)\[\/(url)\]/ism','\red_escape_codeblock',$body);
|
$body = preg_replace_callback('/\[url(.*?)\[\/(url)\]/ism','\red_escape_codeblock',$body);
|
||||||
$body = preg_replace_callback('/\[zrl(.*?)\[\/(zrl)\]/ism','\red_escape_codeblock',$body);
|
$body = preg_replace_callback('/\[zrl(.*?)\[\/(zrl)\]/ism','\red_escape_codeblock',$body);
|
||||||
@ -3336,7 +3337,6 @@ function cleanup_bbcode($body) {
|
|||||||
|
|
||||||
$body = scale_external_images($body,false);
|
$body = scale_external_images($body,false);
|
||||||
|
|
||||||
|
|
||||||
return $body;
|
return $body;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ function zid($s, $address = '') {
|
|||||||
$url_match = true;
|
$url_match = true;
|
||||||
|
|
||||||
if ($mine && $myaddr && (! $url_match))
|
if ($mine && $myaddr && (! $url_match))
|
||||||
$zurl = $s . (($num_slashes >= 3) ? '' : '/') . $achar . 'zid=' . urlencode($myaddr);
|
$zurl = $s . (($num_slashes >= 3) ? '' : '/') . (($achar === '?') ? '?f=&' : '&') . 'zid=' . urlencode($myaddr);
|
||||||
else
|
else
|
||||||
$zurl = $s;
|
$zurl = $s;
|
||||||
|
|
||||||
@ -103,6 +103,10 @@ function strip_zats($s) {
|
|||||||
return preg_replace('/[\?&]zat=(.*?)(&|$)/ism','$2',$s);
|
return preg_replace('/[\?&]zat=(.*?)(&|$)/ism','$2',$s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function strip_escaped_zids($s) {
|
||||||
|
$x = preg_replace('/&\;zid=(.*?)(&|$)/ism','$2',$s);
|
||||||
|
return strip_query_param($x,'f');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
function clean_query_string($s = '') {
|
function clean_query_string($s = '') {
|
||||||
|
Reference in New Issue
Block a user