aboutsummaryrefslogblamecommitdiffstats
path: root/Zotlabs/Daemon/Onedirsync.php
blob: cc16c0b58830bae6ee356b44b7c8141ebb3ce7ab (plain) (tree)










































































                                                                                                                                                    
<?php /** @file */

namespace Zotlabs\Daemon;

require_once('include/zot.php');
require_once('include/dir_fns.php');


class Onedirsync {

	static public function run($argc,$argv) {

		logger('onedirsync: start ' . intval($argv[1]));
	
		if(($argc > 1) && (intval($argv[1])))
			$update_id = intval($argv[1]);

		if(! $update_id) {
			logger('onedirsync: no update');
			return;
		}
	
		$r = q("select * from updates where ud_id = %d limit 1",
			intval($update_id)
		);

		if(! $r)
			return;
		if(($r[0]['ud_flags'] & UPDATE_FLAGS_UPDATED) || (! $r[0]['ud_addr']))
			return;

		// Have we probed this channel more recently than the other directory server
		// (where we received this update from) ?
		// If we have, we don't need to do anything except mark any older entries updated

		$x = q("select * from updates where ud_addr = '%s' and ud_date > '%s' and ( ud_flags & %d )>0 order by ud_date desc limit 1",
			dbesc($r[0]['ud_addr']),
			dbesc($r[0]['ud_date']),
			intval(UPDATE_FLAGS_UPDATED)
		);
		if($x) {
			$y = q("update updates set ud_flags = ( ud_flags | %d ) where ud_addr = '%s' and ( ud_flags & %d ) = 0 and ud_date != '%s'",
				intval(UPDATE_FLAGS_UPDATED),
				dbesc($r[0]['ud_addr']),
				intval(UPDATE_FLAGS_UPDATED),
				dbesc($x[0]['ud_date'])
			);
			return;
		}

		// ignore doing an update if this ud_addr refers to a known dead hubloc

		$h = q("select * from hubloc where hubloc_addr = '%s' limit 1",
			dbesc($r[0]['ud_addr'])
		);
		if(($h) && ($h[0]['hubloc_status'] & HUBLOC_OFFLINE)) {
			$y = q("update updates set ud_flags = ( ud_flags | %d ) where ud_addr = '%s' and ( ud_flags & %d ) = 0 ",
				intval(UPDATE_FLAGS_UPDATED),
				dbesc($r[0]['ud_addr']),
				intval(UPDATE_FLAGS_UPDATED)
			);

			return;
		}

		// we might have to pull this out some day, but for now update_directory_entry() 
		// runs zot_finger() and is kind of zot specific

		if($h && $h[0]['hubloc_network'] !== 'zot')
			return;

		update_directory_entry($r[0]);		

		return;
	}
}