On 03/10/2010 07:44 PM, Caleb James DeLisle wrote:
  Take a look at the "sammy is my hero" worm,
myspace sent a hash to the user like the one you propose,
 the worm made the required get request to get the hash, then made the post along with the
hash.
 What prevents javascript from opening the page with the hash in an iframe and then
reading in the iframe
 to get the hash, then creating a form with the required data and posting it to the save
action?
 If we were to combine a requirement for post requests with checking of the referrer
header, then we
 would block links, forms and javascript based attacks leaving only an attack through
older versions
 of flash which support referrer forgery and at this point the difficulty of the attack
becomes such that
 we need to consider a wider array of attack vectors. 
Sammy also required that XSS is enabled.
Protecting from attacks originating in the wiki is kind of impossible at
the moment, since JS can be inserted anywhere, and there's no (nice) way
to prevent attacks from JS inside the application. As long as JS can be
inserted, an attacker can do all the steps that the client would do to
perform an action.
The secret token works as a prevention mechanism when the attack comes
from another site because the browser security model prevents the attack
code to read the form.
 Caleb
 Alex Busenius wrote:
  Unfortunately, using POST requests instead of GET
requests is not
 enough. It will not prevent attacks that use forms and/or JavaScript to
 generate POST requests.
 Alex
 On 03/09/2010 02:48 PM, Caleb James DeLisle wrote:
  I had thought about proposing this myself but
decided against it because it seems
 to me like a workaround for problems which can be solved in other ways.
 Suppose we were to add a check to the actions which alter data which made sure the
request method
 was 'post' and made it configurable in one of the configuration files? We would
have
 to look over the default skins for incorrect links and leave the configuration
 option off by default for backward compatibility at least until the next major version
 but we could provide wiki operators the ability to prevent CSRF.
 Caleb
 
 _______________________________________________
 devs mailing list
 devs(a)xwiki.org
 
http://lists.xwiki.org/mailman/listinfo/devs
 
 _______________________________________________
 devs mailing list
 devs(a)xwiki.org
 
http://lists.xwiki.org/mailman/listinfo/devs
 
--
Sergiu Dumitriu
http://purl.org/net/sergiu/