Vergleich inc/plugins/hello.php - 1.8.0 - 1.8.4

  Keine Änderungen   Hinzugefügt   Modifiziert   Entfernt
Zeile 8Zeile 8
 *
*/


 *
*/


// Disallow direct access to this file for security reasons
if(!defined("IN_MYBB"))

// Make sure we can't access this file directly from the browser.
if(!defined('IN_MYBB'))

{

{

	die("Direct initialization of this file is not allowed.<br /><br />Please make sure IN_MYBB is defined.");










































	die('This file cannot be accessed directly.');
}

// cache templates - this is important when it comes to performance
// THIS_SCRIPT is defined by some of the MyBB scripts, including index.php
if(defined('THIS_SCRIPT'))
{
global $templatelist;

if(isset($templatelist))
{
$templatelist .= ',';
}

if(THIS_SCRIPT== 'index.php')
{
$templatelist .= 'hello_index, hello_message';
}
elseif(THIS_SCRIPT== 'showthread.php')
{
$templatelist .= 'hello_post, hello_message';
}
}

if(defined('IN_ADMINCP'))
{
// Add our hello_settings() function to the setting management module to load language strings.
$plugins->add_hook('admin_config_settings_manage', 'hello_settings');
$plugins->add_hook('admin_config_settings_change', 'hello_settings');
$plugins->add_hook('admin_config_settings_start', 'hello_settings');
// We could hook at 'admin_config_settings_begin' only for simplicity sake.
}
else
{
// Add our hello_index() function to the index_start hook so when that hook is run our function is executed
$plugins->add_hook('index_start', 'hello_index');

// Add our hello_post() function to the postbit hook so it gets executed on every post
$plugins->add_hook('postbit', 'hello_post');

// Add our hello_new() function to the misc_start hook so our misc.php?action=hello inserts a new message into the created DB table.
$plugins->add_hook('misc_start', 'hello_new');

}

}


$plugins->add_hook("pre_output_page", "hello_world");
$plugins->add_hook("postbit", "hello_world_postbit");

 

function hello_info()
{


function hello_info()
{

 
	global $lang;
$lang->load('hello');


	/**
* Array of information about the plugin.
* name: The name of the plugin

	/**
* Array of information about the plugin.
* name: The name of the plugin

Zeile 27Zeile 68
	 * author: The name of the author of the plugin
* authorsite: The URL to the website of the author (Optional)
* version: The version number of the plugin

	 * author: The name of the author of the plugin
* authorsite: The URL to the website of the author (Optional)
* version: The version number of the plugin

	 * guid: Unique ID issued by the MyBB Mods site for version checking
* compatibility: A CSV list of MyBB versions supported. Ex, "121,123", "12*". Wildcards supported.

	 * compatibility: A CSV list of MyBB versions supported. Ex, '121,123', '12*'. Wildcards supported.
* codename: An unique code name to be used by updated from the official MyBB Mods community.

	 */
return array(

	 */
return array(

		"name"			=> "Hello World!",
"description" => "A sample plugin that prints hello world and prepends the content of each post to 'Hello world!'",
"website" => "http://www.mybb.com",
"author" => "MyBB Group",
"authorsite" => "http://www.mybb.com",
"version" => "1.0",
"guid" => "",
"compatibility" => "*"

		'name'			=> 'Hello World!',
'description' => $lang->hello_desc,
'website' => 'http://mybb.com',
'author' => 'MyBB Group',
'authorsite' => 'http://www.mybb.com',
'version' => '2.0',
'compatibility' => '18*',
'codename' => 'hello'

	);
}


	);
}


/**
* ADDITIONAL PLUGIN INSTALL/UNINSTALL ROUTINES
*




































































































































































































































































/*
* _activate():
* Called whenever a plugin is activated via the Admin CP. This should essentially make a plugin
* 'visible' by adding templates/template changes, language changes etc.
*/
function hello_activate()
{
global $db, $lang;
$lang->load('hello');

// Add a new template (hello_index) to our global templates (sid = -1)
$templatearray = array(
'index' => '<br />
<table border="0" cellspacing="{$theme[\'borderwidth\']}" cellpadding="{$theme[\'tablespace\']}" class="tborder">
<thead>
<tr>
<td class="thead">
<strong>{$lang->hello}</strong>
</td>
</tr>
</thead>
<tbody>
<tr>
<td class="tcat">
<form method="POST" action="misc.php">
<input type="hidden" name="my_post_key" value="{$mybb->post_code}" />
<input type="hidden" name="action" value="hello" />
{$lang->hello_add_message}: <input type="text" name="message" class="textbox" /> <input type="submit" name="submit" class="button" value="{$lang->hello_add}" />
</form>
</td>
</tr>
<tr>
<td class="trow1">
{$messages}
</td>
</tr>
</tbody>
</table>
<br />',
'post' => '<br /><br /><strong>{$lang->hello}:</strong><br />{$messages}',
'message' => '<br /> - {$message}'
);

$group = array(
'prefix' => $db->escape_string('hello'),
'title' => $db->escape_string('Hello World!')
);

// Update or create template group:
$query = $db->simple_select('templategroups', 'prefix', "prefix='{$group['prefix']}'");

if($db->fetch_field($query, 'prefix'))
{
$db->update_query('templategroups', $group, "prefix='{$group['prefix']}'");
}
else
{
$db->insert_query('templategroups', $group);
}

// Query already existing templates.
$query = $db->simple_select('templates', 'tid,title,template', "sid=-2 AND (title='{$group['prefix']}' OR title LIKE '{$group['prefix']}=_%' ESCAPE '=')");

$templates = $duplicates = array();

while($row = $db->fetch_array($query))
{
$title = $row['title'];
$row['tid'] = (int)$row['tid'];

if(isset($templates[$title]))
{
// PluginLibrary had a bug that caused duplicated templates.
$duplicates[] = $row['tid'];
$templates[$title]['template'] = false; // force update later
}
else
{
$templates[$title] = $row;
}
}

// Delete duplicated master templates, if they exist.
if($duplicates)
{
$db->delete_query('templates', 'tid IN ('.implode(",", $duplicates).')');
}

// Update or create templates.
foreach($templatearray as $name => $code)
{
if(strlen($name))
{
$name = "hello_{$name}";
}
else
{
$name = "hello";
}

$template = array(
'title' => $db->escape_string($name),
'template' => $db->escape_string($code),
'version' => 1,
'sid' => -2,
'dateline' => TIME_NOW
);

// Update
if(isset($templates[$name]))
{
if($templates[$name]['template'] !== $code)
{
// Update version for custom templates if present
$db->update_query('templates', array('version' => 0), "title='{$template['title']}'");

// Update master template
$db->update_query('templates', $template, "tid={$templates[$name]['tid']}");
}
}
// Create
else
{
$db->insert_query('templates', $template);
}

// Remove this template from the earlier queried list.
unset($templates[$name]);
}

// Remove no longer used templates.
foreach($templates as $name => $row)
{
$db->delete_query('templates', "title='{$db->escape_string($name)}'");
}

// Settings group array details
$group = array(
'name' => 'hello',
'title' => $db->escape_string($lang->setting_group_hello),
'description' => $db->escape_string($lang->setting_group_hello_desc),
'isdefault' => 0
);

// Check if the group already exists.
$query = $db->simple_select('settinggroups', 'gid', "name='hello'");

if($gid = (int)$db->fetch_field($query, 'gid'))
{
// We already have a group. Update title and description.
$db->update_query('settinggroups', $group, "gid='{$gid}'");
}
else
{
// We don't have a group. Create one with proper disporder.
$query = $db->simple_select('settinggroups', 'MAX(disporder) AS disporder');
$disporder = (int)$db->fetch_field($query, 'disporder');

$group['disporder'] = ++$disporder;

$gid = (int)$db->insert_query('settinggroups', $group);
}

// Deprecate all the old entries.
$db->update_query('settings', array('description' => 'HELLODELETEMARKER'), "gid='{$gid}'");

// add settings
$settings = array(
'display1' => array(
'optionscode' => 'yesno',
'value' => 1
),
'display2' => array(
'optionscode' => 'yesno',
'value' => 1
));

$disporder = 0;

// Create and/or update settings.
foreach($settings as $key => $setting)
{
// Prefix all keys with group name.
$key = "hello_{$key}";

$lang_var_title = "setting_{$key}";
$lang_var_description = "setting_{$key}_desc";

$setting['title'] = $lang->{$lang_var_title};
$setting['description'] = $lang->{$lang_var_description};

// Filter valid entries.
$setting = array_intersect_key($setting,
array(
'title' => 0,
'description' => 0,
'optionscode' => 0,
'value' => 0,
));

// Escape input values.
$setting = array_map(array($db, 'escape_string'), $setting);

// Add missing default values.
++$disporder;

$setting = array_merge(
array('description' => '',
'optionscode' => 'yesno',
'value' => 0,
'disporder' => $disporder),
$setting);

$setting['name'] = $db->escape_string($key);
$setting['gid'] = $gid;

// Check if the setting already exists.
$query = $db->simple_select('settings', 'sid', "gid='{$gid}' AND name='{$setting['name']}'");

if($sid = $db->fetch_field($query, 'sid'))
{
// It exists, update it, but keep value intact.
unset($setting['value']);
$db->update_query('settings', $setting, "sid='{$sid}'");
}
else
{
// It doesn't exist, create it.
$db->insert_query('settings', $setting);
// Maybe use $db->insert_query_multiple somehow
}
}

// Delete deprecated entries.
$db->delete_query('settings', "gid='{$gid}' AND description='HELLODELETEMARKER'");

// This is required so it updates the settings.php file as well and not only the database - they must be synchronized!
rebuild_settings();

// Include this file because it is where find_replace_templatesets is defined
require_once MYBB_ROOT.'inc/adminfunctions_templates.php';

// Edit the index template and add our variable to above {$forums}
find_replace_templatesets('index', '#'.preg_quote('{$forums}').'#', "{\$hello}\n{\$forums}");
}

/*
* _deactivate():
* Called whenever a plugin is deactivated. This should essentially 'hide' the plugin from view
* by removing templates/template changes etc. It should not, however, remove any information
* such as tables, fields etc - that should be handled by an _uninstall routine. When a plugin is
* uninstalled, this routine will also be called before _uninstall() if the plugin is active.
*/
function hello_deactivate()
{
require_once MYBB_ROOT.'inc/adminfunctions_templates.php';

// remove template edits
find_replace_templatesets('index', '#'.preg_quote('{$hello}').'#', '');
}

/*

 * _install():

 * _install():

 *   Called whenever a plugin is installed by clicking the "Install" button in the plugin manager.

 *   Called whenever a plugin is installed by clicking the 'Install' button in the plugin manager.

 *   If no install routine exists, the install button is not shown and it assumed any work will be
* performed in the _activate() routine.

 *   If no install routine exists, the install button is not shown and it assumed any work will be
* performed in the _activate() routine.

 *
* function hello_install()
* {
* }
*
















*/
function hello_install()
{
global $db;

// Create our entries table
$collation = $db->build_create_table_collation();

// create table if it doesn't exist already
if(!$db->table_exists('hello_messages'))
{
$db->write_query("CREATE TABLE `".TABLE_PREFIX."hello_messages` (
`mid` int(10) UNSIGNED NOT NULL auto_increment,
`message` varchar(100) NOT NULL default '',
PRIMARY KEY (`mid`)
) ENGINE=MyISAM{$collation}");
}
}

/*

 * _is_installed():
* Called on the plugin management page to establish if a plugin is already installed or not.
* This should return TRUE if the plugin is installed (by checking tables, fields etc) or FALSE
* if the plugin is not installed.

 * _is_installed():
* Called on the plugin management page to establish if a plugin is already installed or not.
* This should return TRUE if the plugin is installed (by checking tables, fields etc) or FALSE
* if the plugin is not installed.

 *
* function hello_is_installed()
* {
* global $db;
* if($db->table_exists("hello_world"))
* {
* return true;
* }
* return false;
* }
*

*/
function hello_is_installed()
{
global $db;

// If the table exists then it means the plugin is installed because we only drop it on uninstallation
return $db->table_exists('hello_messages');
}

/*


 * _uninstall():
* Called whenever a plugin is to be uninstalled. This should remove ALL traces of the plugin
* from the installation (tables etc). If it does not exist, uninstall button is not shown.

 * _uninstall():
* Called whenever a plugin is to be uninstalled. This should remove ALL traces of the plugin
* from the installation (tables etc). If it does not exist, uninstall button is not shown.

 *
* function hello_uninstall()
* {
* }
*
* _activate():
* Called whenever a plugin is activated via the Admin CP. This should essentially make a plugin
* "visible" by adding templates/template changes, language changes etc.
*
* function hello_activate()
* {
* }
*
* _deactivate():
* Called whenever a plugin is deactivated. This should essentially "hide" the plugin from view
* by removing templates/template changes etc. It should not, however, remove any information
* such as tables, fields etc - that should be handled by an _uninstall routine. When a plugin is
* uninstalled, this routine will also be called before _uninstall() if the plugin is active.
*
* function hello_deactivate()
* {
* }
*/


function hello_world($page)

*/
function hello_uninstall()

























{

{

	$page = str_replace("<div id=\"content\">", "<div id=\"content\"><p>Hello World!<br />This is a sample MyBB Plugin (which can be disabled!) that displays this message on all pages.</p>", $page);
return $page;



















































































































































	global $db, $mybb;

if($mybb->request_method != 'post')
{
global $page, $lang;
$lang->load('hello');

$page->output_confirm_action('index.php?module=config-plugins&action=deactivate&uninstall=1&plugin=hello', $lang->hello_uninstall_message, $lang->hello_uninstall);
}

// remove our templates group
// Query the template groups
$query = $db->simple_select('templategroups', 'prefix', "prefix='hello'");

// Build where string for templates
$sqlwhere = array();

while($prefix = $db->fetch_field($query, 'prefix'))
{
$tprefix = $db->escape_string($prefix);
$sqlwhere[] = "title='{$tprefix}' OR title LIKE '{$tprefix}=_%' ESCAPE '='";
}

if($sqlwhere) // else there are no groups to delete
{
// Delete template groups.
$db->delete_query('templategroups', "prefix='hello'");

// Delete templates belonging to template groups.
$db->delete_query('templates', implode(' OR ', $sqlwhere));
}

// delete settings group
$db->delete_query('settinggroups', "name='hello'");

// remove settings
$db->delete_query('settings', "name IN ('hello_display1','hello_display2')");

// This is required so it updates the settings.php file as well and not only the database - they must be synchronized!
rebuild_settings();

// drop tables if desired
if(!isset($mybb->input['no']))
{
$db->drop_table('hello_messages');
}
}

/*
* Loads the settings language strings.
*/
function hello_settings()
{
global $lang;

// Load our language file
$lang->load('hello');
}

/*
* Displays the list of messages on index and a form to submit new messages - depending on the setting of course.
*/
function hello_index()
{
global $mybb;

// Only run this function is the setting is set to yes
if($mybb->settings['hello_display1'] == 0)
{
return;
}

global $db, $lang, $templates, $hello, $theme;

// Load our language file
$lang->load('hello');

// Retreive all messages from the database
$messages = '';
$query = $db->simple_select('hello_messages', 'message', '', array('order_by' => 'mid', 'order_dir' => 'DESC'));
while($message = $db->fetch_field($query, 'message'))
{
// htmlspecialchars_uni is similar to PHP's htmlspecialchars but allows unicode
$message = htmlspecialchars_uni($message);
$messages .= eval($templates->render('hello_message'));
}

// If no messages were found, display that notice.
if(empty($messages))
{
$message = $lang->hello_empty;
$messages = eval($templates->render('hello_message'));
}

// Set $hello as our template and use eval() to do it so we can have our variables parsed
#eval('$hello = "'.$templates->get('hello_index').'";');
$hello = eval($templates->render('hello_index'));
}

/*
* Displays the list of messages under every post - depending on the setting.
* @param $post Array containing information about the current post. Note: must be received by reference otherwise our changes are not preserved.
*/
function hello_post(&$post)
{
global $settings;

// Only run this function is the setting is set to yes
if($settings['hello_display2'] == 0)
{
return;
}

global $lang, $templates;

// Load our language file
if(!isset($lang->hello))
{
$lang->load('hello');
}

static $messages;

// Only retreive messages from the database if they were not retreived already
if(!isset($messages))
{
global $db;

// Retreive all messages from the database
$messages = '';
$query = $db->simple_select('hello_messages', 'message', '', array('order_by' => 'mid', 'order_dir' => 'DESC'));
while($message = $db->fetch_field($query, 'message'))
{
// htmlspecialchars_uni is similar to PHP's htmlspecialchars but allows unicode
$message = htmlspecialchars_uni($message);
$messages .= eval($templates->render('hello_message'));
}

// If no messages were found, display that notice.
if(empty($messages))
{
$message = $lang->hello_empty;
$messages = eval($templates->render('hello_message'));
}
}

// Alter the current post's message
$post['message'] .= eval($templates->render('hello_post'));

}

}


function hello_world_postbit(&$post)





/*
* This is where new messages get submitted.
*/
function hello_new()

{

{

	$post['message'] = "<strong>Hello world!</strong><br /><br />{$post['message']}";








































	global $mybb;

// If we're not running the 'hello' action as specified in our form, get out of there.
if($mybb->get_input('action') != 'hello')
{
return;
}

// Only accept POST
if($mybb->request_method != 'post')
{
error_no_permission();
}

global $lang;

// Correct post key? This is important to prevent CSRF
verify_post_check($mybb->get_input('my_post_key'));

// Load our language file
$lang->load('hello');

$message = trim($mybb->get_input('message'));

// Message cannot be empty
if(!$message || my_strlen($message) > 100)
{
error($lang->hello_message_empty);
}

global $db;

// Escape input data
$message = $db->escape_string($message);

// Insert into database
$db->insert_query('hello_messages', array('message' => $message));

// Redirect to index.php with a message
redirect('index.php', $lang->hello_done);

}

}