The Arcive of Official vBulletin Modifications Site.It is not a VB3 engine, just a parsed copy! |
|
vBulletin-WordPress Bridge Details »» | |||||||||||||||||||||||||
I have been looking around for a WordPress - vBulletin plug-in and can?t seem to find one. I had time today to look at the WordPress code and tried out some things, and came up with a small hack for a bridge.
This bridge will let you use vBulletin as the main comments area for the blog entry. A copy of the intro blog entry is automatically created in a specific forum you choose, as well as a link back to the original blog entry from the forum. The blog entry will also show the total comments made. Let me first say that I don?t have any experience in creating plug-ins for WordPress so please don?t ask me to convert this to one. If you plan to make this as an official plug-in or improve on it, please make sure to let me know so I can place a link on this article to yours. Thanks and I hope you all enjoy it. Note:
Database Changes: I have added a new column in WordPress? posts table to maintian the vBulletin thread id that will be automatically generated for the blog entry. Note that the table name prefix might be different from your WordPress table settings: Code:
ALTER TABLE `wp_posts` ADD `vb_threadid` INT(10); Save the following as vb3?settings.php and upload it to the Wordpress wp-includes folder: Code:
<?php // This just holds the vb variables $vb_bridge = 1; // 1=on 0=off $vb_forumid = '2'; // forum id to post copy of article $vb_userid = '1'; // user id to use for posting the article $vb_username = 'admin'; // name of the user id $vb_path = 'http://www.yoursite.com/forum'; //complete url of forums $vb_dbprefix = 'vb3_'; //vBulletin database prefix $vb_readmessage = 'Read the full blog entry.'; //message to be used in the forum to link back to the blog entry ?>
Added in v1.1: In the attached files at the right, download postfeed.php and upload it to the root folder of your vB forums (it should be in the same folder where external.php is). Files to be Modified: Here comes the slightly harder part. We need to modify some WordPress files. Part of the changes assume that you are using the Kubrick default theme. If you are using a different theme, change the corresponding files accordingly. wp-includes/comment-functions.php Replace: Code:
function get_comments_number( $comment_id ) { global $wpdb, $comment_count_cache; $comment_id = (int) $comment_id; if (!isset($comment_count_cache[$comment_id])) $comment_count_cache[$comment_id] = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->comments WHERE comment_post_ID = '$comment_id' AND comment_approved = '1'"); return apply_filters('get_comments_number', $comment_count_cache[$comment_id]); } Code:
function get_comments_number( $comment_id ) { global $wpdb, $comment_count_cache; include (ABSPATH . WPINC . '/vb3-settings.php'); $comment_id = (int) $comment_id; if (!isset($comment_count_cache[$comment_id])) { if ($vb_bridge){ $vb_threadid = $wpdb->get_var("SELECT vb_threadid FROM $wpdb->comments WHERE id = '$comment_id'"); $comment_count_cache[$comment_id] = $wpdb->get_var("SELECT count(*)-1 FROM {$vb_dbprefix}post WHERE threadid = '$vb_threadid'"); } else { $comment_count_cache[$comment_id] = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->comments WHERE comment_post_ID = '$comment_id' AND comment_approved = '1'"); } } return apply_filters('get_comments_number', $comment_count_cache[$comment_id]); } Code:
function comments_popup_link($zero='No Comments', $one='1 Comment', $more='% Comments', $CSSclass='', $none='Comments Off') { global $id, $wpcommentspopupfile, $wpcommentsjavascript, $post, $wpdb; global $comment_count_cache; Code:
include (ABSPATH . WPINC . '/vb3-settings.php'); if ($vb_bridge){ $vb_threadid = $post->vb_threadid; if ($vb_threadid == "") { echo $none; return; } else { $comment_count_cache[$id] = $wpdb->get_var("SELECT count(*)-1 FROM {$vb_dbprefix}post WHERE threadid = '$vb_threadid'"); } $number = $comment_count_cache[$id]; echo '<a href="'.$vb_path.'/showthread.php?t=' . $vb_threadid .'&goto=newpost">'; comments_number($zero, $one, $more, $number); echo '</a>'; return; } Added in v1.1: wp-includes/feed-functions.php Replace: Code:
function comments_rss_link($link_text = 'Comments RSS', $commentsrssfilename = '') { $url = comments_rss($commentsrssfilename); echo "<a href='$url'>$link_text</a>"; } Code:
function comments_rss_link($link_text = 'Comments RSS', $commentsrssfilename = '') { global $post; include_once (ABSPATH . WPINC . '/vb3-settings.php'); if ($vb_bridge){ $url = $vb_path . '/postfeed.php?t=' . $post->vb_threadid . '&type=rss2'; } else { $url = comments_rss($commentsrssfilename); } echo "<a href='$url'>$link_text</a>"; } wp-admin/post.php Below: Code:
require_once('admin.php'); Code:
include_once (ABSPATH . WPINC . '/vb3-settings.php'); Code:
$result = $wpdb->query($postquery); Code:
// VB Bridge Start if ($vb_bridge) { if ($post_title == "") { return; } $saveid = $vb_userid; $savename = $vb_username; $author_name = $wpdb->get_var("SELECT `user_login` FROM $wpdb->users WHERE `id` = '$post_author'"); if ($author_name != ""){ $vb_authorid = $wpdb->get_var("SELECT `userid` FROM " . $vb_dbprefix . "user WHERE `username` = '$author_name'"); if ($vb_authorid != ""){ $saveid = $vb_authorid; $savename = $author_name; } } $curtime = time(); $sql = "INSERT INTO `{$vb_dbprefix}thread` SET `title`='{$post_title}',`lastpost`='{$curtime}', `forumid`='{$vb_forumid}', `open`='1', `postusername`='{$savename}', `postuserid`='{$saveid}', `lastposter`='{$savename}', `dateline`='{$curtime}', `visible`='1'"; $vbresult = $wpdb->query($sql); $vb_threadid = $wpdb->insert_id; if ($excerpt == ""){ $moreflag = strpos($content,'<!--more-->'); if ($moreflag === false) { $introtext = $content; } else { $introtext = substr($content, 0, $moreflag); } $bbcontent = '[quote'.']'.strip_tags($introtext).'['.'/quote]'; } else { $bbcontent = '[quote'.']'.strip_tags($excerpt).'['.'/quote]'; } $bbcontent .= '[URL='.get_permalink($post_ID).']['.'b]'.$vb_readmessage.'['.'/b]['.'/URL]'; $sql = "INSERT INTO `{$vb_dbprefix}post` SET `threadid`='{$vb_threadid}', `username`='{$savename}', `userid`='{$saveid}', `title`='{$post_title}', `pagetext`='{$bbcontent}', `ipaddress`='{$REMOTE_ADDR}', `allowsmilie`='1', `iconid`='1',`visible`='1', `dateline`='{$curtime}'"; $vbresult = $wpdb->query($sql); $sql = "UPDATE `{$vb_dbprefix}forum` SET `threadcount`=`threadcount`+1, `lastpost`='{$curtime}', `lastposter`='{$savename}', `lastthread`='{$post_title}', `lastthreadid`='{$vb_threadid}', `lasticonid`='1' WHERE `forumid`='{$vb_forumid}' LIMIT 1"; $vbresult = $wpdb->query($sql); $sql = "UPDATE $wpdb->posts SET `vb_threadid`={$vb_threadid} WHERE `ID`='{$post_ID}'"; $vbresult = $wpdb->query($sql); } // VB Bridge End If you are using the Kubrick default theme, open wp-content/themes/default/comments.php Replace contents with: Code:
<?php // Do not delete these lines if ('comments.php' == basename($_SERVER['SCRIPT_FILENAME'])) die ('Please do not load this page directly. Thanks!'); if (!empty($post->post_password)) { // if there's a password if ($_COOKIE['wp-postpass_' . COOKIEHASH] != $post->post_password) { // and it doesn't match the cookie ?> <p class="nocomments">This post is password protected. Enter the password to view comments.<p> <?php return; } } /* This variable is for alternating comment background */ $oddcomment = 'alt'; ?> <!-- You can start editing here. --> <p class="postmetadata">Discuss: <?php comments_popup_link('No Comments ?', '1 Comment ?', '% Comments ?'); ?></p> If you are using the Kubrick default theme, open wp-content/themes/default/single.php Replace: Code:
You can <a href="#respond">leave a response</a>, or <a href="<?php trackback_url(true); ?>" rel="trackback">trackback</a> from your own site. Code:
You can <a href="/forum/showthread.php?t=<?php echo( $post->vb_threadid ); ?>&goto=newpost">leave a response</a>, or <a href="<?php trackback_url(true); ?>" rel="trackback">trackback</a> from your own site. If you are using the Kubrick default theme, open wp-content/themes/default/footer.php Replace: Code:
and <a href="feed:<?php bloginfo('comments_rss2_url'); ?>">Comments (RSS)</a>. Code:
<!-- and <a href="feed:<?php bloginfo('comments_rss2_url'); ?>">Comments (RSS)</a>.--> Lastly, open wp-rss2.php Replace: Code:
<wfw:commentRSS><?php echo comments_rss(); ?></wfw:commentRSS> Code:
<wfw:commentRSS>http://www.yoursite.com/forum/showthread.php?t=<?php echo $post->vb_threadid; ?></wfw:commentRSS> vBulletin Settings: The RSS feed will not work if you haven't activated RSS External synidcation on your forum. To do this, on your forums admincp, go to vBulletin Options->External Data Provider and check 'Yes' on Enable RSS Syncidcation. Final Words: Well, that?s about it! I?m not sure how often I can visit this thread but I hope those who find success in implementing the bridge, can help those who are having problems. Again, if you have suggestions on improving the script, let me know. Thanks and happy modding! Live Demo: http://www.internettablettalk.com/blog/ Revision History: v1.2 (12/7/2005): Uses correct vB user id and user name of the blog author. This will work only if the username of the Wordpress user is exactly the same as the vB username. If not, it uses $vb_userid and $vb_username defined in the settings. v1.1 (8/19/2005): Revisions are based on reports by Darth Gill (see discussion). New version includes vB RSS thread parser and a bug fix on vB not displaying recently added blog entry on the forum level. Current revisions are marked in green. Changes:
Screenshots: Show Your Support
|
Comments |
#42
|
|||
|
|||
Thank you! I'm going to try this with 3.5
|
#43
|
|||
|
|||
still need help
|
#44
|
|||
|
|||
Quote:
http://www.cyberxp9.net/blog/?p=15 and click on the "RSS 2.0" link, it tries to run postfeed.php which is correct. I think the problem on your part is you haven't activated RSS on your forums. To activate it, on your forums admincp, go to vBulletin Options->External Data Provider and check 'Yes' on Enable RSS Syncidcation. That should fix it. |
#45
|
|||
|
|||
Quote:
|
#46
|
|||
|
|||
First, I see that your blog comments RSS is already working:
http://www.cyberxp9.net/forum/postfe...=170&type=rss2 For the Entries (RSS), no, the change should not have affected it. Actually it works. If you try: http://www.cyberxp9.net/blog/?feed=rss2 you should see the actuall RSS of your blog's entries. |
#47
|
|||
|
|||
Let me ask this regarding the vBulletin integration:
If someone wanted for the comments to be posted exclusively by forum members within the blog itself and not the forum, is that possible? Just like how Sitepoint.com has it, in where members of the message board could post comments inside the blog article and not on the forum. |
#48
|
|||
|
|||
It seems like you are asking for an integration of the user database. That would be an entirely different hack. This hack aims to have users not register via WordPress at all and just use vBulletin as the main user database. Only the authors are intended to be registered in Wordpress.
I thought that having just one database will be more efficient. Also, a lot of 3rd party commercial programs integrate best with vB, like PhotoPost, ReviewPost, Coppermine, Chat apps, etc. |
#49
|
|||
|
|||
Quote:
|
#50
|
|||
|
|||
I can probably create an enhancement to list the comments made in vB. If they want to add a comment, they have to do it in the forums though.
|
#51
|
|||
|
|||
Quote:
|
|
|
X vBulletin 3.8.12 by vBS Debug Information | |
---|---|
|
|
More Information | |
Template Usage:
Phrase Groups Available:
|
Included Files:
Hooks Called:
|