mirror of
https://github.com/YunoHost-Apps/piwigo_ynh.git
synced 2024-09-03 20:06:03 +02:00
278 lines
8.4 KiB
PHP
278 lines
8.4 KiB
PHP
|
<?php
|
||
|
// +-----------------------------------------------------------------------+
|
||
|
// | Piwigo - a PHP based photo gallery |
|
||
|
// +-----------------------------------------------------------------------+
|
||
|
// | Copyright(C) 2008-2014 Piwigo Team http://piwigo.org |
|
||
|
// | Copyright(C) 2003-2008 PhpWebGallery Team http://phpwebgallery.net |
|
||
|
// | Copyright(C) 2002-2003 Pierrick LE GALL http://le-gall.net/pierrick |
|
||
|
// +-----------------------------------------------------------------------+
|
||
|
// | This program is free software; you can redistribute it and/or modify |
|
||
|
// | it under the terms of the GNU General Public License as published by |
|
||
|
// | the Free Software Foundation |
|
||
|
// | |
|
||
|
// | This program is distributed in the hope that it will be useful, but |
|
||
|
// | WITHOUT ANY WARRANTY; without even the implied warranty of |
|
||
|
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
||
|
// | General Public License for more details. |
|
||
|
// | |
|
||
|
// | You should have received a copy of the GNU General Public License |
|
||
|
// | along with this program; if not, write to the Free Software |
|
||
|
// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
|
||
|
// | USA. |
|
||
|
// +-----------------------------------------------------------------------+
|
||
|
|
||
|
/**
|
||
|
* This file is included by the picture page to manage user comments
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
// the picture is commentable if it belongs at least to one category which
|
||
|
// is commentable
|
||
|
$page['show_comments'] = false;
|
||
|
foreach ($related_categories as $category)
|
||
|
{
|
||
|
if ($category['commentable']=='true')
|
||
|
{
|
||
|
$page['show_comments'] = true;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if ( $page['show_comments'] and isset( $_POST['content'] ) )
|
||
|
{
|
||
|
if ( is_a_guest() and !$conf['comments_forall'] )
|
||
|
{
|
||
|
die ('Session expired');
|
||
|
}
|
||
|
|
||
|
$comm = array(
|
||
|
'author' => trim( @$_POST['author'] ),
|
||
|
'content' => trim( $_POST['content'] ),
|
||
|
'website_url' => trim( $_POST['website_url'] ),
|
||
|
'email' => trim( @$_POST['email'] ),
|
||
|
'image_id' => $page['image_id'],
|
||
|
);
|
||
|
|
||
|
include_once(PHPWG_ROOT_PATH.'include/functions_comment.inc.php');
|
||
|
|
||
|
$comment_action = insert_user_comment($comm, @$_POST['key'], $page['errors']);
|
||
|
|
||
|
switch ($comment_action)
|
||
|
{
|
||
|
case 'moderate':
|
||
|
$page['infos'][] = l10n('An administrator must authorize your comment before it is visible.');
|
||
|
case 'validate':
|
||
|
$page['infos'][] = l10n('Your comment has been registered');
|
||
|
break;
|
||
|
case 'reject':
|
||
|
set_status_header(403);
|
||
|
$page['errors'][] = l10n('Your comment has NOT been registered because it did not pass the validation rules');
|
||
|
break;
|
||
|
default:
|
||
|
trigger_error('Invalid comment action '.$comment_action, E_USER_WARNING);
|
||
|
}
|
||
|
|
||
|
// allow plugins to notify what's going on
|
||
|
trigger_action( 'user_comment_insertion',
|
||
|
array_merge($comm, array('action'=>$comment_action) )
|
||
|
);
|
||
|
}
|
||
|
elseif ( isset($_POST['content']) )
|
||
|
{
|
||
|
set_status_header(403);
|
||
|
die('ugly spammer');
|
||
|
}
|
||
|
|
||
|
if ($page['show_comments'])
|
||
|
{
|
||
|
if ( !is_admin() )
|
||
|
{
|
||
|
$validated_clause = ' AND validated = \'true\'';
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$validated_clause = '';
|
||
|
}
|
||
|
|
||
|
// number of comments for this picture
|
||
|
$query = '
|
||
|
SELECT
|
||
|
COUNT(*) AS nb_comments
|
||
|
FROM '.COMMENTS_TABLE.'
|
||
|
WHERE image_id = '.$page['image_id']
|
||
|
.$validated_clause.'
|
||
|
;';
|
||
|
$row = pwg_db_fetch_assoc( pwg_query( $query ) );
|
||
|
|
||
|
// navigation bar creation
|
||
|
if (!isset($page['start']))
|
||
|
{
|
||
|
$page['start'] = 0;
|
||
|
}
|
||
|
|
||
|
$navigation_bar = create_navigation_bar(
|
||
|
duplicate_picture_url(array(), array('start')),
|
||
|
$row['nb_comments'],
|
||
|
$page['start'],
|
||
|
$conf['nb_comment_page'],
|
||
|
true // We want a clean URL
|
||
|
);
|
||
|
|
||
|
$template->assign(
|
||
|
array(
|
||
|
'COMMENT_COUNT' => $row['nb_comments'],
|
||
|
'navbar' => $navigation_bar,
|
||
|
)
|
||
|
);
|
||
|
|
||
|
if ($row['nb_comments'] > 0)
|
||
|
{
|
||
|
// comments order (get, session, conf)
|
||
|
if (!empty($_GET['comments_order']) && in_array(strtoupper($_GET['comments_order']), array('ASC', 'DESC')))
|
||
|
{
|
||
|
pwg_set_session_var('comments_order', $_GET['comments_order']);
|
||
|
}
|
||
|
$comments_order = pwg_get_session_var('comments_order', $conf['comments_order']);
|
||
|
|
||
|
$template->assign(array(
|
||
|
'COMMENTS_ORDER_URL' => add_url_params( duplicate_picture_url(), array('comments_order'=> ($comments_order == 'ASC' ? 'DESC' : 'ASC') ) ),
|
||
|
'COMMENTS_ORDER_TITLE' => $comments_order == 'ASC' ? l10n('Show latest comments first') : l10n('Show oldest comments first'),
|
||
|
));
|
||
|
|
||
|
$query = '
|
||
|
SELECT
|
||
|
com.id,
|
||
|
author,
|
||
|
author_id,
|
||
|
u.'.$conf['user_fields']['email'].' AS user_email,
|
||
|
date,
|
||
|
image_id,
|
||
|
website_url,
|
||
|
com.email,
|
||
|
content,
|
||
|
validated
|
||
|
FROM '.COMMENTS_TABLE.' AS com
|
||
|
LEFT JOIN '.USERS_TABLE.' AS u
|
||
|
ON u.'.$conf['user_fields']['id'].' = author_id
|
||
|
WHERE image_id = '.$page['image_id'].'
|
||
|
'.$validated_clause.'
|
||
|
ORDER BY date '.$comments_order.'
|
||
|
LIMIT '.$conf['nb_comment_page'].' OFFSET '.$page['start'].'
|
||
|
;';
|
||
|
$result = pwg_query( $query );
|
||
|
|
||
|
while ($row = pwg_db_fetch_assoc($result))
|
||
|
{
|
||
|
if ($row['author'] == 'guest')
|
||
|
{
|
||
|
$row['author'] = l10n('guest');
|
||
|
}
|
||
|
|
||
|
$email = null;
|
||
|
if (!empty($row['user_email']))
|
||
|
{
|
||
|
$email = $row['user_email'];
|
||
|
}
|
||
|
elseif (!empty($row['email']))
|
||
|
{
|
||
|
$email = $row['email'];
|
||
|
}
|
||
|
|
||
|
$tpl_comment =
|
||
|
array(
|
||
|
'ID' => $row['id'],
|
||
|
'AUTHOR' => trigger_event('render_comment_author', $row['author']),
|
||
|
'DATE' => format_date($row['date'], true),
|
||
|
'CONTENT' => trigger_event('render_comment_content',$row['content']),
|
||
|
'WEBSITE_URL' => $row['website_url'],
|
||
|
);
|
||
|
|
||
|
if (can_manage_comment('delete', $row['author_id']))
|
||
|
{
|
||
|
$tpl_comment['U_DELETE'] = add_url_params(
|
||
|
$url_self,
|
||
|
array(
|
||
|
'action'=>'delete_comment',
|
||
|
'comment_to_delete'=>$row['id'],
|
||
|
'pwg_token' => get_pwg_token(),
|
||
|
)
|
||
|
);
|
||
|
}
|
||
|
if (can_manage_comment('edit', $row['author_id']))
|
||
|
{
|
||
|
$tpl_comment['U_EDIT'] = add_url_params(
|
||
|
$url_self,
|
||
|
array(
|
||
|
'action'=>'edit_comment',
|
||
|
'comment_to_edit'=>$row['id'],
|
||
|
)
|
||
|
);
|
||
|
if (isset($edit_comment) and ($row['id'] == $edit_comment))
|
||
|
{
|
||
|
$tpl_comment['IN_EDIT'] = true;
|
||
|
$key = get_ephemeral_key(2, $page['image_id']);
|
||
|
$tpl_comment['KEY'] = $key;
|
||
|
$tpl_comment['CONTENT'] = $row['content'];
|
||
|
$tpl_comment['PWG_TOKEN'] = get_pwg_token();
|
||
|
$tpl_comment['U_CANCEL'] = $url_self;
|
||
|
}
|
||
|
}
|
||
|
if (is_admin())
|
||
|
{
|
||
|
$tpl_comment['EMAIL'] = $email;
|
||
|
|
||
|
if ($row['validated'] != 'true')
|
||
|
{
|
||
|
$tpl_comment['U_VALIDATE'] = add_url_params(
|
||
|
$url_self,
|
||
|
array(
|
||
|
'action' => 'validate_comment',
|
||
|
'comment_to_validate' => $row['id'],
|
||
|
'pwg_token' => get_pwg_token(),
|
||
|
)
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
$template->append('comments', $tpl_comment);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$show_add_comment_form = true;
|
||
|
if (isset($edit_comment))
|
||
|
{
|
||
|
$show_add_comment_form = false;
|
||
|
}
|
||
|
if (is_a_guest() and !$conf['comments_forall'])
|
||
|
{
|
||
|
$show_add_comment_form = false;
|
||
|
}
|
||
|
|
||
|
if ($show_add_comment_form)
|
||
|
{
|
||
|
$key = get_ephemeral_key(3, $page['image_id']);
|
||
|
|
||
|
$tpl_var = array(
|
||
|
'F_ACTION' => $url_self,
|
||
|
'KEY' => $key,
|
||
|
'CONTENT' => '',
|
||
|
'SHOW_AUTHOR' => !is_classic_user(),
|
||
|
'AUTHOR_MANDATORY' => $conf['comments_author_mandatory'],
|
||
|
'AUTHOR' => '',
|
||
|
'WEBSITE_URL' => '',
|
||
|
'SHOW_EMAIL' => !is_classic_user() or empty($user['email']),
|
||
|
'EMAIL_MANDATORY' => $conf['comments_email_mandatory'],
|
||
|
'EMAIL' => '',
|
||
|
);
|
||
|
|
||
|
if ('reject'==@$comment_action)
|
||
|
{
|
||
|
foreach( array('content', 'author', 'website_url', 'email') as $k)
|
||
|
{
|
||
|
$tpl_var[strtoupper($k)] = htmlspecialchars( stripslashes(@$_POST[$k]) );
|
||
|
}
|
||
|
}
|
||
|
$template->assign('comment_add', $tpl_var);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
?>
|