aboutsummaryrefslogtreecommitdiffstats
path: root/Zotlabs/Module/Rmagic.php
blob: 04536e54edb905b83b37a6428305be24d5ca42d6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<?php
namespace Zotlabs\Module;


class Rmagic extends \Zotlabs\Web\Controller {

	function init() {
	
		if(local_channel())
			goaway(z_root());
	
		$me = get_my_address();
		if($me) {
			$r = q("select hubloc_url from hubloc where hubloc_addr = '%s' limit 1",
				dbesc($me)
			);		
			if($r) {	
				if($r[0]['hubloc_url'] === z_root())
					goaway(z_root() . '/login');
				$dest = z_root() . '/' . str_replace('zid=','zid_=',\App::$query_string);
				goaway($r[0]['hubloc_url'] . '/magic' . '?f=&dest=' . $dest);
			}
		}
	}
	
	function post() {
	
		$address = trim($_REQUEST['address']);
	
		if(strpos($address,'@') === false) {
			$arr = array('address' => $address);
			call_hooks('reverse_magic_auth', $arr);		
	
			try {
				require_once('library/openid/openid.php');
				$openid = new \LightOpenID(z_root());
				$openid->identity = $address;
				$openid->returnUrl = z_root() . '/openid'; 
				$openid->required = array('namePerson/friendly', 'namePerson');
				$openid->optional = array('namePerson/first','media/image/aspect11','media/image/default');
				goaway($openid->authUrl());
			} catch (\Exception $e) {
				notice( t('We encountered a problem while logging in with the OpenID you provided. Please check the correct spelling of the ID.').'<br /><br >'. t('The error message was:').' '.$e->getMessage());
			}
	
			// if they're still here...
			notice( t('Authentication failed.') . EOL);		
			return;
		}
		else {
	
			// Presumed Red identity. Perform reverse magic auth
	
			if(strpos($address,'@') === false) {
				notice('Invalid address.');
				return;
			}
	
			$r = null;
			if($address) {
				$r = q("select hubloc_url from hubloc where hubloc_addr = '%s' limit 1",
					dbesc($address)
				);		
			}
			if($r) {
				$url = $r[0]['hubloc_url'];
			}
			else {
				$url = 'https://' . substr($address,strpos($address,'@')+1);
			}	
	
			if($url) {	
				if($_SESSION['return_url']) 
					$dest = urlencode(z_root() . '/' . str_replace('zid=','zid_=',$_SESSION['return_url']));
				else
					$dest = urlencode(z_root() . '/' . str_replace('zid=','zid_=',\App::$query_string));
	
				goaway($url . '/magic' . '?f=&dest=' . $dest);
			}
		}
	}
	
	
	function get() {
	
		$o = replace_macros(get_markup_template('rmagic.tpl'),array(
			'$title' => t('Remote Authentication'),
			'$desc' => t('Enter your channel address (e.g. channel@example.com)'),
			'$submit' => t('Authenticate')
		));
		return $o;
	
	}
}