Parse filters in API code
This commit is contained in:
parent
79a627014c
commit
67886cf513
4 changed files with 27 additions and 25 deletions
|
@ -15,6 +15,21 @@
|
||||||
|
|
||||||
using content::BrowserThread;
|
using content::BrowserThread;
|
||||||
|
|
||||||
|
namespace mate {
|
||||||
|
|
||||||
|
template<>
|
||||||
|
struct Converter<extensions::URLPattern> {
|
||||||
|
static bool FromV8(v8::Isolate* isolate, v8::Local<v8::Value> val,
|
||||||
|
extensions::URLPattern* out) {
|
||||||
|
std::string pattern;
|
||||||
|
if (!ConvertFromV8(isolate, val, &pattern))
|
||||||
|
return false;
|
||||||
|
return out->Parse(pattern) == extensions::URLPattern::PARSE_SUCCESS;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace mate
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
@ -28,9 +43,12 @@ WebRequest::~WebRequest() {
|
||||||
|
|
||||||
template<AtomNetworkDelegate::EventType type>
|
template<AtomNetworkDelegate::EventType type>
|
||||||
void WebRequest::SetListener(mate::Arguments* args) {
|
void WebRequest::SetListener(mate::Arguments* args) {
|
||||||
scoped_ptr<base::DictionaryValue> filter(new base::DictionaryValue);
|
// { urls }.
|
||||||
args->GetNext(filter.get());
|
URLPatterns patterns;
|
||||||
|
mate::Dictionary dict;
|
||||||
|
args->GetNext(&dict) && dict.Get("urls", &patterns);
|
||||||
|
|
||||||
|
// Function or null.
|
||||||
v8::Local<v8::Value> value;
|
v8::Local<v8::Value> value;
|
||||||
AtomNetworkDelegate::Listener callback;
|
AtomNetworkDelegate::Listener callback;
|
||||||
if (!args->GetNext(&callback) &&
|
if (!args->GetNext(&callback) &&
|
||||||
|
@ -43,7 +61,7 @@ void WebRequest::SetListener(mate::Arguments* args) {
|
||||||
BrowserThread::PostTask(BrowserThread::IO, FROM_HERE,
|
BrowserThread::PostTask(BrowserThread::IO, FROM_HERE,
|
||||||
base::Bind(&AtomNetworkDelegate::SetListenerInIO,
|
base::Bind(&AtomNetworkDelegate::SetListenerInIO,
|
||||||
base::Unretained(delegate),
|
base::Unretained(delegate),
|
||||||
type, base::Passed(&filter), callback));
|
type, patterns, callback));
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
|
|
|
@ -167,31 +167,15 @@ AtomNetworkDelegate::AtomNetworkDelegate() {
|
||||||
AtomNetworkDelegate::~AtomNetworkDelegate() {
|
AtomNetworkDelegate::~AtomNetworkDelegate() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomNetworkDelegate::SetListenerInIO(
|
void AtomNetworkDelegate::SetListenerInIO(EventType type,
|
||||||
EventType type,
|
const URLPatterns& patterns,
|
||||||
scoped_ptr<base::DictionaryValue> filter,
|
const Listener& callback) {
|
||||||
const Listener& callback) {
|
|
||||||
if (callback.is_null()) {
|
if (callback.is_null()) {
|
||||||
event_listener_map_.erase(type);
|
event_listener_map_.erase(type);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ListenerInfo info;
|
event_listener_map_[type] = { patterns, callback };
|
||||||
info.callback = callback;
|
|
||||||
|
|
||||||
const base::ListValue* url_list = nullptr;
|
|
||||||
if (filter->GetList("urls", &url_list)) {
|
|
||||||
for (size_t i = 0; i < url_list->GetSize(); ++i) {
|
|
||||||
std::string url;
|
|
||||||
extensions::URLPattern pattern;
|
|
||||||
if (url_list->GetString(i, &url) &&
|
|
||||||
pattern.Parse(url) == extensions::URLPattern::PARSE_SUCCESS) {
|
|
||||||
info.url_patterns.insert(pattern);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
event_listener_map_[type] = info;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int AtomNetworkDelegate::OnBeforeURLRequest(
|
int AtomNetworkDelegate::OnBeforeURLRequest(
|
||||||
|
|
|
@ -65,7 +65,7 @@ class AtomNetworkDelegate : public brightray::NetworkDelegate {
|
||||||
~AtomNetworkDelegate() override;
|
~AtomNetworkDelegate() override;
|
||||||
|
|
||||||
void SetListenerInIO(EventType type,
|
void SetListenerInIO(EventType type,
|
||||||
scoped_ptr<base::DictionaryValue> filter,
|
const URLPatterns& patterns,
|
||||||
const Listener& callback);
|
const Listener& callback);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
2
vendor/native_mate
vendored
2
vendor/native_mate
vendored
|
@ -1 +1 @@
|
||||||
Subproject commit 5e70868fd0c005dc2c43bea15ca6e93da0b68741
|
Subproject commit a3dcf8ced663e974ac94ad5e50a1d25a43995a9d
|
Loading…
Add table
Add a link
Reference in a new issue