vb.org Archive

vb.org Archive (https://vborg.vbsupport.ru/index.php)
-   vB4 Programming Discussions (https://vborg.vbsupport.ru/forumdisplay.php?f=252)
-   -   Group Messagebit Plugin Query (https://vborg.vbsupport.ru/showthread.php?t=273899)

Mark.B 11-12-2011 12:33 PM

Group Messagebit Plugin Query
 
Right this one has me totally baffled and I can't fix it.

On vB3 I was able to query custom user fields (at the hook group_messagebit_display_complete) so the data could be used in the template group_message as follows:

Code:

$username = $message['username'];

$sql = "SELECT user.userid, user.usergroupid, userfield.field14, userfield.field13, userfield.field15
FROM user AS user
LEFT JOIN userfield AS userfield ON (userfield.userid = user.userid)
WHERE user.username = '" . mysql_real_escape_string($username) . "' LIMIT 1";

$query = mysql_query($sql);

// Do our error checking first...
if(!$query)
{
echo 'Username: Invalid';
}
else
{
// Use mysql_fetch_assoc to return [field] => [value] array result
$data = mysql_fetch_assoc($query);

$message['field14'] = $data['field14'];
$message['field13'] = $data['field13'];
$message['field15'] = $data['field15'];
}

Parts of this are borrowed from hacks on here.

Anyway this worked fine on vB3.

Now that I have reopened my groups on vB4 I thought I'd use the same code but it simply doesn't work.

Some diagnostics have revealed that the hook itself works, the problem seems to be that the variable $message is no longer recognised at this hook.

My test for that has been to add the following line:
Code:

$template_hook['field15'] = "Test";
I can then output {vb:raw template_hook.message15} in the template and it works.
But if I try:
Code:

$template_hook['field15'] = $message['username'];
Then {vb:raw template_hook.field15} returns nothing.

It can't be a variable registration issue as $message is definitely available in the template, it is already used throughout.

Therefore, I'm finally stumped. Anyone got any idea how I can plug this code in? Even if it means editing a file I don't mind.

kh99 11-12-2011 12:39 PM

Which hook is it you're using?

Mark.B 11-12-2011 01:01 PM

Oops forgot to put that vital information in. :o

group_messagebit_display_complete.

I'll edit the first post.

kh99 11-12-2011 05:19 PM

Try using $this->item in place of $message, like

Code:

$template_hook['field15'] = $this->item['username'];

Mark.B 11-12-2011 07:08 PM

Perfect, thank you.


All times are GMT. The time now is 05:12 AM.

Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2025, vBulletin Solutions Inc.

X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01026 seconds
  • Memory Usage 1,716KB
  • Queries Executed 10 (?)
More Information
Template Usage:
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (4)bbcode_code_printable
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_navbar_search
  • (1)printthread
  • (5)printthreadbit
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • showthread
Included Files:
  • ./printthread.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/class_bbcode_alt.php
  • ./includes/class_bbcode.php
  • ./includes/functions_bigthree.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • printthread_start
  • bbcode_fetch_tags
  • bbcode_create
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • printthread_post
  • printthread_complete