OStatus: Better handling of changed nicknames
This commit is contained in:
		
					parent
					
						
							
								ed13034e23
							
						
					
				
			
			
				commit
				
					
						763838c78d
					
				
			
		
					 2 changed files with 36 additions and 18 deletions
				
			
		|  | @ -607,6 +607,10 @@ function get_contact($url, $uid = 0, $no_update = false) { | ||||||
| 		$data = array_merge($data, $gcontacts); | 		$data = array_merge($data, $gcontacts); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	if (!$contact_id && ($data["alias"] != '') && ($data["alias"] != $url)) { | ||||||
|  | 		$contact_id = get_contact($data["alias"], $uid, true); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	$url = $data["url"]; | 	$url = $data["url"]; | ||||||
| 	if (!$contact_id) { | 	if (!$contact_id) { | ||||||
| 		dba::insert('contact', array('uid' => $uid, 'created' => datetime_convert(), 'url' => $data["url"], | 		dba::insert('contact', array('uid' => $uid, 'created' => datetime_convert(), 'url' => $data["url"], | ||||||
|  | @ -658,7 +662,7 @@ function get_contact($url, $uid = 0, $no_update = false) { | ||||||
| 
 | 
 | ||||||
| 	update_contact_avatar($data["photo"], $uid, $contact_id); | 	update_contact_avatar($data["photo"], $uid, $contact_id); | ||||||
| 
 | 
 | ||||||
| 	$contact = dba::select('contact', array('addr', 'alias', 'name', 'nick', 'keywords', 'location', 'about', 'avatar-date'), | 	$contact = dba::select('contact', array('url', 'nurl', 'addr', 'alias', 'name', 'nick', 'keywords', 'location', 'about', 'avatar-date'), | ||||||
| 				array('id' => $contact_id), array('limit' => 1)); | 				array('id' => $contact_id), array('limit' => 1)); | ||||||
| 
 | 
 | ||||||
| 	// This condition should always be true
 | 	// This condition should always be true
 | ||||||
|  | @ -668,6 +672,8 @@ function get_contact($url, $uid = 0, $no_update = false) { | ||||||
| 
 | 
 | ||||||
| 	$updated = array('addr' => $data['addr'], | 	$updated = array('addr' => $data['addr'], | ||||||
| 			'alias' => $data['alias'], | 			'alias' => $data['alias'], | ||||||
|  | 			'url' => $data['url'], | ||||||
|  | 			'nurl' => normalise_link($data['url']), | ||||||
| 			'name' => $data['name'], | 			'name' => $data['name'], | ||||||
| 			'nick' => $data['nick']); | 			'nick' => $data['nick']); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -62,12 +62,26 @@ class ostatus { | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 |  | ||||||
| 		$author["contact-id"] = $contact["id"]; | 		$author["contact-id"] = $contact["id"]; | ||||||
| 
 | 
 | ||||||
| 		$found = false; | 		$found = false; | ||||||
| 
 | 
 | ||||||
| 		if ($author["author-link"] != "") { | 		if ($aliaslink != '') { | ||||||
|  | 			$condition = array("`uid` = ? AND `alias` = ? AND `network` != ?", | ||||||
|  | 					$importer["uid"], $aliaslink, NETWORK_STATUSNET); | ||||||
|  | 			$r = dba::select('contact', array(), $condition, array('limit' => 1)); | ||||||
|  | 
 | ||||||
|  | 			if (dbm::is_result($r)) { | ||||||
|  | 				$found = true; | ||||||
|  | 				if ($r['blocked']) { | ||||||
|  | 					$r['id'] = -1; | ||||||
|  | 				} | ||||||
|  | 				$contact = $r; | ||||||
|  | 				$author["contact-id"] = $r["id"]; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if (!$found && ($author["author-link"] != "")) { | ||||||
| 			if ($aliaslink == "") { | 			if ($aliaslink == "") { | ||||||
| 				$aliaslink = $author["author-link"]; | 				$aliaslink = $author["author-link"]; | ||||||
| 			} | 			} | ||||||
|  | @ -83,7 +97,6 @@ class ostatus { | ||||||
| 				} | 				} | ||||||
| 				$contact = $r; | 				$contact = $r; | ||||||
| 				$author["contact-id"] = $r["id"]; | 				$author["contact-id"] = $r["id"]; | ||||||
| 				$author["author-link"] = $r["url"]; |  | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | @ -93,12 +106,12 @@ class ostatus { | ||||||
| 			$r = dba::select('contact', array(), $condition, array('limit' => 1)); | 			$r = dba::select('contact', array(), $condition, array('limit' => 1)); | ||||||
| 
 | 
 | ||||||
| 			if (dbm::is_result($r)) { | 			if (dbm::is_result($r)) { | ||||||
|  | 				$found = true; | ||||||
| 				if ($r['blocked']) { | 				if ($r['blocked']) { | ||||||
| 					$r['id'] = -1; | 					$r['id'] = -1; | ||||||
| 				} | 				} | ||||||
| 				$contact = $r; | 				$contact = $r; | ||||||
| 				$author["contact-id"] = $r["id"]; | 				$author["contact-id"] = $r["id"]; | ||||||
| 				$author["author-link"] = $r["url"]; |  | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | @ -138,6 +151,9 @@ class ostatus { | ||||||
| 
 | 
 | ||||||
| 			// Update contact data
 | 			// Update contact data
 | ||||||
| 
 | 
 | ||||||
|  | 			$current = $contact; | ||||||
|  | 			unset($current['name-date']); | ||||||
|  | 
 | ||||||
| 			// This query doesn't seem to work
 | 			// This query doesn't seem to work
 | ||||||
| 			// $value = $xpath->query("atom:link[@rel='salmon']", $context)->item(0)->nodeValue;
 | 			// $value = $xpath->query("atom:link[@rel='salmon']", $context)->item(0)->nodeValue;
 | ||||||
| 			// if ($value != "")
 | 			// if ($value != "")
 | ||||||
|  | @ -148,6 +164,9 @@ class ostatus { | ||||||
| 			// if ($value != "")
 | 			// if ($value != "")
 | ||||||
| 			//	$contact["poll"] = $value;
 | 			//	$contact["poll"] = $value;
 | ||||||
| 
 | 
 | ||||||
|  | 			$contact['url'] = $author["author-link"]; | ||||||
|  | 			$contact['nurl'] = normalise_link($contact['url']); | ||||||
|  | 
 | ||||||
| 			$value = $xpath->evaluate('atom:author/atom:uri/text()', $context)->item(0)->nodeValue; | 			$value = $xpath->evaluate('atom:author/atom:uri/text()', $context)->item(0)->nodeValue; | ||||||
| 			if ($value != "") | 			if ($value != "") | ||||||
| 				$contact["alias"] = $value; | 				$contact["alias"] = $value; | ||||||
|  | @ -168,32 +187,25 @@ class ostatus { | ||||||
| 			if ($value != "") | 			if ($value != "") | ||||||
| 				$contact["location"] = $value; | 				$contact["location"] = $value; | ||||||
| 
 | 
 | ||||||
| 			if (($contact["name"] != $r[0]["name"]) || ($contact["nick"] != $r[0]["nick"]) || ($contact["about"] != $r[0]["about"]) || | 			$contact['name-date'] = datetime_convert(); | ||||||
| 				($contact["alias"] != $r[0]["alias"]) || ($contact["location"] != $r[0]["location"])) { |  | ||||||
| 
 | 
 | ||||||
| 				logger("Update contact data for contact ".$contact["id"], LOGGER_DEBUG); | 			dba::update('contact', $contact, array('id' => $contact["id"]), $current); | ||||||
| 
 | 
 | ||||||
| 				q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `alias` = '%s', `about` = '%s', `location` = '%s', `name-date` = '%s' WHERE `id` = %d", | 			if (!empty($author["author-avatar"]) && ($author["author-avatar"] != $current['avatar'])) { | ||||||
| 					dbesc($contact["name"]), dbesc($contact["nick"]), dbesc($contact["alias"]), |  | ||||||
| 					dbesc($contact["about"]), dbesc($contact["location"]), |  | ||||||
| 					dbesc(datetime_convert()), intval($contact["id"])); |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			if (isset($author["author-avatar"]) && ($author["author-avatar"] != $r[0]['avatar'])) { |  | ||||||
| 				logger("Update profile picture for contact ".$contact["id"], LOGGER_DEBUG); | 				logger("Update profile picture for contact ".$contact["id"], LOGGER_DEBUG); | ||||||
| 
 |  | ||||||
| 				update_contact_avatar($author["author-avatar"], $importer["uid"], $contact["id"]); | 				update_contact_avatar($author["author-avatar"], $importer["uid"], $contact["id"]); | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			// Ensure that we are having this contact (with uid=0)
 | 			// Ensure that we are having this contact (with uid=0)
 | ||||||
| 			$cid = get_contact($author["author-link"], 0); | 			$cid = get_contact($aliaslink, 0); | ||||||
| 
 | 
 | ||||||
| 			if ($cid) { | 			if ($cid) { | ||||||
| 				$fields = array('url', 'name', 'nick', 'alias', 'about', 'location'); | 				$fields = array('url', 'nurl', 'name', 'nick', 'alias', 'about', 'location'); | ||||||
| 				$old_contact = dba::select('contact', $fields, array('id' => $cid), array('limit' => 1)); | 				$old_contact = dba::select('contact', $fields, array('id' => $cid), array('limit' => 1)); | ||||||
| 
 | 
 | ||||||
| 				// Update it with the current values
 | 				// Update it with the current values
 | ||||||
| 				$fields = array('url' => $author["author-link"], 'name' => $contact["name"], | 				$fields = array('url' => $author["author-link"], 'name' => $contact["name"], | ||||||
|  | 						'nurl' => normalise_link($author["author-link"]), | ||||||
| 						'nick' => $contact["nick"], 'alias' => $contact["alias"], | 						'nick' => $contact["nick"], 'alias' => $contact["alias"], | ||||||
| 						'about' => $contact["about"], 'location' => $contact["location"], | 						'about' => $contact["about"], 'location' => $contact["location"], | ||||||
| 						'success_update' => datetime_convert(), 'last-update' => datetime_convert()); | 						'success_update' => datetime_convert(), 'last-update' => datetime_convert()); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue