File: /var/www/ilya/data/www/kamforum.ru/sources/sql/mysql_admin_queries.php
<?php
/*
+--------------------------------------------------------------------------
| Invision Power Board v2.1.5
| =============================================
| by Matthew Mecham
| (c) 2001 - 2005 Invision Power Services, Inc.
| http://www.invisionpower.com
| =============================================
| Web: http://www.invisionboard.com
| Time: Wed, 04 Jan 2006 19:53:17 GMT
| Release: 2d174325a5cb8288fdab03b953f0e659
| Licence Info: http://www.invisionboard.com/?license
+---------------------------------------------------------------------------
| > $Date: 2005-12-30 23:02:19 +0000 (Fri, 30 Dec 2005) $
| > $Revision: 109 $
| > $Author: bfarber $
+---------------------------------------------------------------------------
|
| > MySQL ADMIN DB Queries abstraction module
| > Module written by Matt Mecham
| > Date started: 24th May 2004
|
| > Module Version Number: 1.0.0
+--------------------------------------------------------------------------
*/
class sql_queries extends db_driver
{
var $db = "";
var $tbl = "";
/*========================================================================*/
// Set up...
/*========================================================================*/
function sql_queries( &$obj )
{
$this->db = &$obj;
if ( ! $this->db->obj['sql_tbl_prefix'] )
{
$this->db->obj['sql_tbl_prefix'] = '".SQL_PREFIX."';
}
$this->tbl = $this->db->obj['sql_tbl_prefix'];
}
/*========================================================================*/
# IPB 2.1 BETA 2: NEW NEW NEW!
function acpperms_get_main_groups( $a )
{
return "SELECT perm_key, perm_main, perm_child FROM ".SQL_PREFIX."admin_permission_keys WHERE perm_main='{$a['perm_main']}' GROUP BY perm_child";
}
# IPB 2.1 BETA 2: NEW NEW NEW!
function login_getmember_by_dname( $a )
{
return "SELECT m.*, g.*
FROM ibf_members m, ibf_groups g
WHERE LOWER(members_display_name)='{$a['username']}' and m.mgroup=g.g_id";
}
function admin_emo_count( $a )
{
return "SELECT id, count(id) as count, emo_set FROM ".SQL_PREFIX."emoticons GROUP BY emo_set ORDER BY emo_set";
}
function adminlogs_view_one( $a )
{
return "SELECT m.*, mem.id, mem.name, mem.members_display_name FROM ".SQL_PREFIX."admin_logs m, ".SQL_PREFIX."members mem
WHERE m.member_id={$a['mid']} AND m.member_id=mem.id ORDER BY m.ctime DESC LIMIT {$a['limit_a']}, 20";
}
function adminlogs_view_two( $a )
{
return "SELECT m.*, mem.id, mem.name, mem.members_display_name FROM ".SQL_PREFIX."admin_logs m, ".SQL_PREFIX."members mem
WHERE m.member_id=mem.id AND {$a['dbq']} ORDER BY m.ctime DESC LIMIT {$a['limit_a']}, 20";
}
function adminlogs_view_list_current( $a )
{
return "SELECT m.*, mem.id, mem.members_display_name as name FROM ".SQL_PREFIX."admin_logs m, ".SQL_PREFIX."members mem
WHERE m.member_id=mem.id ORDER BY m.ctime DESC LIMIT 0, 5";
}
function adminlogs_view_list_current_two( $a )
{
return "SELECT m.*, mem.members_display_name as name, count(m.id) as act_count
FROM ".SQL_PREFIX."admin_logs m, ".SQL_PREFIX."members mem
WHERE m.member_id=mem.id
GROUP BY m.member_id ORDER BY act_count DESC";
}
function attachments_bulk_remove( $a )
{
return "SELECT a.*, p.pid, p.topic_id
FROM ".SQL_PREFIX."attachments a
LEFT JOIN ".SQL_PREFIX."posts p ON (p.pid=a.attach_pid)
WHERE a.attach_pid > 0 AND a.attach_id IN(".implode(",",$a['ids']).")";
}
function emaillogs_view_email( $a )
{
return "SELECT email.*, m.id, m.members_display_name as name, mem.id as to_id, mem.members_display_name as to_name FROM ".SQL_PREFIX."email_logs email
LEFT JOIN ".SQL_PREFIX."members m ON (m.id=email.from_member_id)
LEFT JOIN ".SQL_PREFIX."members mem ON (mem.id=email.to_member_id)
WHERE email.email_id={$a['id']}";
}
function emaillogs_list_current( $a )
{
return "SELECT email.*, m.id, m.members_display_name as name, mem.id as to_id, mem.members_display_name as to_name FROM ".SQL_PREFIX."email_logs email
LEFT JOIN ".SQL_PREFIX."members m ON (m.id=email.from_member_id)
LEFT JOIN ".SQL_PREFIX."members mem ON (mem.id=email.to_member_id) {$a['dbe']}
ORDER BY email_date DESC LIMIT {$a['limit_a']},25";
}
function groups_permsplash( $a )
{
return "SELECT COUNT(id) as count, org_perm_id FROM ".SQL_PREFIX."members WHERE (org_perm_id IS NOT NULL AND org_perm_id != '') GROUP by org_perm_id";
}
# Changed [ 2.1 ] Added OR m.mgroup_others LIKE CONCAT('%,',g.g_id,',%')
function groups_main_screen( $a )
{
return "SELECT g.g_id, g.g_access_cp, g.g_is_supmod, g.g_title,g.prefix, g.suffix,
COUNT(m.id) as count
FROM ".SQL_PREFIX."groups as g
LEFT JOIN ".SQL_PREFIX."members m ON (m.mgroup = g.g_id OR m.mgroup_others LIKE CONCAT('%,',g.g_id,',%'))
GROUP BY g.g_id ORDER BY g.g_title";
}
function index_admin_logs( $a )
{
return "SELECT m.*, mem.id, mem.name, mem.members_display_name FROM ".SQL_PREFIX."admin_logs m, ".SQL_PREFIX."members mem
WHERE m.member_id=mem.id ORDER BY m.ctime DESC LIMIT 0, 5";
}
function languages_list_current( $a )
{
return "select ".SQL_PREFIX."languages.*, count(".SQL_PREFIX."members.id) as mcount from ".SQL_PREFIX."languages
left join ".SQL_PREFIX."members on(".SQL_PREFIX."members.language=".SQL_PREFIX."languages.ldir)
where (".SQL_PREFIX."members.language is not null or ".SQL_PREFIX."members.language = 'en')
group by ".SQL_PREFIX."languages.ldir
order by ".SQL_PREFIX."languages.lname";
}
function member_tools_learn_ip_one( $a )
{
return "SELECT m.id, m.members_display_name as name, m.email, m.posts, m.joined, p.pid, p.author_id, p.post_date, p.ip_address, p.topic_id
FROM ".SQL_PREFIX."posts p
LEFT JOIN ".SQL_PREFIX."members m ON ( p.author_id=m.id)
WHERE p.ip_address{$a['query']} GROUP BY p.author_id ORDER BY p.post_date DESC LIMIT 250";
}
function member_tools_learn_ip_two( $a )
{
return "SELECT m.id, m.members_display_name as name, m.email, m.posts, m.joined, p.vote_date, p.ip_address, p.tid
FROM ".SQL_PREFIX."voters p
LEFT JOIN ".SQL_PREFIX."members m ON ( p.member_id=m.id)
WHERE p.ip_address{$a['query']} GROUP BY p.member_id ORDER BY p.vote_date DESC LIMIT 250";
}
function member_tools_learn_ip_three( $a )
{
return "SELECT m.id, m.members_display_name as name, m.email, m.posts, m.joined, p.email_date, p.from_ip_address
FROM ".SQL_PREFIX."email_logs p
LEFT JOIN ".SQL_PREFIX."members m ON ( p.from_member_id=m.id)
WHERE p.from_ip_address{$a['query']} GROUP BY p.from_member_id ORDER BY p.email_date DESC LIMIT 250";
}
function member_tools_learn_ip_four( $a )
{
return "SELECT m.id, m.members_display_name as name, m.email, m.posts, m.joined, p.entry_date, p.ip_address
FROM ".SQL_PREFIX."validating p
LEFT JOIN ".SQL_PREFIX."members m ON ( p.member_id=m.id)
WHERE p.ip_address{$a['query']} GROUP BY p.member_id ORDER BY p.entry_date DESC LIMIT 250";
}
function member_tools_show_ips( $a )
{
return "SELECT count(ip_address) as ip, ip_address, pid, topic_id, post_date
FROM ".SQL_PREFIX."posts
WHERE author_id={$a['mid']}
GROUP BY ip_address
ORDER BY ip DESC LIMIT {$a['st']}, {$a['end']}";
}
function member_domod( $a )
{
return "SELECT m.id, m.name, m.email, m.mgroup, v.* FROM ".SQL_PREFIX."validating v
LEFT JOIN ".SQL_PREFIX."members m ON (v.member_id=m.id)
WHERE m.id IN(".implode( ",",$a['ids'] ).")";
}
# Updated 2.1 (member_view_mod) [ Added: extra query bit AND m.members_display_name AND m.ip_address]
function member_view_mod( $a )
{
return "SELECT m.name, m.members_display_name, m.ip_address, m.id, m.email, m.posts, m.joined, v.*
FROM ".SQL_PREFIX."validating v
LEFT JOIN ".SQL_PREFIX."members m ON (v.member_id=m.id)
WHERE v.lost_pass=0 {$a['extra']}
ORDER BY {$a['col']} {$a['ord']} LIMIT {$a['st']},75";
}
function member_search_form_one( $a )
{
return "SELECT m.*, me.*, m.id as memid
FROM ".SQL_PREFIX."members m
LEFT JOIN ".SQL_PREFIX."member_extra me ON (me.id=m.id)
LEFT JOIN ".SQL_PREFIX."pfields_content p ON (p.member_id=m.id)
{$a['rq']} ORDER BY m.members_display_name LIMIT {$a['st']},25";
}
function member_search_form_two( $a )
{
return "SELECT m.*, me.*, m.id as memid
FROM ".SQL_PREFIX."members m
LEFT JOIN ".SQL_PREFIX."member_extra me ON (me.id=m.id)
LEFT JOIN ".SQL_PREFIX."pfields_content p ON (p.member_id=m.id)
{$a['rq']}";
}
function member_search_form_count( $a )
{
return "SELECT COUNT(*) as count
FROM ".SQL_PREFIX."members m
LEFT JOIN ".SQL_PREFIX."member_extra me ON (me.id=m.id)
LEFT JOIN ".SQL_PREFIX."pfields_content p ON (p.member_id=m.id)
{$a['rq']}";
}
function member_search_do_edit_form( $a )
{
return "SELECT m.*, me.*, p.*, m.id as memid, g.g_access_cp FROM ".SQL_PREFIX."members m
LEFT JOIN ".SQL_PREFIX."member_extra me on (me.id=m.id)
LEFT JOIN ".SQL_PREFIX."pfields_content p on (p.member_id=m.id)
LEFT JOIN ".SQL_PREFIX."groups g on (g.g_id=m.mgroup)
WHERE m.id=".$a['mid'];
}
function modlogs_view_one( $a )
{
return "SELECT mem.members_display_name, m.*, f.id as forum_id, f.name FROM ".SQL_PREFIX."moderator_logs m
LEFT JOIN ".SQL_PREFIX."members mem ON(mem.id=m.member_id)
LEFT JOIN ".SQL_PREFIX."forums f ON(f.id=m.forum_id)
WHERE m.member_id={$a['mid']} ORDER BY m.ctime DESC LIMIT {$a['start']}, 20";
}
function modlogs_view_two( $a )
{
return "SELECT mem.members_display_name, m.*, f.id as forum_id, f.name FROM ".SQL_PREFIX."moderator_logs m
LEFT JOIN ".SQL_PREFIX."members mem ON(mem.id=m.member_id)
LEFT JOIN ".SQL_PREFIX."forums f ON(f.id=m.forum_id)
WHERE {$a['dbq']} ORDER BY m.ctime DESC LIMIT {$a['start']}, 20";
}
function modlogs_view_three( $a )
{
return "SELECT mem.members_display_name, m.*, f.id as forum_id, f.name FROM ".SQL_PREFIX."moderator_logs m
LEFT JOIN ".SQL_PREFIX."members mem ON(mem.id=m.member_id)
LEFT JOIN ".SQL_PREFIX."forums f ON(f.id=m.forum_id)
ORDER BY m.ctime DESC LIMIT {$a['start']}, 20";
}
function modlogs_list_current_last_five( $a )
{
return "SELECT mem.members_display_name, m.*, f.id as forum_id, f.name FROM ".SQL_PREFIX."moderator_logs m
LEFT JOIN ".SQL_PREFIX."members mem ON(mem.id=m.member_id)
LEFT JOIN ".SQL_PREFIX."forums f ON (f.id=m.forum_id)
ORDER BY m.ctime DESC LIMIT 0, 5";
}
function modlogs_list_current_show_all( $a )
{
return "SELECT mem.members_display_name, m.*, count(m.id) as act_count
FROM ".SQL_PREFIX."moderator_logs m
LEFT JOIN ".SQL_PREFIX."members mem ON(mem.id=m.member_id)
GROUP BY m.member_id
ORDER BY act_count DESC";
}
function spiderlogs_list_current( $a )
{
return "SELECT count(*) as cnt, bot, max(entry_date) as entry_date, query_string FROM ".SQL_PREFIX."spider_logs GROUP BY bot ORDER BY entry_date DESC";
}
function statistics_show_views( $a )
{
return "SELECT SUM(t.views) as result_count, t.forum_id, f.name as result_name
FROM ".SQL_PREFIX."topics t, ".SQL_PREFIX."forums f
WHERE t.start_date > '{$a['from_time']}'
AND t.start_date < '{$a['to_time']}'
AND t.forum_id=f.id
GROUP BY t.forum_id
ORDER BY result_count {$a['sortby']}";
}
function statistics_result_screen( $a )
{
return "SELECT MAX({$a['sql_field']}) as result_maxdate,
COUNT(*) as result_count,
DATE_FORMAT(from_unixtime({$a['sql_field']}),'{$a['sql_date']}') AS result_time
FROM ".SQL_PREFIX."{$a['sql_table']}
WHERE {$a['sql_field']} > '{$a['from_time']}'
AND {$a['sql_field']} < '{$a['to_time']}'
GROUP BY result_time
ORDER BY {$a['sql_field']} {$a['sortby']}";
}
function stylesets_list_sets_templates( $a )
{
return "SELECT set_id FROM ".SQL_PREFIX."skin_templates GROUP BY set_id";
}
function stylesets_list_sets_macros( $a )
{
return "SELECT macro_set FROM ".SQL_PREFIX."skin_macro GROUP BY macro_set";
}
function stylesheets_do_form_concat( $a )
{
return "SELECT *, instr(',{$a['id']}{$a['parent']},1,', concat(',',set_skin_set_id,',') ) as theorder
FROM ".SQL_PREFIX."skin_sets
WHERE set_skin_set_id in ({$a['id']}{$a['parent']},1)
ORDER BY theorder";
}
function warnlogs_view_note( $a )
{
return "SELECT l.*, m.id as a_id, m.members_display_name as a_name, p.id as p_id, p.members_display_name as p_name
FROM ".SQL_PREFIX."warn_logs l
LEFT JOIN ".SQL_PREFIX."members m ON (m.id=l.wlog_mid)
LEFT JOIN ".SQL_PREFIX."members p ON (p.id=l.wlog_addedby)
WHERE l.wlog_id={$a['id']}";
}
function warnlogs_view( $a )
{
return "SELECT l.*, m.id as a_id, m.members_display_name as a_name, p.id as p_id, p.members_display_name as p_name
FROM ".SQL_PREFIX."warn_logs l
LEFT JOIN ".SQL_PREFIX."members m ON (m.id=l.wlog_mid)
LEFT JOIN ".SQL_PREFIX."members p ON (p.id=l.wlog_addedby)
WHERE l.wlog_mid={$a['mid']}
ORDER BY l.wlog_date DESC LIMIT {$a['start']},30";
}
function warnlogs_view_two( $a )
{
return "SELECT l.*, m.id as a_id, m.members_display_name as a_name, p.id as p_id, p.members_display_name as p_name
FROM ".SQL_PREFIX."warn_logs l
LEFT JOIN ".SQL_PREFIX."members m ON (m.id=l.wlog_mid)
LEFT JOIN ".SQL_PREFIX."members p ON (p.id=l.wlog_addedby)
WHERE {$a['dbq']}
ORDER BY l.wlog_date DESC LIMIT {$a['start']},30";
}
function warnlogs_list_current( $a )
{
return "SELECT l.*, m.id as a_id, m.members_display_name as a_name, p.id as p_id, p.members_display_name as p_name
FROM ".SQL_PREFIX."warn_logs l
LEFT JOIN ".SQL_PREFIX."members m ON (m.id=l.wlog_mid)
LEFT JOIN ".SQL_PREFIX."members p ON (p.id=l.wlog_addedby)
ORDER BY l.wlog_date DESC LIMIT 0,10";
}
function warnlogs_list_current_two( $a )
{
return "SELECT l.*, m.name, m.members_display_name, count(l.wlog_mid) as act_count
from ".SQL_PREFIX."warn_logs l, ".SQL_PREFIX."members m
WHERE m.id=l.wlog_mid
GROUP BY l.wlog_mid
ORDER BY act_count DESC";
}
function cache_wrapper( $a )
{
return "SELECT *, instr(',{$a['id']}{$a['parent_in']},{$a['root']},', concat(',',set_skin_set_id,',') ) as theorder
FROM ".SQL_PREFIX."skin_sets
WHERE set_wrapper != '' AND set_skin_set_id in ({$a['id']}{$a['parent_in']},{$a['root']})
ORDER BY theorder
LIMIT 0,1";
}
function cache_templates_titles( $a )
{
return "SELECT group_name, set_id, suid, func_name, func_data,
INSTR(',{$a['id']}{$a['parent_in']},{$a['root']},' , CONCAT(',',set_id,',') ) as theorder
FROM ".SQL_PREFIX."skin_templates WHERE set_id IN ({$a['id']}{$a['parent_in']},{$a['root']}) ORDER BY group_name, theorder DESC";
}
function cache_templates_bits( $a )
{
return "SELECT *,
INSTR(',{$a['id']}{$a['parent_in']},{$a['root']},' , CONCAT(',',set_id,',') ) as theorder
FROM ".SQL_PREFIX."skin_templates WHERE set_id IN ({$a['id']}{$a['parent_in']},{$a['root']}) AND group_name='{$a['group']}' ORDER BY func_name,theorder DESC";
}
function cache_templates_all( $a )
{
return "SELECT *,
INSTR(',{$a['id']}{$a['parent_in']},{$a['root']},' , CONCAT(',',set_id,',') ) as theorder
FROM ".SQL_PREFIX."skin_templates WHERE set_id IN ({$a['id']}{$a['parent_in']},{$a['root']}) ORDER BY group_name, func_name, theorder DESC";
}
function cache_templates_css( $a )
{
return "SELECT *, instr(',{$a['id']}{$a['parent_in']},{$a['root']},', concat(',',set_skin_set_id,',') ) as theorder
FROM ".SQL_PREFIX."skin_sets
WHERE set_css != '' AND set_skin_set_id in ({$a['id']}{$a['parent_in']},{$a['root']})
ORDER BY theorder
LIMIT 0,1";
}
function cache_templates_macros( $a )
{
return "SELECT *,
INSTR(',{$a['id']}{$a['parent_in']},{$a['root']},' , CONCAT(',',macro_set,',') ) as theorder
FROM ".SQL_PREFIX."skin_macro
WHERE macro_set IN ({$a['id']}{$a['parent_in']},{$a['root']})
ORDER BY macro_value ASC,theorder DESC";
}
function cache_empty_css( $a )
{
return "SELECT * FROM ".SQL_PREFIX."skin_sets WHERE set_css like '' AND set_skin_set_parent={$a['parent_id']}";
}
function cache_empty_wrapper( $a )
{
return "SELECT * FROM ".SQL_PREFIX."skin_sets WHERE set_wrapper like '' AND set_skin_set_parent={$a['parent_id']}";
}
function mod_func_get_last_post( $a )
{
return "SELECT p.post_date, p.topic_id, p.author_id, p.author_name, p.pid, t.forum_id
FROM ".SQL_PREFIX."posts p
LEFT JOIN ".SQL_PREFIX."topics t ON (p.topic_id=t.tid)
WHERE topic_id={$a['tid']} and queued <> 1
ORDER BY pid DESC LIMIT 0,1";
}
function mod_func_get_attach_count( $a )
{
return "SELECT COUNT(*) as count FROM ".SQL_PREFIX."attachments a
LEFT JOIN ".SQL_PREFIX."posts p on (a.attach_pid=p.pid)
WHERE p.topic_id={$a['tid']}";
}
function mod_func_get_topic_tracker( $a )
{
return "SELECT tr.*, m.id, m.mgroup, m.org_perm_id, t.tid, t.forum_id, g.g_id, g.g_perm_id
FROM ".SQL_PREFIX."tracker tr
LEFT JOIN ".SQL_PREFIX."topics t ON (tr.topic_id=t.tid)
LEFT JOIN ".SQL_PREFIX."members m on (m.id=tr.member_id)
LEFT JOIN ".SQL_PREFIX."groups g on (g.g_id=m.mgroup)
WHERE tr.topic_id".$a['tid'];
}
function ucp_get_all_announcements( $a )
{
return "SELECT a.*, m.id, m.name, m.members_display_name
FROM ".SQL_PREFIX."announcements a
LEFT JOIN ".SQL_PREFIX."members m on (a.announce_member_id=m.id)
ORDER BY announce_end DESC";
}
function ucp_get_all_announcements_byid( $a )
{
return "SELECT a.*, m.*, me.*
FROM ".SQL_PREFIX."announcements a
LEFT JOIN ".SQL_PREFIX."members m on (a.announce_member_id=m.id)
LEFT JOIN ".SQL_PREFIX."member_extra me on (me.id=m.id)
WHERE a.announce_id={$a['id']}";
}
function ucp_tracker_prune( $a )
{
return "SELECT tr.trid FROM ".SQL_PREFIX."tracker tr, ".SQL_PREFIX."topics t WHERE t.tid=tr.topic_id AND t.last_post < {$a['time']}";
}
function login_getmember( $a )
{
return "SELECT m.*, g.*
FROM ibf_members m, ibf_groups g
WHERE LOWER(name)='{$a['username']}' and m.mgroup=g.g_id";
}
function settings_search( $a )
{
return "SELECT c.*, ct.conf_title_noshow
FROM ".SQL_PREFIX."conf_settings c
LEFT JOIN ".SQL_PREFIX."conf_settings_titles ct ON ct.conf_title_id=c.conf_group
WHERE LOWER(conf_title) LIKE '%{$a['keywords']}%' OR LOWER(conf_description) LIKE '%{$a['keywords']}%'
ORDER BY conf_title
LIMIT {$a['limit_a']}, {$a['limit_b']}";
}
} // end class
?>