Reputation: 351
How can I implement that my event-handler returns true? (Tried everything but the error returns)
I'm getting following error:
"Unchecked runtime.lastError: The message port closed before a response was received."
Solution is:
"Note: The sendResponse callback is only valid if used synchronously, or if the event handler returns true to indicate that it will respond asynchronously. The sendMessage function's callback will be invoked automatically if no handlers return true or if the sendResponse callback is garbage-collected."
https://developer.chrome.com/extensions/messaging#simple
edit: See also (chrome): https://github.com/mozilla/webextension-polyfill/issues/130
Here's my code, I would be very thankful:
// receive message from pop-up or options
chrome.extension.onMessage.addListener(function (aRequest, aSender,
aSendResponse) {
if (!aSender) {
return;
}
switch (aRequest.cmd) {
// reload lists
case 'reload':
XX.blockedDomains = {};
XX.load();
break;
// send list of recently blocked
case 'blocked':
aSendResponse(Object.keys(XX.blockedDomains));
break;
// deny domain
case 'deny':
XX.blocklist[aRequest.domain] = 1;
delete XX.blockedDomains[aRequest.domain];
XX.save();
break;
}
});
Upvotes: 10
Views: 25564
Reputation: 743
return true can resolve your problem just because:
you always need to sendresponse, you can sendresponse to any value, but you must sendresponse.
In your code, there are many situations, than no sendresponse.
This sendresponse function becomes invalid when the event listener returns, unless you return true from the event listener to indicate you wish to send a response asynchronously (this will keep the message channel open to the other end until sendResponse is called).
ref: https://developer.chrome.com/extensions/runtime#event-onMessage
Upvotes: 1
Reputation: 351
Seems fixed now. I added return true;
on the second last line and now there are no more error entries in the log.
Is this solution ok? Would be glad for feedback if something is wrong with it. Otherwise, I will mark this thread in a few days as solved.
// receive message from pop-up or options
chrome.extension.onMessage.addListener(function (aRequest, aSender,
aSendResponse) {
if (!aSender) {
return;
}
switch (aRequest.cmd) {
// reload lists
case 'reload':
XX.blockedDomains = {};
XX.load();
break;
// send list of recently blocked
case 'blocked':
aSendResponse(Object.keys(XX.blockedDomains));
break;
// deny domain
case 'deny':
XX.blocklist[aRequest.domain] = 1;
delete XX.blockedDomains[aRequest.domain];
XX.save();
break;
}
return true;
});
Upvotes: 14