function comment_reply
This function is responsible for generating a comment reply form. There are several cases that have to be handled, including:
- replies to comments
- replies to nodes
- attempts to reply to nodes that can no longer accept comments
- respecting access permissions ('access comments', 'post comments', etc.)
The node or comment that is being replied to must appear above the comment form to provide the user context while authoring the comment.
Parameters
$node: Every comment belongs to a node. This is that node.
$pid: Some comments are replies to other comments. In those cases, $pid is the parent comment's cid.
Return value
array An associative array containing:
- An array for rendering the node or parent comment.
- comment_node: If the comment is a reply to the node.
- comment_parent: If the comment is a reply to another comment.
- comment_form: The comment form as a renderable array.
1 string reference to 'comment_reply'
- comment_menu in modules/
comment/ comment.module - Implements hook_menu().
File
-
modules/
comment/ comment.pages.inc, line 33
Code
function comment_reply($node, $pid = NULL) {
// Set the breadcrumb trail.
drupal_set_breadcrumb(array(
l(t('Home'), NULL),
l($node->title, 'node/' . $node->nid),
));
$op = isset($_POST['op']) ? $_POST['op'] : '';
$build = array();
// The user is previewing a comment prior to submitting it.
if ($op == t('Preview')) {
if (user_access('post comments')) {
$build['comment_form'] = drupal_get_form("comment_node_{$node->type}_form", (object) array(
'pid' => $pid,
'nid' => $node->nid,
));
}
else {
drupal_set_message(t('You are not authorized to post comments.'), 'error');
drupal_goto("node/{$node->nid}");
}
}
else {
// $pid indicates that this is a reply to a comment.
if ($pid) {
if (user_access('access comments')) {
// Load the comment whose cid = $pid
$comment = db_query('SELECT c.*, u.uid, u.name AS registered_name, u.signature, u.signature_format, u.picture, u.data FROM {comment} c INNER JOIN {users} u ON c.uid = u.uid WHERE c.cid = :cid AND c.status = :status', array(
':cid' => $pid,
':status' => COMMENT_PUBLISHED,
))->fetchObject();
if ($comment) {
// If that comment exists, make sure that the current comment and the
// parent comment both belong to the same parent node.
if ($comment->nid != $node->nid) {
// Attempting to reply to a comment not belonging to the current nid.
drupal_set_message(t('The comment you are replying to does not exist.'), 'error');
drupal_goto("node/{$node->nid}");
}
// Display the parent comment
$comment->node_type = 'comment_node_' . $node->type;
field_attach_load('comment', array(
$comment->cid => $comment,
));
$comment->name = $comment->uid ? $comment->registered_name : $comment->name;
$build['comment_parent'] = comment_view($comment, $node);
}
else {
drupal_set_message(t('The comment you are replying to does not exist.'), 'error');
drupal_goto("node/{$node->nid}");
}
}
else {
drupal_set_message(t('You are not authorized to view comments.'), 'error');
drupal_goto("node/{$node->nid}");
}
}
elseif (user_access('access content')) {
$build['comment_node'] = node_view($node);
}
// Should we show the reply box?
if ($node->comment != COMMENT_NODE_OPEN) {
drupal_set_message(t("This discussion is closed: you can't post new comments."), 'error');
drupal_goto("node/{$node->nid}");
}
elseif (user_access('post comments')) {
$edit = array(
'nid' => $node->nid,
'pid' => $pid,
);
$build['comment_form'] = drupal_get_form("comment_node_{$node->type}_form", (object) $edit);
}
else {
drupal_set_message(t('You are not authorized to post comments.'), 'error');
drupal_goto("node/{$node->nid}");
}
}
return $build;
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.