[tahoe-dev] web "control panel"
Brian Warner
warner at lothar.com
Tue Jan 25 13:25:10 UTC 2011
>> Also, how does the "standard solution" deal with GETs?
>
> You can put the secret parameter in the URL query string, thus
> defeating the porpoise.
>
> More to the point, GETs are supposed to be idempotent and safe. Updating
> your server's configuration does not fall into that category. Use only POSTs
> for changes in state, just like the HTTP spec says.
But "safe" != "public". Part of the control panel may
(side-effect-freely) show information that's supposed to be private to
the node operator, like comments they've entered about other servers, or
their remaining $ balance with a commercial server operator. It sounds
like the usual framework's reliance upon ambient cookies leaves this
uncovered, or assumes that Same-Origin-Policy protects them because the
usual ways to avoid it don't make it easy to get data back out. Hrm.
> Hilariously, the Ruby community found this out the hard way when Google Web
> Accelerator (a cacheing proxy just like any other) prefetched links in Rails
> apps like Delete Item and Buy Now and Blow Up Everything. (Note that
> browsers also prefetch now, too.)
Yeah, I had a similar lesson ten years ago when I stupidly used GET
links to delete records in a Petmail server that I put online. The
Google spider deleted every address record ever published there, one at
a time. Awesome.
> If you crave the visual style of text links, you can always give them
> JavaScript event handlers:
>
> <a onclick="deleteAccount()">Delete Account</a>
Hrm, so mandatory JS. I'll think about it.
thanks!
-Brian
More information about the tahoe-dev
mailing list