Для LibNotify устанавливаемый файл JSON имеет неверный идентификатор расширения. Обновление идентификатора расширения до правильного исправляет его.
Перейдите к .config/google-chrome/NativeMessagingHosts
(для Google Chrome) или .config/chromium/NativeMessagingHosts
(для Chromium). Откройте файл JSON в папке и обратите внимание, что в allowed_origins
разделе он позволяет использовать идентификатор расширения gphchdpdmccpjmpiilaabhpdfogeiphf
. Однако расширение ID (по крайней мере, в моем случае, но оно должно быть одинаковым для всех) на самом деле epckjefillidgmfmclhcbaembhpdeijg
.
Чтобы это исправить, либо замените неправильный идентификатор расширения на правильный, либо добавьте запятую и правильный идентификатор расширения после нее. Я лично выбрал последний вариант, и вот как выглядит мой JSON-файл:
{
"name": "com.initiated.chrome_libnotify_notifications",
"description": "Libnotify Notifications in Chrome",
"path": path to the location of install.sh,
"type": "stdio",
"allowed_origins": [
"chrome-extension://gphchdpdmccpjmpiilaabhpdfogeiphf/",
"chrome-extension://epckjefillidgmfmclhcbaembhpdeijg/"
]
}
РЕДАКТИРОВАТЬ: Это не единственное изменение, которое должно быть сделано. Расширение опирается на уведомления Webkit, которые устарели и удалены в Chrome (ium) и, вероятно, в других браузерах в пользу уведомлений HTML5. Поэтому google-chrome/default/Extensions/epckjefillidgmfmclhcbaembhpdeijg/1.0_0/notify_hook.js
необходимо обновить. Я написал короткий сценарий для этого, но он нарушает большую часть стандарта, за исключением отображения уведомления. Замените все в файле следующим (добавлена базовая поддержка для сайтов, которые все еще используются window.webkitNotifications
и (надеюсь) улучшена поддержка изображений) (добавлена поддержка разрешений):
OriginalNotification = Notification
Notification = function(title, properties) {
if (Notification.permission != "granted") {
if (this.onError) {
this.onError();
}
return;
}
if (!properties.hasOwnProperty("body")) {
properties["body"] = "";
}
if (!properties.hasOwnProperty("icon")) {
properties["icon"] = "";
}
if (properties["icon"]) {
properties["icon"] = getBaseURL() + properties["icon"];
}
document.getElementById('libnotify-notifications-transfer-dom-area').innerText = JSON.stringify({title:title, body:properties["body"], iconUrl:properties["icon"]});
var event = document.createEvent("UIEvents");
event.initUIEvent("change", true, true);
document.getElementById('libnotify-notifications-transfer-dom-area').dispatchEvent(event);
if (this.onShow) {
this.onShow();
}
};
Object.defineProperty(Notification, "permission", {
get: function() {
return OriginalNotification.permission;
},
set: undefined
});
Notification.requestPermission = function(callback) {
OriginalNotification.requestPermission(callback);
}
window.webkitNotifications = {}
window.webkitNotifications.checkPermission = function() {
return 0;
}
window.webkitNotifications.createNotification = function(image, title, body) {
if (image) {
image = getBaseURL() + image;
}
document.getElementById('libnotify-notifications-transfer-dom-area').innerText = JSON.stringify({title:title, body:body, iconUrl:image});
var event = document.createEvent("UIEvents");
event.initUIEvent("change", true, true);
document.getElementById('libnotify-notifications-transfer-dom-area').dispatchEvent(event);
}
function getBaseURL() {
return location.protocol + "//" + location.hostname +
(location.port && ":" + location.port) + "/";
}
chrome://flags/#enable-native-notifications
.