-
Notifications
You must be signed in to change notification settings - Fork 586
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
Could a list of 2 way audio supported cameras be created? Aka, a list of known-working cameras with go2rtc 2 way audio #1493
Comments
Great ideia |
Nothing good can come of this. Even cameras that work well can fail due to firmware issues. Examples a known for Reolink, TPLink Tapo, Dahua, DVRIP, etc. |
Well that seems extremely harsh. Of course good things can come from this. People can have a basic idea of which cameras should and shouldn't have support. I don't have to purchase a camera to see if two way audio works, I can check with the community first in an efficient manner. I don't have to try to search for issues related to my camera and only get mixed/inaccurate/not helpful results - eg my Hik having weird issues, I can just look in the list and see what's there as a starting point. Instead of creating potentially duplicate issues, I can easily see what information is available on the list as a starting point, before other action.
Isn't that more of a reason to have the list than to not have it? There are examples known for Tapo devices not functioning on certain firmwares, so the Wiki entry should contain entries for which firmwares work and which don't. That gives the user a better understanding of what to expect before they run into problems/buy the camera, not afterwards. I checked the issues here before I purchased a Tapo, but because I didn't find a single very specific issue, I didn't see that Tapos had a firmware issue in the latest versions which didn't allow them to function properly with go2rtc in even a basic capacity, much less with 2 way audio support. Therefore, I ended up creating an issue which didn't resolve the problem, and had to return the camera. A big waste of time for everyone involved, including you. This could've been avoided with a basic list of known devices, and those device limitations. It should result in less issues being created for go2rtc for compatibility related discussions, but even to your point, in no way does the list imply 100% guaranteed compatibility. No one expects professional guarantees of device support from a FOSS project, and those extremely few who do will expect it regardless of a list like this being present. Example: I can avoid Tapo products due to their firmware issues and lack of proper open standards before I purchase one. I can avoid Reolink models that only support proprietary 2 way audio. I can see that X model supports ONVIF 2 way audio with firmware update Y. I can confirm whether this Dahua camera supports ONVIF 2 way audio before I purchase it. I can see about this Hikvision issue and the proper config steps necessary to get it working before I purchase it. That results in less headache for literally everyone involved, including those who provide support for issues here. I don't see any drawbacks to this idea. All you really have to do is link to a community maintained list of cameras and promote the idea, and allow others to fill in the rest. The exact implementation of the list doesn't really matter so long as the community can contribute to it with some method. What's your argument against it? |
I don't mind if someone wants to make such a list and maintain it. I don't want a person to spend their money and come to me asking why it doesn't work. Maybe a list that has camera model, hardware revision, firmware version makes sense. For cameras like roborock the date of operation and go2rtc version makes sense. Because the manufacturer can change the logic on the server. |
I'd be happy to maintain a list for this purpose, but on the condition that it is, "officially unoffically" supported. What I mean by that term is that I'd like some way for people to actually know it exists. In the main go2rtc readme page, it'd be nice to have a link to it with a brief description, etc. Something that people could find with various ctrl+f's for The purpose of this would be twofold:
Would you be fine with pointing people towards it when appropriate? Eg - A paragraph/section(ish) in the readme (explaining that it is not officially maintained by go2rtc and there are no guarantees made by go2rtc, but is instead community supported, the purpose of it as a general guidance and not a hard and fast truth, and a link to a page on how to contribute perhaps), and perhaps pointing people to the list when you see a new brand and/or model walk through the issues page (or tagging me to the thread). I'm not trying to make this into a bigger deal than it should be, but I would just like a bit of confidence that if I go down this path that it's not in vain (for the previous two listed reasons). If that's fine by you, do you have any thoughts on the best way to keep up with this data? I could see several arguments for different implementation options, but the idea that stands out the most to me is as follows: I create a separate github repo for the task. It'd basically just be a readme/wiki page, but the issues/discussion tools would allow others to contribute their changes in an organized fashion. This would have the benefit of 100% account compatibility with all who make issues on this go2rtc repo for go2rtc requests/problems/etc. There'd be no need to create an example on fandom.com for example with a traditional wiki style website. I could also tie it loosely into Frigate as well for similar reasoning, especially given the go2rtc tie in (though I recognize they are separate projects - I will consult with them as well of course, maybe even separating the two entirely somehow). I can get a basic "site" layout with my own entries added before you make any readme changes here, of course. My thoughts on what the list looks like exactly might change a bit, but on the top of my head it could look something like this template: Template Example (click me)brandcategorymodel:short_description_and_overview
Example_config:
Description_of_config Alternate_config:
Description_of_alternate_config API_endpoints:
Additional information: And here's an example with a real camera (subject to change): Reolink Example (click me)Reolink:Wireless Cameras:Reolink Video Doorbell WiFiA doorbell camera from Reolink. Comes in Wi-Fi and PoE versions, with identical functionality otherwise. A popular self-hosted offline only option, with no major quirks other than Reolink's RTSP stream as noted below. Can be setup via Ethernet interface and 12V power jack (even on Wi-Fi version).
Camera Stream Endpoints/URLs:
Example config:
This config is known to work with go2rtc and Frigate for two way audio on this device. It primarily utilizes the RTMP/FLV stream for basic streaming, but allows for using the RTSP stream when two way audio is needed thanks to go2rtc. I'd also include a general page (main readme probably) with some expectations on my end of things. I'd heavily stress and emphasize that go2rtc doesn't maintain the list, and that go2rtc isn't to blame for firmware changes breaking things (eg Tapo, at least in the past - I'm not sure of their current status). I'd stress that users should check with known firmware versions, and have an issue page for each camera so people can chime in with changes, updates, additional information, etc. I could slightly pivot the list to be almost more of a general IP Camera help page than something that is 100% only for go2rtc. I'd still primarily target go2rtc, since my stack is Frigate, but it'd be positioned in such a way so that it'd help people regardless of what NVR or NVR-helping software they use. So, all cameras would include a go2rtc config, but the information included with it wouldn't only help go2rtc users. That might help to alleviate your concerns slightly. What are your thoughts? I understand your hesitation with a list which can come across as providing, "official support" and I'd like to help address that as best possible while still "advertising" (for lack of a better word - obviously I have no financial interest in this) the list. Do you think the last change I mentioned would help in this issue? |
Excellent idea @distinctjuggle and @rowskilled14 , i was about to suggest/request the same thing! (but first i need to have atleast my own first two way camera working). Trust me, you may do it or not, but i definitely WILL make such a list, i purchased a domain just to use as blog for my home lab lessons, because i have started as non IT side noob and set my home lab, so i just want to document atleast my own experiences, A CCTV camera setup is integral part of every home network these days, and if there is a place (apart from reddit etc), where people can even share their working experiences, it can even be like a Testimonial for Alex great work! (And yes, i totally understand his concerns, i would be hesitant too if i were him, as there could be possible needless legal and moral issues if he starts, that is the last thing a busy software engineer needs, BUT, if some other people start, and it is a community contribution, sharing of working experiences, there is no Corporate or Political entity that can stop it. As i see it, The starting intention is definitely good, the plan seems reasonable and feasible, (it is almost like Proton or WINE edition for Go2RTC for IP Cameras for now), So yes, atleast i am all for it, and i will keep checking this post, All the best! |
A separate repository seems reasonable. I don't mind mentioning references to it in readme or issues. |
Sounds good! I'll get started on a setup in the next few days and will update you when I have something. |
Good idea, but the list should include also additional information regarding runtime enviroment and, very important: firmware information. E.g. I had the 2-way communication running more or less w/o any problems (just some delay issues..) with a Reolink Camera (E1 Outdoor pro), Frigate as Docker on LXC@Proxmox PVE, UI by Homeassistant Lovelace Card. In December I was a little busy with the HASS update 24.12 which caused many problems regarding WebRTC, Frigate Lovelace card.. and so on. In the meanwhilse everything was stable again but suddenly 2-way audio caused the complete LXC (not just the frigate conainer) going to 100% CPU and memory load and finally crashing, as soon as the microphone was enabled.... Root cause analysis costed me hours (container crahed w/o useful logs), even to figure out that the microphone is the problem (as it was enabled automatically in the background just via https access....) and finally I remembered that there was a Reolink firmware update in December too (available via Reolink HASS integration, not via Reolink firmware page (maybe another region server). Today I decided to downgrade the camera to the last official firmware 24/07 from the Reolink server) and...: Everything works perfectly again. I want to share my experience, but what I want to say is, that I spent in total days with this (f***) 2-way communication issue (from initial setup until it worked and additionally with the issue above) and just a small firmware update or using the wrong firmware can ruine everything respectively can avoid success even during first setup. However, thanks to @rowskilled14 for the plan to create such a data base. BR |
I agree. I've already planned on including firmware version information and setup information, but you've made me realize that I should be more specific in requesting exact Frigate/NVR environment details rather than just requesting basic high level information. The past month has been busier than expected even considering the time of year, but I've got a very rough template created. I was hoping to make a few additional template enhancements before moving forward, but I should be close! |
I think personal user issues about WebRTC hot related to this list. This issues will have same effect on any camera. But camera firmware and hardware versions may be really useful. |
I have to correct my original comment... It seems I was too enthusiastic, the problem I have seems to be more complex, not just the firmware. The key message, that the runtime enviroment, including firmware plays a key role is correct, but in my case there is something else wrong, not only the firmware and I have to give up at the moment. I had Frigate 0.12.X or 0.13.X with custom go2rtc 1.8.5 stable in my lxc container, including 2-way audio with my Reolink E1 Outdoor Pro but it looks like I lost this feature during some updates of Frigate with go2rtc. Not just 2-way audio, the whole system is not stable any more. As soon as I upgrade go2rtc (even embedded in Frigate 0.14.1 or 0.15 beta 4 or with customized go2rtc v1.9.8) and I simply access the stream via frigate or go2rtc links my lxc container still crashes frequently (first cpu load 100%, then memory 100%). The last entries I can see in the go2rtc logs is that the fps rate exceeds some limit (ffmpeg). Maybe @AlexxIT is right and a simple firmware note is enough, all other environmental parameters are too complex/ maybe too much for the list. BR Max
|
To clarify yeah I don't intend to document every issue that any user has ever encountered regardless of cause, but rather to gather issues which are indeed hardware or firmware specific and document them as such. I've made some more progress with the issue templating and I have a basic Github Actions workflow in place. The Github Actions workflow is intended to make adding entries manually to the wiki very easy after users fill out the given template. This was a design choice to try to cut back on entries which don't follow existing formatting practices, similar to traditional issues/PRs for git style systems. The idea was for curation of entries in a very easy and nearly hands free approach rather than having a fully open wiki which is prone to style differences between contributors. I may revisit options here in the future, but I think it'd be a great starting point. I am also working on a generic, "Intro to IP cameras" type of guide to throw into the Wiki since it seems extremely relevant and potentially helpful. I still have a fair bit I want to do with that, however. Long term I'd like it to be fairly all inclusive, with better sources. As of now, it's mostly just me going from memory and experience, and in a perfect world it should read a bit more objective than the current WIP. Once I get this, "Intro to IP cameras" guide/wiki filled in a bit more, there's only a template or two more that I need to fill out before I'm ready to move forward on my end of things. Feedback and thoughts are of course welcome. |
Title, basically. It's not always easy to tell if cameras support ONVIF Profile T compliant 2 way audio or not, and I think there'd be a lot of merit to having a list of community maintained, known working cameras in the Wiki here, or something similar.
For example, Reolink has ONVIF compliant 2 way audio for their CX-410/810, and for their Doorbell cameras. However, they have other products which support only proprietary 2 way audio methods. Hikvision doesn't support ONVIF compliant 2 way audio, but does have go2rtc supported 2 way audio functionality via ISAPI go2rtc integration.
It would be really nice if there was a list of cameras where feedback could be entered for 2 way audio functionality, as well as other go2rtc related config and functionality. I've got some Hikvision cameras which require a bit of a special config to function, and that could also make it to the wiki.
The text was updated successfully, but these errors were encountered: