Extract utility to get hash from string

This commit is contained in:
Piro / YUKI Hiroshi 2016-08-24 02:11:34 +09:00
parent 40191c6082
commit 2f12218ce6
4 changed files with 58 additions and 25 deletions

View File

@ -12,12 +12,14 @@
var Cr = Components.results; var Cr = Components.results;
var { TreeStyleTabConstants } = Cu.import('resource://treestyletab-modules/constants.js', {}); var { TreeStyleTabConstants } = Cu.import('resource://treestyletab-modules/constants.js', {});
var { getHashString } = Cu.import('resource://treestyletab-modules/getHashString.js', {});
var { XPCOMUtils } = Cu.import('resource://gre/modules/XPCOMUtils.jsm', {}); var { XPCOMUtils } = Cu.import('resource://gre/modules/XPCOMUtils.jsm', {});
function free() { function free() {
cleanup = cleanup =
Cc = Ci = Cu = Cr = Cc = Ci = Cu = Cr =
TreeStyleTabConstants = TreeStyleTabConstants =
getHashString =
XPCOMUtils = XPCOMUtils =
messageListener = messageListener =
handleEvent = handleEvent =
@ -74,7 +76,7 @@
global.sendAsyncMessage(TreeStyleTabConstants.MESSAGE_TYPE, { global.sendAsyncMessage(TreeStyleTabConstants.MESSAGE_TYPE, {
command : TreeStyleTabConstants.COMMAND_REPORT_LOCATION_CHANGE, command : TreeStyleTabConstants.COMMAND_REPORT_LOCATION_CHANGE,
locations : this.collectLocations(global.content).map(function(aURI) { locations : this.collectLocations(global.content).map(function(aURI) {
return this.getHashString(aURI); return getHashString(aURI);
}, this) }, this)
}); });
}, },
@ -98,16 +100,6 @@
this.collectLocations(aSubFrame, aLocations); this.collectLocations(aSubFrame, aLocations);
}, this); }, this);
return Object.keys(aLocations); return Object.keys(aLocations);
},
getHashString : function(aString) {
let hasher = Cc['@mozilla.org/security/hash;1']
.createInstance(Ci.nsICryptoHash);
hasher.init(Ci.nsICryptoHash.MD5);
let input = Cc['@mozilla.org/io/string-input-stream;1']
.createInstance(Ci.nsIStringInputStream);
input.data = aString;
hasher.updateFromStream(input, -1);
return hasher.finish(true);
} }
}; };
global.docShell global.docShell

52
modules/getHashString.js Normal file
View File

@ -0,0 +1,52 @@
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is the Tree Style Tab.
*
* The Initial Developer of the Original Code is YUKI "Piro" Hiroshi.
* Portions created by the Initial Developer are Copyright (C) 2016
* the Initial Developer. All Rights Reserved.
*
* Contributor(s): YUKI "Piro" Hiroshi <piro.outsider.reflex@gmail.com>
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ******/
"use strict";
var EXPORTED_SYMBOLS = ['getHashString'];
const Cc = Components.classes;
const Ci = Components.interfaces;
function getHashString(aString) {
const hasher = Cc['@mozilla.org/security/hash;1']
.createInstance(Ci.nsICryptoHash);
hasher.init(Ci.nsICryptoHash.MD5);
const input = Cc['@mozilla.org/io/string-input-stream;1']
.createInstance(Ci.nsIStringInputStream);
input.data = aString;
hasher.updateFromStream(input, -1);
return hasher.finish(true);
}

View File

@ -730,18 +730,6 @@ var TreeStyleTabUtils = {
return 'about:treestyletab-group?' + parameters.join('&'); return 'about:treestyletab-group?' + parameters.join('&');
}, },
getHashString : function utils_getHashString(aString)
{
let hasher = Cc['@mozilla.org/security/hash;1']
.createInstance(Ci.nsICryptoHash);
hasher.init(Ci.nsICryptoHash.MD5);
let input = Cc['@mozilla.org/io/string-input-stream;1']
.createInstance(Ci.nsIStringInputStream);
input.data = aString;
hasher.updateFromStream(input, -1);
return hasher.finish(true);
},
isMac : Cc['@mozilla.org/xre/app-info;1'] isMac : Cc['@mozilla.org/xre/app-info;1']

View File

@ -69,6 +69,7 @@ XPCOMUtils.defineLazyModuleGetter(this, 'TreeStyleTabThemeManager', 'resource://
XPCOMUtils.defineLazyModuleGetter(this, 'FullscreenObserver', 'resource://treestyletab-modules/fullscreenObserver.js'); XPCOMUtils.defineLazyModuleGetter(this, 'FullscreenObserver', 'resource://treestyletab-modules/fullscreenObserver.js');
XPCOMUtils.defineLazyModuleGetter(this, 'BrowserUIShowHideObserver', 'resource://treestyletab-modules/browserUIShowHideObserver.js'); XPCOMUtils.defineLazyModuleGetter(this, 'BrowserUIShowHideObserver', 'resource://treestyletab-modules/browserUIShowHideObserver.js');
XPCOMUtils.defineLazyModuleGetter(this, 'ContentBridge', 'resource://treestyletab-modules/contentBridge.js'); XPCOMUtils.defineLazyModuleGetter(this, 'ContentBridge', 'resource://treestyletab-modules/contentBridge.js');
XPCOMUtils.defineLazyModuleGetter(this, 'getHashString', 'resource://treestyletab-modules/getHashString.js');
XPCOMUtils.defineLazyServiceGetter(this, 'SessionStore', XPCOMUtils.defineLazyServiceGetter(this, 'SessionStore',
'@mozilla.org/browser/sessionstore;1', 'nsISessionStore'); '@mozilla.org/browser/sessionstore;1', 'nsISessionStore');
@ -1431,13 +1432,13 @@ TreeStyleTabWindow.prototype = inherit(TreeStyleTabBase, {
// from remote contents, we have to detect its opener from the URI. // from remote contents, we have to detect its opener from the URI.
let referrer = aParamsOrOpener.referrer; let referrer = aParamsOrOpener.referrer;
if (referrer) { if (referrer) {
let referrerHash = utils.getHashString(referrer); let referrerHash = getHashString(referrer);
let activeTab = this.browser.selectedTab; let activeTab = this.browser.selectedTab;
let possibleOwners = [activeTab].concat(this.getAncestorTabs(activeTab)); let possibleOwners = [activeTab].concat(this.getAncestorTabs(activeTab));
for (let i = 0, maxi = possibleOwners.length; i < maxi; i++) { for (let i = 0, maxi = possibleOwners.length; i < maxi; i++) {
let possibleOwner = possibleOwners[i]; let possibleOwner = possibleOwners[i];
let contentLocations = possibleOwner.__treestyletab__contentLocations || let contentLocations = possibleOwner.__treestyletab__contentLocations ||
[utils.getHashString(possibleOwner.linkedBrowser.currentURI.spec)]; [getHashString(possibleOwner.linkedBrowser.currentURI.spec)];
if (contentLocations.indexOf(referrerHash) < 0) if (contentLocations.indexOf(referrerHash) < 0)
continue; continue;
hasOwnerTab = true; hasOwnerTab = true;