abconfig
This commit is contained in:
parent
44b2503572
commit
be2b7c0b5f
4
boot.php
4
boot.php
@ -47,10 +47,10 @@ require_once('include/account.php');
|
|||||||
|
|
||||||
define ( 'PLATFORM_NAME', 'hubzilla' );
|
define ( 'PLATFORM_NAME', 'hubzilla' );
|
||||||
define ( 'RED_VERSION', trim(file_get_contents('version.inc')));
|
define ( 'RED_VERSION', trim(file_get_contents('version.inc')));
|
||||||
define ( 'STD_VERSION', '1.2.4' );
|
define ( 'STD_VERSION', '1.2.5' );
|
||||||
define ( 'ZOT_REVISION', 1 );
|
define ( 'ZOT_REVISION', 1 );
|
||||||
|
|
||||||
define ( 'DB_UPDATE_VERSION', 1164 );
|
define ( 'DB_UPDATE_VERSION', 1165 );
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -550,3 +550,67 @@ function set_aconfig($account_id, $family, $key, $value) {
|
|||||||
function del_aconfig($account_id, $family, $key) {
|
function del_aconfig($account_id, $family, $key) {
|
||||||
return del_xconfig('a_' . $account_id, $family, $key);
|
return del_xconfig('a_' . $account_id, $family, $key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function load_abconfig($chash,$xhash) {
|
||||||
|
$r = q("select * from abconfig where chan = '%s' and xchan = '%s'",
|
||||||
|
dbesc($chash),
|
||||||
|
dbesc($xhash)
|
||||||
|
);
|
||||||
|
return $r;
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_abconfig($chash,$xhash,$family,$key) {
|
||||||
|
$r = q("select * from abconfig where chan = '%s' and xchan = '%s' and cat = '%s' and k = '%s' limit 1",
|
||||||
|
dbesc($chash),
|
||||||
|
dbesc($xhash),
|
||||||
|
dbesc($family),
|
||||||
|
dbesc($key)
|
||||||
|
);
|
||||||
|
if($r) {
|
||||||
|
return ((preg_match('|^a:[0-9]+:{.*}$|s', $r[0]['v'])) ? unserialize($r[0]['v']) : $r[0]['v']);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function set_abconfig($chash,$xhash,$family,$key,$value) {
|
||||||
|
|
||||||
|
$dbvalue = ((is_array($value)) ? serialize($value) : $value);
|
||||||
|
$dbvalue = ((is_bool($dbvalue)) ? intval($dbvalue) : $dbvalue);
|
||||||
|
|
||||||
|
if(get_abconfig($chash,$xhash,$family,$key) === false) {
|
||||||
|
$r = q("insert into abconfig ( chan, xchan, cat, k, v ) values ( '%s', '%s', '%s', '%s', '%s' ) ",
|
||||||
|
dbesc($chash),
|
||||||
|
dbesc($xhash),
|
||||||
|
dbesc($family),
|
||||||
|
dbesc($key),
|
||||||
|
dbesc($dbvalue)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$r = q("update abconfig set v = '%s' where chan = '%s' and xchan = '%s' and cat = '%s' and k = '%s' ",
|
||||||
|
dbesc($dbvalue),
|
||||||
|
dbesc($chash),
|
||||||
|
dbesc($xhash),
|
||||||
|
dbesc($family),
|
||||||
|
dbesc($key)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if($r)
|
||||||
|
return $value;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function del_abconfig($chash,$xhash,$family,$key) {
|
||||||
|
|
||||||
|
$r = q("delete from abconfig where chan = '%s' and xchan = '%s' and cat = '%s' and k = '%s' ",
|
||||||
|
dbesc($chash),
|
||||||
|
dbesc($xhash),
|
||||||
|
dbesc($family),
|
||||||
|
dbesc($key)
|
||||||
|
);
|
||||||
|
|
||||||
|
return $r;
|
||||||
|
}
|
||||||
|
@ -505,8 +505,12 @@ function identity_basic_export($channel_id, $items = false) {
|
|||||||
if($r) {
|
if($r) {
|
||||||
$ret['abook'] = $r;
|
$ret['abook'] = $r;
|
||||||
|
|
||||||
foreach($r as $rr)
|
for($x = 0; $x < count($ret['abook']); $x ++) {
|
||||||
$xchans[] = $rr['abook_xchan'];
|
$xchans[] = $ret['abook'][$x]['abook_chan'];
|
||||||
|
$abconfig = load_abconfig($ret['channel']['channel_hash'],$ret['abook'][$x]['abook_xchan']);
|
||||||
|
if($abconfig)
|
||||||
|
$ret['abook'][$x]['abconfig'] = $abconfig;
|
||||||
|
}
|
||||||
stringify_array_elms($xchans);
|
stringify_array_elms($xchans);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -522,6 +522,11 @@ function zot_refresh($them, $channel = null, $force = false) {
|
|||||||
unset($new_connection[0]['abook_id']);
|
unset($new_connection[0]['abook_id']);
|
||||||
unset($new_connection[0]['abook_account']);
|
unset($new_connection[0]['abook_account']);
|
||||||
unset($new_connection[0]['abook_channel']);
|
unset($new_connection[0]['abook_channel']);
|
||||||
|
|
||||||
|
$abconfig = load_abconfig($channel['channel_hash'],$new_connection['abook_xchan']);
|
||||||
|
if($abconfig)
|
||||||
|
$new_connection['abconfig'] = $abconfig;
|
||||||
|
|
||||||
build_sync_packet($channel['channel_id'], array('abook' => $new_connection));
|
build_sync_packet($channel['channel_id'], array('abook' => $new_connection));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3124,6 +3129,11 @@ function process_channel_sync_delivery($sender, $arr, $deliveries) {
|
|||||||
|
|
||||||
foreach($arr['abook'] as $abook) {
|
foreach($arr['abook'] as $abook) {
|
||||||
|
|
||||||
|
$abconfig = null;
|
||||||
|
|
||||||
|
if(array_key_exists('abconfig',$abook) && is_array($abook['abconfig']) && count($abook['abconfig']))
|
||||||
|
$abconfig = $abook['abconfig'];
|
||||||
|
|
||||||
if(! array_key_exists('abook_blocked',$abook)) {
|
if(! array_key_exists('abook_blocked',$abook)) {
|
||||||
// convert from redmatrix
|
// convert from redmatrix
|
||||||
$abook['abook_blocked'] = (($abook['abook_flags'] & 0x0001) ? 1 : 0);
|
$abook['abook_blocked'] = (($abook['abook_flags'] & 0x0001) ? 1 : 0);
|
||||||
@ -3214,8 +3224,13 @@ function process_channel_sync_delivery($sender, $arr, $deliveries) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($abconfig) {
|
||||||
|
// @fixme does not handle sync of del_abconfig
|
||||||
|
foreach($abconfig as $abc) {
|
||||||
|
if($abc['chan'] === $channel['channel_hash'])
|
||||||
|
set_abconfig($abc['chan'],$abc['xchan'],$abc['cat'],$abc['k'],$abc['v']);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,18 @@
|
|||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `abconfig` (
|
||||||
|
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
|
`chan` char(255) NOT NULL DEFAULT '',
|
||||||
|
`xchan` char(255) NOT NULL DEFAULT '',
|
||||||
|
`cat` char(255) NOT NULL DEFAULT '',
|
||||||
|
`k` char(255) NOT NULL DEFAULT '',
|
||||||
|
`v` mediumtext NOT NULL,
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
KEY `chan` (`chan`),
|
||||||
|
KEY `xchan` (`xchan`),
|
||||||
|
KEY `cat` (`cat`),
|
||||||
|
KEY `k` (`k`)
|
||||||
|
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS `abook` (
|
CREATE TABLE IF NOT EXISTS `abook` (
|
||||||
`abook_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
`abook_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
`abook_account` int(10) unsigned NOT NULL DEFAULT '0',
|
`abook_account` int(10) unsigned NOT NULL DEFAULT '0',
|
||||||
|
@ -1,3 +1,16 @@
|
|||||||
|
CREATE TABLE "abconfig" (
|
||||||
|
"id" serial NOT NULL,
|
||||||
|
"chan" text NOT NULL,
|
||||||
|
"xchan" text NOT NULL,
|
||||||
|
"cat" text NOT NULL,
|
||||||
|
"k" text NOT NULL,
|
||||||
|
"v" text NOT NULL,
|
||||||
|
PRIMARY KEY ("id")
|
||||||
|
);
|
||||||
|
create index "abconfig_chan" on abconfig ("chan");
|
||||||
|
create index "abconfig_xchan" on abconfig ("xchan");
|
||||||
|
create index "abconfig_cat" on abconfig ("cat");
|
||||||
|
create index "abconfig_k" on abconfig ("k");
|
||||||
CREATE TABLE "abook" (
|
CREATE TABLE "abook" (
|
||||||
"abook_id" serial NOT NULL,
|
"abook_id" serial NOT NULL,
|
||||||
"abook_account" bigint NOT NULL,
|
"abook_account" bigint NOT NULL,
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
define( 'UPDATE_VERSION' , 1164 );
|
define( 'UPDATE_VERSION' , 1165 );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@ -2019,3 +2019,42 @@ function update_r1163() {
|
|||||||
return UPDATE_SUCCESS;
|
return UPDATE_SUCCESS;
|
||||||
return UPDATE_FAILED;
|
return UPDATE_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function update_r1164() {
|
||||||
|
|
||||||
|
if(ACTIVE_DBTYPE == DBTYPE_POSTGRES) {
|
||||||
|
$r1 = q("CREATE TABLE \"abconfig\" (
|
||||||
|
\"id\" serial NOT NULL,
|
||||||
|
\"chan\" text NOT NULL,
|
||||||
|
\"xchan\" text NOT NULL,
|
||||||
|
\"cat\" text NOT NULL,
|
||||||
|
\"k\" text NOT NULL,
|
||||||
|
\"v\" text NOT NULL,
|
||||||
|
PRIMARY KEY (\"id\") ");
|
||||||
|
$r2 = q("create index \"abconfig_chan\" on abconfig (\"chan\") ");
|
||||||
|
$r3 = q("create index \"abconfig_xchan\" on abconfig (\"xchan\") ");
|
||||||
|
$r4 = q("create index \"abconfig_cat\" on abconfig (\"cat\") ");
|
||||||
|
$r5 = q("create index \"abconfig_k\" on abconfig (\"k\") ");
|
||||||
|
$r = $r1 && $r2 && $r3 && $r4 && $r5;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$r = q("CREATE TABLE IF NOT EXISTS `abconfig` (
|
||||||
|
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
|
`chan` char(255) NOT NULL DEFAULT '',
|
||||||
|
`xchan` char(255) NOT NULL DEFAULT '',
|
||||||
|
`cat` char(255) NOT NULL DEFAULT '',
|
||||||
|
`k` char(255) NOT NULL DEFAULT '',
|
||||||
|
`v` mediumtext NOT NULL,
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
KEY `chan` (`chan`),
|
||||||
|
KEY `xchan` (`xchan`),
|
||||||
|
KEY `cat` (`cat`),
|
||||||
|
KEY `k` (`k`)
|
||||||
|
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ");
|
||||||
|
|
||||||
|
}
|
||||||
|
if($r)
|
||||||
|
return UPDATE_SUCCESS;
|
||||||
|
return UPDATE_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -322,6 +322,9 @@ function connedit_clone(&$a) {
|
|||||||
if(! $a->poi)
|
if(! $a->poi)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
||||||
|
$channel = $a->get_channel();
|
||||||
|
|
||||||
$r = q("SELECT abook.*, xchan.*
|
$r = q("SELECT abook.*, xchan.*
|
||||||
FROM abook left join xchan on abook_xchan = xchan_hash
|
FROM abook left join xchan on abook_xchan = xchan_hash
|
||||||
WHERE abook_channel = %d and abook_id = %d LIMIT 1",
|
WHERE abook_channel = %d and abook_id = %d LIMIT 1",
|
||||||
@ -338,6 +341,10 @@ function connedit_clone(&$a) {
|
|||||||
unset($clone['abook_account']);
|
unset($clone['abook_account']);
|
||||||
unset($clone['abook_channel']);
|
unset($clone['abook_channel']);
|
||||||
|
|
||||||
|
$abconfig = load_abconfig($channel['channel_hash'],$clone['abook_xchan']);
|
||||||
|
if($abconfig)
|
||||||
|
$clone['abconfig'] = $abconfig;
|
||||||
|
|
||||||
build_sync_packet(0 /* use the current local_channel */, array('abook' => array($clone)));
|
build_sync_packet(0 /* use the current local_channel */, array('abook' => array($clone)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,7 +14,9 @@ function follow_init(&$a) {
|
|||||||
$return_url = $_SESSION['return_url'];
|
$return_url = $_SESSION['return_url'];
|
||||||
$confirm = intval($_REQUEST['confirm']);
|
$confirm = intval($_REQUEST['confirm']);
|
||||||
|
|
||||||
$result = new_contact($uid,$url,$a->get_channel(),true,$confirm);
|
$channel = $a->get_channel();
|
||||||
|
|
||||||
|
$result = new_contact($uid,$url,$channel,true,$confirm);
|
||||||
|
|
||||||
if($result['success'] == false) {
|
if($result['success'] == false) {
|
||||||
if($result['message'])
|
if($result['message'])
|
||||||
@ -34,6 +36,10 @@ function follow_init(&$a) {
|
|||||||
unset($clone['abook_account']);
|
unset($clone['abook_account']);
|
||||||
unset($clone['abook_channel']);
|
unset($clone['abook_channel']);
|
||||||
|
|
||||||
|
$abconfig = load_abconfig($channel['channel_hash'],$clone['abook_xchan']);
|
||||||
|
if($abconfig)
|
||||||
|
$clone['abconfig'] = $abconfig;
|
||||||
|
|
||||||
build_sync_packet(0 /* use the current local_channel */, array('abook' => array($clone)));
|
build_sync_packet(0 /* use the current local_channel */, array('abook' => array($clone)));
|
||||||
|
|
||||||
|
|
||||||
|
@ -341,6 +341,10 @@ function import_account(&$a, $account_id) {
|
|||||||
if($abooks) {
|
if($abooks) {
|
||||||
foreach($abooks as $abook) {
|
foreach($abooks as $abook) {
|
||||||
|
|
||||||
|
$abconfig = null;
|
||||||
|
if(array_key_exists('abconfig',$abook) && is_array($abook['abconfig']) && count($abook['abconfig']))
|
||||||
|
$abconfig = $abook['abconfig'];
|
||||||
|
|
||||||
unset($abook['abook_id']);
|
unset($abook['abook_id']);
|
||||||
unset($abook['abook_rating']);
|
unset($abook['abook_rating']);
|
||||||
unset($abook['abook_rating_text']);
|
unset($abook['abook_rating_text']);
|
||||||
@ -382,6 +386,17 @@ function import_account(&$a, $account_id) {
|
|||||||
$friends ++;
|
$friends ++;
|
||||||
if(intval($abook['abook_feed']))
|
if(intval($abook['abook_feed']))
|
||||||
$feeds ++;
|
$feeds ++;
|
||||||
|
|
||||||
|
if($abconfig) {
|
||||||
|
// @fixme does not handle sync of del_abconfig
|
||||||
|
foreach($abconfig as $abc) {
|
||||||
|
if($abc['chan'] === $channel['channel_hash'])
|
||||||
|
set_abconfig($abc['chan'],$abc['xchan'],$abc['cat'],$abc['k'],$abc['v']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
logger('import step 8');
|
logger('import step 8');
|
||||||
|
Reference in New Issue
Block a user