var PLUGIN_INFO = {NAME} clear privacy data 2.0pre 2.0pre teramako MPL 1.1/GPL 2.0/LGPL 2.1 0.1 http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk/clear_privacy_data.js ; liberator.plugins.privacySanitizer = (function(){ var isFx31 = (Application.version.substring(0, 3) == "3.1") var prefPrefix = isFx31 ? "privacy.cpd." : "privacy.item."; var privacyManager = { // {{{ cache: { clear: function(){ var cacheService = Cc["@mozilla.org/network/cache-service;1"].getService(Ci.nsICacheService); try { getCacheService.evictEntries(Ci.nsICache.STORE_ANYWHERE); } catch (er){} }, getPref: function() options.getPref(prefPrefix + "cache") }, cookies: { clear: function(range){ var cookieMgr = Cc["@mozilla.org/cookiemanager;1"].getService(Ci.nsICookieManager); if (range){ let cookiesEnum = cookieMgr.enumrator; while (cookiesEnum.hasMoreElements()){ let cookie = cookiesEnum.getNext().QueryInterface(Ci.nsICookie2); if (cookie.creationTime > this.range[0]) cookieMgr.remove(cookie.host, cookie.name, cookie.path, false); } } else { cookieMgr.removeAll(); } }, getPref: function() options.getPref(prefPrefix + "cookies") }, offlineApps: { clear: function(){ var cacheService = Cc["@mozilla.org/network/cache-service;1"].getService(Ci.nsICacheService); try { cacheService.evictEntries(Ci.nsICache.STORE_OFFLINE); } catch(er){} var storageManagerService = Cc["@mozilla.org/dom/storagemanager;1"].getService(Ci.nsIDOMStorageManager); storageManagerService.clearOfflineApps(); }, getPref: function() options.getPref(prefPrefix + "offlineApps") }, history: { clear: function(range){ var globalHistory = Cc["@mozilla.org/browser/global-history;2"].getService(Ci.nsIBrowserHistory); if (range) globalHistory.removePageByTimeframe(range[0], range[1]); else globalHistory.removeAllPages(); try { let os = Cc["@mozilla.org/observer-service;1"].getService(Ci.nsIObserverService); os.notifyObservers(null, "browser:purge-session-history", ""); } catch(e){} var prefs = Cc["@mozilla.org/preferences-service;1"].getService(Ci.nsIPrefBranch2); try { prefs.clearUserPref("general.open_location.last_url"); } catch(er){} }, getPref: function() options.getPref(prefPrefix + "history") }, formdata: { clear: function(range){ var windowManager = Cc["@mozilla.org/appshell/window-mediator;1"].getService(Ci.nsIWindowMediator); var windows = windowManager.getEnumerator("navigator:browser"); while (windows.hasMoreElements()){ let searchBar = windows.getNext().document.getElementById("searchbar"); if (searchBar){ searchBar.value = ""; searchBar.textbox.editor.transactionManager.clear(); } } var formHistory = Cc["@mozilla.org/satchel/form-history;1"].getService(Ci.nsIFormHistory2); if (range) formHistory.removeEntriesByTimeframe(range[0], range[1]); else formHistory.removeAllEntries(); }, getPref: function() options.getPref(prefPrefix + "formdata") }, downloads: { clear: function(range){ var dlMgr = Cc["@mozilla.org/download-manager;1"].getService(Ci.nsIDownloadManager); let dlIDsRemove = []; if (range){ dlMgr.removeDownloadsByTimeframe(range[0], range[1]); let dlsEnum = dlMgr.activeDownloads; while (dlsEnum.hasMoreElements()){ let dl = dlsEnum.next(); if (dl.startTime >= range[0]) dlIDsRemove.push(dl.id); } } else { dlMgr.cleanUp(); let dlsEnum = dlMgr.activeDownloads; while (dlsEnum.hasMoreElements()){ dlIDsRemove.push(dlsEnum.next().id) } } dlIDsRemove.forEach(function(id) { dlMgr.removeDownload(id); }); }, getPref: function() options.getPref(prefPrefix + "downloads") }, sessions: { clear: function(){ var sdr = Cc["@mozilla.org/security/sdr;1"].getService(Ci.nsISecretDecoderRing); sdr.logoutAndTeardown(); var authMgr = Cc["@mozilla.org/network/http-auth-manager;1"].getService(Ci.nsIHttpAuthManager); authMgr.clearAll(); }, getPref: function() options.getPref(prefPrefix + "sessions") } }; // }}} function getDefaultClearList(){ var list = []; for (let name in privacyManager){ if (privacyManager[name].getPref()) list.push(name); } return list; } function getTimeRange(ts, isPref){ var endDate = Date.now() * 1000; var startDate; if (isPref){ if (ts == 0) return null; switch (ts){ case 1: case 2: startDate = endDate - (ts*60*60*1000000); break; case 3: startDate = endDate - (4*60*60*1000000); break; case 4: let d = new Date(); d.setHours(0); d.setMinutes(0); d.setSeconds(0); startDate = d.valueof() * 1000; break; default: throw "Invalid time span for clear private data: " + ts; } } else { startDate = endDate - parseTime(ts); } return [startDate, endDate]; } // TODO: かなり適当なので要修正 function parseTime(ts){ var int = parseInt(ts, 10); if (isNaN(int)){ let matches = ts.match(/^(?:(\d+)m)?(?:(\d+)d)?(?:(\d+)h)?$/); let [, month, day, hour] = matches; let time = (month ? month * 30 * 24 * 60 * 60 * 1000000 : 0) + (day ? day * 24 * 60 * 60 * 1000000 : 0) + (hour ? hour * 60 * 60 * 1000000 : 0); return time; } return int * 60 * 60 * 1000000; } var ops = [ [["-list", "-l"], commands.OPTION_LIST, null, [[name, "-"] for (name in privacyManager)]], ]; if (isFx31) ops.push([["-time", "-t"], commands.OPTION_STRING]); // -------------------------- // Command // -------------------------- commands.addUserCommand(["clearp[rivacy]"], "Clear Privacy data", function(args){ var clearList = args["-data"] || getDefaultClearList(); var range = null; if (isFx31){ range = args["-time"] ? getTimeRange(args["-time"], false) : getTimeRange(options.getPref("privacy.sanitize.timeSpan"), true); } clearList.forEach(function(name) this[name].clear(range), plugins.privacySanitizer); }, { options: ops, }, true); return privacyManager; })(); // vim:sw=4 ts=4 et fdm=marker: n183'>183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233
/* NEW BSD LICENSE {{{
Copyright (c) 2010, anekos.
All rights reserved.

Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:

    1. Redistributions of source code must retain the above copyright notice,
       this list of conditions and the following disclaimer.
    2. Redistributions in binary form must reproduce the above copyright notice,
       this list of conditions and the following disclaimer in the documentation
       and/or other materials provided with the distribution.
    3. The names of the authors may not be used to endorse or promote products
       derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
THE POSSIBILITY OF SUCH DAMAGE.


###################################################################################
# http://sourceforge.jp/projects/opensource/wiki/licenses%2Fnew_BSD_license       #
# に参考になる日本語訳がありますが、有効なのは上記英文となります。                #
###################################################################################

}}} */

// INFO {{{
let INFO =
<>
  <plugin name="ePub Reader" version="1.1.0"
          href="http://vimpr.github.com/"
          summary="for ePub Reader addon"
          lang="en-US"
          xmlns="http://vimperator.org/namespaces/liberator">
    <author email="anekos@snca.net">anekos</author>
    <license>New BSD License</license>
    <project name="Vimperator" minVersion="3.0"/>
    <item>
      <tags>:epubreader</tags>
      <spec>:epubreader <a>action</a> <oa>number</oa></spec>.
      <description><p>Do <a>action</a>.</p></description>
    </item>
    <p>
      Action list:
      <dl>
        <dt>next</dt><dd>Go next page</dd>
        <dt>prev</dt><dd>Go previous page</dd>
        <dt>nextchapter</dt><dd>Go next chapter</dd>
        <dt>prevchapter</dt><dd>Go previous chapter</dd>
        <dt>bookmark</dt><dd>Bookmark in ePub Reader addon</dd>
        <dt>library</dt><dd>Open ePub Reader library</dd>
        <dt>jump</dt><dd>Jump to the page</dd>
      </dl>
    </p>
    <p>
      Each actions can do mapping.
      e.g.
      <code>
      let g:epub_reader_map_&gt;action&lt; = 'l >';
      </code>
    </p>
  </plugin>
  <plugin name="ePub Reader" version="1.1.0"
          href="http://vimpr.github.com/"
          summary="for ePub Reader addon"
          lang="ja"
          xmlns="http://vimperator.org/namespaces/liberator">
    <author email="anekos@snca.net">anekos</author>
    <license>New BSD License</license>
    <project name="Vimperator" minVersion="3.0"/>
    <item>
      <tags>:epubreader</tags>
      <spec>:epubreader <a>action</a> <oa>number</oa></spec>.
      <description><p><a>action</a>を実行する。</p></description>
    </item>
    <p>
      Action のリスト:
      <dl>
        <dt>next</dt><dd>Go next page</dd>
        <dt>prev</dt><dd>Go previous page</dd>
        <dt>nextchapter</dt><dd>Go next chapter</dd>
        <dt>prevchapter</dt><dd>Go previous chapter</dd>
        <dt>bookmark</dt><dd>Bookmark in ePub Reader addon</dd>
        <dt>library</dt><dd>Open ePub Reader library</dd>
        <dt>jump</dt><dd>Jump to the page</dd>
      </dl>
    </p>
    <p>
      各アクションは
      <code>
      let g:epub_reader_map_&gt;action&lt; = 'l >';
      </code>
      のようにしてマッピングできます
      一つのアクションに複数のマッピングをしたいときはスペースで区切ります
    </p>
  </plugin>
</>;
// }}}


(function () {

  const MapKeys = {
    prev: 'goPreviousPage',
    next: 'goNextPage',
    prevchapter: 'goPreviousChapter',
    nextchapter: 'goNextChapter',
    save: 'save',
    bookmark: 'bookmark',
    library: 'openLibrary',
    jump: 'jump'
  };

  const ReaderUrls = /^chrome:\/\/epubreader\/content\/reader.xul/;


  function press (query)
    content.document.querySelector(query).click();

  function pressN (query, n) {
    for (let i = 0; i < (n || 1); i++)
      press(query);
  }

  function makePress (query)
    function ()
      press(query);

  function makePressN (query)
    function (count)
      pressN(query, count);

  function withCompleter (main, completer) {
    main.completer = completer;
    return main;
  }

  function getIndexLinks ()
    let (frame = content.document.querySelector('#nav_frame').contentDocument)
      Array.slice(frame.querySelectorAll('.navPoint .childLevel > a'));

  let api = __context__.API = {
    bookmark:
      makePress('toolbarbutton#save'),
    goPreviousPage:
      makePressN('toolbarbutton#nav_page_backwards_button'),
    goNextPage:
      makePressN('toolbarbutton#nav_page_forwards_button'),
    goPreviousChapter:
      makePressN('toolbarbutton#nav_backwards_button'),
    goNextChapter:
      makePressN('toolbarbutton#nav_forwards_button'),
    openLibrary:
      makePress('toolbarbutton#library'),
    save:
      makePress('toolbarbutton#bookmark'),
    jump:
      withCompleter(
        function (index) {
          buffer.followLink(getIndexLinks()[index]);
        },
        function (context, args) {
          context.compare = void 0;
          context.completions = [
            [i + ': ' + link.textContent, link.href.replace(/.*\//g, '').replace(/\.[^.]+$/, '')]
            for ([i, link] in Iterator(getIndexLinks()))
          ];
        }
      )
  };

  for (let keyValue in Iterator(MapKeys)) {
    let [key, value] = keyValue;
    let gvname = 'epub_reader_map_' + key;
    let map = liberator.globalVariables[gvname];

    if (!map)
      continue;

    let func = api[value];
    mappings.addUserMap(
      [modes.NORMAL],
      map.split(/\s+/),
      'for ePub Reader',
      function (count) func(count),
      {
        count: !!func.length,
        matchingUrls: ReaderUrls
      }
    );
  }

  commands.addUserCommand(
    ['epubreader'],
    'ePub Reader addon controler',
    function (args) {
      if (!ReaderUrls(buffer.URL))
        return liberator.echoerr('Not in ePub Reader');

      let [cmd, num] = args;
      let func = api[MapKeys[cmd]];
      if (!func)
        return liberator.echoerr('Unknown command: ' + cmd);
      func(parseInt(num, 10));
    },
    {
      literal: 1,
      completer: function (context, args) {
        if (args.length > 1) {
          let [cmd] = args;
          let func = api[MapKeys[cmd]];
          if (!func.completer)
            return;
          return func.completer(context, args);
        }

        context.completions = [keyValue for (keyValue in Iterator(MapKeys))];
      }
    },
    true
  );

})();

// vim:sw=2 ts=2 et si fdm=marker: