Opened 6 weeks ago

Closed 3 weeks ago

Last modified 9 days ago

#7088 closed change (fixed)

Implement hide-if-contains-image snippet

Reported by: mjethani Assignee: agiammarchi
Priority: P2 Milestone:
Module: Core Keywords: circumvention
Cc: agiammarchi, hfiguiere, Ross, BrentM, weissmar Blocked By:
Blocking: Platform: Unknown / Cross platform
Ready: yes Confidential: no
Tester: Ross Verified working: yes
Review URL(s):

https://codereview.adblockplus.org/29914555/
https://gitlab.com/eyeo/adblockplus/adblockpluscore/merge_requests/9

Description (last modified by mjethani)

Background

Sometimes ads are clearly labeled, but the label is an image loaded over the network. In such cases, it would help to be able to examine the image data to determine whether it is an ad label.

What to change

Implement a snippet called hide-if-contains-image with the following signature:

function hideIfContainsImage(search, selector, searchSelector)

Similar to hide-if-contains (#6809, #6847, and #6848), it should take a search "string" (in this case hexadecimal or Base64), a CSS selector to hide, and a CSS selector to search. It should examine the background-image computed style of the element matching searchSelector. If the background-image data (downloaded using fetch) matches the search string, it should hide the ancestor matching selector.

Hints for testers

Try this:

<!-- test.html -->
<div id="lbiddvhck3">
  Lorem ipsum dolor sit amet, consectetur
  adipiscing elit, sed do eiusmod tempor
  incididunt ut labore et dolore magna aliqua.
  <div style="margin: 10px auto; display: inline-block; width: 728px; height: 90px; background-image: url()"></div>
</div>
<script src="script.js"></script>
/* script.js */
setTimeout(() =>
{
  let ad = document.createElement("div");
  ad.id = Math.random().toString(36).substring(2);
  ad.innerHTML = "<div style='margin: 10px auto; display: inline-block; width: 728px; height: 90px; background-image: url()'></div>";
  if (Math.random() < .5)
    document.body.insertBefore(ad, document.body.firstElementChild);
  else
    document.body.appendChild(ad);
},
500);

The filter example.com#$#hide-if-contains-image /^89504e470d0a1a0a0000000d49484452000002d80000005a08/ div[id] div should hide the ad but not the content.

Attachments (2)

ad.png (5.8 KB) - added by mjethani 3 weeks ago.
Ad
decoy.png (5.8 KB) - added by mjethani 3 weeks ago.
Decoy

Download all attachments as: .zip

Change History (16)

comment:1 Changed 3 weeks ago by mjethani

  • Ready set
  • Status changed from new to reviewing

comment:2 Changed 3 weeks ago by mjethani

  • Cc agiammarchi hfiguiere Ross added

comment:3 Changed 3 weeks ago by mjethani

  • Description modified (diff)

comment:4 Changed 3 weeks ago by mjethani

  • Description modified (diff)

Changed 3 weeks ago by mjethani

Ad

Changed 3 weeks ago by mjethani

Decoy

comment:5 Changed 3 weeks ago by mjethani

I have also attached the ad and decoy images so you can load them remotely over HTTP.

comment:6 Changed 3 weeks ago by abpbot

A commit referencing this issue has landed:
Issue 7088 - Implement hide-if-contains-image snippet

comment:7 Changed 3 weeks ago by mjethani

  • Review URL(s) modified (diff)

comment:8 Changed 3 weeks ago by mjethani

  • Owner changed from mjethani to agiammarchi

comment:9 Changed 3 weeks ago by abpbot

A commit referencing this issue has landed:
Issue 7088 - Implement a fetchContent smart cache/utility

comment:10 Changed 3 weeks ago by mjethani

  • Resolution set to fixed
  • Status changed from reviewing to closed

comment:12 Changed 2 weeks ago by kzar

  • Cc BrentM weissmar added

comment:13 Changed 12 days ago by Ross

  • Tester changed from Unknown to Ross
  • Verified working set

Done. This snippet seems to be working as described.

ABP 3.4.1.2204
Chrome 70 / 49 / Windows 10
Firefox 63 / 51 / Windows 10

comment:14 Changed 9 days ago by mjethani

  • Sensitive unset
Note: See TracTickets for help on using tickets.