aboutsummaryrefslogtreecommitdiffstats
path: root/include/settings.php
diff options
context:
space:
mode:
authorfriendica <info@friendica.com>2013-06-26 17:31:02 -0700
committerfriendica <info@friendica.com>2013-06-26 17:31:02 -0700
commitb9466941e77eea806539ea56b6b625d354968f4c (patch)
treef5f5c8eac6991609771ebd82941325b8b479968f /include/settings.php
parent156cf592eeeaf1ef2fe446655b1f28debab7814c (diff)
downloadvolse-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.php33
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']),