Search code examples
fiwarefiware-wirecloud

Referencing images stored in object storage containers (Wirecloud) from img tag


We want to develop a widget to upload images to containers. This is a very well documented task:

1.- Object Storage Tutorial

2.- Fireware-Wiki

3.- OpenStack Object Storage Docs (Swift)

With all this you can manage to get (download), upload, delete files in a container. This is relatively clear.

On the other hand, we want to develop another widget to display images stored in a container. I think in something like this to show them:

<img src="public_object_url"/>

But I do not know how to do that. Where I get this public URL? Is there a public URL? Is it get in some step during the uploading process?

I am a bit lost how to do that. Any help would be highly appreciated.

Thanks in advance.

EDIT 1

We get blocked displaying images once they are downloaded.

enter image description here

A look inside "img" tags shows this:

enter image description here

what is the string returned by URL.createObjectURL(). If we look inside this link, the browser displays this:

enter image description here

We have decoded the string coming in the property "value" and the image is there!

To get the image from the object storage server we used a very similar code that the one used in the operator Álvaro recommended.

objectstorage.getFile(  containerName,
                            reports[i].urlImagen,{
                            token: token,
                            onSuccess: onGetFileSuccess.bind(null, i),
                            onFailure: onGetFileFailure
                          });




function onGetFileSuccess(index, picture){
    downloadedPicsCont--;
    reports[index].urlImagen = URL.createObjectURL(picture);
    if(!(downloadedPicsCont > 0)){
        MashupPlatform.wiring.pushEvent('reports_output', JSON.stringify(reports));
}

}

The picture variable has the following structure, which seems to be ok too.

enter image description here

What is it happening?

EDIT 2

Finally, we found the reason. We were downloading images that were created directly from the cloud and not with objectStorageAPI. In you upload images from the cloud, when you download them you get them inside cdmi objects so the URL.createObjectURL doesn't not work as expected. In the other hand, if you upload them using objectStorageAPI, when downloading them, they come in raw format, so the method works correctly.


Solution

  • As far as I know, FIWARE Object Storage needs authentication, so there are no such public URL. But... you can download the image using your credentials and then use the URL.createObjectURL method for getting an URL usable in the src attribute of the img element.

    It's a bit old, but you can use this operator as reference.