Hello,
I've attached a diagram of the setup I'm trying to achieve. Hopefully its clearer than trying to explain it with text...
Basically I'm trying to stream the camera to a selfhosted webpage.
The camera is connected to the VPN server
The stream is picked up on the Media Server (MediaMTX)
The stream is available from anywhere on the local network via whatever protocol MediaMTX offers. All good here.
The webserver set up is Nginx. Works fine.
A basic Wordpress site is set up and I can access it via a domain name over the internet with HTTPS.
What I'm struggling with is getting the "local stream" (read local IP) in to the website. I have WP plugins that let me embed streams, but I suspect the issue is the local IP is not available over the internet so you cant just point it to 192.X.X.X. Saying that though, even on my local network I cant see the stream.
So the questions are,
- how can I serve the stream to nginx/ wordpress and
- can I somehow have nginx treat the stream as a locally hosted resource that can proxy the stream to remote web browsers?
Ideally I dont want to open up a port on the LAN for a direct streaming to the internet which the website then points to as it seems a unsafe... But if that's the only way then I guess it can''t be helped.
Happy to provide more info if needed.
TIA
Edit: Wordpress is for a separate website project outside of the scope of this post. Only 1 page will be for the video player/ stream but there will be other uses for the website. Not just streaming
Edit 2: Seems the general consensus is that I do need to publicise my video stream.
I've just made my website accessible through its local IP and gotten embedded HLS and WebRTC streams working. Putting the domain back no longer plays the videos so its certainly a networking access issue or even a https issue as the streams are currently http.
I didn't realise you could reverse proxy a video stream! (Even though i did once upon a time use the nginx rtmp server).
I've also been made aware of tailscale + funnel which does a similar thing without exposing my own domain.
I'll have a go at reverse proxying it, which should also sort out the https issue and hopefully be done 🤞
You guys rock!
Good suggestions in the chat. Ill throw in my setup for your consideration.
I have several cameras, specifically with Ingenic SOCs on which ive flashed Thingino firmware (foss) so thats a bit of security on the camera side. Some others like hikvision ive picked up but not gotten around to setting up yet. But itll be plug and play as youll see next.
Next i have a router flashed with freshtomato but openwrt is also an option. On that ive set up a vlan for the cameras that do not have internet or inter vlan access. So even if i didnt have custom camera firmware, they still wouldnt be able to send it anywhere.
Next my home vlan has one way access in to the "camera vlan" so i can view from my network.
Finally wireguard server (on the home vlan so it has internet access) so i can monitor remotely
I just pull the rtsp streams. Havent gotten round to feed analysis yet but i used to use zoneminder. But i hear frigate and another software (cant remember off my head) supports for coral tpu quite well even after it has been dropped from support