The behaviour when following a new contact is now unified.
This commit is contained in:
		
					parent
					
						
							
								9b6922fa86
							
						
					
				
			
			
				commit
				
					
						f6ea872986
					
				
			
		
					 6 changed files with 121 additions and 10 deletions
				
			
		|  | @ -15,7 +15,7 @@ | ||||||
| 
 | 
 | ||||||
| function new_contact($uid,$url,$interactive = false) { | function new_contact($uid,$url,$interactive = false) { | ||||||
| 
 | 
 | ||||||
| 	$result = array('success' => false,'message' => ''); | 	$result = array('cid' => -1, 'success' => false,'message' => ''); | ||||||
| 
 | 
 | ||||||
| 	$a = get_app(); | 	$a = get_app(); | ||||||
| 
 | 
 | ||||||
|  | @ -208,7 +208,7 @@ function new_contact($uid,$url,$interactive = false) { | ||||||
| 
 | 
 | ||||||
| 	$contact = $r[0]; | 	$contact = $r[0]; | ||||||
| 	$contact_id  = $r[0]['id']; | 	$contact_id  = $r[0]['id']; | ||||||
| 
 | 	$result['cid'] = $contact_id; | ||||||
| 
 | 
 | ||||||
| 	$g = q("select def_gid from user where uid = %d limit 1", | 	$g = q("select def_gid from user where uid = %d limit 1", | ||||||
| 		intval($uid) | 		intval($uid) | ||||||
|  |  | ||||||
|  | @ -664,6 +664,21 @@ function dfrn_request_content(&$a) { | ||||||
| 		$dfrn_url = notags(trim(hex2bin($_GET['dfrn_url']))); | 		$dfrn_url = notags(trim(hex2bin($_GET['dfrn_url']))); | ||||||
| 		$aes_allow = (((x($_GET,'aes_allow')) && ($_GET['aes_allow'] == 1)) ? 1 : 0); | 		$aes_allow = (((x($_GET,'aes_allow')) && ($_GET['aes_allow'] == 1)) ? 1 : 0); | ||||||
| 		$confirm_key = (x($_GET,'confirm_key') ? $_GET['confirm_key'] : ""); | 		$confirm_key = (x($_GET,'confirm_key') ? $_GET['confirm_key'] : ""); | ||||||
|  | 
 | ||||||
|  | 		// Checking fastlane for validity
 | ||||||
|  | 		if (x($_SESSION, "fastlane") AND (normalise_link($_SESSION["fastlane"]) == normalise_link($dfrn_url))) { | ||||||
|  | 			$_POST["dfrn_url"] = $dfrn_url; | ||||||
|  | 			$_POST["confirm_key"] = $confirm_key; | ||||||
|  | 			$_POST["localconfirm"] = 1; | ||||||
|  | 			$_POST["hidden-contact"] = 0; | ||||||
|  | 			$_POST["submit"] = t('Confirm'); | ||||||
|  | 
 | ||||||
|  | 			dfrn_request_post($a); | ||||||
|  | 
 | ||||||
|  | 			killme(); | ||||||
|  | 			return; // NOTREACHED
 | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		$tpl = get_markup_template("dfrn_req_confirm.tpl"); | 		$tpl = get_markup_template("dfrn_req_confirm.tpl"); | ||||||
| 		$o  = replace_macros($tpl,array( | 		$o  = replace_macros($tpl,array( | ||||||
| 			'$dfrn_url' => $dfrn_url, | 			'$dfrn_url' => $dfrn_url, | ||||||
|  |  | ||||||
							
								
								
									
										84
									
								
								mod/follow.php
									
										
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										84
									
								
								mod/follow.php
									
										
									
									
									
										
										
										Normal file → Executable file
									
								
							|  | @ -3,7 +3,7 @@ | ||||||
| require_once('include/Scrape.php'); | require_once('include/Scrape.php'); | ||||||
| require_once('include/follow.php'); | require_once('include/follow.php'); | ||||||
| 
 | 
 | ||||||
| function follow_init(&$a) { | function follow_content(&$a) { | ||||||
| 
 | 
 | ||||||
| 	if(! local_user()) { | 	if(! local_user()) { | ||||||
| 		notice( t('Permission denied.') . EOL); | 		notice( t('Permission denied.') . EOL); | ||||||
|  | @ -11,10 +11,85 @@ function follow_init(&$a) { | ||||||
| 		// NOTREACHED
 | 		// NOTREACHED
 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	$uid = local_user(); | ||||||
|  | 	$url = notags(trim($_REQUEST['url'])); | ||||||
|  | 
 | ||||||
|  | 	$r = q("SELECT `url` FROM `contact` WHERE `uid` = %d AND (`nurl` = '%s' OR `alias` = '%s' OR `alias` = '%s') LIMIT 1", | ||||||
|  | 		intval(local_user()), dbesc(normalise_link($url)), dbesc(normalise_link($url)), dbesc($url)); | ||||||
|  | 
 | ||||||
|  | 	if ($r) { | ||||||
|  | 		notice(t('You already added this contact.').EOL); | ||||||
|  | 		goaway($_SESSION['return_url']); | ||||||
|  | 		// NOTREACHED
 | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	$ret = probe_url($url); | ||||||
|  | 
 | ||||||
|  | 	if($ret['network'] === NETWORK_DFRN) { | ||||||
|  | 		$request = $ret["request"]; | ||||||
|  | 		$tpl = get_markup_template('dfrn_request.tpl'); | ||||||
|  | 	} else { | ||||||
|  | 		$request = $a->get_baseurl()."/follow"; | ||||||
|  | 		$tpl = get_markup_template('auto_request.tpl'); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	$r = q("SELECT `url` FROM `contact` WHERE `uid` = %d AND `self` LIMIT 1", intval($uid)); | ||||||
|  | 
 | ||||||
|  | 	if (!$r) { | ||||||
|  | 		notice( t('Permission denied.') . EOL); | ||||||
|  | 		goaway($_SESSION['return_url']); | ||||||
|  | 		// NOTREACHED
 | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	$myaddr = $r[0]["url"]; | ||||||
|  | 
 | ||||||
|  | 	// Makes the connection request for friendica contacts easier
 | ||||||
|  | 	$_SESSION["fastlane"] = $ret["url"]; | ||||||
|  | 
 | ||||||
|  | 	$o  = replace_macros($tpl,array( | ||||||
|  | 			'$header' => $ret["name"]." (".$ret["addr"].")", | ||||||
|  | 			'$photo' => $ret["photo"], | ||||||
|  |                         '$desc' => "", | ||||||
|  |                         '$pls_answer' => t('Please answer the following:'), | ||||||
|  |                         '$does_know_you' => array('knowyou', sprintf(t('Does %s know you?'),$ret["name"]), false, '', array(t('No'),t('Yes'))), | ||||||
|  |                         '$add_note' => t('Add a personal note:'), | ||||||
|  |                         '$page_desc' => "", | ||||||
|  |                         '$friendica' => "", | ||||||
|  |                         '$statusnet' => "", | ||||||
|  |                         '$diaspora' => "", | ||||||
|  |                         '$diasnote' => "", | ||||||
|  |                         '$your_address' => t('Your Identity Address:'), | ||||||
|  |                         '$invite_desc' => "", | ||||||
|  |                         '$emailnet' => "", | ||||||
|  |                         '$submit' => t('Submit Request'), | ||||||
|  |                         '$cancel' => t('Cancel'), | ||||||
|  |                         '$nickname' => "", | ||||||
|  |                         '$name' => $ret["name"], | ||||||
|  |                         '$url' => $ret["url"], | ||||||
|  |                         '$myaddr' => $myaddr, | ||||||
|  | 			'$request' => $request | ||||||
|  | 	)); | ||||||
|  | 	return $o; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function follow_post(&$a) { | ||||||
|  | 
 | ||||||
|  | 	if(! local_user()) { | ||||||
|  | 		notice( t('Permission denied.') . EOL); | ||||||
|  | 		goaway($_SESSION['return_url']); | ||||||
|  | 		// NOTREACHED
 | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if ($_REQUEST['cancel']) | ||||||
|  | 		goaway($_SESSION['return_url']); | ||||||
|  | 
 | ||||||
| 	$uid = local_user(); | 	$uid = local_user(); | ||||||
| 	$url = notags(trim($_REQUEST['url'])); | 	$url = notags(trim($_REQUEST['url'])); | ||||||
| 	$return_url = $_SESSION['return_url']; | 	$return_url = $_SESSION['return_url']; | ||||||
| 
 | 
 | ||||||
|  | 	// Makes the connection request for friendica contacts easier
 | ||||||
|  | 	// This is just a precaution if maybe this page is called somewhere directly via POST
 | ||||||
|  | 	$_SESSION["fastlane"] = $url; | ||||||
| 
 | 
 | ||||||
| 	$result = new_contact($uid,$url,true); | 	$result = new_contact($uid,$url,true); | ||||||
| 
 | 
 | ||||||
|  | @ -22,12 +97,13 @@ function follow_init(&$a) { | ||||||
| 		if($result['message']) | 		if($result['message']) | ||||||
| 			notice($result['message']); | 			notice($result['message']); | ||||||
| 		goaway($return_url); | 		goaway($return_url); | ||||||
| 	} | 	} elseif ($result['cid']) | ||||||
|  | 		goaway($a->get_baseurl().'/contacts/'.$result['cid']); | ||||||
| 
 | 
 | ||||||
| 	info( t('Contact added') . EOL); | 	info( t('Contact added').EOL); | ||||||
| 
 | 
 | ||||||
| 	if(strstr($return_url,'contacts')) | 	if(strstr($return_url,'contacts')) | ||||||
| 		goaway($a->get_baseurl() . '/contacts/' . $contact_id); | 		goaway($a->get_baseurl().'/contacts/'.$contact_id); | ||||||
| 
 | 
 | ||||||
| 	goaway($return_url); | 	goaway($return_url); | ||||||
| 	// NOTREACHED
 | 	// NOTREACHED
 | ||||||
|  |  | ||||||
|  | @ -20,16 +20,27 @@ | ||||||
| </p> | </p> | ||||||
| {{/if}} | {{/if}} | ||||||
| 
 | 
 | ||||||
|  | {{if $request}} | ||||||
|  | <form action="{{$request}}" method="post" /> | ||||||
|  | {{else}} | ||||||
| <form action="dfrn_request/{{$nickname}}" method="post" /> | <form action="dfrn_request/{{$nickname}}" method="post" /> | ||||||
|  | {{/if}} | ||||||
|  | 
 | ||||||
|  | {{if $photo}} | ||||||
|  | <img src="{{$photo}}" alt="" id="dfrn-request-photo"> | ||||||
|  | {{/if}} | ||||||
| 
 | 
 | ||||||
| <div id="dfrn-request-url-wrapper" > | <div id="dfrn-request-url-wrapper" > | ||||||
| 	<label id="dfrn-url-label" for="dfrn-url" >{{$your_address}}</label> | 	<label id="dfrn-url-label" for="dfrn-url" >{{$your_address}}</label> | ||||||
|         {{if $myaddr}} |         {{if $myaddr}} | ||||||
|                 {{$myaddr}} |                 {{$myaddr}} | ||||||
|                 <input type="hidden" name="dfrn_url" id="dfrn-url" size="32" value="{{$myaddr|escape:'html'}}" /> |                 <input type="hidden" name="dfrn_url" id="dfrn-url" value="{{$myaddr|escape:'html'}}" /> | ||||||
|         {{else}} |         {{else}} | ||||||
|         <input type="text" name="dfrn_url" id="dfrn-url" size="32" value="{{$myaddr|escape:'html'}}" /> |         <input type="text" name="dfrn_url" id="dfrn-url" size="32" value="{{$myaddr|escape:'html'}}" /> | ||||||
|         {{/if}} |         {{/if}} | ||||||
|  |         {{if $url}} | ||||||
|  |                 <input type="hidden" name="url" id="url" value="{{$url|escape:'html'}}" /> | ||||||
|  |         {{/if}} | ||||||
| 	<div id="dfrn-request-url-end"></div> | 	<div id="dfrn-request-url-end"></div> | ||||||
| </div> | </div> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,5 +1,3 @@ | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| <h1>{{$header}}</h1> | <h1>{{$header}}</h1> | ||||||
| 
 | 
 | ||||||
| {{if $myaddr}} | {{if $myaddr}} | ||||||
|  | @ -19,7 +17,15 @@ | ||||||
| </p> | </p> | ||||||
| {{/if}} | {{/if}} | ||||||
| 
 | 
 | ||||||
|  | {{if $request}} | ||||||
|  | <form action="{{$request}}" method="post" /> | ||||||
|  | {{else}} | ||||||
| <form action="dfrn_request/{{$nickname}}" method="post" /> | <form action="dfrn_request/{{$nickname}}" method="post" /> | ||||||
|  | {{/if}} | ||||||
|  | 
 | ||||||
|  | {{if $photo}} | ||||||
|  | <img src="{{$photo}}" alt="" id="dfrn-request-photo"> | ||||||
|  | {{/if}} | ||||||
| 
 | 
 | ||||||
| <div id="dfrn-request-url-wrapper" > | <div id="dfrn-request-url-wrapper" > | ||||||
| 	<label id="dfrn-url-label" for="dfrn-url" >{{$your_address}}</label> | 	<label id="dfrn-url-label" for="dfrn-url" >{{$your_address}}</label> | ||||||
|  | @ -29,6 +35,9 @@ | ||||||
| 	{{else}} | 	{{else}} | ||||||
| 	<input type="text" name="dfrn_url" id="dfrn-url" size="32" value="{{$myaddr|escape:'html'}}" /> | 	<input type="text" name="dfrn_url" id="dfrn-url" size="32" value="{{$myaddr|escape:'html'}}" /> | ||||||
| 	{{/if}} | 	{{/if}} | ||||||
|  | 	{{if $url}} | ||||||
|  | 		<input type="hidden" name="url" id="url" value="{{$url|escape:'html'}}" /> | ||||||
|  | 	{{/if}} | ||||||
| 	<div id="dfrn-request-url-end"></div> | 	<div id="dfrn-request-url-end"></div> | ||||||
| </div> | </div> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ | ||||||
| <div id="follow-sidebar" class="widget"> | <div id="follow-sidebar" class="widget"> | ||||||
| 	<h3>{{$connect}}</h3> | 	<h3>{{$connect}}</h3> | ||||||
| 	<div id="connect-desc">{{$desc}}</div> | 	<div id="connect-desc">{{$desc}}</div> | ||||||
| 	<form action="follow" method="post" > | 	<form action="follow" method="get" > | ||||||
| 		<input id="side-follow-url" type="text" name="url" value="{{$value|escape:'html'}}" size="24" placeholder="{{$hint|escape:'html'}}" title="{{$hint|escape:'html'}}" /><input id="side-follow-submit" type="submit" name="submit" value="{{$follow|escape:'html'}}" /> | 		<input id="side-follow-url" type="text" name="url" value="{{$value|escape:'html'}}" size="24" placeholder="{{$hint|escape:'html'}}" title="{{$hint|escape:'html'}}" /><input id="side-follow-submit" type="submit" name="submit" value="{{$follow|escape:'html'}}" /> | ||||||
| 	</form> | 	</form> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue