-
Notifications
You must be signed in to change notification settings - Fork 51
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Pure Rust DTLS aka supplementing openssl #326
Comments
Why is openssl support a problem? It's performant and some organizations are not allowed to use other crypto libraries. Even Webrtc-rs has added dependency on it now: webrtc-rs/webrtc#477 I can understand why one would want a feature to build without it, but removing support seems counterproductive.... |
I don't see a reason to remove it, it will be there with a feature flag, but i'd like the default to be a rust native crypto. I'm a bit hesitant about the webrtc-rs DTLS since, afaik, it's only used by webrtc-rs. I think it's bespoke and it's unclear how many crypto experts have read the code. This is why my preferred path is for someone to engage with the rustls project and do DTLS there. |
That makes sense, thank you for clarifying. I'll reword the title and description! :) |
I agree with this concern, but it is worth noting that the webrtc-rs implementation is a port of pion/dtls so not entirely bespoke. |
Some associated discussion in #413 |
I did some further investigation. openssl does not support the latest DTLS 1.3 standard yet (openssl/openssl#13900). libWebRTC uses boringssl which is a fork of openssl. I think that means most WebRTC traffic uses DTLS 1.2 (though firefox might support 1.3) That means a pure DTLS 1.3 implementation wouldn't be of much use to str0m – any attempt to build this with rustls or otherwise must do 1.2 compatibility. |
@thomaseizinger maybe good to summarize what you found regarding full non-openssl feature during your ice-agent work here. |
I am not sure I understand. The only reason I made |
RIght that was what I was looking for. So potentially a rust only implementation could skip the older aes_128_cm_sha1_80 and only implement GCM. |
Logic needs to be tweaked a little for this, currently we assume the supported SRTP profiles are common across all crypto implementations |
Yeah that is why I argued for not creating too many abstractions regarding the crypto implementations for now. The real requirements will show once another one is integrated :) |
And now that Substrate pulled litep2p that pulled str0m I'm also looking forward to get rid of OpenSSL. Looking forward to ability to disable OpenSSL in str0m, even if second option is not yet audited or as performant as OpenSSL. |
Sadly Rustls has taken an awkward direction for us here. They are now primarily relying on aws-lc for crypto instead of ring (which is an optional dep). My vision for str0m would be to have a rust native solution and aws-lc is not that. I have made one attempt at writing DTLS myself, but didn't make it very far and of course, rolling our own is only slightly better than using webrtc-rs variant. |
My understanding is that |
Yeah, I know. My comment is more about being uncertain whether the rustls project is going in a direction is compatible with str0m. The ambitions might be mismatched. |
@xnorpx why is openssl a problem? It's native code that isn't rust and thus on a variety of systems it requires more work to make it compile than
I can't see rustls not having a pure rust option in the future. That would be a very retrograde step and would do damage to the wider ecosystem as many tools would only work if you happened to have various native bits properly configured. |
@gilescope Rustls and aws-lc is in some respects neither here nor there because that project doesn't have a DTLS implementation either. The requirements are:
Any solution in that direction is interesting to explore. |
From a build perspective OpenSSL is a pain no disagreement there. I fully support having a feature once someone is motivated enough to implement their own DTLS implementation and get it integrated. This is probably what is closest to @algesten requirement so far but looks WIP atm. https://github.com/webrtc-rs/rtc/tree/master/rtc-dtls Maybe @gilescope Polkadot has people/resources to spare to help finalize that work and integrate it? Some relevant links: |
I think we'd need both an implementation(the webrtc-rs one could be a starting point) and then, ideally, a security audit of the resulting code. This requires both a contribution in terms of work and in terms of finances. webrtc-rs has quite a bit of cash on hand. Maybe an option is to refactor their implementation to be sans-io and ask if they would be open to funding a security audit. |
Might be worth pointing out in this thread for Windows str0m builds you can now use "wincrypto" featureflag and you don't have to deal with installing/compile OpenSSL/Perl on Windows. |
I wanted to open this issue as a central place for discussing the removal/supplementing of the openssl dependency. As far as I understand, this is desired, see #107 (comment) for example.
It seems that
webrtc-rs
has a pure-Rust DTLS implementation at https://github.com/webrtc-rs/webrtc/tree/master/dtls but it seems to not be audited.The text was updated successfully, but these errors were encountered: