
    i                         U d Z ddlZddlZddlmZ ddlmZ ddlmZ  ej        e	          Z
	 ddlmZ n# e$ r	 ddlmZ Y nw xY wdaee         ed<   daee         ed<   d	aeed
<   defdZdedee         fdZdee         fdZdefdZdS )u  
Timezone-aware clock for Hermes.

Provides a single ``now()`` helper that returns a timezone-aware datetime
based on the user's configured IANA timezone (e.g. ``Asia/Kolkata``).

Resolution order:
  1. ``HERMES_TIMEZONE`` environment variable
  2. ``timezone`` key in ``~/.hermes/config.yaml``
  3. Falls back to the server's local time (``datetime.now().astimezone()``)

Invalid timezone values log a warning and fall back safely — Hermes never
crashes due to a bad timezone string.
    N)datetime)get_config_path)Optional)ZoneInfo
_cached_tz_cached_tz_nameF_cache_resolvedreturnc                     t          j        dd                                          } | r| S 	 ddl}t	                      }|                                rt          |          5 }|                    |          pi }ddd           n# 1 swxY w Y   |                    dd          }t          |t                    r(|                                r|                                S n# t          $ r Y nw xY wdS )zRead the configured IANA timezone string (or empty string).

    This does file I/O when falling through to config.yaml, so callers
    should cache the result rather than calling on every ``now()``.
    HERMES_TIMEZONE r   Ntimezone)osgetenvstripyamlr   existsopen	safe_loadget
isinstancestr	Exception)tz_envr   config_pathfcfgtz_cfgs         0/home/ubuntu/.hermes/hermes-agent/hermes_time.py_resolve_timezone_namer    %   s<    Y("--3355F 
%'' 	&k"" .annQ''-2. . . . . . . . . . . . . . .WWZ,,F&#&& &6<<>> &||~~%    2s6   5C% "B:C% B

C% B
AC% %
C21C2namec                     | sdS 	 t          |           S # t          t          f$ r'}t                              d| |           Y d}~dS d}~ww xY w)z3Validate and return a ZoneInfo, or None if invalid.Nz=Invalid timezone '%s': %s. Falling back to server local time.)r   KeyErrorr   loggerwarning)r!   excs     r   _get_zoneinfor'   @   sq     t~~i    K#	
 	
 	
 ttttts    AAAc                  f    t           s$t                      at          t                    ada t          S )zReturn the user's configured ZoneInfo, or None (meaning server-local).

    Resolved once and cached. Call ``reset_cache()`` after config changes.
    T)r	   r    r   r'   r        r   get_timezoner+   N   s/      022"?33
r*   c                      t                      } | t          j        |           S t          j                                                    S )z
    Return the current time as a timezone-aware datetime.

    If a valid timezone is configured, returns wall-clock time in that zone.
    Otherwise returns the server's local time (via ``astimezone()``).
    )r+   r   now
astimezone)tzs    r   r-   r-   [   s:     
B	~|B<>>$$&&&r*   )__doc__loggingr   r   hermes_constantsr   typingr   	getLogger__name__r$   zoneinfor   ImportErrorbackports.zoneinfor   __annotations__r   r   r	   boolr    r'   r+   r-   r)   r*   r   <module>r;      s      				       , , , , , ,      		8	$	$,!!!!!!! , , ,++++++++, "&
HX % % %!%# % % %       6  2    
hx( 
 
 
 
'X ' ' ' ' ' 's   6 AA