- From: Seetharama Rao Durbha <S.Durbha@cablelabs.com>
- Date: Mon, 8 Oct 2012 15:32:24 -0600
- To: Vijay Bharadwaj <Vijay.Bharadwaj@microsoft.com>, "public-webcrypto@w3.org" <public-webcrypto@w3.org>
- CC: David Dahl <ddahl@mozilla.com>, Emily Stark <estark@mit.edu>, Wan-Teh Chang <wtc@google.com>, GALINDO Virginie <Virginie.GALINDO@gemalto.com>, "'Harry Halpin'" <hhalpin@w3.org>, Ryan Sleevi <sleevi@google.com>
- Message-ID: <CC989F1E.709F%s.durbha@cablelabs.com>
On 10/8/12 1:22 PM, "Vijay Bharadwaj" <Vijay.Bharadwaj@microsoft.com<mailto:Vijay.Bharadwaj@microsoft.com>> wrote: Ø Then, what threat model does crypto in JA make sense for at all? Obviously, when there's some lack of trust on the server *or* connection to the server that can be ameliorated by public key crypto. Harry asked the above on a different email thread. This is an important question. But first we should be precise about what we’re asking. WebCrypto is not (only) about “crypto in JS”. It is about giving JS access to the crypto capabilities of the underlying platform. This includes cases in which the actual crypto is done elsewhere such as in a smart card. So when does it make sense to give JS access to the platform’s crypto capabilities? In my mind, there are a few possible answers. It makes sense when one wants a trusted piece of JS in a trusted UA to interact with a less trusted data store. This is the Facebook use case. It is also David’s cloud storage use case if the script is retrieved from somewhere other than the server that keeps the data. It makes sense when one wants a trusted piece of JS in a trusted UA to be able to interoperate with a server using an existing protocol (e.g. sign requests to access-controlled REST APIs, JimD’s use cases on authenticating to government services). It makes sense when a server wants to deliver JS that uses a trusted piece of pre-provisioned crypto hardware to establish end-to-end trust independent of the UA (e.g. using a smart dongle for online banking, some of the Netflix use cases). There may be others, and I’d love to hear what others think. It’s important to note that the “trusted UA” assumption is not as outlandish as it might seem at first; as Ryan points out on other threads, we routinely make an assumption that the OS is trusted when talking about native apps. One does not argue that including crypto APIs in operating systems is futile just because malware and rootkits exist. Many methods exist to improve the trust in the UA, including the use of non-browser JS implementations. <snip> I am not sure I can agree with this. I think the whole confusion so far has been regarding our position on the trustability of UA and the JS it is running. I personally think that we should steer away from the responsibility of providing a trusted UA. What is a trusted UA, BTW? A server has no way to say that it is communicating with a trusted UA. There is also difference between a JS running within a browser on the far end of the world, and a native application a user is using. As I pointed out earlier – in the former case, the trust refers to the one between the server application and the client UA/JS. In the later case, the trust refers to one between the human user using the app and the app itself. Apples and oranges. We will have to convince others that this API is not about trust – as you said earlier, it is a gateway into the crypto functionality (provided by the platform) - stronger and uniform. Whether it be preexisting keys or newly created ones, there is an element of user education when it comes to implementations. For example, verifying URL of the web site before accepting a signing request. If the implementation is so bad to allow injection of malicious JS on their sites, too bad. </snip> One could also argue that various crypto primitives – notably hash and RNG – are only meaningful if one accepts this assumption. Since this question seems to keep coming up in feedback, maybe we should develop a position on it as a group. Does anyone else have any thoughts on the matter?
Received on Monday, 8 October 2012 21:33:07 UTC