diff options
author | friendica <info@friendica.com> | 2013-06-26 17:31:02 -0700 |
---|---|---|
committer | friendica <info@friendica.com> | 2013-06-26 17:31:02 -0700 |
commit | b9466941e77eea806539ea56b6b625d354968f4c (patch) | |
tree | f5f5c8eac6991609771ebd82941325b8b479968f /include/settings.php | |
parent | 156cf592eeeaf1ef2fe446655b1f28debab7814c (diff) | |
download | volse-hubzilla-b9466941e77eea806539ea56b6b625d354968f4c.tar.gz volse-hubzilla-b9466941e77eea806539ea56b6b625d354968f4c.tar.bz2 volse-hubzilla-b9466941e77eea806539ea56b6b625d354968f4c.zip |
more work on channel sync
Diffstat (limited to 'include/settings.php')
-rw-r--r-- | include/settings.php | 33 |
1 files changed, 27 insertions, 6 deletions
diff --git a/include/settings.php b/include/settings.php index 94cb6f65b..e53cfedfa 100644 --- a/include/settings.php +++ b/include/settings.php @@ -1,9 +1,17 @@ <?php /** @file */ -function build_sync_packet($packet = null) { +/** + * Send a zot packet to all hubs where this channel is duplicated, refreshing + * such things as personal settings, channel permissions, address book updates, etc. + */ + + +function build_sync_packet($uid = 0, $packet = null) { $a = get_app(); - $uid = local_user(); + if(! $uid) + $uid = local_user(); + if(! $uid) return; @@ -27,6 +35,15 @@ function build_sync_packet($packet = null) { if(! $synchubs) return; + $r = q("select xchan_guid, xchan_guid_sig from xchan where xchan_hash = '%s' limit 1", + dbesc($channel['channel_hash']) + ); + if(! $r) + return; + + $env_recips = array(); + $env_recips[] = array('guid' => $r[0]['xchan_guid'],'guid_sig' => $r[0]['xchan_guid_sig']); + $info = (($packet) ? $packet : array()); if(array_key_exists($uid,$a->config) && array_key_exists('transient',$a->config[$uid])) { @@ -41,10 +58,14 @@ function build_sync_packet($packet = null) { foreach($channel as $k => $v) { if(strpos('channel_',$k) !== 0) continue; - if($k === 'channel_id') - continue; - if($k === 'channel_account_id') + + // don't pass these elements, they should not be synchronised + + $disallowed = array('channel_id','channel_account_id','channel_primary','channel_prvkey'); + + if(in_array($k,$disallowed)) continue; + $info['channel'][$k] = $v; } } @@ -55,7 +76,7 @@ function build_sync_packet($packet = null) { foreach($synchubs as $hub) { $hash = random_string(); - $n = zot_build_packet($channel,'channel_sync'); + $n = zot_build_packet($channel,'channel_sync',$env_recips,$hub['hubloc_sitekey'],null,$hash); q("insert into outq ( outq_hash, outq_account, outq_channel, outq_posturl, outq_async, outq_created, outq_updated, outq_notify, outq_msg ) values ( '%s', %d, %d, '%s', %d, '%s', '%s', '%s', '%s' )", dbesc($hash), intval($channel['channel_account']), |