*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
Introduction
Objective
System Architecture
Implementation Details
User Survey
Agent.ai Webhook Integration
Python Backend Logic
Browser Extension
Testing and Deployment
Conclusion
Future Enhancements
Appendices (Code Snippets)
- 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.
- 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.
- System Architecture
The project consists of five core components:
User Input (Survey): Users specify preferences via a survey form, including keywords to block and preferred video categories.
Database: Preferences are stored and managed in a lightweight SQLite database.
Agent.ai Webhooks: Triggers backend actions based on user interaction.
Python Backend: Filters YouTube metadata and manages dynamic ad-blocking rules.
Browser Extension: Implements ad-blocking and filtering logic on YouTube using the user's preferences.
- 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!"})
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
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"]
);
- 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.
- 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.
- 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.
- 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)