tabs-data.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /*
  2. * Copyright 2010-2019 Gildas Lormeau
  3. * contact : gildas.lormeau <at> gmail.com
  4. *
  5. * This file is part of SingleFile.
  6. *
  7. * The code in this file is free software: you can redistribute it and/or
  8. * modify it under the terms of the GNU Affero General Public License
  9. * (GNU AGPL) as published by the Free Software Foundation, either version 3
  10. * of the License, or (at your option) any later version.
  11. *
  12. * The code in this file is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero
  15. * General Public License for more details.
  16. *
  17. * As additional permission under GNU AGPL version 3 section 7, you may
  18. * distribute UNMODIFIED VERSIONS OF THIS file without the copy of the GNU
  19. * AGPL normally required by section 4, provided you include this license
  20. * notice and a URL through which recipients can access the Corresponding
  21. * Source.
  22. */
  23. /* global browser, singlefile, setTimeout */
  24. singlefile.extension.core.bg.tabsData = (() => {
  25. let persistentData, temporaryData, cleanedUp;
  26. setTimeout(() => getPersistent().then(tabsData => persistentData = tabsData), 0);
  27. return {
  28. onMessage,
  29. onTabRemoved,
  30. getTemporary,
  31. get: getPersistent,
  32. set: setPersistent
  33. };
  34. async function onMessage(message) {
  35. if (message.method.endsWith(".get")) {
  36. return getPersistent();
  37. }
  38. if (message.method.endsWith(".set")) {
  39. return setPersistent(message.tabsData);
  40. }
  41. }
  42. async function onTabRemoved(tabId) {
  43. if (temporaryData) {
  44. delete temporaryData[tabId];
  45. }
  46. const tabsData = await getPersistent();
  47. delete tabsData[tabId];
  48. setPersistent(tabsData);
  49. }
  50. function getTemporary(desiredTabId) {
  51. if (!temporaryData) {
  52. temporaryData = {};
  53. }
  54. if (desiredTabId !== undefined && !temporaryData[desiredTabId]) {
  55. temporaryData[desiredTabId] = {};
  56. }
  57. return temporaryData;
  58. }
  59. async function getPersistent(desiredTabId) {
  60. if (!persistentData) {
  61. const config = await browser.storage.local.get();
  62. persistentData = config.tabsData || {};
  63. }
  64. cleanup();
  65. if (desiredTabId !== undefined && !persistentData[desiredTabId]) {
  66. persistentData[desiredTabId] = {};
  67. }
  68. return persistentData;
  69. }
  70. async function setPersistent(tabsData) {
  71. persistentData = tabsData;
  72. await browser.storage.local.set({ tabsData });
  73. }
  74. async function cleanup() {
  75. if (!cleanedUp && singlefile.extension.core.bg.tabs) {
  76. cleanedUp = true;
  77. const allTabs = await singlefile.extension.core.bg.tabs.get({ currentWindow: true, highlighted: true });
  78. Object.keys(persistentData).filter(key => {
  79. if (key != "autoSaveAll" && key != "autoSaveUnpinned" && key != "profileName") {
  80. return !allTabs.find(tab => tab.id == key);
  81. }
  82. }).forEach(tabId => delete persistentData[tabId]);
  83. await browser.storage.local.set({ tabsData: persistentData });
  84. }
  85. }
  86. })();