Closed
Bug 1457457
Opened 7 years ago
Closed 7 years ago
Port bug 1420223 and bug 1421655 : Replace imgITools.decodeImage() with imgITools.decodeImageFromBuffer() - see comment #23
Categories
(Thunderbird :: Instant Messaging, defect)
Tracking
(thunderbird_esr60 fixed, thunderbird60 fixed, thunderbird61 wontfix, thunderbird62 fixed)
RESOLVED
FIXED
Thunderbird 62.0
People
(Reporter: cardbook.thunderbird, Assigned: jorgk-bmo)
Details
(Keywords: regression)
Attachments
(1 file, 2 obsolete files)
1.28 KB,
patch
|
mkmelin
:
review+
|
Details | Diff | Splinter Review |
User Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:59.0) Gecko/20100101 Firefox/59.0
Build ID: 20180323154952
Steps to reproduce:
var imagedata = '';
var io = Components.classes["@mozilla.org/network/io-service;1"].getService(Components.interfaces.nsIIOService);
var channel = io.newChannel(imagedata, null, null);
var input = channel.open();
var imgTools = Components.classes["@mozilla.org/image/tools;1"].getService(Components.interfaces.imgITools);
var container = {};
imgTools.decodeImageData(input, channel.contentType, container);
var wrapped = Components.classes["@mozilla.org/supports-interface-pointer;1"].createInstance(Components.interfaces.nsISupportsInterfacePointer);
wrapped.data = container.value;
var trans = Components.classes["@mozilla.org/widget/transferable;1"].createInstance(Components.interfaces.nsITransferable);
trans.addDataFlavor(channel.contentType);
trans.setTransferData(channel.contentType, wrapped, -1);
var clipid = Components.interfaces.nsIClipboard;
var clip = Components.classes["@mozilla.org/widget/clipboard;1"].getService(clipid);
clip.setData(trans, null, clipid.kGlobalClipboard);
Actual results:
with Thunderbird 52, this code works on Windows but not on Linux... I'm getting : "imgTools.decodeImageData is not a function"
Expected results:
image copied to the clipboard
Reporter | ||
Comment 1•7 years ago
|
||
code taken here : https://bugzilla.mozilla.org/show_bug.cgi?format=default&id=750108
Assignee | ||
Comment 2•7 years ago
|
||
Why is this a TB bug? Something in TB doesn't work?
Reporter | ||
Comment 3•7 years ago
|
||
Hi Jorg
there is no functional issue with Thunderbird, just for an issue for addon that want to use the code given here : https://bugzilla.mozilla.org/show_bug.cgi?format=default&id=750108...
I'd like to try to understand why the Components.interfaces.imgITools is different on Windows and on Linux...
Reporter | ||
Comment 4•7 years ago
|
||
ooops sorry for the noise... It is working on Linux with Thunderbird 52 (it is with Thunderbird 57 that it fails)
(In reply to Philippe VIGNEAU from comment #4)
> ooops sorry for the noise... It is working on Linux with Thunderbird 52 (it
> is with Thunderbird 57 that it fails)
Not working with Thunderbird 60.0b4 on Linux. Does that mean there is a regression that need to be fixed?
Reporter | ||
Comment 7•7 years ago
|
||
to summarize :
Thunderbird 52.7.0 : working Windows + Linux
Thunderbird 60.0b5 : working Windows, not working Linux
Assignee | ||
Comment 8•7 years ago
|
||
(In reply to Óvári from comment #5)
> Not working with Thunderbird 60.0b4 on Linux. Does that mean there is a
> regression that need to be fixed?
Sure. But imgITools is an Mozilla Central component, so please file a bug there.
We use imgItools only in chat. Is there a mal-function in chat on Linux somewhere due to this?
https://dxr.mozilla.org/comm-central/search?q=imgtools&redirect=false
Flags: needinfo?(richard.marti)
Flags: needinfo?(clokep)
Flags: needinfo?(acelists)
(In reply to Jorg K (GMT+1) from comment #8)
> (In reply to Óvári from comment #5)
> > Not working with Thunderbird 60.0b4 on Linux. Does that mean there is a
> > regression that need to be fixed?
> Sure. But imgITools is an Mozilla Central component, so please file a bug
> there.
Does this relate to any of these:
Bug 527007 - imgITools::DecodeImageData(...) doesn't support unbuffered streams (such as nsIFileInputStream), must use nsIBufferedInputStream (in nsIBufferedStreams.h)
Bug 816362 - Refactor imgTools::DecodeImageData to remove imgIContainer argument and use ImageFactory
Bug 1172496 - crash in imgTools::GetImgCacheForDocument
Bug 1181863 - Add a function similar to imgTools::DecodeImage which works off-main-thread
Comment 10•7 years ago
|
||
I see no decodeImageData() method in msgITools (https://dxr.mozilla.org/comm-central/source/mozilla/image/imgITools.idl).
It was removed in bug 1387790.
See the patch https://hg.mozilla.org/mozilla-central/rev/3ceb0bc8a730 for replacements.
Chat seems to only use functions that are still in the file.
Reporter | ||
Comment 11•7 years ago
|
||
If I use the code used in chat I get "imgTools.decodeImage is not a function"... so I think there also is a problem in the chat...
Comment 12•7 years ago
|
||
There is also no decodeImage() function.
So yes, as chat uses that one, it needs to be updated too. Thanks.
Flags: needinfo?(acelists)
Assignee | ||
Comment 13•7 years ago
|
||
Do we know how chat is affected?
Comment 14•7 years ago
|
||
I can't say if it affected. It seems it's used to show a user icon but I don't know which protocol uses this.
Flags: needinfo?(richard.marti)
Assignee | ||
Comment 15•7 years ago
|
||
XMPP/Jabber? - https://en.wikipedia.org/wiki/XMPP
Comment 16•7 years ago
|
||
Yes, it's used by XMPP to encode the image for sending as part of your vCard. (When another user requests your information we send your contact image as part of it.)
Flags: needinfo?(clokep)
Assignee | ||
Comment 17•7 years ago
|
||
Aceman, could you do a patch for us here.
Flags: needinfo?(acelists)
Reporter | ||
Comment 18•7 years ago
|
||
I finally have found a workaround using the decodeImageFromArrayBuffer() function. Here is my code to copy an image file to the clipboard as an image (works for Thunderbird 52 and 60) :
var imgTools = Components.classes["@mozilla.org/image/tools;1"].getService(Components.interfaces.imgITools);
var myFileURISpec = document.getElementById('photolocalURITextBox').value;
var myFileURI = Services.io.newURI(myFileURISpec, null, null);
// Thunderbird 52 and Linux
if (imgTools.decodeImageData) {
var myExtension = cardbookUtils.getFileNameExtension(myFileURISpec);
var imagedata = 'data:image/' + myExtension + ';base64,' + btoa(cardbookSynchronization.getFileBinary(myFileURI));
var io = Components.classes["@mozilla.org/network/io-service;1"].getService(Components.interfaces.nsIIOService);
var channel = io.newChannel(imagedata, null, null);
var input = channel.open();
var container = {};
imgTools.decodeImageData(input, channel.contentType, container);
var wrapped = Components.classes["@mozilla.org/supports-interface-pointer;1"].createInstance(Components.interfaces.nsISupportsInterfacePointer);
wrapped.data = container.value;
var trans = Components.classes["@mozilla.org/widget/transferable;1"].createInstance(Components.interfaces.nsITransferable);
trans.addDataFlavor(channel.contentType);
trans.setTransferData(channel.contentType, wrapped, -1);
var clipid = Components.interfaces.nsIClipboard;
var clipboard = Components.classes["@mozilla.org/widget/clipboard;1"].getService(clipid);
clipboard.setData(trans, null, clipid.kGlobalClipboard);
// Thunderbird 60
} else if (imgTools.decodeImageFromArrayBuffer) {
var myChannel = Services.io.newChannelFromURI2(myFileURI,
null,
Services.scriptSecurityManager.getSystemPrincipal(),
null,
Components.interfaces.nsILoadInfo.SEC_REQUIRE_SAME_ORIGIN_DATA_INHERITS,
Components.interfaces.nsIContentPolicy.TYPE_OTHER);
NetUtil.asyncFetch(myChannel, function (inputStream, status) {
if (!Components.isSuccessCode(status)) {
return;
}
var octetArray = [];
var binaryIS = Components.classes["@mozilla.org/binaryinputstream;1"].createInstance(Components.interfaces.nsIBinaryInputStream);
binaryIS.setInputStream(inputStream);
octetArray = binaryIS.readByteArray(binaryIS.available());
var arrayBuffer = (new Int8Array(octetArray)).buffer;
var container = imgTools.decodeImageFromArrayBuffer(arrayBuffer, myChannel.contentType);
var wrapped = Components.classes["@mozilla.org/supports-interface-pointer;1"].createInstance(Components.interfaces.nsISupportsInterfacePointer);
wrapped.data = container;
var trans = Components.classes["@mozilla.org/widget/transferable;1"].createInstance(Components.interfaces.nsITransferable);
trans.addDataFlavor(myChannel.contentType);
trans.setTransferData(myChannel.contentType, wrapped, -1);
var clipid = Components.interfaces.nsIClipboard;
var clipboard = Components.classes["@mozilla.org/widget/clipboard;1"].getService(clipid);
clipboard.setData(trans, null, clipid.kGlobalClipboard);
});
Comment 19•7 years ago
|
||
Should something like:
* imgTools.decodeImageData -- replacement: decodeImageFromArrayBuffer
be added to:
https://wiki.mozilla.org/Thunderbird/Add-ons_Guide_57#Changes_in_thunderbird57
Assignee | ||
Comment 20•7 years ago
|
||
We'll add something to the guide. Right now I'm a little confused why the replacement function decodeImage()
https://hg.mozilla.org/mozilla-central/rev/3ceb0bc8a730#l4.9
wouldn't be working.
Aceman is on Linux, so I hope he can look at this soon.
Assignee | ||
Comment 21•7 years ago
|
||
Actually, TB switched from decodeImageData() to decodeImage() here:
https://hg.mozilla.org/comm-central/rev/cc8153293e2e
Comment 22•7 years ago
|
||
Because decodeImage() was renamed too in https://hg.mozilla.org/mozilla-central/rev/e60f002f07d0.
And this is not Linux specific, the methods were simply renamed, globally.
Status: UNCONFIRMED → NEW
Component: Untriaged → Instant Messaging
Depends on: 1387790
Ever confirmed: true
Keywords: regression
OS: Unspecified → All
Hardware: Unspecified → All
Summary: imgTools.decodeImageData is not a function on Linux → "imgITools.decodeImageData is not a function" due to its rename in bug 1387790
Version: 52 Branch → 57 Branch
Assignee | ||
Comment 23•7 years ago
|
||
This has become far too confusing. These are the facts:
We originally used decodeImageData(). That was replaced by decodeImage() in bug 1387790 which we followed in bug 1389475 in August 2017.
We didn't notice that decodeImage() was also replaced by decodeImageBuffer() in bug 1420223 in November 2017 here:
https://hg.mozilla.org/mozilla-central/rev/e60f002f07d0#l4.29
So we simply need to port 1420223.
As noted in comment #18, decodeImageFromArrayBuffer() is also a function that could be used.
No longer depends on: 1387790
Flags: needinfo?(acelists)
Summary: "imgITools.decodeImageData is not a function" due to its rename in bug 1387790 → Port bug 1420223: Replace imgITools.decodeImage() with imgITools.decodeImageBuffer() - see comment #23
Assignee | ||
Comment 24•7 years ago
|
||
Straight port of:
https://hg.mozilla.org/mozilla-central/rev/e60f002f07d0#l6.90
-container = imgTools.decodeImage(istream, inMimeType);
+buffer = NetUtil.readInputStreamToString(istream, istream.available());
+container = imgTools.decodeImageBuffer(buffer, buffer.length, inMimeType);
One review will do, whoever comes first. This should be corrected in TB 60 asap.
Assignee: nobody → jorgk
Status: NEW → ASSIGNED
Attachment #8972684 -
Flags: review?(clokep)
Attachment #8972684 -
Flags: review?(acelists)
Assignee | ||
Comment 25•7 years ago
|
||
Removed trailing white-space. Sorry about the noise.
Attachment #8972684 -
Attachment is obsolete: true
Attachment #8972684 -
Flags: review?(clokep)
Attachment #8972684 -
Flags: review?(acelists)
Attachment #8972685 -
Flags: review?(clokep)
Attachment #8972685 -
Flags: review?(acelists)
Comment 26•7 years ago
|
||
Comment on attachment 8972685 [details] [diff] [review]
1457457-decodeImageBuffer.patch
Review of attachment 8972685 [details] [diff] [review]:
-----------------------------------------------------------------
I can't test XMPP so I'll let clokep test this, but I do not trust stream.available(), see bug 1356780. Please use a read loop for safety.
Attachment #8972685 -
Flags: review?(acelists) → feedback+
Assignee | ||
Comment 27•7 years ago
|
||
Well, M-C use that code.
Comment 28•7 years ago
|
||
Yes, I see. It's up to a chat peer to decide on that risk.
Assignee | ||
Updated•7 years ago
|
tracking-thunderbird60:
--- → +
Reporter | ||
Comment 29•7 years ago
|
||
seems to me that the function decodeImageBuffer() was renamed to decodeImageFromBuffer()...
Assignee | ||
Comment 30•7 years ago
|
||
Assignee | ||
Updated•7 years ago
|
Summary: Port bug 1420223: Replace imgITools.decodeImage() with imgITools.decodeImageBuffer() - see comment #23 → Port bug 1420223 and bug 1421655 : Replace imgITools.decodeImage() with imgITools.decodeImageFromBuffer() - see comment #23
Assignee | ||
Comment 31•7 years ago
|
||
Catering for a further rename in bug 1421655 (part 3) :-(
Attachment #8972685 -
Attachment is obsolete: true
Attachment #8972685 -
Flags: review?(clokep)
Attachment #8972826 -
Flags: review?(clokep)
Assignee | ||
Updated•7 years ago
|
Attachment #8972826 -
Flags: review?(florian)
Assignee | ||
Updated•7 years ago
|
Attachment #8972826 -
Flags: review?(mkmelin+mozilla)
Attachment #8972826 -
Flags: review?(martin)
Comment 32•7 years ago
|
||
Pushed by mozilla@jorgk.com:
https://hg.mozilla.org/comm-central/rev/242d96a1e0de
Port bug 1420223 and bug 1421655: Replace imgITools.decodeImage() with imgITools.decodeImageFromBuffer(). rs=bustage-fix DONTBUILD
Status: ASSIGNED → RESOLVED
Closed: 7 years ago
Resolution: --- → FIXED
Assignee | ||
Updated•7 years ago
|
Whiteboard: [PLR]
Target Milestone: --- → Thunderbird 62.0
Assignee | ||
Comment 33•7 years ago
|
||
TB 60 beta 8 (BETA_60_CONTINUATION branch):
https://hg.mozilla.org/releases/comm-beta/rev/21436230ba7f5fd8f7f6d59a3c48a8dba5d4b844
status-thunderbird60:
--- → fixed
status-thunderbird61:
--- → wontfix
status-thunderbird62:
--- → fixed
status-thunderbird_esr60:
--- → affected
tracking-thunderbird60:
+ → ---
Updated•7 years ago
|
Attachment #8972826 -
Flags: review?(mkmelin+mozilla) → review+
Assignee | ||
Updated•7 years ago
|
Attachment #8972826 -
Flags: review?(martin)
Attachment #8972826 -
Flags: review?(florian)
Attachment #8972826 -
Flags: review?(clokep)
Assignee | ||
Updated•7 years ago
|
Whiteboard: [PLR]
Assignee | ||
Comment 34•7 years ago
|
||
You need to log in
before you can comment on or make changes to this bug.
Description
•