Make 'all websites' permission optional. #793
This commit is contained in:
parent
e827b63336
commit
6f8e0a3bbd
@ -1,6 +1,24 @@
|
|||||||
requestID = 0
|
requestID = 0
|
||||||
|
|
||||||
chrome.runtime.onMessage.addListener (request, sender, sendResponse) ->
|
chrome.runtime.onMessage.addListener (request, sender, sendResponse) ->
|
||||||
|
if request.responseType is 'arraybuffer'
|
||||||
|
# Cross-origin image fetching. Need permission.
|
||||||
|
chrome.permissions.contains
|
||||||
|
origins: ['*://*/']
|
||||||
|
, (result) ->
|
||||||
|
if result
|
||||||
|
ajax request, sender, sendResponse
|
||||||
|
else
|
||||||
|
chrome.permissions.request
|
||||||
|
origins: ['*://*/']
|
||||||
|
, ->
|
||||||
|
ajax request, sender, sendResponse
|
||||||
|
return true
|
||||||
|
else
|
||||||
|
# JSON fetching from non-HTTPS archive.
|
||||||
|
ajax request, sender, sendResponse
|
||||||
|
|
||||||
|
ajax = (request, sender, sendResponse) ->
|
||||||
id = requestID
|
id = requestID
|
||||||
requestID++
|
requestID++
|
||||||
sendResponse id
|
sendResponse id
|
||||||
@ -10,11 +28,11 @@ chrome.runtime.onMessage.addListener (request, sender, sendResponse) ->
|
|||||||
xhr.responseType = request.responseType
|
xhr.responseType = request.responseType
|
||||||
xhr.addEventListener 'load', ->
|
xhr.addEventListener 'load', ->
|
||||||
if @readyState is @DONE && xhr.status is 200
|
if @readyState is @DONE && xhr.status is 200
|
||||||
contentType = @getResponseHeader 'Content-Type'
|
|
||||||
contentDisposition = @getResponseHeader 'Content-Disposition'
|
|
||||||
{response} = @
|
{response} = @
|
||||||
if request.responseType is 'arraybuffer'
|
if request.responseType is 'arraybuffer'
|
||||||
response = [new Uint8Array(response)...]
|
response = [new Uint8Array(response)...]
|
||||||
|
contentType = @getResponseHeader 'Content-Type'
|
||||||
|
contentDisposition = @getResponseHeader 'Content-Disposition'
|
||||||
chrome.tabs.sendMessage sender.tab.id, {id, response, contentType, contentDisposition}
|
chrome.tabs.sendMessage sender.tab.id, {id, response, contentType, contentDisposition}
|
||||||
else
|
else
|
||||||
chrome.tabs.sendMessage sender.tab.id, {id, error: true}
|
chrome.tabs.sendMessage sender.tab.id, {id, error: true}
|
||||||
|
|||||||
@ -25,7 +25,9 @@
|
|||||||
<% } %> "minimum_chrome_version": "<%= meta.min.chrome %>",
|
<% } %> "minimum_chrome_version": "<%= meta.min.chrome %>",
|
||||||
"permissions": [
|
"permissions": [
|
||||||
"storage",
|
"storage",
|
||||||
"http://*/",
|
"*://a.4cdn.org/"
|
||||||
"https://*/"
|
],
|
||||||
|
"optional_permissions": [
|
||||||
|
"*://*/"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@ -14,7 +14,7 @@ CrossOrigin =
|
|||||||
# XXX https://forums.lanik.us/viewtopic.php?f=64&t=24173&p=78310
|
# XXX https://forums.lanik.us/viewtopic.php?f=64&t=24173&p=78310
|
||||||
url = url.replace /^((?:https?:)?\/\/(?:\w+\.)?4c(?:ha|d)n\.org)\/adv\//, '$1//adv/'
|
url = url.replace /^((?:https?:)?\/\/(?:\w+\.)?4c(?:ha|d)n\.org)\/adv\//, '$1//adv/'
|
||||||
<% if (type === 'crx') { %>
|
<% if (type === 'crx') { %>
|
||||||
if /^https:\/\//.test(url) or location.protocol is 'http:'
|
if url.split('/')[...3].join('/') is "#{location.protocol}//i.4cdn.org"
|
||||||
xhr = new XMLHttpRequest()
|
xhr = new XMLHttpRequest()
|
||||||
xhr.open 'GET', url, true
|
xhr.open 'GET', url, true
|
||||||
xhr.setRequestHeader key, value for key, value of headers
|
xhr.setRequestHeader key, value for key, value of headers
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user