Gulzat commited on
Commit
3a431a1
·
verified ·
1 Parent(s): 8c5c24b

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +81 -51
app.py CHANGED
@@ -1,69 +1,99 @@
1
- from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
2
  import datetime
3
- import requests
4
- import pytz
5
- import yaml
6
- from tools.final_answer import FinalAnswerTool
7
-
8
- from Gradio_UI import GradioUI
9
 
10
- # Below is an example of a tool that does nothing. Amaze us with your creativity !
11
- @tool
12
- def my_custom_tool(arg1:str, arg2:int)-> str: #it's import to specify the return type
13
- #Keep this format for the description / args / args description but feel free to modify the tool
14
- """A tool that does nothing yet
15
- Args:
16
- arg1: the first argument
17
- arg2: the second argument
18
- """
19
- return "What magic will you build ?"
20
 
 
 
 
21
  @tool
22
  def get_current_time_in_timezone(timezone: str) -> str:
23
- """A tool that fetches the current local time in a specified timezone.
24
- Args:
25
- timezone: A string representing a valid timezone (e.g., 'America/New_York').
26
- """
27
  try:
28
- # Create timezone object
29
  tz = pytz.timezone(timezone)
30
- # Get current time in that timezone
31
  local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
32
- return f"The current local time in {timezone} is: {local_time}"
33
  except Exception as e:
34
- return f"Error fetching time for timezone '{timezone}': {str(e)}"
35
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
36
 
37
- final_answer = FinalAnswerTool()
 
 
 
 
38
 
39
- # If the agent does not answer, the model is overloaded, please use another model or the following Hugging Face Endpoint that also contains qwen2.5 coder:
40
- # model_id='https://pflgm2locj2t89co.us-east-1.aws.endpoints.huggingface.cloud'
 
 
 
 
 
 
 
 
 
41
 
42
- model = HfApiModel(
43
- max_tokens=2096,
44
- temperature=0.5,
45
- model_id='Qwen/Qwen2.5-Coder-32B-Instruct',# it is possible that this model may be overloaded
46
- custom_role_conversions=None,
47
- )
48
 
 
 
 
49
 
50
- # Import tool from Hub
51
- image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
52
 
53
- with open("prompts.yaml", 'r') as stream:
54
- prompt_templates = yaml.safe_load(stream)
55
-
56
- agent = CodeAgent(
57
- model=model,
58
- tools=[final_answer], ## add your tools here (don't remove final answer)
59
- max_steps=6,
60
- verbosity_level=1,
61
- grammar=None,
62
- planning_interval=None,
63
- name=None,
64
- description=None,
65
- prompt_templates=prompt_templates
66
- )
67
 
 
 
 
 
 
 
 
 
 
 
68
 
69
- GradioUI(agent).launch()
 
 
 
 
 
 
 
 
 
 
1
  import datetime
2
+ from typing import List, Dict, Tuple
 
 
 
 
 
3
 
4
+ import pytz
5
+ from langchain.tools import tool # or whatever decorator you use
 
 
 
 
 
 
 
 
6
 
7
+ # ────────────────────────────────────────────────────────────────────────────
8
+ # 1️⃣ Keep your existing helper (unchanged)
9
+ # ────────────────────────────────────────────────────────────────────────────
10
  @tool
11
  def get_current_time_in_timezone(timezone: str) -> str:
12
+ """Return the current local time in a given timezone (YYYY-MM-DD HH:MM:SS)."""
 
 
 
13
  try:
 
14
  tz = pytz.timezone(timezone)
 
15
  local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
16
+ return local_time
17
  except Exception as e:
18
+ return f"Error: {e}"
19
 
20
+ # ────────────────────────────────────────────────────────────────────────────
21
+ # 2️⃣ New tool: find the first 30-minute slot that fits everyone’s workday
22
+ # ────────────────────────────────────────────────────────────────────────────
23
+ @tool
24
+ def find_overlap_slot(
25
+ timezones: List[str],
26
+ workday_start: int = 9,
27
+ workday_end: int = 18,
28
+ slot_minutes: int = 30
29
+ ) -> str:
30
+ """
31
+ Find the next common slot for a stand-up.
32
+
33
+ Args:
34
+ timezones: List of IANA tz strings (e.g. ["Europe/Berlin", "Asia/Bishkek"])
35
+ workday_start: Local workday start hour (24h clock, default 09)
36
+ workday_end: Local workday end hour (default 18)
37
+ slot_minutes: Length of slot to find (default 30)
38
+ Returns:
39
+ Human-readable description of the first viable slot, or error msg.
40
+ """
41
+ # 1. Build a list of "free intervals" for each participant
42
+ now_utc = datetime.datetime.utcnow().replace(tzinfo=pytz.utc)
43
+ candidates: List[Tuple[datetime.datetime, datetime.datetime]] = []
44
 
45
+ for tz_name in timezones:
46
+ try:
47
+ tz = pytz.timezone(tz_name)
48
+ except pytz.UnknownTimeZoneError:
49
+ return f"Unknown timezone: {tz_name}"
50
 
51
+ local_now = now_utc.astimezone(tz)
52
+ # Next work-day window
53
+ start_local = local_now.replace(hour=workday_start, minute=0, second=0, microsecond=0)
54
+ end_local = local_now.replace(hour=workday_end, minute=0, second=0, microsecond=0)
55
+ if local_now > end_local:
56
+ # Move to tomorrow
57
+ start_local += datetime.timedelta(days=1)
58
+ end_local += datetime.timedelta(days=1)
59
+ elif local_now > start_local:
60
+ # Move start forward so we don't schedule in the past
61
+ start_local = local_now
62
 
63
+ # Convert to UTC for overlap maths
64
+ candidates.append((
65
+ start_local.astimezone(pytz.utc),
66
+ end_local.astimezone(pytz.utc)
67
+ ))
 
68
 
69
+ # 2. Intersect all availability windows
70
+ slot_start = max(interval[0] for interval in candidates)
71
+ slot_end = min(interval[1] for interval in candidates)
72
 
73
+ if slot_end - slot_start < datetime.timedelta(minutes=slot_minutes):
74
+ return "No overlapping work-hour slot found in the next day."
75
 
76
+ # 3. Return the first slot of the requested length
77
+ chosen_start = slot_start
78
+ chosen_end = slot_start + datetime.timedelta(minutes=slot_minutes)
 
 
 
 
 
 
 
 
 
 
 
79
 
80
+ # 4. Build a friendly summary
81
+ summary_lines = [
82
+ f"✅ Proposed stand-up slot ({slot_minutes} min)",
83
+ f" • UTC: {chosen_start.strftime('%Y-%m-%d %H:%M')} – {chosen_end.strftime('%H:%M')}"
84
+ ]
85
+ for tz_name in timezones:
86
+ tz = pytz.timezone(tz_name)
87
+ loc_start = chosen_start.astimezone(tz).strftime('%Y-%m-%d %H:%M')
88
+ loc_end = chosen_end.astimezone(tz).strftime('%H:%M')
89
+ summary_lines.append(f" • {tz_name}: {loc_start} – {loc_end}")
90
 
91
+ return "\n".join(summary_lines)
92
+
93
+ # ────────────────────────────────────────────────────────────────────────────
94
+ # 3️⃣ Example of an empty placeholder tool you can extend later
95
+ # ────────────────────────────────────────────────────────────────────────────
96
+ @tool
97
+ def my_custom_tool(arg1: str, arg2: int) -> str:
98
+ """A template tool you can repurpose for anything."""
99
+ return f"Received arg1={arg1}, arg2={arg2}. What magic will you build?"