???<!-- GIF89;a -->
123123123123
.....................................................................................................................................???<!-- GIF89;a -->
123123123123
.....................................................................................................................................ó
¿öYc           @@ sÚ   d  Z  d d l m Z d d l m Z d d l Z d d l Z d d l Z d d l Z d d l m	 Z	 m
 Z
 m Z d d l m Z d d l m Z d d l m Z e d ƒ Z e d „ Z d e j e f d „  ƒ  YZ d S(   s©   
raven.handlers.logging
~~~~~~~~~~~~~~~~~~~~~~

:copyright: (c) 2010-2012 by the Sentry Team, see AUTHORS for more details.
:license: BSD, see LICENSE for more details.
i    (   t   absolute_import(   t   print_functionN(   t   string_typest	   iteritemst	   text_type(   t   Client(   t	   to_string(   t   iter_stack_framest   stackt   namet   modulet   funcNamet   argst   msgt   levelnot   exc_textt   exc_infot   datat   createdt	   levelnamet   msecst   relativeCreatedt   tagst   messagec         C@ sÉ   i  } t  |  d d  ƒ } t | t ƒ sF | r= i | d 6} qF i  } n  xv t t |  ƒ ƒ D]b \ } } | | k rw qY n  | j d ƒ rŒ qY n  d | k r± | d k r± | | | <qY | | | <qY W| | f S(   NR   t   _t   .t   culpritt   server_namet   fingerprint(   R   R   R   (   t   getattrt   Nonet
   isinstancet   dictR   t   varst
   startswith(   t   recordt   reservedR   t   extrat   kt   v(    (    sG   /opt/alt/python27/lib/python2.7/site-packages/raven/handlers/logging.pyt   extract_extra   s    	t   SentryHandlerc           B@ s5   e  Z d  „  Z d „  Z d „  Z d „  Z d „  Z RS(   c         O@ sû   | j  d t ƒ } t | ƒ d k r | d } t | t ƒ rU | d | |  |  _ q½ t | t ƒ rp | |  _ q½ t d |  j j | f ƒ ‚ n. d | k r« | d |  _ n | | | Ž  |  _ | j	 d d  ƒ |  _ t j j |  d | j  d t j ƒ ƒd  S(	   Nt
   client_clsi   i    t   dsnsS   The first argument to %s must be either a Client instance or a DSN, got %r instead.t   clientR   t   level(   t   getR   t   lenR   R   R,   t
   ValueErrort	   __class__t   __name__t   popR   R   t   loggingt   Handlert   __init__t   NOTSET(   t   selfR   t   kwargsR,   t   arg(    (    sG   /opt/alt/python27/lib/python2.7/site-packages/raven/handlers/logging.pyR6   5   s    
c         C@ s    | j  d k p | j  j d ƒ S(   Nt   ravens   sentry.errorss   raven.(   s   sentry.errorss   raven.(   R	   R"   (   R8   R#   (    (    sG   /opt/alt/python27/lib/python2.7/site-packages/raven/handlers/logging.pyt
   can_recordJ   s    c         C@ sÅ   yM |  j  | ƒ |  j | ƒ s? t t | j ƒ d t j ƒd  S|  j | ƒ SWnq t k
 rÀ |  j	 j
 ro ‚  n  t d d t j ƒt t | j ƒ d t j ƒt t t j ƒ  ƒ d t j ƒn Xd  S(   Nt   files>   Top level Sentry exception caught - failed creating log record(   t   formatR<   t   printR   R   t   syst   stderrt   _emitt	   ExceptionR,   t   raise_send_errorsR   t	   tracebackt
   format_exc(   R8   R#   (    (    sG   /opt/alt/python27/lib/python2.7/site-packages/raven/handlers/logging.pyt   emitP   s    	
c         C@ sè   t  | ƒ } g  } t } d } x¹ | D]± } t | t  t f ƒ rO | \ } } n | | j } } | sÃ t | d i  ƒ }	 |	 j d d ƒ }
 | r· | j d ƒ r· |
 j d ƒ r· t } qÃ |
 } q% n  | j	 | | f ƒ q% W| sä | S| S(   Nt    t	   f_globalsR2   R4   (
   t   listt   FalseR   t   tuplet   f_linenoR   R.   R"   t   Truet   append(   R8   R   R#   t   framest   startedt   last_modt   itemt   framet   linenoRI   t   module_name(    (    sG   /opt/alt/python27/lib/python2.7/site-packages/raven/handlers/logging.pyt   _get_targetted_stackb   s(    	c         K@ s  t  | ƒ \ } } t | d d  ƒ } | t k r< t ƒ  } n  | rW |  j | | ƒ } n  t j j | j ƒ } d } i | j	 d 6} y t
 | j ƒ | d <Wn+ t k
 rÆ t | j ƒ d d !| d <n Xy t
 | j ƒ | d <Wn+ t k
 rt | j ƒ d d !| d <n X| j ret | j ƒ re|  j j | ƒ }	 | j |	 j |   ƒ d } i | j d	 6} n  | j | d
 <| j | d <i  | d <}
 |  j r©|
 j |  j ƒ n  |
 j t | d i  ƒ ƒ | j | ƒ | j d d  ƒ } |  j j | d | d | d | d | d | | S(   NR   s   raven.events.Messaget   paramsR   i   iÿÿÿÿt	   formatteds   raven.events.ExceptionR   R-   t   loggerR   t   sample_rateR   R%   t   date(   R(   R   R   RN   R   RW   t   datetimet   utcfromtimestampR   R   R   R   t   UnicodeDecodeErrort   reprR   R   t   allR,   t   get_handlert   updatet   captureR   R	   R   R3   (   R8   R#   R9   R   R%   R   R\   t
   event_typet   handler_kwargst   handlerR   R[   (    (    sG   /opt/alt/python27/lib/python2.7/site-packages/raven/handlers/logging.pyRB      sF    		(   R2   t
   __module__R6   R<   RG   RW   RB   (    (    (    sG   /opt/alt/python27/lib/python2.7/site-packages/raven/handlers/logging.pyR)   4   s
   				(   R   R	   R
   R   R   R   R   R   R   R   R   R   R   R   R   R   (   t   __doc__t
   __future__R    R   R]   R4   R@   RE   t   raven.utils.compatR   R   R   t
   raven.baseR   t   raven.utils.encodingR   t   raven.utils.stacksR   t	   frozensett   RESERVEDR(   R5   t   objectR)   (    (    (    sG   /opt/alt/python27/lib/python2.7/site-packages/raven/handlers/logging.pyt   <module>   s      	