Seditio Source
Root |
./othercms/ips_4.3.4/applications/core/sources/DeletionLog/DeletionLog.php
<?php
/**
 * @brief        Deletion Log Model
 * @author        <a href='https://www.invisioncommunity.com'>Invision Power Services, Inc.</a>
 * @copyright    (c) Invision Power Services, Inc.
 * @license        https://www.invisioncommunity.com/legal/standards/
 * @package        Invision Community
 * @since        10 Nov 2016
 */

namespace IPS\core;

/* To prevent PHP errors (extending class does not exist) revealing path */
if ( !defined( '\IPS\SUITE_UNIQUE_KEY' ) )
{
   
header( ( isset( $_SERVER['SERVER_PROTOCOL'] ) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0' ) . ' 403 Forbidden' );
    exit;
}

/**
 * Deletion Log Model
 */
class _DeletionLog extends \IPS\Patterns\ActiveRecord
{
   
/**
     * @brief    Database Table
     */
   
public static $databaseTable = 'core_deletion_log';
   
   
/**
     * @brief    Database Prefix
     */
   
public static $databasePrefix = 'dellog_';
   
   
/**
     * @brief    Multiton Store
     */
   
protected static $multitons;
       
   
/**
     * @brief    [ActiveRecord] ID Database Column
     */
   
public static $databaseColumnId = 'id';
   
   
/**
     * @brief    [ActiveRecord] Multiton Map
     */
   
protected static $multitonMap    = array();
   
   
/**
     * Set Default Values
     *
     * @return    void
     */
   
public function setDefaultValues()
    {
       
$this->deleted_date = \IPS\DateTime::create();
    }
   
   
/**
     * Set deleted date
     *
     * @param    \IPS\DateTime    A DateTime object
     * @return    void
     */
   
public function set_deleted_date( \IPS\DateTime $time )
    {
       
$this->_data['deleted_date'] = $time->getTimestamp();
    }
   
   
/**
     * Get deleted date
     *
     * @return    \IPS\DateTime
     */
   
public function get_deleted_date()
    {
        return \
IPS\DateTime::ts( $this->_data['deleted_date'] );
    }
   
   
/**
     * Set Deleted By
     *
     * @param    \IPS\Member        The member
     * @return    void
     */
   
public function set_deleted_by( \IPS\Member $member )
    {
       
$this->_data['deleted_by']            = $member->member_id;
       
$this->_data['deleted_by_name']        = $member->real_name;
       
$this->_data['deleted_by_seo_name']    = $member->members_seo_name;
    }
   
   
/**
     * @brief    Deleted By Cache
     */
   
protected $_deletedBy = NULL;
   
   
/**
     * Get Deleted By
     *
     * @return    \IPS\Member
     */
   
public function get__deleted_by()
    {
        if (
$this->_deletedBy === NULL )
        {
           
$this->_deletedBy = \IPS\Member::load( $this->_data['deleted_by'] );
        }
        return
$this->_deletedBy;
    }
   
   
/**
     * Get Permissions
     *
     * @return    array|string
     */
   
public function get_content_permissions()
    {
        if (
$this->_data['content_permissions'] == '*' )
        {
            return
$this->_data['content_permissions'];
        }
       
       
$perms = explode( ',', $this->_data['content_permissions'] );
       
       
$return = array( 'members' => array(), 'groups' => array() );
        foreach(
$perms AS $perm )
        {
            if ( \
substr( $perm, 0, 1 ) == 'm' )
            {
               
$return['members'][] = str_replace( 'm', '', $perm );
            }
            else
            {
               
$return['groups'][] = $perm;
            }
        }
       
        return
$return;
    }
   
   
/**
     * Get the date the content will be permanently removed on
     *
     * @return    \IPS\DateTime
     */
   
public function get_deletion_date()
    {
        return
$this->deleted_date->add( new \DateInterval( 'P' . \IPS\Settings::i()->dellog_retention_period . 'D' ) );
    }
   
   
/**
     * Set Content and Member
     *
     * @param    \IPS\Content        The content being deleted.
     * @param    \IPS\Member|NULL    The member performing the deletion, or NULL for the currently logged in member
     * @return    void
     * @note Convenience ftw
     */
   
public function setContentAndMember( \IPS\Content $content, \IPS\Member $member = NULL )
    {
       
$member = $member ?: \IPS\Member::loggedIn();
       
       
$idField = $content::$databaseColumnId;
       
       
$item = $content;
        if (
$content instanceof \IPS\Content\Comment )
        {
           
$item = $content->item();
        }
       
       
/* Content Data */
       
$this->content_class        = get_class( $content );
       
$this->content_id            = $content->$idField;
       
$this->content_title        = $item->mapped('title');
       
$this->content_seo_title    = \IPS\Http\Url\Friendly::seoTitle( $item->mapped('title') );
       
$this->content_permissions    = $item->deleteLogPermissions();
       
       
/* Member Data */
       
$this->deleted_by            = $member;
    }
   
   
/**
     * Save
     *
     * @return    void
     */
   
public function save()
    {
        if ( !
$this->id )
        {
           
$contentClass    = $this->content_class;
           
$content        = $contentClass::load( $this->content_id );

            if(
$content instanceof \IPS\Content\Searchable )
            {
                \
IPS\Content\Search\Index::i()->removeFromSearchIndex( $content );
            }
        }
       
       
parent::save();
    }
   
   
/**
     * Load and check perms
     *
     * @param    int        ID
     * @return    static
     * @throws
     *    @li \OutOfRangeException
     */
   
public static function loadAndCheckPerms( $id )
    {
       
$obj = parent::load( $id );
       
        if ( !
$obj->canView() )
        {
            throw new \
OutOfRangeException;
        }
       
        return
$obj;
    }
   
   
/**
     * Can View
     *
     * @param    \IPS\Member|NULL    The member, or NULL for currently logged in
     * @return    bool
     */
   
public function canView( \IPS\Member $member = NULL )
    {
       
$member = $member ?: \IPS\Member::loggedIn();
       
        if ( !
is_array( $this->content_permissions ) AND $this->content_permissions == '*' )
        {
            return
TRUE;
        }
       
        if (
in_array( $member->member_id, $this->content_permissions['members'] ) )
        {
            return
TRUE;
        }
       
        if (
$member->inGroup( $this->content_permissions['groups'] ) )
        {
            return
TRUE;
        }
       
        return
FALSE;
    }
   
   
/**
     * URL
     *
     * @param    string|NULL        "action" parameter or NULL to go to the content
     * @return    \IPS\Http\Url
     */
   
public function url( $action=NULL )
    {
        if (
$action === NULL )
        {
            try
            {
               
$class    = $this->content_class;
                if (
class_exists( $this->content_class ) )
                {
                   
$item    = $class::load( $this->content_id );
                    return
$item->url()->setQueryString( 'showDeleted', 1 );
                }
                else
                {
                   
/* Content class doesn't exist anymore */
                   
$this->delete();
                    return \
IPS\Http\Url::internal( "app=core&module=modcp&controller=modcp&tab=deleted", 'front', 'modcp_deleted' )->setQueryString( array( 'id' => $this->id, 'action' => $action ) );
                }
            }
            catch( \
OutOfRangeException $e )
            {
               
/* Orphaned item */
               
$this->delete();
               
                return \
IPS\Http\Url::internal( "app=core&module=modcp&controller=modcp&tab=deleted", 'front', 'modcp_deleted' )->setQueryString( array( 'id' => $this->id, 'action' => $action ) );
            }
        }
        else
        {
            return \
IPS\Http\Url::internal( "app=core&module=modcp&controller=modcp&tab=deleted", 'front', 'modcp_deleted' )->setQueryString( array( 'id' => $this->id, 'action' => $action ) );
        }
    }
}