DEV Community

Maani K
Maani K

Posted on

YouTube agent ( filterbot)

*This is a submission for the Agent.ai Challenge: Full-Stack Agent

Project Report: Personalized Content Filter and Ad Blocker for YouTube

Table of Contents

  1. Introduction

  2. Objective

  3. System Architecture

  4. Implementation Details

User Survey

Agent.ai Webhook Integration

Python Backend Logic

Browser Extension

  1. Testing and Deployment

  2. Conclusion

  3. Future Enhancements

  4. Appendices (Code Snippets)


  1. Introduction

Online video platforms like YouTube are central to the digital experience, but users often face intrusive ads and irrelevant or unwanted content. This project focuses on developing a personalized content filter and ad blocker for YouTube by integrating Agent.ai webhooks and Python for backend logic. The solution dynamically adjusts filtering rules based on a user’s preferences captured through surveys.


  1. Objective

The primary goal is to build a user-specific content filtering system with the following functionalities:

Block YouTube ads dynamically.

Filter videos based on a user’s personalized preferences.

Provide real-time updates to filtering rules via backend integration with a browser extension.


  1. System Architecture

The project consists of five core components:

  1. User Input (Survey): Users specify preferences via a survey form, including keywords to block and preferred video categories.

  2. Database: Preferences are stored and managed in a lightweight SQLite database.

  3. Agent.ai Webhooks: Triggers backend actions based on user interaction.

  4. Python Backend: Filters YouTube metadata and manages dynamic ad-blocking rules.

  5. Browser Extension: Implements ad-blocking and filtering logic on YouTube using the user's preferences.


  1. Implementation Details

4.1 User Survey

A simple web-based survey captures user preferences for content filtering.

Backend Code (Flask):

from flask import Flask, request, jsonify
import sqlite3

app = Flask(name)

def init_db():
conn = sqlite3.connect("preferences.db")
cursor = conn.cursor()
cursor.execute("""
CREATE TABLE IF NOT EXISTS preferences (
user_id TEXT PRIMARY KEY,
keywords_to_block TEXT,
preferred_categories TEXT
)
""")
conn.commit()
conn.close()

@app.route('/survey', methods=['POST'])
def save_preferences():
user_id = request.json['user_id']
keywords_to_block = ','.join(request.json['keywords_to_block'])
preferred_categories = ','.join(request.json['preferred_categories'])

conn = sqlite3.connect("preferences.db")
cursor = conn.cursor()
cursor.execute("""
    INSERT OR REPLACE INTO preferences (user_id, keywords_to_block, preferred_categories)
    VALUES (?, ?, ?)
""", (user_id, keywords_to_block, preferred_categories))
conn.commit()
conn.close()
return jsonify({"message": "Preferences saved successfully!"})
Enter fullscreen mode Exit fullscreen mode

if name == 'main':
init_db()
app.run(debug=True)


4.2 Agent.ai Webhook Integration

Agent.ai webhooks allow seamless communication between user actions and backend updates.

Webhook Handler:

import requests

AGENT_AI_WEBHOOK = "https://api.agent.ai/webhook"

def send_to_agent_ai(user_id, action, metadata):
payload = {
"user_id": user_id,
"action": action,
"metadata": metadata
}
response = requests.post(AGENT_AI_WEBHOOK, json=payload)
return response.json()


4.3 Python Backend Logic

The backend fetches user preferences and applies them to filter YouTube metadata.

Filtering Logic:

import sqlite3
import re

def filter_videos(user_id, video_metadata):
conn = sqlite3.connect("preferences.db")
cursor = conn.cursor()
cursor.execute("SELECT keywords_to_block FROM preferences WHERE user_id = ?", (user_id,))
result = cursor.fetchone()
conn.close()

if not result:
    return False

keywords_to_block = result[0].split(',')
for keyword in keywords_to_block:
    if re.search(keyword, video_metadata['title'], re.IGNORECASE):
        return True  # Block video

return False  # Allow video
Enter fullscreen mode Exit fullscreen mode

4.4 Browser Extension

The browser extension intercepts requests and blocks ads or unwanted videos.

manifest.json:

{
"manifest_version": 3,
"name": "YouTube Content Filter",
"version": "1.0",
"permissions": ["webRequest", "webRequestBlocking", "storage"],
"host_permissions": ["://.youtube.com/*"],
"background": {
"service_worker": "background.js"
}
}

background.js:

chrome.webRequest.onBeforeRequest.addListener(
function(details) {
const blockedKeywords = ["ad", "sponsored"];
for (const keyword of blockedKeywords) {
if (details.url.includes(keyword)) {
return { cancel: true };
}
}
return { cancel: false };
},
{ urls: ["://.youtube.com/*"] },
["blocking"]
);


  1. Testing and Deployment

5.1 Testing

Tested the Python backend for real-time filtering using sample YouTube metadata.

Verified that the browser extension blocks ads and filters unwanted content based on preferences.

5.2 Deployment

Hosted the backend using Flask and Socket.IO on a cloud service (e.g., AWS or Heroku).

Published the browser extension for Chrome and Firefox.

  1. Conclusion

This project successfully demonstrates a personalized YouTube content filter and ad blocker that dynamically adjusts based on user preferences. It integrates Python backend logic with Agent.ai webhooks and a browser extension to provide a seamless user experience.

  1. Future Enhancements

Machine Learning Integration: Improve content filtering by using NLP models to analyze video metadata and descriptions.

Cross-Platform Support: Extend support to mobile applications.

User Analytics: Provide insights into viewing patterns and filtering effectiveness.


  1. Appendices (Code Snippets)

Database Initialization

def init_db():
conn = sqlite3.connect("preferences.db")
cursor = conn.cursor()
cursor.execute("""
CREATE TABLE IF NOT EXISTS preferences (
user_id TEXT PRIMARY KEY,
keywords_to_block TEXT,
preferred_categories TEXT
)
""")
conn.commit()
conn.close()

Socket.IO Integration

from flask_socketio import SocketIO

app = Flask(name)
socketio = SocketIO(app)

@app.route('/update_filters', methods=['POST'])
def update_filters():
data = request.json
socketio.emit('update', data)
return {"message": "Filters updated!"}


This report outlines a scalable and extensible solution for personalizing content filtering and ad blocking on YouTube. Let me know if you need additionally .

Top comments (0)