mangled urls on redirects
This commit is contained in:
@@ -14,15 +14,16 @@ class Magic extends \Zotlabs\Web\Controller {
|
|||||||
logger('mod_magic: args: ' . print_r($_REQUEST,true),LOGGER_DATA);
|
logger('mod_magic: args: ' . print_r($_REQUEST,true),LOGGER_DATA);
|
||||||
|
|
||||||
$addr = ((x($_REQUEST,'addr')) ? $_REQUEST['addr'] : '');
|
$addr = ((x($_REQUEST,'addr')) ? $_REQUEST['addr'] : '');
|
||||||
|
$bdest = ((x($_REQUEST,'bdest')) ? $_REQUEST['bdest'] : '');
|
||||||
$dest = ((x($_REQUEST,'dest')) ? $_REQUEST['dest'] : '');
|
$dest = ((x($_REQUEST,'dest')) ? $_REQUEST['dest'] : '');
|
||||||
$test = ((x($_REQUEST,'test')) ? intval($_REQUEST['test']) : 0);
|
$test = ((x($_REQUEST,'test')) ? intval($_REQUEST['test']) : 0);
|
||||||
$rev = ((x($_REQUEST,'rev')) ? intval($_REQUEST['rev']) : 0);
|
$rev = ((x($_REQUEST,'rev')) ? intval($_REQUEST['rev']) : 0);
|
||||||
$owa = ((x($_REQUEST,'owa')) ? intval($_REQUEST['owa']) : 0);
|
$owa = ((x($_REQUEST,'owa')) ? intval($_REQUEST['owa']) : 0);
|
||||||
$delegate = ((x($_REQUEST,'delegate')) ? $_REQUEST['delegate'] : '');
|
$delegate = ((x($_REQUEST,'delegate')) ? $_REQUEST['delegate'] : '');
|
||||||
|
|
||||||
// Apache(?) appears to perform an htmlentities() operation on this variable
|
|
||||||
|
|
||||||
$dest = html_entity_decode($dest);
|
if($bdest)
|
||||||
|
$dest = hex2bin($bdest);
|
||||||
|
|
||||||
$parsed = parse_url($dest);
|
$parsed = parse_url($dest);
|
||||||
if(! $parsed) {
|
if(! $parsed) {
|
||||||
|
@@ -156,7 +156,7 @@ class Manage extends \Zotlabs\Web\Controller {
|
|||||||
|
|
||||||
if($delegates) {
|
if($delegates) {
|
||||||
for($x = 0; $x < count($delegates); $x ++) {
|
for($x = 0; $x < count($delegates); $x ++) {
|
||||||
$delegates[$x]['link'] = 'magic?f=&dest=' . urlencode($delegates[$x]['xchan_url'])
|
$delegates[$x]['link'] = 'magic?f=&bdest=' . bin2hex($delegates[$x]['xchan_url'])
|
||||||
. '&delegate=' . urlencode($delegates[$x]['xchan_addr']);
|
. '&delegate=' . urlencode($delegates[$x]['xchan_addr']);
|
||||||
$delegates[$x]['channel_name'] = $delegates[$x]['xchan_name'];
|
$delegates[$x]['channel_name'] = $delegates[$x]['xchan_name'];
|
||||||
$delegates[$x]['delegate'] = 1;
|
$delegates[$x]['delegate'] = 1;
|
||||||
|
@@ -7,8 +7,8 @@ class Nojs extends \Zotlabs\Web\Controller {
|
|||||||
function init() {
|
function init() {
|
||||||
$n = ((argc() > 1) ? intval(argv(1)) : 1);
|
$n = ((argc() > 1) ? intval(argv(1)) : 1);
|
||||||
setcookie('jsdisabled', $n, 0, '/');
|
setcookie('jsdisabled', $n, 0, '/');
|
||||||
$p = $_GET['redir'];
|
$p = hex2bin($_GET['redir']);
|
||||||
$hasq = strpos($p,'?');
|
$hasq = strpbrk($p,'?&');
|
||||||
goaway(z_root() . (($p) ? '/' . $p : '') . (($hasq) ? '' : '?f=' ) . '&jsdisabled=' . $n);
|
goaway(z_root() . (($p) ? '/' . $p : '') . (($hasq) ? '' : '?f=' ) . '&jsdisabled=' . $n);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -17,8 +17,8 @@ class Rmagic extends \Zotlabs\Web\Controller {
|
|||||||
if($r) {
|
if($r) {
|
||||||
if($r[0]['hubloc_url'] === z_root())
|
if($r[0]['hubloc_url'] === z_root())
|
||||||
goaway(z_root() . '/login');
|
goaway(z_root() . '/login');
|
||||||
$dest = z_root() . '/' . str_replace(['rmagic','zid='],['','zid_='],\App::$query_string);
|
$dest = bin2hex(z_root() . '/' . str_replace(['rmagic','zid='],['','zid_='],\App::$query_string));
|
||||||
goaway($r[0]['hubloc_url'] . '/magic' . '?f=&owa=1&dest=' . $dest);
|
goaway($r[0]['hubloc_url'] . '/magic' . '?f=&owa=1&bdest=' . $dest);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -59,11 +59,11 @@ class Rmagic extends \Zotlabs\Web\Controller {
|
|||||||
|
|
||||||
if($url) {
|
if($url) {
|
||||||
if($_SESSION['return_url'])
|
if($_SESSION['return_url'])
|
||||||
$dest = urlencode(z_root() . '/' . str_replace('zid=','zid_=',$_SESSION['return_url']));
|
$dest = bin2hex(z_root() . '/' . str_replace('zid=','zid_=',$_SESSION['return_url']));
|
||||||
else
|
else
|
||||||
$dest = urlencode(z_root() . '/' . str_replace([ 'rmagic', 'zid=' ] ,[ '', 'zid_='],\App::$query_string));
|
$dest = bin2hex(z_root() . '/' . str_replace([ 'rmagic', 'zid=' ] ,[ '', 'zid_='],\App::$query_string));
|
||||||
|
|
||||||
goaway($url . '/magic' . '?f=&owa=1&dest=' . $dest);
|
goaway($url . '/magic' . '?f=&owa=1&bdest=' . $dest);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -18,7 +18,7 @@ class CheckJS {
|
|||||||
$this->jsdisabled = 0;
|
$this->jsdisabled = 0;
|
||||||
|
|
||||||
if(! $this->jsdisabled) {
|
if(! $this->jsdisabled) {
|
||||||
$page = urlencode(\App::$query_string);
|
$page = bin2hex(\App::$query_string);
|
||||||
|
|
||||||
if($test) {
|
if($test) {
|
||||||
$this->jsdisabled = 1;
|
$this->jsdisabled = 1;
|
||||||
|
@@ -1712,7 +1712,7 @@ function zid_init() {
|
|||||||
$query = str_replace(array('?zid=','&zid='),array('?rzid=','&rzid='),$query);
|
$query = str_replace(array('?zid=','&zid='),array('?rzid=','&rzid='),$query);
|
||||||
$dest = '/' . urlencode($query);
|
$dest = '/' . urlencode($query);
|
||||||
if($r && ($r[0]['hubloc_url'] != z_root()) && (! strstr($dest,'/magic')) && (! strstr($dest,'/rmagic'))) {
|
if($r && ($r[0]['hubloc_url'] != z_root()) && (! strstr($dest,'/magic')) && (! strstr($dest,'/rmagic'))) {
|
||||||
goaway($r[0]['hubloc_url'] . '/magic' . '?f=&rev=1&owa=1&dest=' . z_root() . $dest);
|
goaway($r[0]['hubloc_url'] . '/magic' . '?f=&rev=1&owa=1&bdest=' . bin2hex(z_root() . $dest));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
logger('No hubloc found.');
|
logger('No hubloc found.');
|
||||||
|
@@ -120,7 +120,7 @@ function vcard_from_xchan($xchan, $observer = null, $mode = '') {
|
|||||||
App::$profile_uid = $xchan['channel_id'];
|
App::$profile_uid = $xchan['channel_id'];
|
||||||
|
|
||||||
$url = (($observer)
|
$url = (($observer)
|
||||||
? z_root() . '/magic?f=&owa=1&dest=' . $xchan['xchan_url'] . '&addr=' . $xchan['xchan_addr']
|
? z_root() . '/magic?f=&owa=1&bdest=' . bin2hex($xchan['xchan_url']) . '&addr=' . $xchan['xchan_addr']
|
||||||
: $xchan['xchan_url']
|
: $xchan['xchan_url']
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@@ -1018,7 +1018,7 @@ function chanlink_cid($d) {
|
|||||||
|
|
||||||
function magiclink_url($observer,$myaddr,$url) {
|
function magiclink_url($observer,$myaddr,$url) {
|
||||||
return (($observer)
|
return (($observer)
|
||||||
? z_root() . '/magic?f=&owa=1&dest=' . $url . '&addr=' . $myaddr
|
? z_root() . '/magic?f=&owa=1&bdest=' . bin2hex($url) . '&addr=' . $myaddr
|
||||||
: $url
|
: $url
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -1454,7 +1454,7 @@ function theme_attachments(&$item) {
|
|||||||
if(is_foreigner($item['author_xchan']))
|
if(is_foreigner($item['author_xchan']))
|
||||||
$url = $r['href'];
|
$url = $r['href'];
|
||||||
else
|
else
|
||||||
$url = z_root() . '/magic?f=&owa=1&hash=' . $item['author_xchan'] . '&dest=' . $r['href'] . '/' . $r['revision'];
|
$url = z_root() . '/magic?f=&owa=1&hash=' . $item['author_xchan'] . '&bdest=' . bin2hex($r['href'] . '/' . $r['revision']);
|
||||||
|
|
||||||
//$s .= '<a href="' . $url . '" title="' . $title . '" class="attachlink" >' . $icon . '</a>';
|
//$s .= '<a href="' . $url . '" title="' . $title . '" class="attachlink" >' . $icon . '</a>';
|
||||||
$attaches[] = array('label' => $label, 'url' => $url, 'icon' => $icon, 'title' => $title);
|
$attaches[] = array('label' => $label, 'url' => $url, 'icon' => $icon, 'title' => $title);
|
||||||
|
Reference in New Issue
Block a user