honour service class restrictions for total_identities, total_channels ("friends") and total_feeds both when importing channels and subsequently when syncing clones. Limits are based on the local system - additional entries are silently dropped.
This commit is contained in:
parent
c841714ba5
commit
bbc9e4427e
@ -616,6 +616,29 @@ function service_class_fetch($uid,$property) {
|
||||
return((array_key_exists($property,$arr)) ? $arr[$property] : false);
|
||||
}
|
||||
|
||||
// like service_class_fetch but queries by account rather than channel
|
||||
|
||||
function account_service_class_fetch($aid,$property) {
|
||||
|
||||
$r = q("select account_service_class as service_class from account where account_id = %d limit 1",
|
||||
intval($aid)
|
||||
);
|
||||
if($r !== false && count($r)) {
|
||||
$service_class = $r[0]['service_class'];
|
||||
}
|
||||
|
||||
if(! x($service_class))
|
||||
return false; // everything is allowed
|
||||
|
||||
$arr = get_config('service_class',$service_class);
|
||||
|
||||
if(! is_array($arr) || (! count($arr)))
|
||||
return false;
|
||||
|
||||
return((array_key_exists($property,$arr)) ? $arr[$property] : false);
|
||||
}
|
||||
|
||||
|
||||
function upgrade_link($bbcode = false) {
|
||||
$l = get_config('service_class','upgrade_link');
|
||||
if(! $l)
|
||||
|
@ -2336,7 +2336,7 @@ function build_sync_packet($uid = 0, $packet = null, $groups_changed = false) {
|
||||
function process_channel_sync_delivery($sender,$arr,$deliveries) {
|
||||
|
||||
// FIXME - this will sync red structures (channel, pconfig and abook). Eventually we need to make this application agnostic.
|
||||
// TODO: missing group membership changes
|
||||
|
||||
|
||||
$result = array();
|
||||
|
||||
@ -2352,6 +2352,10 @@ function process_channel_sync_delivery($sender,$arr,$deliveries) {
|
||||
|
||||
$channel = $r[0];
|
||||
|
||||
$max_friends = service_class_fetch($channel['channel_id'],'total_channels');
|
||||
$max_feeds = account_service_class_fetch($channel['channel_account_id'],'total_feeds');
|
||||
|
||||
|
||||
if($channel['channel_hash'] != $sender['hash']) {
|
||||
logger('process_channel_sync_delivery: possible forgery. Sender ' . $sender['hash'] . ' is not ' . $channel['channel_hash']);
|
||||
$result[] = array($d['hash'],'channel mismatch',$channel['channel_name'],'');
|
||||
@ -2385,6 +2389,19 @@ function process_channel_sync_delivery($sender,$arr,$deliveries) {
|
||||
|
||||
|
||||
if(array_key_exists('abook',$arr) && is_array($arr['abook']) && count($arr['abook'])) {
|
||||
$total_friends = 0;
|
||||
$total_feeds = 0;
|
||||
|
||||
$r = q("select abook_id, abook_flags from abook where abook_channel = %d",
|
||||
intval($channel['channel_id'])
|
||||
);
|
||||
if($r) {
|
||||
// don't count yourself
|
||||
$total_friends = ((count($r) > 0) ? $count($r) - 1 : 0);
|
||||
foreach($r as $rr)
|
||||
if($rr['abook_flags'] & ABOOK_FLAG_FEED)
|
||||
$total_feeds ++;
|
||||
}
|
||||
|
||||
$disallowed = array('abook_id','abook_account','abook_channel');
|
||||
|
||||
@ -2395,14 +2412,18 @@ function process_channel_sync_delivery($sender,$arr,$deliveries) {
|
||||
logger('process_channel_sync_delivery: removing abook entry for ' . $abook['abook_xchan']);
|
||||
require_once('include/Contact.php');
|
||||
|
||||
$r = q("select abook_id from abook where abook_xchan = '%s' and abook_channel = %d and not ( abook_flags & %d ) limit 1",
|
||||
$r = q("select abook_id, abook_flags from abook where abook_xchan = '%s' and abook_channel = %d and not ( abook_flags & %d ) limit 1",
|
||||
dbesc($abook['abook_xchan']),
|
||||
intval($channel['channel_id']),
|
||||
intval(ABOOK_FLAG_SELF)
|
||||
);
|
||||
if($r)
|
||||
if($r) {
|
||||
contact_remove($channel['channel_id'],$r[0]['abook_id']);
|
||||
|
||||
if($total_friends)
|
||||
$total_friends --;
|
||||
if($r[0]['abook_flags'] & ABOOK_FLAG_FEED)
|
||||
$total_feeds --;
|
||||
}
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -2449,10 +2470,21 @@ function process_channel_sync_delivery($sender,$arr,$deliveries) {
|
||||
// make sure we have an abook entry for this xchan on this system
|
||||
|
||||
if(! $r) {
|
||||
if($max_friends !== false && $total_friends > $max_friends) {
|
||||
logger('process_channel_sync_delivery: total_channels service class limit exceeded');
|
||||
continue;
|
||||
}
|
||||
if($max_feeds !== false && ($clean['abook_flags'] & ABOOK_FLAG_FEED) && $total_feeds > $max_feeds) {
|
||||
logger('process_channel_sync_delivery: total_feeds service class limit exceeded');
|
||||
continue;
|
||||
}
|
||||
q("insert into abook ( abook_xchan, abook_channel ) values ('%s', %d ) ",
|
||||
dbesc($clean['abook_xchan']),
|
||||
intval($channel['channel_id'])
|
||||
);
|
||||
$total_friends ++;
|
||||
if($clean['abook_flags'] & ABOOK_FLAG_FEED)
|
||||
$total_feeds ++;
|
||||
}
|
||||
|
||||
if(count($clean)) {
|
||||
|
@ -9,10 +9,25 @@ require_once('include/identity.php');
|
||||
|
||||
function import_post(&$a) {
|
||||
|
||||
if(! get_account_id()) {
|
||||
$account_id = get_account_id();
|
||||
if(! $account_id)
|
||||
return;
|
||||
|
||||
$max_identities = account_service_class_fetch($account_id,'total_identities');
|
||||
$max_friends = account_service_class_fetch($account_id,'total_channels');
|
||||
$max_feeds = account_service_class_fetch($account_id,'total_feeds');
|
||||
|
||||
if($max_identities !== false) {
|
||||
$r = q("select channel_id from channel where channel_account_id = %d",
|
||||
intval($account_id)
|
||||
);
|
||||
if($r && count($r) > $max_identities) {
|
||||
notice( sprintf( t('Your service plan only allows %d channels.'), $max_identities) . EOL);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
$data = null;
|
||||
$seize = ((x($_REQUEST,'make_primary')) ? intval($_REQUEST['make_primary']) : 0);
|
||||
|
||||
@ -276,10 +291,18 @@ function import_post(&$a) {
|
||||
// FIXME - ensure we have an xchan if somebody is trying to pull a fast one
|
||||
|
||||
|
||||
$friends = 0;
|
||||
$feeds = 0;
|
||||
|
||||
// import contacts
|
||||
$abooks = $data['abook'];
|
||||
if($abooks) {
|
||||
foreach($abooks as $abook) {
|
||||
if($max_friends !== false && $friends > $max_friends)
|
||||
continue;
|
||||
if($max_feeds !== false && ($abook['abook_flags'] & ABOOK_FLAG_FEED) && $feeds > $max_feeds)
|
||||
continue;
|
||||
|
||||
unset($abook['abook_id']);
|
||||
$abook['abook_account'] = get_account_id();
|
||||
$abook['abook_channel'] = $channel['channel_id'];
|
||||
@ -289,6 +312,10 @@ function import_post(&$a) {
|
||||
. "`) VALUES ('"
|
||||
. implode("', '", array_values($abook))
|
||||
. "')" );
|
||||
|
||||
$friends ++;
|
||||
if($abook['abook_flags'] & ABOOK_FLAG_FEED)
|
||||
$feeds ++;
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user