mirror of
https://github.com/YunoHost-Apps/hubzilla_ynh.git
synced 2024-09-03 19:26:21 +02:00
76 lines
2.3 KiB
PHP
76 lines
2.3 KiB
PHP
<?php /** @file */
|
|
|
|
function update_channels_total_stat() {
|
|
$r = q("select count(channel_id) as channels_total from channel left join account on account_id = channel_account_id
|
|
where account_flags = 0 ");
|
|
if($r) {
|
|
$channels_total_stat = intval($r[0]['channels_total']);
|
|
set_config('system','channels_total_stat',$channels_total_stat);
|
|
} else {
|
|
set_config('system','channels_total_stat',null);
|
|
}
|
|
}
|
|
|
|
function update_channels_active_halfyear_stat() {
|
|
$r = q("select channel_id from channel left join account on account_id = channel_account_id
|
|
where account_flags = 0 and account_lastlog > %s - INTERVAL %s",
|
|
db_utcnow(), db_quoteinterval('6 MONTH')
|
|
);
|
|
if($r) {
|
|
$s = '';
|
|
foreach($r as $rr) {
|
|
if($s)
|
|
$s .= ',';
|
|
$s .= intval($rr['channel_id']);
|
|
}
|
|
$x = q("select uid from item where uid in ( $s ) and item_wall = 1 and created > %s - INTERVAL %s group by uid",
|
|
db_utcnow(), db_quoteinterval('6 MONTH')
|
|
);
|
|
if($x) {
|
|
$channels_active_halfyear_stat = count($x);
|
|
set_config('system','channels_active_halfyear_stat',$channels_active_halfyear_stat);
|
|
} else {
|
|
set_config('system','channels_active_halfyear_stat',null);
|
|
}
|
|
} else {
|
|
set_config('system','channels_active_halfyear_stat',null);
|
|
}
|
|
}
|
|
|
|
function update_channels_active_monthly_stat() {
|
|
$r = q("select channel_id from channel left join account on account_id = channel_account_id
|
|
where account_flags = 0 and account_lastlog > %s - INTERVAL %s",
|
|
db_utcnow(), db_quoteinterval('1 MONTH')
|
|
);
|
|
if($r) {
|
|
$s = '';
|
|
foreach($r as $rr) {
|
|
if($s)
|
|
$s .= ',';
|
|
$s .= intval($rr['channel_id']);
|
|
}
|
|
$x = q("select uid from item where uid in ( $s ) and item_wall = 1 and created > %s - INTERVAL %s group by uid",
|
|
db_utcnow(), db_quoteinterval('1 MONTH')
|
|
);
|
|
if($x) {
|
|
$channels_active_monthly_stat = count($x);
|
|
set_config('system','channels_active_monthly_stat',$channels_active_monthly_stat);
|
|
} else {
|
|
set_config('system','channels_active_monthly_stat',null);
|
|
}
|
|
} else {
|
|
set_config('system','channels_active_monthly_stat',null);
|
|
}
|
|
}
|
|
|
|
function update_local_posts_stat() {
|
|
$posts = q("SELECT COUNT(*) AS local_posts FROM `item` WHERE item_wall = 1 ");
|
|
if (is_array($posts)) {
|
|
$local_posts_stat = intval($posts[0]["local_posts"]);
|
|
set_config('system','local_posts_stat',$local_posts_stat);
|
|
} else {
|
|
set_config('system','local_posts_stat',null);
|
|
}
|
|
}
|
|
|
|
|