Displaying Raw Image in Habpanel

Hi there,
I am trying to get HABPanel to display a raw image item (cover channel from squeezebox binding)
I created a custom widget but the image is not being displayed.
After investigating, I found out, that an “unsafe:” string is added before the URL.
Googling for this leads me to answers that suggest manupulations to the DomSanitizer.
But I have no idea how to do that in one of those custom widgets.
My attempts to just open a item and adding the functionality there have not been successful.
Any help?

If you have an Image item, the built-in Image widget has support for it.

image

The trick to include one in a custom widget is documented here:

In your case that would be something like:

<div ng-init="imagemodel = { 'image_source': 'item-image', 'item': 'TestImage' }">
   <widget-image ng-model="imagemodel"></widget-image>
</div>

You might need some additional CSS to display it the way you want it.

2 Likes

Hi Yannick!
Thank you very much for your answer.
It turns out that this feature was not present in openhab 2.1 so I had to do a very painful migration but now the feature is present in HabPanel.
I can now select an image item.
BUT: Sadly it does not work.
The same image item works in the sitemap but not in habpanel.
I have simply selected the image item in the configuration but the resulting html still has the “unsafe:” tag in front of the actual data.
This is very depressing.
What am I doing wrong?

I also have that problem (Squeezebox Cover item with image widget). Maybe there’s something wrong with the Squeezebox binding?

There was a recent PR to fix the cover art. Unless you are on a recent snapshot, it may not work for you.

@mhilbush I installed 2.2 snapshot last night, and it doesn’t work.

@baeron52
It would surprise me, if this were a bug in the sqzeezebox plugin.
From what I have recently learned, I think the problem is that the Angularjs safety mechanism that prevents XSS attacks is blocking the image content. And the reason it is doing this (and this is a wild, speculative guess on my side) is, that the content type of the image is not whitelisted in the imgSrcSanitizationWhitelist for the compileProvider.
And the reason it is not whitelistet might be, that the content type for the image from the squeezebox binding is “application:octet-stream” and not some image type.
So perhaps this type was not whitelisted in the HabPanel configuration.

But again: wild guesses.
@ysc what do you think?

That’s probably your problem right there.

I tried updating an Image item manually with the openHAB console like this:

openhab> smarthome:update TestImage ""

(note that has an image/jpeg media type)

openhab> smarthome:status TestImage
raw type (image/jpeg): 8641 bytes

The HABPanel widget displays the image without problems.

If I try again with an application/octet-stream media type, it adds the unsafe: prefix indeed. I also have a ‘Failed to load resource: net::ERR_UNKNOWN_URL_SCHEME’ error in the Console. Which is to be expected I think – data URIs should always have their actual media types properly set (even if the browser might be able to figure it out by looking at the content). This looks like a problem with the binding.

1 Like

@ysc thanks for confirming. I will open an issue for the binding.

I think this might be a problem with the Squeezebox Server (i.e. Logitech Media Server). The coverart image is served directly by the LMS web server, not by the binding.

Right, but the data is downloaded by the binding and exposed in a channel as a RawType.

This might be the culprit:

There is a constructor for RawType allowing to specify a mime type, if not it’ll fallback to application/octet-stream:

Digging further on this, the HttpUtil class has downloadImage methods to retrieve an image directly wrapped in a RawType with the proper mime type by using some heuristics to guess it (if I understood correctly).
The binding should use that instead of downloadData and constructing a RawType itself.

2 Likes

Does it mean that this is an issue with the binding only? Is there any plan to fix it? Cheers.