Merge pull request #166 from CorentinB/facebook-ads-lib

Add support for Facebook ads library and fix closing
This commit is contained in:
Noah Levitt 2019-09-26 14:13:47 -07:00 committed by GitHub
commit 7273c7c3a2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 4 deletions

View File

@ -17,6 +17,15 @@
#
# first matched behavior is used, so order matters here
-
url_regex: '^https?://(?:www\.)?facebook\.com/ads/library/.*$'
behavior_js_template: umbraBehavior.js.j2
request_idle_timeout_sec: 30
default_parameters:
interval: 500
actions:
- selector: 'a[data-testid="snapshot_footer_link"]'
closeSelector: 'div._7lq1 > button'
-
url_regex: '^https?://(?:www\.)?facebook\.com/.*$'
behavior_js_template: facebook.js

View File

@ -43,6 +43,7 @@ class UmbraBehavior {
var documents = [];
documents[0] = document;
var iframes = document.querySelectorAll("iframe");
var iframesLength = iframes.length;
for (var i = 0; i < iframesLength; i++) {
@ -54,25 +55,31 @@ class UmbraBehavior {
// console.log("exception looking at iframe" + iframes[i] + ": " + e);
}
}
var documentsLength = documents.length;
for (var j = 0; j < documentsLength; j++) {
if (closeSelector) {
var closeTargets = documents[j].querySelectorAll(closeSelector);
if ((closeTargets.length > 0) &&
(this.alreadyDone.indexOf(closeTargets[0]) === -1) &&
(this.isVisible(closeTargets[0]))) {
doTarget(closeTargets[0], 'click');
for (var i = 0; i < closeTargets.length; i++) {
if (this.isVisible(closeTargets[i])) {
closeTargets[i].click();
didSomething = true;
break;
}
}
}
if (firstMatchOnly) {
var doTargets = [ documents[j].querySelector(selector) ];
} else {
var doTargets = documents[j].querySelectorAll(selector);
}
var doTargetsLength = doTargets.length;
if (!(doTargetsLength > 0)) {
continue;
}
for ( var i = 0; i < doTargetsLength; i++) {
if (!repeatSameElement && this.alreadyDone.indexOf(doTargets[i]) > -1) {
continue;