Вход Регистрация
Файл: admin/applications/members/extensions/attachments/plugin_msg.php
Строк: 229
<?php

/**
 * <pre>
 * Invision Power Services
 * IP.Board v3.3.3
 * IP.Board messenger attachments plugin
 * Last Updated: $Date: 2012-05-10 16:10:13 -0400 (Thu, 10 May 2012) $
 * </pre>
 *
 * @author         $Author: bfarber $
 * @copyright    (c) 2001 - 2009 Invision Power Services, Inc.
 * @license        http://www.invisionpower.com/company/standards.php#license
 * @package        IP.Board
 * @subpackage    Core
 * @link        http://www.invisionpower.com
 * @since        6/24/2008
 * @version        $Revision: 10721 $
 */

if ( ! defined'IN_IPB' ) )
{
    print 
"<h1>Incorrect access</h1>You cannot access this file directly. If you have recently upgraded, make sure you upgraded all the relevant files.";
    exit();
}

class 
plugin_msg extends class_attach
{
    
/**
     * Module type
     *
     * @var        string
     */
    
public $module 'msg';
    
    
/**
     * Checks the attachment and checks for download / show perms
     *
     * @param    integer        Attachment id
     * @return    array         Attachment data
     */
    
public function getAttachmentData$attach_id )
    {
        
//-----------------------------------------
        // INIT
        //-----------------------------------------
        
        
$_ok 0;
        
        
//-----------------------------------------
        // Grab 'em
        //-----------------------------------------
        
        
$this->DB->build( array( 'select'   => 'a.*',
                                 
'from'     => array( 'attachments' => 'a' ),
                                 
'where'    => "a.attach_rel_module='".$this->module."' AND a.attach_id=".$attach_id,
                                 
'add_join' => array( => array( 'select' => 'p.*',
                                                                  
'from'   => array( 'message_posts' => 'p' ),
                                                                  
'where'  => "p.msg_id=a.attach_rel_id",
                                                                  
'type'   => 'left' ),
                                                      
=> array( 'select' => 't.*',
                                                                  
'from'   => array( 'message_topics' => 't' ),
                                                                  
'where'  => "t.mt_id=p.msg_topic_id",
                                                                  
'type'   => 'left' ),
                                                      
=> array( 'select' => 'u.*',
                                                                  
'from'   => array( 'message_topic_user_map' => 'u' ),
                                                                  
'where'  => "u.map_topic_id=t.mt_id AND u.map_user_id=" $this->memberData['member_id'],
                                                                  
'type'   => 'left' ) ) ) );

        
$attach_sql $this->DB->execute();
        
        
$attach     $this->DB->fetch$attach_sql );
        
        
//-----------------------------------------
        // Check..
        //-----------------------------------------
        
        
if ( empty( $attach['msg_id'] ) )
        {
            if( 
$attach['attach_member_id'] != $this->memberData['member_id'] )
            {
                return 
FALSE;
            }
        }
        
        
//-----------------------------------------
        // For previews
        //-----------------------------------------
        
        
if ( $attach['attach_rel_id'] == AND $attach['attach_member_id'] == $this->memberData['member_id'] )
        {
            
$_ok 1;
        }
        else if ( 
$attach['map_user_id'] )
        { 
            
$_ok 1;
        }

        
//-----------------------------------------
        // Ok?
        //-----------------------------------------

        
if ( $_ok )
        {
            return 
$attach;
        }
        else
        {
            return 
FALSE;
        }
    }
    
    
/**
     * Check the attachment and make sure its OK to display
     *
     * @param    array        Array of ids
     * @param    array         Array of relationship ids
     * @return    array         Attachment data
     */
    
public function renderAttachment$attach_ids$rel_ids=array(), $attach_post_key=)
    {
        
//-----------------------------------------
        // INIT
        //-----------------------------------------
        
        
$rows          = array();
        
$query_bits    = array();
        
$query         '';
        
$match         0;
        
        
//-----------------------------------------
        // Check
        //-----------------------------------------
        
        
if ( is_array$attach_ids ) AND count$attach_ids ) )
        {
            
$query_bits[] = "attach_id IN (" implode","$attach_ids ) .")";
        }
        
        if ( 
is_array$rel_ids ) and count$rel_ids ) )
        {
            
$rel_ids array_map'intval'$rel_ids );
            
// We need to reset the array - this query bit will return everything we need, but
            // if we "OR" join the above query bit with this one, it causes bigger mysql loads
            
$query_bits      = array();
            
$query_bits[] = "attach_rel_id IN (" implode","$rel_ids ) . ")";
            
            
$match 1;
        }
        
        if ( 
$attach_post_key )
        {
            
$query_bits[] = "attach_post_key='".$this->DB->addSlashes$attach_post_key )."'";
            
            
$match  2;
        }
        
        
//-----------------------------------------
        // Grab 'em
        //-----------------------------------------
        
        
if( count($query_bits) )
        {
            
$this->DB->build( array( 'select' => '*''from' => 'attachments''where' => "attach_rel_module='{$this->module}' AND ( " implode' OR '$query_bits ) . " )" ) );
            
$attach_sql $this->DB->execute();
        
            
//-----------------------------------------
            // Loop through and filter off naughty ids
            //-----------------------------------------
            
            
while( $db_row $this->DB->fetch$attach_sql ) )
            {
                
$_ok 1;
                
                if ( 
$match == )
                {
                    if ( ! 
in_array$db_row['attach_rel_id'], $rel_ids ) )
                    {
                        
$_ok 0;
                    }
                }
                else if ( 
$match == )
                {
                    if ( 
$db_row['attach_post_key'] != $attach_post_key )
                    {
                        
$_ok 0;
                    }
                }
                
                
//-----------------------------------------
                // Ok?
                //-----------------------------------------
                
                
if ( $_ok )
                {
                    
$rows$db_row['attach_id'] ] = $db_row;
                }
            }
        }
        
        
//-----------------------------------------
        // Return
        //-----------------------------------------
    
        
return $rows;
    }
    
    
/**
     * Recounts number of attachments for the articles row
     *
     * @param    string        Post key
     * @param    integer        Related ID
     * @param    array         Arguments for query
     * @return    array         Returns count of items found
     */
    
public function postUploadProcess$post_key$rel_id$args=array() )
    {
        
//-----------------------------------------
        // INIT
        //-----------------------------------------
        
        
$cnt = array( 'cnt' => );
        
        
//-----------------------------------------
        // Check..
        //-----------------------------------------
        
        
if ( ! $post_key )
        {
            return array( 
'count' => );
        }
        
        
        
$cnt    $this->DB->buildAndFetch( array( "select"    => 'COUNT(*) as cnt',
                                                    
'from'    => 'attachments',
                                                    
'where'    => "attach_post_key='{$post_key}'") );

        
/*if ( $cnt['cnt'] )
        {
            $this->DB->update( 'message_topics', "mt_hasattach=mt_hasattach+" . $cnt['cnt'], "mt_id=" . intval( $args['mt_id'] ), FALSE, TRUE );
        }*/
        
        
return array( 'count' => $cnt['cnt'] );
    }
    
    
/**
     * Recounts number of attachments for the articles row
     *
     * @param    array         Attachment data
     * @return    boolean
     */
    
public function attachmentRemovalCleanup$attachment )
    {
        
//-----------------------------------------
        // Check
        //-----------------------------------------
        
        
if ( ! $attachment['attach_id'] )
        {
            return 
FALSE;
        }

        
$message $this->DB->buildAndFetch( array( 'select' => '*',
                                                     
'from'   => 'message_posts',
                                                     
'where'  => 'msg_id=' intval$attachment['attach_rel_id'] ) ) );

        if ( isset( 
$message['msg_topic_id'] ) )
        {
            
//-----------------------------------------
            // GET ALL MSG IDS IN THIS TOPIC
            //-----------------------------------------
        
            
$pids  = array();
            
$count 0;
        
            
$this->DB->build( array( 'select' => 'msg_id',
                                       
'from'   => 'message_posts',
                                     
'where'  => "msg_topic_id="$message['msg_topic_id'] ) );
            
$this->DB->execute();
                
            while ( 
$p $this->DB->fetch() )
            {
                
$pids[] = $p['msg_id'];
            }

            
//-----------------------------------------
            // GET ATTACHMENT COUNT
            //-----------------------------------------
        
            
if ( count$pids ) )
            {
                
$this->DB->build( array( "select" => 'count(*) as cnt',
                                         
'from'   => 'attachments',
                                         
'where'  => "attach_rel_module='msg' AND attach_rel_id IN(".implode(",",$pids).")") );
                
$this->DB->execute();
            
                
$cnt $this->DB->fetch();
            
                
$count intval$cnt['cnt'] );
            }
        
            
$this->DB->update'message_topics', array( 'mt_hasattach' => $count ), "mt_id=" $message['msg_topic_id'] );
        }
        
        return 
TRUE;
    }
    
    
/**
     * Determines if you have permission for bulk attachment removal
     * Returns TRUE or FALSE
     * IT really does
     *
     * @param    array         Ids to check against
     * @return    boolean
     */
    
public function canBulkRemove$attach_rel_ids=array() )
    {
        return 
$this->memberData['g_is_supmod'] ? true false;
    }
    
    
/**
     * Determines if you can remove this attachment
     * Returns TRUE or FALSE
     * IT really does
     *
     * @param    array         Attachment data
     * @return    boolean
     */
    
public function canRemove$attachment )
    {
        
//-----------------------------------------
        // INIT
        //-----------------------------------------
        
        
$ok_to_remove FALSE;
        
        
//-----------------------------------------
        // Check
        //-----------------------------------------
        
        
if ( ! $attachment['attach_id'] )
        {
            return 
FALSE;
        }
        
        
//-----------------------------------------
        // Allowed to remove?
        //-----------------------------------------
        
        
if ( $this->memberData['member_id'] == $attachment['attach_member_id'] )
        {
            
$ok_to_remove TRUE;
        }
        else if ( 
$this->memberData['g_is_supmod'] )
        {
            
$ok_to_remove TRUE;
        }
        else
        {
            
$message $this->DB->buildAndFetch( array( 'select' => '*',
                                                         
'from'   => 'message_posts',
                                                         
'where'  => 'msg_id=' intval$attachment['attach_rel_id'] ) ) );
                                                                                        
            if ( 
$this->memberData['member_id'] == $message['msg_author_id'] )
            {
                
$ok_to_remove TRUE;
            }
        }
        
        return 
$ok_to_remove;
    }
    
    
/**
     * Returns an array of the allowed upload sizes in bytes.
     * Return 'space_allowed' as -1 to not allow uploads.
     * Return 'space_allowed' as 0 to allow unlimited uploads
     * Return 'max_single_upload' as 0 to not set a limit
     *
     * @param    string        MD5 post key
     * @param    id            Member ID
     * @return    array         [ 'space_used', 'space_left', 'space_allowed', 'max_single_upload' ]
     */
    
public function getSpaceAllowance$post_key=''$member_id='' )
    {
        
$max_php_size      intvalIPSLib::getMaxPostSize() );
        
$member_id         intval$member_id $member_id $this->memberData['member_id'] );
        
$space_left        0;
        
$space_used        0;
        
$space_allowed     0;
        
$max_single_upload 0;
        
        
//-----------------------------------------
        // Allowed to attach?
        //-----------------------------------------
        
        
if ( ! $member_id )
        {
            
$space_allowed = -1;
        }
        else
        {
            
//-----------------------------------------
            // Generate total space allowed
            //-----------------------------------------

            
$total_space_allowed = ( $this->memberData['g_attach_per_post'] ? $this->memberData['g_attach_per_post'] : $this->memberData['g_attach_max'] ) * 1024;
            
            
//-----------------------------------------
            // Generate space used figure
            //-----------------------------------------
            
            
if ( $this->memberData['g_attach_per_post'] )
            {
                
//-----------------------------------------
                // Per post limit...
                //-----------------------------------------
                
                
$_space_used $this->DB->buildAndFetch( array( 'select' => 'SUM(attach_filesize) as figure',
                                                                
'from'   => 'attachments',
                                                                
'where'  => "attach_post_key='".$post_key."'" ) );

                
$space_used    $_space_used['figure'] ? $_space_used['figure'] : 0;
            }
            else
            {
                
//-----------------------------------------
                // Global limit...
                //-----------------------------------------
                
                
$_space_used $this->DB->buildAndFetch( array( 'select' => 'SUM(attach_filesize) as figure',
                                                                
'from'   => 'attachments',
                                                                
'where'  => 'attach_member_id='.$member_id " AND attach_rel_module IN( 'post', 'msg' )" ) );

                
$space_used    $_space_used['figure'] ? $_space_used['figure'] : 0;
            }    
            
//-----------------------------------------
            // Generate space allowed figure
            //-----------------------------------------
        
            
if ( $this->memberData['g_attach_max'] > )
            {
                if ( 
$this->memberData['g_attach_per_post'] )
                {
                    
$_g_space_used    $this->DB->buildAndFetch( array( 'select' => 'SUM(attach_filesize) as figure',
                                                                       
'from'   => 'attachments',
                                                                       
'where'  => 'attach_member_id='.$member_id " AND attach_rel_module IN( 'post', 'msg' )" ) );

                    
$g_space_used    $_g_space_used['figure'] ? $_g_space_used['figure'] : 0;
                    
                    if( ( 
$this->memberData['g_attach_max'] * 1024 ) - $g_space_used )
                    {
                        
$space_used                $g_space_used;
                        
$total_space_allowed    $this->memberData['g_attach_max'] * 1024;
                        
                        
$space_allowed = ( $this->memberData['g_attach_max'] * 1024 ) - $space_used;
                        
$space_allowed $space_allowed ? -$space_allowed;
                    }
                    else
                    {
                        
$space_allowed = ( $this->memberData['g_attach_per_post'] * 1024 ) - $space_used;
                        
$space_allowed $space_allowed ? -$space_allowed;
                    }
                }
                else
                {
                    
$space_allowed = ( $this->memberData['g_attach_max'] * 1024 ) - $space_used;
                    
$space_allowed $space_allowed ? -$space_allowed;
                }
            }
            else
            {
                if ( 
$this->memberData['g_attach_per_post'] )
                {
                    
$space_allowed = ( $this->memberData['g_attach_per_post'] * 1024 ) - $space_used;
                    
$space_allowed $space_allowed ? -$space_allowed;
                }
                else
                { 
                    
# Unlimited
                    
$space_allowed 0;
                }
            }
            
            
//-----------------------------------------
            // Generate space left figure
            //-----------------------------------------
            
            
$space_left $space_allowed $space_allowed 0;
            
$space_left = ($space_left 0) ? -$space_left;
            
            
//-----------------------------------------
            // Generate max upload size
            //-----------------------------------------
            
            
if ( ! $max_single_upload )
            {
                if ( 
$space_left AND $space_left $max_php_size )
                {
                    
$max_single_upload $space_left;
                }
                else if ( 
$max_php_size )
                {
                    
$max_single_upload $max_php_size;
                }
            }
        }

        
IPSDebug::fireBug'info', array( 'Space left: ' $space_left ) );
        
IPSDebug::fireBug'info', array( 'Max PHP size: ' $max_php_size ) );
        
IPSDebug::fireBug'info', array( 'Max single file size: ' $max_single_upload ) );
        
        
$return = array( 'space_used' => $space_used'space_left' => $space_left'space_allowed' => $space_allowed'max_single_upload' => $max_single_upload'total_space_allowed' => $total_space_allowed );
        
        return 
$return;
    }
    
    
/**
     * Returns an array of settings:
     * 'siu_thumb' = Allow thumbnail creation?
     * 'siu_height' = Height of the generated thumbnail in pixels
     * 'siu_width' = Width of the generated thumbnail in pixels
     * 'upload_dir' = Base upload directory (must be a full path)
     *
     * You can omit any of these settings and IPB will use the default
     * settings (which are the ones entered into the ACP for post thumbnails)
     *
     * @return    boolean
     */
    
public function getSettings()
    {
        
$this->mysettings = array();
        
        return 
true;
    }

}
Онлайн: 0
Реклама