mod_filestorage: provide a URL for linking to webpages and other websites
This commit is contained in:
@@ -733,6 +733,51 @@ function attach_delete($channel_id,$resource) {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function get_cloudpath($arr) {
|
||||||
|
|
||||||
|
$basepath = 'store/';
|
||||||
|
if($arr['uid']) {
|
||||||
|
$r = q("select channel_address from channel where channel_id = %d limit 1",
|
||||||
|
intval($arr['uid'])
|
||||||
|
);
|
||||||
|
if($r)
|
||||||
|
$basepath .= $r[0]['channel_address'] . '/';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$path = $basepath;
|
||||||
|
|
||||||
|
if($arr['folder']) {
|
||||||
|
|
||||||
|
$lpath = '';
|
||||||
|
$lfile = $arr['folder'];
|
||||||
|
|
||||||
|
do {
|
||||||
|
$r = q("select filename, hash, flags, folder from attach where uid = %d and hash = '%s' and ( flags & %d )
|
||||||
|
limit 1",
|
||||||
|
intval($arr['uid']),
|
||||||
|
dbesc($lfile),
|
||||||
|
intval(ATTACH_FLAG_DIR)
|
||||||
|
);
|
||||||
|
|
||||||
|
if(! $r)
|
||||||
|
break;
|
||||||
|
|
||||||
|
if($lfile)
|
||||||
|
$lpath = $r[0]['filename'] . '/' . $lpath;
|
||||||
|
$lfile = $r[0]['folder'];
|
||||||
|
|
||||||
|
} while ( ($r[0]['folder']) && ($r[0]['flags'] & ATTACH_FLAG_DIR)) ;
|
||||||
|
|
||||||
|
$path .= $lpath;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
$path .= $arr['filename'];
|
||||||
|
return $path;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@@ -101,7 +101,7 @@ function filestorage_content(&$a) {
|
|||||||
}
|
}
|
||||||
$file = intval(argv(2));
|
$file = intval(argv(2));
|
||||||
|
|
||||||
$r = q("select id, folder, filename, revision, flags, hash, allow_cid, allow_gid, deny_cid, deny_gid from attach where id = %d and uid = %d limit 1",
|
$r = q("select id, uid, folder, filename, revision, flags, hash, allow_cid, allow_gid, deny_cid, deny_gid from attach where id = %d and uid = %d limit 1",
|
||||||
intval($file),
|
intval($file),
|
||||||
intval($owner)
|
intval($owner)
|
||||||
);
|
);
|
||||||
@@ -110,6 +110,7 @@ function filestorage_content(&$a) {
|
|||||||
|
|
||||||
$channel = $a->get_channel();
|
$channel = $a->get_channel();
|
||||||
|
|
||||||
|
$cloudpath = get_cloudpath($f);
|
||||||
|
|
||||||
$aclselect_e = populate_acl($f);
|
$aclselect_e = populate_acl($f);
|
||||||
$is_a_dir = (($f['flags'] & ATTACH_FLAG_DIR) ? true : false);
|
$is_a_dir = (($f['flags'] & ATTACH_FLAG_DIR) ? true : false);
|
||||||
@@ -118,6 +119,7 @@ function filestorage_content(&$a) {
|
|||||||
$o = replace_macros(get_markup_template('attach_edit.tpl'), array(
|
$o = replace_macros(get_markup_template('attach_edit.tpl'), array(
|
||||||
'$header' => t('Edit file permissions'),
|
'$header' => t('Edit file permissions'),
|
||||||
'$file' => $f,
|
'$file' => $f,
|
||||||
|
'$cloudpath' => z_root() . '/' . $cloudpath,
|
||||||
'$uid' => $channel['channel_id'],
|
'$uid' => $channel['channel_id'],
|
||||||
'$channelnick' => $channel['channel_address'],
|
'$channelnick' => $channel['channel_address'],
|
||||||
'$permissions' => t('Permissions'),
|
'$permissions' => t('Permissions'),
|
||||||
@@ -126,6 +128,7 @@ function filestorage_content(&$a) {
|
|||||||
'$backlink' => t('Return to file list'),
|
'$backlink' => t('Return to file list'),
|
||||||
'$isadir' => $is_a_dir,
|
'$isadir' => $is_a_dir,
|
||||||
'$cpdesc' => t('Copy/paste this code to attach file to a post'),
|
'$cpdesc' => t('Copy/paste this code to attach file to a post'),
|
||||||
|
'$cpldesc' => t('Copy/paste this URL to link file from a web page'),
|
||||||
'$submit' => t('Submit')
|
'$submit' => t('Submit')
|
||||||
|
|
||||||
));
|
));
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#attach-edit-backlink, #cut-paste-link {
|
#attach-edit-backlink, #cutpasteinput, #linkpasteinput {
|
||||||
margin-bottom: 10px;
|
margin-bottom: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -6,6 +6,6 @@
|
|||||||
margin-top: 20px;
|
margin-top: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#cutpasteinput {
|
#cutpasteinput, #linkpasteinput {
|
||||||
width: 600px;
|
width: 600px;
|
||||||
}
|
}
|
@@ -22,10 +22,11 @@
|
|||||||
</div>
|
</div>
|
||||||
{{else}}
|
{{else}}
|
||||||
<div class="cut-paste-desc">{{$cpdesc}}</div>
|
<div class="cut-paste-desc">{{$cpdesc}}</div>
|
||||||
<div id="cut-paste-link">
|
<input type="text" id="cutpasteinput" name="cutpastelink" value="[attachment]{{$file.hash}},{{$file.revision}}[/attachment]" onclick="this.select();" /><br />
|
||||||
<input type="text" id="cutpasteinput" name="cutpastelink" value="[attachment]{{$file.hash}},{{$file.revision}}[/attachment]" />
|
|
||||||
<script>$('#cutpasteinput').select();</script>
|
<div class="cut-paste-desc">{{$cpldesc}}</div>
|
||||||
</div>
|
<input type="text" id="linkpasteinput" name="cutpasteextlink" value="{{$cloudpath}}" onclick="this.select();"/><br />
|
||||||
|
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
|
||||||
<div id="attach-edit-perms" >
|
<div id="attach-edit-perms" >
|
||||||
|
Reference in New Issue
Block a user