mirror of
https://codeberg.org/claui/mobile-config-firefox.git
synced 2024-11-09 19:30:15 +00:00
autoconfig: add log function
It's pretty hard to get the code right in this autoconfig script, as the only feedback you get is whether the script crashed or not. Add a logging function to make it easier.
This commit is contained in:
parent
9e8c97e894
commit
b6bde3dfae
1 changed files with 24 additions and 3 deletions
|
@ -1,10 +1,10 @@
|
||||||
// Copyright 2022 Arnaud Ferraris, Oliver Smith
|
// Copyright 2023 Arnaud Ferraris, Oliver Smith
|
||||||
// SPDX-License-Identifier: MPL-2.0
|
// SPDX-License-Identifier: MPL-2.0
|
||||||
|
|
||||||
// This is a Firefox autoconfig file:
|
// This is a Firefox autoconfig file:
|
||||||
// https://support.mozilla.org/en-US/kb/customizing-firefox-using-autoconfig
|
// https://support.mozilla.org/en-US/kb/customizing-firefox-using-autoconfig
|
||||||
|
|
||||||
// Import custom userChrome.css on startup or new profile creation
|
// Import custom userChrome.css on startup or new profile creation
|
||||||
|
// Log file: $(find ~/.mozilla -name mobile-config-firefox.log)
|
||||||
|
|
||||||
const {classes: Cc, interfaces: Ci, utils: Cu} = Components;
|
const {classes: Cc, interfaces: Ci, utils: Cu} = Components;
|
||||||
Cu.import("resource://gre/modules/Services.jsm");
|
Cu.import("resource://gre/modules/Services.jsm");
|
||||||
Cu.import("resource://gre/modules/FileUtils.jsm");
|
Cu.import("resource://gre/modules/FileUtils.jsm");
|
||||||
|
@ -18,6 +18,19 @@ if (!chromeDir.exists()) {
|
||||||
chromeDir.create(Ci.nsIFile.DIRECTORY_TYPE, FileUtils.PERMS_DIRECTORY);
|
chromeDir.create(Ci.nsIFile.DIRECTORY_TYPE, FileUtils.PERMS_DIRECTORY);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var logFile = chromeDir.clone();
|
||||||
|
logFile.append("mobile-config-firefox.log");
|
||||||
|
var mode = FileUtils.MODE_WRONLY | FileUtils.MODE_CREATE | FileUtils.MODE_APPEND;
|
||||||
|
var logFileStream = FileUtils.openFileOutputStream(logFile, mode);
|
||||||
|
|
||||||
|
function log(line) {
|
||||||
|
var date = new Date().toISOString().replace("T", " ").slice(0, 19);
|
||||||
|
line = "[" + date + "] " + line + "\n";
|
||||||
|
logFileStream.write(line, line.length);
|
||||||
|
}
|
||||||
|
|
||||||
|
log("Running mobile-config-autoconfig.js");
|
||||||
|
|
||||||
// Create nsIFile objects for userChrome.css in <profile>/chrome/ and in /etc/
|
// Create nsIFile objects for userChrome.css in <profile>/chrome/ and in /etc/
|
||||||
var chromeFile = chromeDir.clone();
|
var chromeFile = chromeDir.clone();
|
||||||
chromeFile.append("userChrome.css");
|
chromeFile.append("userChrome.css");
|
||||||
|
@ -26,11 +39,13 @@ var defaultChrome = new FileUtils.File("/etc/mobile-config-firefox/userChrome.cs
|
||||||
// Remove the existing userChrome.css if older than the installed one
|
// Remove the existing userChrome.css if older than the installed one
|
||||||
if (chromeFile.exists() && defaultChrome.exists() &&
|
if (chromeFile.exists() && defaultChrome.exists() &&
|
||||||
chromeFile.lastModifiedTime < defaultChrome.lastModifiedTime) {
|
chromeFile.lastModifiedTime < defaultChrome.lastModifiedTime) {
|
||||||
|
log("Removing outdated userChrome.css from profile");
|
||||||
chromeFile.remove(false);
|
chromeFile.remove(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy userChrome.css to <profile>/chrome/
|
// Copy userChrome.css to <profile>/chrome/
|
||||||
if (!chromeFile.exists()) {
|
if (!chromeFile.exists()) {
|
||||||
|
log("Copying userChrome.css from /etc/mobile-config-firefox to profile");
|
||||||
defaultChrome.copyTo(chromeDir, "userChrome.css");
|
defaultChrome.copyTo(chromeDir, "userChrome.css");
|
||||||
updated = true;
|
updated = true;
|
||||||
}
|
}
|
||||||
|
@ -43,17 +58,20 @@ var defaultContent = new FileUtils.File("/etc/mobile-config-firefox/userContent.
|
||||||
// Remove the existing userContent.css if older than the installed one
|
// Remove the existing userContent.css if older than the installed one
|
||||||
if (contentFile.exists() && defaultContent.exists() &&
|
if (contentFile.exists() && defaultContent.exists() &&
|
||||||
contentFile.lastModifiedTime < defaultContent.lastModifiedTime) {
|
contentFile.lastModifiedTime < defaultContent.lastModifiedTime) {
|
||||||
|
log("Removing outdated userContent.css from profile");
|
||||||
contentFile.remove(false);
|
contentFile.remove(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy userContent.css to <profile>/chrome/
|
// Copy userContent.css to <profile>/chrome/
|
||||||
if (!contentFile.exists()) {
|
if (!contentFile.exists()) {
|
||||||
|
log("Copying userContent.css from /etc/mobile-config-firefox to profile");
|
||||||
defaultContent.copyTo(chromeDir, "userContent.css");
|
defaultContent.copyTo(chromeDir, "userContent.css");
|
||||||
updated = true;
|
updated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Restart Firefox immediately if one of the files got updated
|
// Restart Firefox immediately if one of the files got updated
|
||||||
if (updated == true) {
|
if (updated == true) {
|
||||||
|
log("Triggering Firefox restart");
|
||||||
var appStartup = Cc["@mozilla.org/toolkit/app-startup;1"].getService(Ci.nsIAppStartup);
|
var appStartup = Cc["@mozilla.org/toolkit/app-startup;1"].getService(Ci.nsIAppStartup);
|
||||||
appStartup.quit(Ci.nsIAppStartup.eForceQuit | Ci.nsIAppStartup.eRestart);
|
appStartup.quit(Ci.nsIAppStartup.eForceQuit | Ci.nsIAppStartup.eRestart);
|
||||||
}
|
}
|
||||||
|
@ -75,3 +93,6 @@ defaultPref('browser.urlbar.suggest.engines', false);
|
||||||
// Show about:home in new tabs, so it's not just a weird looking completely
|
// Show about:home in new tabs, so it's not just a weird looking completely
|
||||||
// empty page.
|
// empty page.
|
||||||
defaultPref('browser.newtabpage.enabled', true);
|
defaultPref('browser.newtabpage.enabled', true);
|
||||||
|
|
||||||
|
log("Done");
|
||||||
|
logFileStream.close();
|
||||||
|
|
Loading…
Reference in a new issue