blob: c961f0d560f2eb80534f33a1afc0a6f6a0bf64e2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
<?php
/**
* @version $Header$
*
* edit_storage_inc
* @author spider <spider@steelsun.com>
* @package liberty
* @subpackage functions
*/
global $gBitSmarty, $gContent, $gBitUser, $gBitSystem, $gBitThemes, $gLibertySystem;
// if we have active plugins with an upload function, we call them:
foreach( $gLibertySystem->getPluginFunctions( 'upload_function' ) as $guid => $func ) {
$func( $gContent );
}
// set up base arguments
$getArgs = explode( '&', $_SERVER['QUERY_STRING'] );
$attachmentBaseArgs = '';
foreach( $getArgs as $arg ) {
$parts = explode( '=', $arg );
if( $parts[0] != 'deleteAttachment' ) {
$attachmentBaseArgs .= $arg."&";
}
}
$gBitSmarty->assign( 'attachmentBaseArgs', $attachmentBaseArgs );
// delete attachment if requested
if( !empty( $_REQUEST['deleteAttachment'] )) {
// $gContent is empty when we're editing our personal webpage
// this is a brutish hack but it seems to work without adverse effeects
if( empty( $gContent )) {
$gContent = $gBitUser;
}
$attachmentId = $_REQUEST['deleteAttachment'];
$attachmentInfo = LibertyMime::getAttachment( $attachmentId );
// the second part of this check seems odd (never used?) to me, but I'll leave it in for now - spiderr 10/17/2007
if( $gContent->hasAdminPermission() || ( $gContent->isOwner( $attachmentInfo ) && $gBitUser->hasPermission( 'p_liberty_delete_attachment' ))) {
$gContent->expungeAttachment( $attachmentId );
}
// in case we have deleted attachments
// seems like there should be a better way to do this -- maybe original assign should have been by reference?
$gBitSmarty->clearAssign( 'gContent' );
$gBitSmarty->assign( 'gContent', $gContent );
}
// make sure js is being loaded
if( $gBitSystem->getConfig( 'liberty_attachment_style' ) == 'ajax' ) {
$gBitThemes->loadJavascript( LIBERTY_PKG_PATH.'scripts/LibertyAttachment.js', true );
}
?>
|