Fixed memory leak and popup not updating after navigation

main
Elbert Alias 4 years ago
parent fa7b9260dc
commit 8f06b60edd

@ -842,9 +842,9 @@ class Site {
}
if (this.options.probe && !this.probed) {
await this.probe(url)
this.probed = true
await this.probe(url)
}
} catch (error) {
this.analyzedUrls[url.href] = {

@ -13,7 +13,7 @@
"software"
],
"homepage": "https://www.wappalyzer.com/",
"version": "6.7.2",
"version": "6.7.3",
"author": "Wappalyzer",
"license": "MIT",
"repository": {

@ -15,7 +15,7 @@ const { agent, promisify, getOption, setOption, open, globEscape } = Utils
const expiry = 1000 * 60 * 60 * 24
const hostnameIgnoreList =
/\b((local|dev(elop(ment)?)?|stag(e|ing)?|preprod|preview|test(ing)?|[^a-z]demo(shop)?|cache)[.-]|localhost|((wappalyzer|google|facebook|twitter|reddit|yahoo|wikipedia|amazon|youtube)\.)|\.local|\.test|\.netlify\.app|\.shopifypreview\.com|^[0-9.]+|[\d.]+$|^([a-f0-9:]+:+)+[a-f0-9]+$)/
/\b((local|dev(elop(ment)?)?|stag(e|ing)?|preprod|preview|test(ing)?|[^a-z]demo(shop)?|cache)[.-]|localhost|((wappalyzer|google|facebook|twitter|reddit|yahoo|wikipedia|amazon|youtube)\.)|\.local|\.test|\.netlify\.app|\.shopifypreview\.com|^([0-9.]+|[\d.]+)$|^([a-f0-9:]+:+)+[a-f0-9]+$)/
const xhrDebounce = []
@ -74,7 +74,19 @@ const Driver = {
types: ['xmlhttprequest'],
})
chrome.tabs.onRemoved.addListener((id) => (Driver.cache.tabs[id] = null))
chrome.tabs.onRemoved.addListener((id) => delete Driver.cache.tabs[id])
chrome.tabs.onUpdated.addListener(async (id, { url }) => {
if (url) {
const { hostname } = new URL(url)
const cache = Driver.cache.hostnames[hostname]
Driver.cache.tabs[id] = cache ? resolve(cache.detections) : []
await Driver.setIcon(url, Driver.cache.tabs[id])
}
})
// Enable messaging between scripts
chrome.runtime.onMessage.addListener(Driver.onMessage)
@ -434,12 +446,12 @@ const Driver = {
cache.detections = cache.detections
.concat(detections)
.filter(({ technology }) => technology)
cache.detections.filter(
.filter(
({ technology: { name }, pattern: { regex } }, index) =>
cache.detections.findIndex(
({ technology: { name: _name }, pattern: { regex: _regex } }) =>
name === _name && (!regex || regex.toString() === _regex.toString())
name === _name &&
(!regex || regex.toString() === _regex.toString())
) === index
)
@ -526,6 +538,10 @@ const Driver = {
* @param {Object} technologies
*/
async setIcon(url, technologies = []) {
if (await Driver.isDisabledDomain(url)) {
technologies = []
}
const dynamicIcon = await getOption('dynamicIcon', false)
const badge = await getOption('badge', true)

@ -4,7 +4,7 @@
"author": "Wappalyzer",
"homepage_url": "https://www.wappalyzer.com/",
"description": "Identify web technologies",
"version": "6.7.2",
"version": "6.7.3",
"default_locale": "en",
"manifest_version": 2,
"icons": {

@ -13,7 +13,7 @@
"software"
],
"homepage": "https://www.wappalyzer.com/",
"version": "6.7.2",
"version": "6.7.3",
"author": "Wappalyzer",
"license": "MIT",
"repository": {

@ -16290,7 +16290,7 @@
},
"SAP": {
"cats": [
22
53
],
"headers": {
"Server": "SAP NetWeaver Application Server"