File size: 3,545 Bytes
bcabae3
9b5b26a
 
 
c19d193
6aae614
9b5b26a
a5390b7
 
c92d5f8
9b5b26a
c46556e
c92d5f8
bcabae3
c92d5f8
c46556e
9b5b26a
ac0f86b
a5390b7
 
 
 
 
 
 
 
 
c92d5f8
a5390b7
 
c92d5f8
db85dcc
a5390b7
7ce227f
a5390b7
 
 
 
 
 
 
 
 
 
 
 
 
 
bcabae3
c92d5f8
 
 
a5390b7
c46556e
c92d5f8
a5390b7
 
 
c92d5f8
a5390b7
c92d5f8
 
9b5b26a
 
 
 
 
 
 
 
 
 
 
 
8c01ffb
6aae614
ae7a494
e121372
bcabae3
 
 
 
13d500a
8c01ffb
9b5b26a
8c01ffb
861422e
 
bcabae3
8c01ffb
8fe992b
bcabae3
8c01ffb
 
 
 
 
 
861422e
8fe992b
 
8c01ffb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
from smolagents import CodeAgent, DuckDuckGoSearchTool, HfApiModel, load_tool, tool
import datetime
import requests
import pytz
import yaml
from tools.final_answer import FinalAnswerTool
from Gradio_UI import GradioUI
from bs4 import BeautifulSoup
import subprocess

@tool
def get_zh_top_news() -> tuple[str, str]:
    """A tool that retrieves the current top news article's title and URL from www.zerohedge.com.
    
    Returns:
        tuple[str, str]: A tuple containing the article title (str) and its URL (str).
    """
    try:
        # Use curl to fetch the HTML content
        result = subprocess.run(
            ["curl", "-s", "https://www.zerohedge.com"],
            capture_output=True,
            text=True,
            check=True
        )
        html_content = result.stdout
        print(f"DEBUG: Fetched HTML length: {len(html_content)}")  # Debug: Check if content is retrieved

        # Parse HTML with BeautifulSoup
        soup = BeautifulSoup(html_content, "html.parser")

        # Find the first <h2> with class starting with 'Article_title___'
        top_article = soup.find("h2", class_=lambda x: x and x.startswith("Article_title___"))
        
        if not top_article:
            print("DEBUG: No matching <h2> found")
            return "Error: Headline not found", "https://www.zerohedge.com"

        # Extract the <a> tag inside the <h2>
        link_tag = top_article.find("a")
        if not link_tag:
            print("DEBUG: No <a> tag found in top article")
            return "Error: Headline not found", "https://www.zerohedge.com"

        # Get title and URL
        article_title = link_tag.get_text(strip=True) or "No title found"
        article_link = link_tag.get("href") or "https://www.zerohedge.com"

        # Ensure the link is absolute
        if not article_link.startswith("http"):
            article_link = f"https://www.zerohedge.com{article_link}"

        print(f"DEBUG: Title = '{article_title}', Link = '{article_link}'")
        return article_title, article_link

    except subprocess.CalledProcessError as e:
        print(f"Error fetching page with curl: {e}")
        return "Error: Fetch failed", "https://www.zerohedge.com"
    except Exception as e:
        print(f"Error parsing content: {e}")
        return "Error: Headline not found", "https://www.zerohedge.com"

@tool
def get_current_time_in_timezone(timezone: str) -> str:
    """A tool that fetches the current local time in a specified timezone.
    Args:
        timezone: A string representing a valid timezone (e.g., 'America/New_York').
    """
    try:
        tz = pytz.timezone(timezone)
        local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
        return f"The current local time in {timezone} is: {local_time}"
    except Exception as e:
        return f"Error fetching time for timezone '{timezone}': {str(e)}"

final_answer = FinalAnswerTool()

model = HfApiModel(
    max_tokens=2096,
    temperature=0.5,
    model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
    custom_role_conversions=None,
)

image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)

with open("prompts.yaml", 'r') as stream:
    prompt_templates = yaml.safe_load(stream)

agent = CodeAgent(
    model=model,
    tools=[get_zh_top_news, get_current_time_in_timezone, final_answer],
    max_steps=6,
    verbosity_level=1,
    grammar=None,
    planning_interval=None,
    name=None,
    description=None,
    prompt_templates=prompt_templates
)

GradioUI(agent).launch()