Вход Регистрация
Файл: contao-3.5.8/system/modules/comments/dca/tl_comments.php
Строк: 502
<?php

/**
 * Contao Open Source CMS
 *
 * Copyright (c) 2005-2016 Leo Feyer
 *
 * @license LGPL-3.0+
 */


/**
 * Table tl_comments
 */
$GLOBALS['TL_DCA']['tl_comments'] = array
(

    
// Config
    
'config' => array
    (
        
'dataContainer'               => 'Table',
        
'enableVersioning'            => true,
        
'closed'                      => true,
        
'notCopyable'                 => true,
        
'onload_callback' => array
        (
            array(
'tl_comments''checkPermission')
        ),
        
'sql' => array
        (
            
'keys' => array
            (
                
'id' => 'primary',
                
'published' => 'index',
                
'source,parent,published' => 'index'
            
)
        )
    ),

    
// List
    
'list' => array
    (
        
'sorting' => array
        (
            
'mode'                    => 2,
            
'fields'                  => array('date DESC'),
            
'flag'                    => 8,
            
'panelLayout'             => 'filter;sort,search,limit'
        
),
        
'label' => array
        (
            
'fields'                  => array('name'),
            
'format'                  => '%s',
            
'label_callback'          => array('tl_comments''listComments')
        ),
        
'global_operations' => array
        (
            
'all' => array
            (
                
'label'               => &$GLOBALS['TL_LANG']['MSC']['all'],
                
'href'                => 'act=select',
                
'class'               => 'header_edit_all',
                
'attributes'          => 'onclick="Backend.getScrollOffset()" accesskey="e"'
            
)
        ),
        
'operations' => array
        (
            
'edit' => array
            (
                
'label'               => &$GLOBALS['TL_LANG']['tl_comments']['edit'],
                
'href'                => 'act=edit',
                
'icon'                => 'edit.gif',
                
'button_callback'     => array('tl_comments''editComment')
            ),
            
'delete' => array
            (
                
'label'               => &$GLOBALS['TL_LANG']['tl_comments']['delete'],
                
'href'                => 'act=delete',
                
'icon'                => 'delete.gif',
                
'attributes'          => 'onclick="if(!confirm('' . $GLOBALS['TL_LANG']['MSC']['deleteConfirm'] . ''))return false;Backend.getScrollOffset()"',
                
'button_callback'     => array('tl_comments''deleteComment')
            ),
            
'toggle' => array
            (
                
'label'               => &$GLOBALS['TL_LANG']['tl_comments']['toggle'],
                
'icon'                => 'visible.gif',
                
'attributes'          => 'onclick="Backend.getScrollOffset();return AjaxRequest.toggleVisibility(this,%s)"',
                
'button_callback'     => array('tl_comments''toggleIcon')
            ),
            
'show' => array
            (
                
'label'               => &$GLOBALS['TL_LANG']['tl_comments']['show'],
                
'href'                => 'act=show',
                
'icon'                => 'show.gif'
            
)
        )
    ),

    
// Palettes
    
'palettes' => array
    (
        
'__selector__'                => array('addReply'),
        
'default'                     => '{author_legend},name,email,website;{comment_legend},comment;{reply_legend},addReply;{publish_legend},published'
    
),

    
// Subpalettes
    
'subpalettes' => array
    (
        
'addReply'                    => 'author,reply'
    
),

    
// Fields
    
'fields' => array
    (
        
'id' => array
        (
            
'sql'                     => "int(10) unsigned NOT NULL auto_increment"
        
),
        
'tstamp' => array
        (
            
'sql'                     => "int(10) unsigned NOT NULL default '0'"
        
),
        
'source' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['source'],
            
'filter'                  => true,
            
'sorting'                 => true,
            
'reference'               => &$GLOBALS['TL_LANG']['tl_comments'],
            
'sql'                     => "varchar(32) NOT NULL default ''"
        
),
        
'parent' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['parent'],
            
'filter'                  => true,
            
'sorting'                 => true,
            
'sql'                     => "int(10) unsigned NOT NULL default '0'"
        
),
        
'date' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['date'],
            
'sorting'                 => true,
            
'filter'                  => true,
            
'flag'                    => 8,
            
'eval'                    => array('rgxp'=>'datim'),
            
'sql'                     => "varchar(64) NOT NULL default ''"
        
),
        
'name' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['name'],
            
'exclude'                 => true,
            
'search'                  => true,
            
'inputType'               => 'text',
            
'eval'                    => array('mandatory'=>true'maxlength'=>64),
            
'sql'                     => "varchar(64) NOT NULL default ''"
        
),
        
'email' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['email'],
            
'exclude'                 => true,
            
'search'                  => true,
            
'inputType'               => 'text',
            
'eval'                    => array('mandatory'=>true'maxlength'=>255'rgxp'=>'email''decodeEntities'=>true'tl_class'=>'w50'),
            
'sql'                     => "varchar(255) NOT NULL default ''"
        
),
        
'website' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['website'],
            
'exclude'                 => true,
            
'search'                  => true,
            
'inputType'               => 'text',
            
'eval'                    => array('maxlength'=>128'rgxp'=>'url''decodeEntities'=>true'tl_class'=>'w50'),
            
'sql'                     => "varchar(128) NOT NULL default ''"
        
),
        
'comment' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['comment'],
            
'exclude'                 => true,
            
'search'                  => true,
            
'inputType'               => 'textarea',
            
'eval'                    => array('mandatory'=>true'rte'=>'tinyMCE'),
            
'sql'                     => "text NULL"
        
),
        
'addReply' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['addReply'],
            
'exclude'                 => true,
            
'filter'                  => true,
            
'inputType'               => 'checkbox',
            
'eval'                    => array('submitOnChange'=>true),
            
'sql'                     => "char(1) NOT NULL default ''"
        
),
        
'author' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['author'],
            
'default'                 => BackendUser::getInstance()->id,
            
'exclude'                 => true,
            
'inputType'               => 'select',
            
'foreignKey'              => 'tl_user.name',
            
'eval'                    => array('mandatory'=>true'chosen'=>true'doNotCopy'=>true'includeBlankOption'=>true),
            
'sql'                     => "int(10) unsigned NOT NULL default '0'",
            
'relation'                => array('type'=>'belongsTo''load'=>'eager')
        ),
        
'reply' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['reply'],
            
'exclude'                 => true,
            
'search'                  => true,
            
'inputType'               => 'textarea',
            
'eval'                    => array('rte'=>'tinyMCE'),
            
'sql'                     => "text NULL"
        
),
        
'published' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['published'],
            
'exclude'                 => true,
            
'filter'                  => true,
            
'inputType'               => 'checkbox',
            
'eval'                    => array('doNotCopy'=>true),
            
'save_callback' => array
            (
                array(
'tl_comments''sendNotifications')
            ),
            
'sql'                     => "char(1) NOT NULL default ''"
        
),
        
'ip' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['ip'],
            
'sql'                     => "varchar(64) NOT NULL default ''"
        
),
        
'notified' => array
        (
            
'label'                   => &$GLOBALS['TL_LANG']['tl_comments']['notified'],
            
'sql'                     => "char(1) NOT NULL default ''"
        
)
    )
);


/**
 * Provide miscellaneous methods that are used by the data configuration array.
 *
 * @author Leo Feyer <https://github.com/leofeyer>
 */
class tl_comments extends Backend
{

    
/**
     * Import the back end user object
     */
    
public function __construct()
    {
        
parent::__construct();
        
$this->import('BackendUser''User');
    }


    
/**
     * Check permissions to edit table tl_comments
     */
    
public function checkPermission()
    {
        switch (
Input::get('act'))
        {
            case 
'select':
            case 
'show':
                
// Allow
                
break;

            case 
'edit':
            case 
'delete':
            case 
'toggle':
                
$objComment $this->Database->prepare("SELECT id, parent, source FROM tl_comments WHERE id=?")
                                             ->
limit(1)
                                             ->
execute(Input::get('id'));

                if (
$objComment->numRows 1)
                {
                    
$this->log('Comment ID ' Input::get('id') . ' does not exist'__METHOD__TL_ERROR);
                    
$this->redirect('contao/main.php?act=error');
                }

                if (!
$this->isAllowedToEditComment($objComment->parent$objComment->source))
                {
                    
$this->log('Not enough permissions to ' Input::get('act') . ' comment ID ' Input::get('id') . ' (parent element: ' $objComment->source ' ID ' $objComment->parent ')'__METHOD__TL_ERROR);
                    
$this->redirect('contao/main.php?act=error');
                }
                break;

            case 
'editAll':
            case 
'deleteAll':
            case 
'overrideAll':
                
$session $this->Session->getData();

                if (!
is_array($session['CURRENT']['IDS']) || empty($session['CURRENT']['IDS']))
                {
                    break;
                }

                
$objComment $this->Database->execute("SELECT id, parent, source FROM tl_comments WHERE id IN(" implode(','array_map('intval'$session['CURRENT']['IDS'])) . ")");

                while (
$objComment->next())
                {
                    if (!
$this->isAllowedToEditComment($objComment->parent$objComment->source) && ($key array_search($objComment->id$session['CURRENT']['IDS'])) !== false)
                    {
                        unset(
$session['CURRENT']['IDS'][$key]);
                    }
                }

                
$session['CURRENT']['IDS'] = array_values($session['CURRENT']['IDS']);
                
$this->Session->setData($session);
                break;

            default:
                if (
strlen(Input::get('act')))
                {
                    
$this->log('Invalid command "'.Input::get('act').'"'__METHOD__TL_ERROR);
                    
$this->redirect('contao/main.php?act=error');
                }
                break;
        }
    }


    
/**
     * Check whether the user is allowed to edit a comment
     *
     * @param integer $intParent
     * @param string  $strSource
     *
     * @return boolean
     */
    
protected function isAllowedToEditComment($intParent$strSource)
    {
        if (
$this->User->isAdmin)
        {
            return 
true;
        }

        
$strKey __METHOD__ '-' $strSource '-' $intParent;

        
// Load cached result
        
if (Cache::has($strKey))
        {
            return 
Cache::get($strKey);
        }

        
// Order deny,allow
        
Cache::set($strKeyfalse);

        switch (
$strSource)
        {
            case 
'tl_content':
                
$objPage $this->Database->prepare("SELECT * FROM tl_page WHERE id=(SELECT pid FROM tl_article WHERE id=(SELECT pid FROM tl_content WHERE id=?))")
                                          ->
limit(1)
                                          ->
execute($intParent);

                
// Do not check whether the page is mounted (see #5174)
                
if ($objPage->numRows && $this->User->isAllowed(BackendUser::CAN_EDIT_ARTICLES$objPage->row()))
                {
                    
Cache::set($strKeytrue);
                }
                break;

            case 
'tl_page':
                
$objPage $this->Database->prepare("SELECT * FROM tl_page WHERE id=?")
                                          ->
limit(1)
                                          ->
execute($intParent);

                
// Do not check whether the page is mounted (see #5174)
                
if ($objPage->numRows && $this->User->isAllowed(BackendUser::CAN_EDIT_PAGE$objPage->row()))
                {
                    
Cache::set($strKeytrue);
                }
                break;

            case 
'tl_news':
                
$objArchive $this->Database->prepare("SELECT pid FROM tl_news WHERE id=?")
                                             ->
limit(1)
                                             ->
execute($intParent);

                
// Do not check the access to the news module (see #5174)
                
if ($objArchive->numRows && $this->User->hasAccess($objArchive->pid'news'))
                {
                    
Cache::set($strKeytrue);
                }
                break;

            case 
'tl_calendar_events':
                
$objCalendar $this->Database->prepare("SELECT pid FROM tl_calendar_events WHERE id=?")
                                              ->
limit(1)
                                              ->
execute($intParent);

                
// Do not check the access to the calendar module (see #5174)
                
if ($objCalendar->numRows && $this->User->hasAccess($objCalendar->pid'calendars'))
                {
                        
Cache::set($strKeytrue);
                }
                break;

            case 
'tl_faq':
                
// Do not check the access to the FAQ module (see #5174)
                
Cache::set($strKeytrue);
                break;

            default:
                
// HOOK: support custom modules
                
if (isset($GLOBALS['TL_HOOKS']['isAllowedToEditComment']) && is_array($GLOBALS['TL_HOOKS']['isAllowedToEditComment']))
                {
                    foreach (
$GLOBALS['TL_HOOKS']['isAllowedToEditComment'] as $callback)
                    {
                        
$this->import($callback[0]);

                        if (
$this->{$callback[0]}->{$callback[1]}($intParent$strSource) === true)
                        {
                            
Cache::set($strKeytrue);
                            break;
                        }
                    }
                }
                break;
        }

        return 
Cache::get($strKey);
    }


    
/**
     * Send out the new comment notifications
     *
     * @param mixed $varValue
     *
     * @return mixed
     */
    
public function sendNotifications($varValue)
    {
        if (
$varValue)
        {
            
Comments::notifyCommentsSubscribers(CommentsModel::findByPk(Input::get('id')));
        }

        return 
$varValue;
    }


    
/**
     * List a particular record
     *
     * @param array $arrRow
     *
     * @return string
     */
    
public function listComments($arrRow)
    {
        
$title $GLOBALS['TL_LANG']['tl_comments'][$arrRow['source']] . ' ' $arrRow['parent'];

        switch (
$arrRow['source'])
        {
            case 
'tl_content':
                
$objParent $this->Database->prepare("SELECT id, title FROM tl_article WHERE id=(SELECT pid FROM tl_content WHERE id=?)")
                                            ->
execute($arrRow['parent']);

                if (
$objParent->numRows)
                {
                    
$title .= ' (<a href="contao/main.php?do=article&amp;table=tl_content&amp;id=' $objParent->id '&amp;rt=' REQUEST_TOKEN '">' $objParent->title '</a>)';
                }
                break;

            case 
'tl_page':
                
$objParent $this->Database->prepare("SELECT id, title FROM tl_page WHERE id=?")
                                            ->
execute($arrRow['parent']);

                if (
$objParent->numRows)
                {
                    
$title .= ' (<a href="contao/main.php?do=page&amp;act=edit&amp;id=' $objParent->id '&amp;rt=' REQUEST_TOKEN '">' $objParent->title '</a>)';
                }
                break;

            case 
'tl_news':
                
$objParent $this->Database->prepare("SELECT id, headline FROM tl_news WHERE id=?")
                                            ->
execute($arrRow['parent']);

                if (
$objParent->numRows)
                {
                    
$title .= ' (<a href="contao/main.php?do=news&amp;table=tl_news&amp;act=edit&amp;id=' $objParent->id '&amp;rt=' REQUEST_TOKEN '">' $objParent->headline '</a>)';
                }
                break;

            case 
'tl_faq':
                
$objParent $this->Database->prepare("SELECT id, question FROM tl_faq WHERE id=?")
                                            ->
execute($arrRow['parent']);

                if (
$objParent->numRows)
                {
                    
$title .= ' (<a href="contao/main.php?do=faq&amp;table=tl_faq&amp;act=edit&amp;id=' $objParent->id '&amp;rt=' REQUEST_TOKEN '">' $objParent->question '</a>)';
                }
                break;

            case 
'tl_calendar_events':
                
$objParent $this->Database->prepare("SELECT id, title FROM tl_calendar_events WHERE id=?")
                                            ->
execute($arrRow['parent']);

                if (
$objParent->numRows)
                {
                    
$title .= ' (<a href="contao/main.php?do=calendar&amp;table=tl_calendar_events&amp;act=edit&amp;id=' $objParent->id '&amp;rt=' REQUEST_TOKEN '">' $objParent->title '</a>)';
                }
                break;

            default:
                
// HOOK: support custom modules
                
if (isset($GLOBALS['TL_HOOKS']['listComments']) && is_array($GLOBALS['TL_HOOKS']['listComments']))
                {
                    foreach (
$GLOBALS['TL_HOOKS']['listComments'] as $callback)
                    {
                        
$this->import($callback[0]);

                        if ((
$tmp $this->{$callback[0]}->{$callback[1]}($arrRow)) != '')
                        {
                            
$title .= $tmp;
                            break;
                        }
                    }
                }
                break;
        }

        
$key = ($arrRow['published'] ? 'published' 'unpublished') . ($arrRow['addReply'] ? ' replied' '');

        return 
'
<div class="comment_wrap">
<div class="cte_type ' 
$key '"><strong><a href="mailto:' $arrRow['email'] . '" title="' specialchars($arrRow['email']) . '">' $arrRow['name'] . '</a></strong>' . (($arrRow['website'] != '') ? ' (<a href="' $arrRow['website'] . '" title="' specialchars($arrRow['website']) . '" target="_blank">' $GLOBALS['TL_LANG']['MSC']['com_website'] . '</a>)' '') . ' - ' Date::parse(Config::get('datimFormat'), $arrRow['date']) . ' - IP ' specialchars($arrRow['ip']) . '<br>' $title '</div>
<div class="limit_height mark_links' 
. (!Config::get('doNotCollapse') ? ' h52' '') . '">
$arrRow['comment'] . '
</div>
</div>' 
"n    ";
    }


    
/**
     * Return the edit comment button
     *
     * @param array  $row
     * @param string $href
     * @param string $label
     * @param string $title
     * @param string $icon
     * @param string $attributes
     *
     * @return string
     */
    
public function editComment($row$href$label$title$icon$attributes)
    {
        return 
$this->isAllowedToEditComment($row['parent'], $row['source']) ? '<a href="'.$this->addToUrl($href.'&amp;id='.$row['id']).'" title="'.specialchars($title).'"'.$attributes.'>'.Image::getHtml($icon$label).'</a> ' Image::getHtml(preg_replace('/.gif$/i''_.gif'$icon)).' ';
    }


    
/**
     * Return the delete comment button
     *
     * @param array  $row
     * @param string $href
     * @param string $label
     * @param string $title
     * @param string $icon
     * @param string $attributes
     *
     * @return string
     */
    
public function deleteComment($row$href$label$title$icon$attributes)
    {
        return 
$this->isAllowedToEditComment($row['parent'], $row['source']) ? '<a href="'.$this->addToUrl($href.'&amp;id='.$row['id']).'" title="'.specialchars($title).'"'.$attributes.'>'.Image::getHtml($icon$label).'</a> ' Image::getHtml(preg_replace('/.gif$/i''_.gif'$icon)).' ';
    }


    
/**
     * Return the "toggle visibility" button
     *
     * @param array  $row
     * @param string $href
     * @param string $label
     * @param string $title
     * @param string $icon
     * @param string $attributes
     *
     * @return string
     */
    
public function toggleIcon($row$href$label$title$icon$attributes)
    {
        if (
strlen(Input::get('tid')))
        {
            
$this->toggleVisibility(Input::get('tid'), (Input::get('state') == 1), (@func_get_arg(12) ?: null));
            
$this->redirect($this->getReferer());
        }

        
// Check permissions AFTER checking the tid, so hacking attempts are logged
        
if (!$this->User->hasAccess('tl_comments::published''alexf'))
        {
            return 
'';
        }

        
$href .= '&amp;tid='.$row['id'].'&amp;state='.($row['published'] ? '' 1);

        if (!
$row['published'])
        {
            
$icon 'invisible.gif';
        }

        if (!
$this->isAllowedToEditComment($row['parent'], $row['source']))
        {
            return 
Image::getHtml($icon) . ' ';
        }

        return 
'<a href="'.$this->addToUrl($href).'" title="'.specialchars($title).'"'.$attributes.'>'.Image::getHtml($icon$label'data-state="' . ($row['published'] ? 0) . '"').'</a> ';
    }


    
/**
     * Disable/enable a user group
     *
     * @param integer       $intId
     * @param boolean       $blnVisible
     * @param DataContainer $dc
     */
    
public function toggleVisibility($intId$blnVisibleDataContainer $dc=null)
    {
        
// Set the ID and action
        
Input::setGet('id'$intId);
        
Input::setGet('act''toggle');

        if (
$dc)
        {
            
$dc->id $intId// see #8043
        
}

        
$this->checkPermission();

        
// Check the field access
        
if (!$this->User->hasAccess('tl_comments::published''alexf'))
        {
            
$this->log('Not enough permissions to publish/unpublish comment ID "'.$intId.'"'__METHOD__TL_ERROR);
            
$this->redirect('contao/main.php?act=error');
        }

        
$objVersions = new Versions('tl_comments'$intId);
        
$objVersions->initialize();

        
// Trigger the save_callback
        
if (is_array($GLOBALS['TL_DCA']['tl_comments']['fields']['published']['save_callback']))
        {
            foreach (
$GLOBALS['TL_DCA']['tl_comments']['fields']['published']['save_callback'] as $callback)
            {
                if (
is_array($callback))
                {
                    
$this->import($callback[0]);
                    
$blnVisible $this->{$callback[0]}->{$callback[1]}($blnVisible, ($dc ?: $this));
                }
                elseif (
is_callable($callback))
                {
                    
$blnVisible $callback($blnVisible, ($dc ?: $this));
                }
            }
        }

        
// Update the database
        
$this->Database->prepare("UPDATE tl_comments SET tstamp="time() .", published='" . ($blnVisible '1' '') . "' WHERE id=?")
                       ->
execute($intId);

        
$objVersions->create();
        
$this->log('A new version of record "tl_comments.id='.$intId.'" has been created'.$this->getParentEntries('tl_comments'$intId), __METHOD__TL_GENERAL);
    }
}
Онлайн: 0
Реклама