Opened on 10/31/2018 at 08:45:20 PM

Closed on 11/22/2018 at 06:37:27 AM

Last modified on 12/04/2018 at 10:00:40 AM

#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 on 11/20/2018 at 05:15:36 AM.
Ad
decoy.png (5.8 KB) - added by mjethani on 11/20/2018 at 05:15:50 AM.
Decoy

Download all attachments as: .zip

Change History (16)

comment:1 Changed on 11/20/2018 at 03:37:49 AM by mjethani

  • Ready set
  • Status changed from new to reviewing

comment:2 Changed on 11/20/2018 at 03:38:38 AM by mjethani

  • Cc agiammarchi hfiguiere Ross added

comment:3 Changed on 11/20/2018 at 05:10:42 AM by mjethani

  • Description modified (diff)

comment:4 Changed on 11/20/2018 at 05:11:36 AM by mjethani

  • Description modified (diff)

Changed on 11/20/2018 at 05:15:36 AM by mjethani

Ad

Changed on 11/20/2018 at 05:15:50 AM by mjethani

Decoy

comment:5 Changed on 11/20/2018 at 05:16:57 AM by mjethani

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

comment:6 Changed on 11/20/2018 at 09:54:18 AM by abpbot

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

comment:7 Changed on 11/20/2018 at 09:55:36 AM by mjethani

  • Review URL(s) modified (diff)

comment:8 Changed on 11/20/2018 at 09:55:53 AM by mjethani

  • Owner changed from mjethani to agiammarchi

comment:9 Changed on 11/22/2018 at 06:32:34 AM by abpbot

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

comment:10 Changed on 11/22/2018 at 06:37:27 AM by mjethani

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

comment:11 Changed on 11/27/2018 at 10:30:48 AM by abpbot

comment:12 Changed on 11/27/2018 at 11:25:54 AM by kzar

  • Cc BrentM weissmar added

comment:13 Changed on 11/30/2018 at 12:58:53 PM 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 on 12/04/2018 at 10:00:40 AM by mjethani

  • Sensitive unset

Add Comment

Modify Ticket

Change Properties
Action
as closed .
The resolution will be deleted. Next status will be 'reopened'.
to The owner will be changed from agiammarchi.
 
Note: See TracTickets for help on using tickets.