Skip to content

Commit

Permalink
- added preferences for types of requests to use
Browse files Browse the repository at this point in the history
  • Loading branch information
koto committed Oct 18, 2011
1 parent c79027c commit 76aaf1f
Showing 1 changed file with 163 additions and 48 deletions.
211 changes: 163 additions & 48 deletions index.html
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@
padding: 0.5em;
}

#help-text,#loader-text,#history-text {
#help-text,#loader-text,#pref-text {
display: none;
}
</style>
Expand All @@ -46,13 +46,48 @@
<strong>Go!</strong>
</button>
<button id=help>?</button>
<button id=history>History</button>
<button id=pref>Preferences</button>
<br />
</div>
<script>
var flash_agree = null;
var flash_agree = null;
var interval; // page loading time

var Preferences = (function() {
var name = 'cors-browser.pref';
var defaults = {
'type' : [ 'cors', 'flash' ]
}
var current = {};

function save(preferences) {
localStorage.setItem(name, JSON.stringify(preferences));
}
;

function load() {
current = $.extend(
JSON.parse(localStorage.getItem(name)) || {}, defaults);
}
;

var inter = {
get : function(name) {
return current[name];
},
getAll : function() {
return current;
},
set : function(name, value) {
current[name] = value;
save(current);
}
}

load();
return inter;
})();

var History = (function() {
var name = 'cors-browser.history';

Expand All @@ -78,26 +113,29 @@
})();

function clicker() {
var url = $(this).attr('href') || $(this).attr('action') || starter.href;
console.log('url',url, 'base', starter.href);
var url = $(this).attr('href') || $(this).attr('action')
|| starter.href;
console.log('url', url, 'base', starter.href);
if (!url.match(/^https?:/)) {
if (url.indexOf('/') === 0) { // domain-absolute url
var base_domain = starter.href.match(/(https?:\/\/[^\/]+)/)[1];
url = base_domain + url;
} else { // relative url
url = starter.href.replace(/\?.*/,'').replace(/\/[^\/]*$/, '') + '/'
+ url;
url = starter.href.replace(/\?.*/, '').replace(/\/[^\/]*$/,
'')
+ '/' + url;
}
} else {
var domain_re = /:\/\/(.*?)(\/|$)/;
var url_domain = url.match(domain_re)[1];
if (starter.href && url_domain !== starter.href.match(domain_re)[1]) {
if (starter.href
&& url_domain !== starter.href.match(domain_re)[1]) {
alert('URL is from other domain: ' + url_domain
+ ', cannot load.');
return false;
}
}
console.log('final',url);
console.log('final', url);
disableTimer();
var method = $(this).attr('method') || "GET", fields = null;

Expand All @@ -111,20 +149,50 @@
History.add(url);
$("#site").val(url);
write($('#loader-text')[0].innerHTML.replace('$url', url));
sendRequest(new XMLHttpRequest(), url, method, fields);
return false;

var types = Preferences.get('type').slice();
console.log("Allowed methods: " + types);
sendRequest(types, url, method, fields);
return false;
}

function sendRequest(xhr, url, method, fields) {
xhr.open(method, url, true);
xhr._url = url;
xhr._method = method;
if (fields) {
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
}
xhr._fields = fields;
xhr.onreadystatechange = display;
xhr.send(fields);

function RequestProcessorFactory(type) {
console.log('Trying ' + type);
switch (type) {
case 'cors':
return new XMLHttpRequest();
case 'flash':
if (location.protocol == 'file:')
throw "Flash will only load from a http[s], not from file://";
if (typeof CrossXHR === 'undefined')
throw "Flash is not loaded!";

return new CrossXHR();
}
throw 'Unsupported request processor type: ' + type;
}

function sendRequest(types, url, method, fields) {
try {
var xhr = RequestProcessorFactory(types.shift()); // get first available type
xhr.open(method, url, true);
xhr._url = url;
xhr._method = method;
xhr._types_left = types;
if (fields) {
xhr.setRequestHeader('Content-Type',
'application/x-www-form-urlencoded');
}
xhr._fields = fields;
xhr.onreadystatechange = processResponse;
xhr.send(fields);
} catch (e) {
alert(e);
}
}

function fallback(xhr) {
sendRequest(xhr._types_left, xhr._url, xhr._method, xhr._fields);
}

function write(text) {
Expand All @@ -146,13 +214,8 @@
interval = null;
}
}

function fallbackToFlash(xhr) {
var xhr2 = new CrossXHR();
sendRequest(xhr2, xhr._url, xhr._method, xhr._fields);
}

function display(event) {
function processResponse(event) {
var xhr = this;

try {
Expand All @@ -166,17 +229,14 @@
post(f.contentDocument)
}, 1000);
} else {
alert("Cannot load ("
+ xhr.statusText
+ ").\nBrowser supports websites that allow CORS requests (Access-Control-Allow-Origin: *)");
if (typeof CrossXHR !== "undefined" && !(xhr instanceof CrossXHR)) {
if (flash_agree === null ) { // no user decision made yet
flash_agree = confirm("I can fallback to method using Adobe Flash file (crossxhr.swf).\nDo you want to enable Flash fallback for this and future requests?");
}

if (flash_agree) { // user is ok with flash fallback
fallbackToFlash(xhr);
}
if (xhr._types_left.length == 0) {
alert("Could not load "
+ xhr._url
+ (xhr.statusText ? " (" + xhr.statusText
+ ")" : "") + "\nUsed methods: "
+ JSON.stringify(Preferences.get('type')));
} else {
return fallback(xhr);
}
}
}
Expand Down Expand Up @@ -231,10 +291,10 @@
write($("#help-text")[0].innerHTML);
});

$("#history").click(
$("#pref").click(
function() {
var h = History.get();
write($("#history-text")[0].innerHTML);
write($("#pref-text")[0].innerHTML);

setTimeout(function() {
var doc = $('#hello')[0].contentDocument;
Expand All @@ -248,11 +308,36 @@
.text(h[i].url)).end()
.show();
}
post(doc); // to activate links

$("#clear-history", doc.body).click(function() {
History.clear();
$('#history').click();
$('#pref').click();
});
post(doc); // to activate links

$("#pref-form", doc.body).unbind('submit').submit(
function() {
// update preferences from field values
var values = $(this).serializeArray();
for ( var i = 0; i < values.length; i++) {
Preferences.set(values[i].name, JSON
.parse(values[i].value));
}
;
$("#pref").click();
return false;
});

// fill form values from preferences
var pref = Preferences.getAll();
for ( var i in pref) {
if (pref.hasOwnProperty(i)) {
$("#pref-form", doc.body).find(
':input[name="' + i + '"]').val(
JSON.stringify(pref[i]));
}
}

}, 100);
});

Expand All @@ -270,6 +355,9 @@ <h2>Description</h2>
<strong>CORS proxy browser</strong> is a proof of concept of how
client-side web proxying can be done using <a target="_blank"
href="http://www.w3.org/TR/cors/">Cross Origin Resource Sharing</a>.



<p>
It allows you to fetch content of websites using
<code>Access-Control-Allow-Origin: *</code>
Expand Down Expand Up @@ -309,7 +397,8 @@ <h2>FAQ</h2>
communication originates from victim's browser, his IP address,
bandwidth etc. There is no server-side code, just a simple HTML
page. <strong>You can even download the file and use it
locally from <code>file://</code> protocol</strong> (Flash fallback won't work from file://).
locally from <code>file://</code> protocol</strong> (Flash fallback won't
work from file://).
</dd>
<dt>
What about Flash
Expand All @@ -321,7 +410,11 @@ <h2>FAQ</h2>
tiny Flash file for sites using <a target="_blank"
href="https://www.owasp.org/index.php/Reviewing_Flash_Applications">permissive</a>
<code>crossdomain.xml</code>
. But now, with CORS, it's possible without any addons, HTML5-style. I've added an optional Flash-based fallback though, because more websites now use permissive <code>crossdomain.xml</code> than CORS headers.
. But now, with CORS, it's possible without any addons, HTML5-style.
I've added an optional Flash-based fallback though, because more
websites now use permissive
<code>crossdomain.xml</code>
than CORS headers.
</dd>
<dt>How does it work?</dt>
<dd>
Expand All @@ -330,7 +423,8 @@ <h2>FAQ</h2>
<li>I ask browser to use <code>XMLHttpRequest</code> to fetch
that remote URL
<li>If we're lucky and website uses <code>Access-Control-Allow-Origin:
*</code>, I get that content. If there's an error and you agree, I try with Flash-based fallback.
*</code>, I get that content. If there's an error and you agree, I try
with Flash-based fallback.
<li>I modify the content adding marquee, base href and a
making an easy attempt to remove ads
<li>I create an iframe and display the content
Expand Down Expand Up @@ -372,7 +466,28 @@ <h2>FAQ</h2>
src="" />
</p>
</div>
<div id="history-text">
<div id="pref-text">
<h1>Preferences</h1>
<form id="pref-form">
<p>Which technology to use for cross domain communication?</p>
<ul>
<li><strong>CORS</strong> requires permissive
Access-Control-Allow-Origin headers on target domain, can be used
form file:// protocol and will not attach &amp; set cookies.</li>
<li><strong>Flash</strong> requires permissive crossdomain.xml
file, requires a server but will attach &amp; set cookies.</li>

</ul>
<select name="type">
<option value='["cors","flash"]'>Cross Origin Resource
Sharing, then Flash</option>
<option value='["flash","cors"]'>Flash, then Cross Origin
Resource Sharing</option>
<option value='["cors"]'>only Cross Origin Resource Sharing</option>
<option value='["flash"]'>only Flash</option>
</select>
<button type="submit">Save</button>
</form>
<h1>History</h1>
<table>
<thead>
Expand All @@ -388,6 +503,6 @@ <h1>History</h1>
</tr>
</tbody>
</table>
<button id="clear-history">Clear</button>
<button id="clear-history">Clear history</button>
</div>
</body>

0 comments on commit 76aaf1f

Please sign in to comment.