[feature/module_services] Move latest_bots to module services

This commit is contained in:
Marc Alexander
2013-11-16 10:42:30 +01:00
parent a1f64e9842
commit 972ad7ae5d
3 changed files with 57 additions and 19 deletions

View File

@@ -125,6 +125,16 @@ services:
tags: tags:
- { name: board3.module } - { name: board3.module }
board3.module.latest_bots:
class: \board3\portal\modules\latest_bots
arguments:
- @config
- @dbal.conn
- @template
- @user
tags:
- { name: board3.module }
board3.module.stylechanger: board3.module.stylechanger:
class: \board3\portal\modules\stylechanger class: \board3\portal\modules\stylechanger
arguments: arguments:

View File

@@ -512,7 +512,7 @@ class v210_beta1 extends \phpbb\db\migration\migration
'module_status' => 1, 'module_status' => 1,
), ),
array( array(
'module_classname' => 'latest_bots', 'module_classname' => '\board3\portal\modules\latest_bots',
'module_column' => 3, 'module_column' => 3,
'module_order' => 5, 'module_order' => 5,
'module_name' => 'LATEST_BOTS', 'module_name' => 'LATEST_BOTS',

View File

@@ -1,24 +1,18 @@
<?php <?php
/** /**
* *
* @package Board3 Portal v2 - Latest Bots * @package Board3 Portal v2.1
* @copyright (c) Board3 Group ( www.board3.de ) * @copyright (c) Board3 Group ( www.board3.de )
* @license http://opensource.org/licenses/gpl-license.php GNU Public License * @license http://opensource.org/licenses/gpl-license.php GNU Public License
* *
*/ */
/** namespace board3\portal\modules;
* @ignore
*/
if (!defined('IN_PHPBB'))
{
exit;
}
/** /**
* @package Latest Bots * @package Latest Bots
*/ */
class portal_latest_bots_module extends \board3\portal\modules\module_base class latest_bots extends module_base
{ {
/** /**
* Allowed columns: Just sum up your options (Exp: left + right = 10) * Allowed columns: Just sum up your options (Exp: left + right = 10)
@@ -52,30 +46,58 @@ class portal_latest_bots_module extends \board3\portal\modules\module_base
*/ */
public $hide_name = false; public $hide_name = false;
/** @var \phpbb\config\config */
protected $config;
/** @var \phpbb\db\driver */
protected $db;
/** @var \phpbb\template */
protected $template;
/** @var \phpbb\user */
protected $user;
/**
* Construct a latest bots object
*
* @param \phpbb\config\config $config phpBB config
* @param \phpbb\db\driver $db phpBB db driver
* @param \phpbb\template $template phpBB template
* @param \phpbb\user $user phpBB user object
*/
public function __construct($config, $db, $template, $user)
{
$this->config = $config;
$this->db = $db;
$this->template = $template;
$this->user = $user;
}
/**
* @inheritdoc
*/
public function get_template_side($module_id) public function get_template_side($module_id)
{ {
global $config, $template, $db, $user;
// Last x visited bots // Last x visited bots
$sql = 'SELECT username, user_colour, user_lastvisit $sql = 'SELECT username, user_colour, user_lastvisit
FROM ' . USERS_TABLE . ' FROM ' . USERS_TABLE . '
WHERE user_type = ' . USER_IGNORE . ' WHERE user_type = ' . USER_IGNORE . '
AND user_lastvisit > 0 AND user_lastvisit > 0
ORDER BY user_lastvisit DESC'; ORDER BY user_lastvisit DESC';
$result = $db->sql_query_limit($sql, $config['board3_last_visited_bots_number_' . $module_id]); $result = $this->db->sql_query_limit($sql, $this->config['board3_last_visited_bots_number_' . $module_id]);
$show_module = false; $show_module = false;
while ($row = $db->sql_fetchrow($result)) while ($row = $this->db->sql_fetchrow($result))
{ {
$template->assign_block_vars('last_visited_bots', array( $this->template->assign_block_vars('last_visited_bots', array(
'BOT_NAME' => get_username_string('full', '', $row['username'], $row['user_colour']), 'BOT_NAME' => get_username_string('full', '', $row['username'], $row['user_colour']),
'LAST_VISIT_DATE' => $user->format_date($row['user_lastvisit']), 'LAST_VISIT_DATE' => $this->user->format_date($row['user_lastvisit']),
)); ));
$show_module = true; $show_module = true;
} }
$db->sql_freeresult($result); $this->db->sql_freeresult($result);
if ($show_module) if ($show_module)
{ {
@@ -83,6 +105,9 @@ class portal_latest_bots_module extends \board3\portal\modules\module_base
} }
} }
/**
* @inheritdoc
*/
public function get_template_acp($module_id) public function get_template_acp($module_id)
{ {
return array( return array(
@@ -95,7 +120,7 @@ class portal_latest_bots_module extends \board3\portal\modules\module_base
} }
/** /**
* API functions * @inheritdoc
*/ */
public function install($module_id) public function install($module_id)
{ {
@@ -103,6 +128,9 @@ class portal_latest_bots_module extends \board3\portal\modules\module_base
return true; return true;
} }
/**
* @inheritdoc
*/
public function uninstall($module_id, $db) public function uninstall($module_id, $db)
{ {
$del_config = array( $del_config = array(