• koolala 8 hours ago

    Any web browser could do a p2p call with just a bookmarklet and a chat room / comment section for trading ICE information.

    • fidotron 7 hours ago

      Yes, I feel I am missing something here. Is this just a signalling server with optional SFU or is there more to it?

      • Sean-Der 4 hours ago

        I think people are excited because it’s easy to run yourself and well documented.

        I find the code base easy to understand since it’s built by one developer. It’s a consistent read and not sprawling/pointless duplication

      • remram 8 hours ago

        Isn't that true of anything a web browser can do?

        • Sean-Der 8 hours ago

          You should build that!

          • ranger_danger 5 hours ago

            They could but they're not, that's the difference.

            If you think that method can become popular, then by all means... be the change.

            • mettamage 7 hours ago

              Could you elaborate?

              • koolala 4 hours ago

                Want to p2p video call? Here run this script. We don't really use our Browsers like terminals to dynamically run user code.

                It would be like a different timeline where a programming console is not a 'dev' feature and anyone is equal at using code. If our computers become smart like AI then all friction for programming could be erased.

                It's hard to elaborate on a world where bookmarklets and user scripting becomes a normal thing where we freely tap into our browser's capabilities.

                • idiotsecant an hour ago

                  And uncle Jimbo accidentally uploads his password cache running a script that was supposed to show him his favorite celebrity naked.

                  The Internet is a common public square now. Unfortunately the public is, statistically, an idiot.

            • m463 an hour ago

              I think a lot of the nonsense on the internet happens because companies become a necessary intermediary for communication.

              I believe this would be solved except...

              "It is difficult to get a man to understand something, when his salary depends on his not understanding it."

              So companies NEED to be intermediaries "for security", "for discovery", because we need TURN, (...and for subscriptions, for ad serving, for revenue idea of the week, etc)

              If more folks were able to use peer to peer communications (think families, not phishing/trolling/etc) a lot of this nonsense would go away.

              • type0 39 minutes ago

                Sadly people are indoctrinated on how they should use computers/smartphones

                most users won't leave the mindset of "there's an app for that"

              • ranger_danger 8 hours ago

                I applaud the real support for TURN (and TCP ICE) and the emphasis on explaining the (IMO very common) issue properly unlike so many other WebRTC projects that think the majority of people will never need it.

                I know Firefox now supports outgoing TCP ICE, but what about incoming TCP connections? I wasn't able to find an answer easily from googling.

                • Sean-Der 8 hours ago

                  I don't think Chrome or FireFox support passive ICE-TCP Candidates.

                  The assumption is that two clients are in the same LAN they would use UDP anyway. If are in two differents NATs doing traversal with TCP isn't support. I have read that it is possible, not something I have tried myself though.

                  • toast0 2 hours ago

                    I've setup TCP and TCP+TLS for an SFU, and at least for my client base, it's barely used, but it is used. Almost everyone can do UDP.

                    For 1:1 calling, I suspect the number of peers that can do peer to peer TCP, but not UDP is so small that it's not worth bothering.

                    But that doesn't answer your question, sorry. I know the application I work on doesn't listen for incoming tcp on clients, but I think there is support for it in the WebRTC library. (Not sure if Firefox pulls that in, or wrote their own implementation?)

                    • ranger_danger an hour ago

                      Many public wifi spots like stores, hotels, airplanes etc. often block UDP (other than local DHCP).

                      • toast0 35 minutes ago

                        Yeah, so your SFU or your TURN server needs to support TCP.

                        But if you're on public wifi, chances are you can't get inbound tcp to work. And the majority of the peers you might connect to probably can't either. It's not worth the effort to eek a tiny % more peer to peer when you have to build the relay server fallback anyway.

                  • 1oooqooq 7 hours ago

                    every time i have to deal with ice and webrtc, i wonder if it is easier to ship a mirai style bot which would hack the modems from the lan side which is even easier than from the wan side, and and just add the portforwards.

                    • IgorPartola 3 hours ago

                      Ship one that uses Tunnel Broker to enable IPv6. Back when Teredo was a thing I wrote an article about how to turn a Raspberry Pi into an add on router for your IPv4 network. Essentially it would get a Toredo IPv6 prefix, then advertise the prefix to your LAN via radvd for stateless auto configuration. The effect would be that soon as you plugged one of these in it would instantly give every device on your LAN IPv6 connectivity without having to do a single thing besides finding a USB and CAT5e cable. Mostly was a proof of concept of course though I did run it like this for a bit. It worked quite well even if it didn’t give you your full bandwidth at all times.

                      • Sean-Der 7 hours ago

                        My dream would be if WebRTC Agents would experiment with Port Control Protocol.

                        I don't know if it is the answer, but a world without dependence on STUN servers sounds pretty amazing. I can see why it would feel like kludge, but how could would it be to remove that dependency.

                        My other wishlist item is to allow mDNS for signaling. Something like https://github.com/pion/offline-browser-communication. It is so silly that I need to exchange a Offer/Answer using a remote server to start a session with a IP Camera in my LAN.

                        • IgorPartola 3 hours ago

                          You know what’s easier than all this happy crappy? Goddamn IPv6. How many engineer-hours have been spent trying to work around NAT and IPv4 which could have been spent implementing IPv6? Every browser tab could have its own publicly routable address if we wanted to. And the more work arounds we create the less pressure there is to get over the hump and treat IPv4 as the weird legacy protocol instead of treating IPv6 as the weird new protocol.

                          I guess engineer activism is all there is really left to do. Enable dual stack, write your code to be IPv6-first (it can automatically do IPv4 connectivity if enabled so really you only need to support one stack and the OS will translate for you; this doesn’t mean you can avoid having IPv4 addresses if you want to have your service IPv4 accessible, just that your code can pretend like every address is an IPv6 address). Test your code without IPv4 connectivity. If you reference localhost, don’t use 127.0.0.1 preferring localhost instead. Don’t be the reason the next engineer has to say “well this codebase isn’t IPv6 compliant so we can’t enable it”.

                          • kelnos 10 minutes ago

                            My network's firewall doesn't let random incoming IPv6 connections come in, and I wouldn't change that even if I didn't need NAT for IPv4.

                            Is there a safe protocol to allow applications inside a network to automatically ask edge firewalls for temporary port forwards (or port unblockings, which would be all that would be needed with routable IPv6)? I still can't see how that could be made safe, though: how would the firewall know that the request was coming from a user on the network, and not malware (or a user being duped by malware)?

                            • EGreg 28 minutes ago

                              Get around hole punching NATs with this one weird trick “they” they don’t want you to know about?

                            • marcodiego 7 hours ago

                              You can user Tor and expose a service running on your lan to the whole world.

                              • noident 5 hours ago

                                I can count to 30 before the onion service running my personal wiki loads. Tor is awesome but onion services are really, really slow!

                              • SahAssar 3 hours ago

                                > My other wishlist item is to allow mDNS for signaling.

                                If you load a webpage with from a mDNS address of the camera what other steps are needed? Your browser and the camera should be able to exchange SDP and connect without any third party.

                            • Muromec 7 hours ago

                              Another reason to use ipv6 and just memorize your address to also not depend on dns