Skip to content
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

Live stream video not working #9

Open
w1ll1am23 opened this issue Jan 31, 2019 · 71 comments
Open

Live stream video not working #9

w1ll1am23 opened this issue Jan 31, 2019 · 71 comments

Comments

@w1ll1am23
Copy link

After looking at the most up-to-date doc on the API https://global.download.synology.com/download/Document/DeveloperGuide/Surveillance_Station_Web_API_v2.8.pdf

I think the Video and Audio stream that was being used was removed? Maybe it was replaced with something else, but I am not familiar with their API.

This is was is called out in the linked doc

Remove following methods
• SYNO.SurveillanceStation.AudioStream
◦ Stream
◦ Query
◦ Open
◦ Close
• SYNO.SurveillanceStation.VideoStream
◦ Stream
◦ Query
• SYNO.SurveillanceStation.Device
◦ ListVS
◦ ListCMS
◦ GetServiceSetting
• SYNO.SurveillanceStation.Streaming
◦ LiveStream
◦ EventStream
`
@pergolafabio
Copy link

i created a thread on synology forum, verry interesting reply today
seems they indeed removed the documentation, but the API should still work...

they have a new stream path now, so the HA code should be changed, but who can do that??
synology forum :

https://community.synology.com/forum/3/post/123094?reply=397361

reply :

@pergola_fabio0183 These APIs are still alive there in SS8.2.3. They are just removed from the document and are not recommended to use due to many aspects including efficiency consideration. And since they are still work, we didn't mention them in the release note. However, you can still use them for 3rd-party integration, but we will not maintain them since they are only used by really older version of DS cam.

If you get any problem using these APIs, you can check the usage flow or check the error code for more specific reason.

The recommended alternative for live view is first using GetLiveViewPath method, and then play the returned rtsp/http path. (You can use 3rd-party player, such as VLC, to test the path)

@snjoetw
Copy link
Owner

snjoetw commented Feb 20, 2019

Based on the discussion it sounds like the streaming should still work in 8.2.3? Is it not working for you?

I'm doing upgrade now, let's see if mine works or not

@snjoetw
Copy link
Owner

snjoetw commented Feb 20, 2019

Ok ya it's broken with 8.2.3 :(
I'll see if I can fix this but probably over the weekend

@pergolafabio
Copy link

pergolafabio commented Feb 20, 2019

Yes , on forum they say nothing changed, just removed the documentation... But it doesn't work I deed... But I think an Synology employee did that reply... It's safe anyway to use the new api

@pergolafabio
Copy link

Ok, Synology replied again, they changed from did to cookie...

https://community.synology.com/forum/3/post/123094?reply=397574

@arsaboo
Copy link

arsaboo commented Feb 21, 2019

I tried the sid method listed on the Synology forums and was able to obtain the URLs, but none of those worked in VLC for me (maybe it is something simple that I am missing).

@pergolafabio
Copy link

sid is not possible anymore with 8.2.3 it seems, you need cookies now
but according to the synology person , who also replied on synology forum, we need to step away from videostream, and use the new method instead, thats also documented in the api

@arsaboo
Copy link

arsaboo commented Feb 21, 2019

Ok...hopefully, we can figure that out and start using it.

@pergolafabio
Copy link

@alekslyse , maybe we can discuss it here

to summarize, videostream was indeed removed from API, i also created a thread on synology forum, see link above
eventually, someone from synology was also replying, he told the community, that the documentation was just removed from API, to force users to use new the API
it should still work in 8.2.3 , he told us, but seems it was a bug after all, and should be fixed in 8.2.4
but then again, he also told us, that videostream will eventually go away

another approach is indeed rtsp, but according to @balloob
its not ready yet , still in prototype :

home-assistant/core#20595 (comment)

@alekslyse
Copy link
Contributor

Well as you did read on the thread what we CAN do while waiting is run a snapshot ever second to make a "fake" stream.

I tested with extracting the URL as the API uses and yeah its not working so nothing we can do if its a synology bug unless we rewrite the synology component (or add another one) to use ffmpeg. Since they use different inheritance components im not sure if the best thing would be to decide to throw the original implementation and go all in on ffmpeg, make an option to choose what method to use or create a seperate platform for each.

Things also depends a lot of what get approved by HA, and if the developer of the synology component is actually working on it, then it would be no point for me to start doing this.

Unless someone can show the correct API url for getting the old stream somehow I see no other option than what I mentioned above.

I dont maintain this repo nor the synology component so I have no idea what the developers are planning for the future

@pergolafabio
Copy link

ok , clear, but maybe to fix this "issue" its best to use the GetLiveViewPath method ?
i think thats for now to best to fix this platform, then HA als works like before, and this issue can be closed anway
dont you think , @snjoetw ?

@alekslyse
Copy link
Contributor

alekslyse commented Mar 7, 2019

I see another component solved it lie this

`
async def handle_async_mjpeg_stream(self, request):
"""Return an MJPEG stream."""
# The snapshot implementation is handled by the parent class
if self._stream_source == STREAM_SOURCE_LIST['snapshot']:
return await super().handle_async_mjpeg_stream(request)

    if self._stream_source == STREAM_SOURCE_LIST['mjpeg']:
        # stream an MJPEG image stream directly from the camera
        websession = async_get_clientsession(self.hass)
        streaming_url = self._camera.mjpeg_url(typeno=self._resolution)
        stream_coro = websession.get(
            streaming_url, auth=self._token, timeout=TIMEOUT)

        return await async_aiohttp_proxy_web(
            self.hass, request, stream_coro)

    # streaming via ffmpeg
    from haffmpeg import CameraMjpeg

    streaming_url = self._camera.rtsp_url(typeno=self._resolution)
    stream = CameraMjpeg(self._ffmpeg.binary, loop=self.hass.loop)
    await stream.open_camera(
        streaming_url, extra_cmd=self._ffmpeg_arguments)

    try:
        return await async_aiohttp_proxy_stream(
            self.hass, request, stream,
            'multipart/x-mixed-replace;boundary=ffserver')
    finally:
        await stream.close()

`

I cant not update the synology component with this before the someone fast make a new api point here to get the rtsp-over-http and rtsp enpoints

@pergolafabio
Copy link

Stream directly from camera? Not all cameras can do that, I have some cheap foscams too, they don't have mpjeg stream...

@alekslyse
Copy link
Contributor

Stream directly from camera? Not all cameras can do that, I have some cheap foscams too, they don't have mpjeg stream...

Well we are talking about streaming from synology here so the camera is less important?

@pergolafabio
Copy link

Ahh ok, my bad... Well, I am not that technical ;)
Sorry

@alekslyse
Copy link
Contributor

Ok I will take a look this weekend, but we need to fix the api endpoints here first or it won’t be accepted in home assistant

@alekslyse
Copy link
Contributor

Have sent in a pull request to use the stream synology wants us to use. I dont have time to make multiple functions so someone feel free to make another function for backward compatible, but as of now the old method doesnt work anyway.

I have fixed the synology component of ha to support this (much faster streaming), but cant push that before I know if this get pulled or not.

@alekslyse
Copy link
Contributor

@pergolafabio Could you try this custom component synology (custom_components/synology/camera.py) - this will pull a test build of this git with support for live streaming

Remember to set your cameras to never expire session: Surveilance station -> ip camera -> right click on camera -> share stream path -> set to never expire and save. Do this on all the cameras

synology.zip

@joshtbernstein
Copy link

I thought I'd give this a try too. The thumbnail loads fine, but the larger view still doesn't. I get the following in my logs: WARNING (MainThread) [haffmpeg.core] Timeout while waiting of FFmpeg

@AZDane
Copy link

AZDane commented Mar 9, 2019

@alekslyse I tried the custom component and it worked for me most of the time. Occasionally I will also get the "Timeout while waiting of FFmpeg". I have 4 cameras that update fine, but one camera opens a big picture, but doesn't update. Everything is configured the same, so a little strange. The 4 cameras that work will occasionally only show a still as well and throw the error.

@pergolafabio
Copy link

pergolafabio commented Mar 9, 2019

Ok, I try testing this evening...
But why do we need to set the rtsp stream to forever? This was not needed before?

Those streams are needed to for other systems , because every stream strarts with a "syno" user and for every cam a different password...
How is this now related to this new .py update?

@alekslyse
Copy link
Contributor

alekslyse commented Mar 9, 2019

Try this two options:

  1. This custom gives ffmpeg 10 seconds to analyse: https://raw.githubusercontent.com/alekslyse/home-assistant/f88b7d28877e21d79a0c70e87854145e6e4ad604/homeassistant/components/camera/synology.py

  2. This option give ffmeg 2,5 seconds to analyse: https://raw.githubusercontent.com/alekslyse/home-assistant/c9516ecd70bbaf4567a98db5163f0e55f25c765d/homeassistant/components/camera/synology.py

So try both and see if any of them helps the issue

@pergolafabio the stream itself is not forever, just the session. That way we dont have to regenerate a new session on every close.

@pergolafabio
Copy link

ok, tried them both, seems also home_mode is present here :)

anyway, tried the first one, if i click on a camera, i even had a videostream now, this i never saw before, on the older component, the quality is not great, but i had a actual stream, the clicked on another camera, no stream, clicked it again, and there was stream

then tried the second one, but i seems less stable, needed to click a few times on the camera to get an stream

then loaded back the first one, but it was also not that stable at first... so i am sure witch one is better ...
both editions gave me those warnings : 2019-03-09 15:39:02 WARNING (MainThread) [haffmpeg.core] Timeout while waiting of FFmpeg

@alekslyse
Copy link
Contributor

Yeah the warning is about ffmpeg is not responding fast enough. Maybe need a bit investigation to make the stream a bit more seamless, but this seem like a home assistant timeout and not ffmpeg timeout

@pergolafabio
Copy link

ok, tried it again, still dont know witch one is better between those 2
what should i see as a difference anyway ?
i also notice , clicking between cameras is not a good idea :)

@alekslyse
Copy link
Contributor

the difference is just what time I give ffmpeg to analyze the content. I was hoping setting it to 2,5 it will just send the stream into hass as hass waits for 5 seconds then gives up by standard. Sometimes it would take a bit more time to start a camera stream so trying to see how I can speed it up

@pergolafabio
Copy link

ok, well, at first sight, i dont notice any difference, lets see what other are saying :)
but i am already glad we are back in business :)
will this merge with the current PR with home mode?

@alekslyse
Copy link
Contributor

@pergolafabio Try this: https://raw.githubusercontent.com/alekslyse/home-assistant/synology/homeassistant/components/camera/synology.py

I gave it just 10 ms to autodetect and on local test it was very fast. Hopefully it could solve the timeout issue

@pergolafabio
Copy link

hmm, in my case its worse :(
it doesnt sometimes load the view now
also saw this now WARNING (MainThread) [haffmpeg.core] FFmpeg isn't running!

strange, but i have to click the camera a few times now, and 1 out of 10 i see the feed

previous versions were better in my case

@pergolafabio
Copy link

and also with stream directly from camera?

@AZDane
Copy link

AZDane commented Mar 9, 2019

@pergolafabio after I changed to direct from camera, all the versions work.

@pergolafabio
Copy link

hmm, not in my case, but maybe its because i dont have cameras that support mpeg ?

@AZDane
Copy link

AZDane commented Mar 9, 2019

It's actually surprising to me that it works with direct from camera because if I pull the cameras directly from withing HA by using the ONVIF platform instead of Synology it works like crap. But maybe thats not strange at all, just me not understanding why probably :)

@pergolafabio
Copy link

yeah, i also tried onvif before, was indeed crap , so not sure

@pergolafabio
Copy link

be carefull, if you change the source (camera/surveillance) seems the rtsp stream resets to 1 hour, instead of forever ... so if you use those stream paths for other software , like me .. :)

@AZDane
Copy link

AZDane commented Mar 9, 2019

@pergolafabio Mine stayed at forever. Just went back an checked.

@joshtbernstein
Copy link

joshtbernstein commented Mar 9, 2019

Going direct from the camera didn't work for me. This is using the most recent code above. Then again my camera has a poor wifi connection so that could be the issue there.

Actually I see the following errors:

Error handling message: {'type': 'camera_thumbnail', 'entity_id': 'camera.door_bell', 'id': 26} 11:22 AM deps/lib/python3.7/site-packages/synology/api.py (ERROR)

Error handling message: {'type': 'camera_thumbnail', 'entity_id': 'camera.door_bell', 'id': 24} 11:22 AM deps/lib/python3.7/site-packages/synology/api.py (ERROR)

FFmpeg isn't running! 11:21 AM custom_components/camera/synology.py (WARNING)

@pergolafabio
Copy link

for me the same, first and second version was working , not always, but better then 3th version
changing to camera feed directly, didnt make any improvemt for me

@alekslyse
Copy link
Contributor

The thumbnail issue is not related to this, its another part of the api.

Are you getting the ffmpeg isnt running after clicking a lot of times on the same videos? It might be related to HA need to stop the ffmpeg process before starting another one. If hass doesnt close it its a hass bug and not an api bug. I asked on their chat if anyone did know about states where ffmpeg isnt shutting down (as for me when I get that error other ffmpeg streams is working)

@alekslyse
Copy link
Contributor

I Will install proxmox on the nuc that runs ha tomorrow so I can this cross platforms. It’s getting better at least.

Anyone of you who know ffmmpeg and how to make I moist possible pass through with no audio. I think it try to auto detect and then something happens to hass

Easier to debug in a venv, will try tomorrow

@pergolafabio
Copy link

PS: there is a new PATCH out from Synology, to fix the 8.2.3 videostream issues
but, this should fix our current problem without this modifief .py file
but then again, we need a new .py file anyway for future, since they are going to drop the videostream api in a future release

from synology community:
Hi Everyone, our developer made a informal version that fix the stream api. You can download apk here with the password "SYNO0311". However, this is an informal testing version, there is no any assurance made.
link : https://supfiles.synology.com/fsdownload/oXkk1MptJ/SS8.2.3-5829

@alekslyse
Copy link
Contributor

My suggestion is that I pull my pull request for the changeover and leave the pr as today with the home mode etc.

Then we can figure out how to choose streams. For those who wants to use my version until the release is finished is welcome to do so.

@AZDane
Copy link

AZDane commented Mar 15, 2019

alekslyse,

When I used your component the resulting pop-up window was bigger than the one I get with the standard component. I liked that a lot. Any way of making the standard window bigger?

@pergolafabio
Copy link

what version are you using 1, 2 or 3 ?
3 is not working for me :(

@AZDane
Copy link

AZDane commented Mar 15, 2019

what version are you using 1, 2 or 3 ?
3 is not working for me :(

They all worked for me, but since Synology came out with a new patch I updated Synology and deleted the custom synology component in HA.

@pergolafabio
Copy link

ah ok

but we need to go further with this, yes, synology created a patch, but eventually in the near fututu they will drop the old videostream api, the one we are using now as a non cusstom component
they told us , that all developers should use the new API

@AZDane
Copy link

AZDane commented Mar 15, 2019

ah ok

but we need to go further with this, yes, synology created a patch, but eventually in the near fututu they will drop the old videostream api, the one we are using now as a non cusstom component
they told us , that all developers should use the new API
I agree. Just wondering why there was a difference in window size. Is the resolution different?

@alekslyse
Copy link
Contributor

The reason is mjpeg as the original code is essential a set of jpg images set together to make a "fake" stream, probably using the preview size, while the method I used actually used the real stream. Thats why when FFMPEG is working its much faster as its not just a set of images, but a video stream.

Sadly the FFMPEG component is a bit unstable on home assistant, but thats the way to go for the future if we can overcome the timeouts. I om not a FFMPEG expert, so if someone know this tool better, we just need to figure out the command how to make FFMPEG to skip trying to autodetect audio etc and just hand over the stream.

Also it seem its an error that HA is keeping a FFMPEG session open (seem like every stream is its own process) and its not getting proplerly closed.

As of now with the syn patch its some more time to figure this out, but for those who want to live with a bit sketchy ffmpeg my component / mod. I wont remove it.

@joshtbernstein
Copy link

@alekslyse It looks like they’ve fixed the FFMPEG issue: home-assistant/core#22091

@pergolafabio
Copy link

Ah, gonna try to load the custom component back later today, see if notice any difference

@pergolafabio
Copy link

tried 0.90, with option number 3 , as posted above

but again :

2019-03-21 09:24:32 WARNING (MainThread) [haffmpeg.core] Timeout while waiting of FFmpeg
2019-03-21 09:24:32 WARNING (MainThread) [haffmpeg.core] FFmpeg isn't running!

@pergolafabio
Copy link

Just a question, I have those cheap foscam C1 models, what I do, if a put the camera as platform generic in with direct rtsp stream from foscams directly, or stream coming from Synology...

Well it's sloooooww , just frame a frame... ,Why is that? Why is HA not able to show me a fluent stream?? The stream in Synology surveillance is good! So why not the stream coming from surveillance to HA? Also if I open the same stream in VLC , it's also fluent?

@pergolafabio
Copy link

home-assistant/core#22427

new ffmpeg 2.0 in 91.0 , not sure what i means? but maybe the few people here with frames issues? this will help?

@pergolafabio
Copy link

hey @alekslyse
are you still working on the PR for HA to release home mode?

@joshtbernstein
Copy link

Looks like it was closed: home-assistant/core#21261

@pergolafabio
Copy link

thats the old one, there was a newer version

home-assistant/core#21757

@joshtbernstein
Copy link

joshtbernstein commented Apr 17, 2019

Oops. Looks like @MartinHjelmare requested some changes: home-assistant/core#21757 (comment)

@pergolafabio
Copy link

btw, just used version 3 , load it back as a custom, was a while ago :)
now with 91.4 , i have this error, when i click on the camera to get the feed

2019-04-17 22:45:47 ERROR (MainThread) [aiohttp.server] Error handling request
Traceback (most recent call last):
  File "/usr/local/lib/python3.7/site-packages/aiohttp/web_protocol.py", line 418, in start
    resp = await task
  File "/usr/local/lib/python3.7/site-packages/aiohttp/web_app.py", line 458, in _handle
    resp = await handler(request)
  File "/usr/local/lib/python3.7/site-packages/aiohttp/web_middlewares.py", line 119, in impl
    return await handler(request)
  File "/usr/local/lib/python3.7/site-packages/homeassistant/components/http/real_ip.py", line 33, in real_ip_middleware
    return await handler(request)
  File "/usr/local/lib/python3.7/site-packages/homeassistant/components/http/ban.py", line 68, in ban_middleware
    return await handler(request)
  File "/usr/local/lib/python3.7/site-packages/homeassistant/components/http/auth.py", line 216, in auth_middleware
    return await handler(request)
  File "/usr/local/lib/python3.7/site-packages/homeassistant/components/http/view.py", line 115, in handle
    result = await result
  File "/usr/local/lib/python3.7/site-packages/homeassistant/components/camera/__init__.py", line 475, in get
    return await self.handle(request, camera)
  File "/usr/local/lib/python3.7/site-packages/homeassistant/components/camera/__init__.py", line 511, in handle
    return await camera.handle_async_mjpeg_stream(request)
  File "/config/custom_components/synology/camera.py", line 120, in handle_async_mjpeg_stream
    from haffmpeg import CameraMjpeg
ImportError: cannot import name 'CameraMjpeg' from 'haffmpeg' (/usr/local/lib/python3.7/site-packages/haffmpeg/__init__.py)

@theit8514
Copy link

theit8514 commented May 11, 2019

The location of CameraMjpeg changed. Change: from haffmpeg import CameraMjpeg to from haffmpeg.camera import CameraMjpeg

Edit: Looks like it's more than that. Closest I've gotten is this:

        from haffmpeg.camera import CameraMjpeg

        camera = CameraMjpeg(self._manager.binary, loop=self.hass.loop)
        await camera.open_camera(
            streaming_url, extra_cmd=self._extra_arguments)

        stream = await camera.get_reader()

        try:
            return await async_aiohttp_proxy_stream(
                self.hass, request, stream,
                self._manager.ffmpeg_stream_content_type)
        finally:
            await camera.close()

But it results in a timeout
2019-05-11 13:23:22 WARNING (MainThread) [haffmpeg.core] Timeout while waiting of FFmpeg

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

8 participants