Skip to content

There is the simplest Java wrapper for the adblock-rust library.

Notifications You must be signed in to change notification settings

breadrock1/adblock-coffee

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

adblock-coffee

Create release Pipelines Last release:

This project is the simplest Java wrapper for the adblock-rust library, allowing you to use the powerful ad-blocking capabilities of adblock-rust in your Java applications.

Table of Contents

Introduction

adblock-rust is a high-performance ad-blocking library written in Rust. This project provides a Java wrapper around adblock-rust, enabling Java developers to integrate ad-blocking functionality into their applications seamlessly.

Features

  • High-performance ad-blocking using adblock-rust.
  • Easy-to-use Java API.
  • Cross-platform support.

Installation

Prerequisites

  • Java Development Kit (JDK) 8 or higher.
  • Rust and Cargo (for building the native library).

Building the Native Library

First, you need to build the adblock-rust library and generate the shared library file (.so, .dll, or .dylib depending on your OS).

  1. Clone the adblock-rust repository:
  2. Build the library:
cargo build --release --manifest-path adblock-rs/Cargo.toml
mvn install

To build it for Android platforms, just use NDK (see installation on official site):

 cargo ndk -t aarch64-linux-android -o ./target build --release
 mv arm64-v8 release 

Go back to project root and enter:

mvn install

If you want to build library to another platform add option --target with needed platform like aarch64-unknown-linux-gnu, . After that, check the path of the built library exists in pom.xml maven-resources-plugin section. By default, rustup uses the current platform and creates target/{debug,release} directories. After switching the target platform using rustup, these directories are created as targer/{target-platform}/{debug,release} directories.

Example of building the library for the aarch64-unknown-linux-gnu target:

cargo build --release --target aarch64-unknown-linux-gnu --manifest-path adblock-rs/Cargo.toml

You alse need to update the pom.xml file:

<plugin>
  <groupId>org.apache.maven.plugins</groupId>
  <artifactId>maven-resources-plugin</artifactId>
  <version>3.2.0</version>
  <executions>
    <execution>
      <id>copy-native-libs</id>
      <phase>process-resources</phase>
      <goals>
        <goal>copy-resources</goal>
      </goals>
      <configuration>
        <outputDirectory>${project.basedir}/target/lib</outputDirectory>
        <resources>
          <resource>
            <directory>${project.basedir}/adblock-rs/target/aarch64-linux-android/debug/</directory>
            <includes>
              <include>**/*.dylib</include>
              <include>**/*.so</include>
              <include>**/*.dll</include>
            </includes>
          </resource>
          <resource>
            <directory>${project.basedir}/adblock-rs/target/aarch64-linux-android/release/</directory>
            <includes>
              <include>**/*.dylib</include>
              <include>**/*.so</include>
              <include>**/*.dll</include>
            </includes>
          </resource>
        </resources>
      </configuration>
    </execution>
  </executions>
</plugin>

And build jar:

mvn install
  1. Locate the generated shared library file in the target/release directory.
public class Main {    
    public static void main(String[] args) {
        List<String> rules = new ArrayList<>(List.of(
            "-advertisement-icon.",
            "-advertisement-management/",
            "-advertisement.",
            "-advertisement/script."
        ));
        
        AdvtBlocker blocker = AdvtBlocker.createInstance(rules);
    }
}

Integrating with Your Java Project

  1. Copy the shared library file to a directory accessible by your Java application.

  2. Add the Java wrapper library to your project. You can do this by including the JAR file or adding the source code directly to your project.

Usage

Loading the Native Library

Before using the wrapper, you need to load the native library. This can be done using System.loadLibrary or System.load.

Using the Wrapper

Here is an example of how to use the Java wrapper to block ads:

import com.example.adblock.AdblockEngine;

public class Main {
    public static void main(String[] args) {
        List<String> rules = new ArrayList<>(List.of(
            "-advertisement-icon.",
            "-advertisement-management/",
            "-advertisement.",
            "-advertisement/script."
        ));
        
        AdvtBlocker blocker = AdvtBlocker.createInstance(rules);
        boolean result = blocker.checkUrls(
            "http://example.com/-advertisement-icon.",
            "http://example.com/helloworld",
            "image"
        );
        
        System.out.println(result);
    }
}