MINI MINI MANI MO

Path : /usr/lib/python2.7/site-packages/firewall/core/
File Upload :
Current File : //usr/lib/python2.7/site-packages/firewall/core/logger.pyc


d[c@s-ddddgZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z
ejdkZejdkZ
defdYZdefd	YZd
efdYZdefd
YZdefdYZdefdYZeZdS(t	LogTargettFileLogtLoggertlogiNt3cBs5eZdZdZddZdZdZRS(s% Abstract class for logging targets. cCs
d|_dS(N(tNonetfd(tself((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt__init__*sicCstddS(Ns%LogTarget.write is an abstract method(tNotImplementedError(Rtdatatleveltloggertis_debug((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytwrite-scCstddS(Ns%LogTarget.flush is an abstract method(R	(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytflush0scCstddS(Ns%LogTarget.close is an abstract method(R	(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytclose3s(t__name__t
__module__t__doc__RRRR(((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR(s
		t
_StdoutLogcBs/eZdZddZdZdZRS(cCstj|tj|_dS(N(RRtsyststdoutR(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR:s
icCs|jj||jdS(N(RRR(RR
RRR
((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR>scCs|jdS(N(R(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRCscCs|jjdS(N(RR(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRFs(RRRRRR(((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR9s		t
_StderrLogcBseZdZRS(cCstj|tj|_dS(N(RRRtstderrR(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRMs
(RRR(((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRLst
_SyslogLogcBs/eZdZddZdZdZRS(cCs=tj|tjtjjtjdtj	tj
dS(Ni(RRtsyslogtopenlogtostpathtbasenameRtargvtLOG_PIDt
LOG_DAEMON(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRUs
	icCsd}|rtj}nl||jkr3tj}nQ||jkrNtj}n6||jkritj}n||j	krtj
}n|jdr|t|d }nt|dkr|dkrtj|qtj||ndS(Ns
ii(
RRt	LOG_DEBUGtINFO1tLOG_INFOtWARNINGtLOG_WARNINGtERRORtLOG_ERRtFATALtLOG_CRITtendswithtlen(RR
RRR
tpriority((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRcs"cCstjdS(N(Rtcloselog(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRyscCsdS(N((R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR|s(RRRRRR(((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRTs		cBsAeZdZddZdZddZdZdZRS(s< FileLog class.
    File will be opened on the first write. twcCs#tj|||_||_dS(N(RRtfilenametmode(RR0R1((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRs
	cCsE|jr
dSt|j|j|_tj|jtjtjdS(N(RtopenR0R1tfcntltF_SETFDt
FD_CLOEXEC(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR2s	icCs7|js|jn|jj||jjdS(N(RR2RR(RR
RRR
((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRs	
cCs'|js
dS|jjd|_dS(N(RRR(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRs	
cCs|js
dS|jjdS(N(RR(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRs	(RRRRR2RRR(((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRs		cBseZdZdZdZdZdZdZdZe	Z
eZe
Zddd	Zd
ZddZdd
ZddZddZdZdZdZdZdZdZed2dZed2dZed2dZed2dZed2dZ ed2dZ!dZ"dZ#dZ$dZ%d Z&d!Z'd"Z(d#Z)d$Z*d%Z+d&Z,dd'Z-d(Z.dd)Z/ed2dd*Z0ed2dd+Z1ed2dd,Z2dd-Z3d.Z4d/Z5d0Z6dd1Z7RS(3sL	
    Format string:

    %(class)s      Calling class the function belongs to, else empty
    %(date)s       Date using Logger.date_format, see time module
    %(domain)s     Full Domain: %(module)s.%(class)s.%(function)s
    %(file)s       Filename of the module
    %(function)s   Function name, empty in __main__
    %(label)s      Label according to log function call from Logger.label
    %(level)d      Internal logging level
    %(line)d       Line number in module
    %(module)s     Module name
    %(message)s    Log message

    Standard levels:

    FATAL                 Fatal error messages
    ERROR                 Error messages
    WARNING               Warning messages
    INFOx, x in [1..5]    Information
    DEBUGy, y in [1..10]  Debug messages
    NO_INFO               No info output
    NO_DEBUG              No debug output
    INFO_MAX              Maximum info level
    DEBUG_MAX             Maximum debug level

    x and y depend on info_max and debug_max from Logger class
    initialization. See __init__ function.

    Default logging targets:

    stdout        Logs to stdout
    stderr        Logs to stderr
    syslog        Logs to syslog

    Additional arguments for logging functions (fatal, error, warning, info
    and debug):

    nl       Disable newline at the end with nl=0, default is nl=1.
    fmt      Format string for this logging entry, overloads global format
             string. Example: fmt="%(file)s:%(line)d %(message)s"
    nofmt    Only output message with nofmt=1. The nofmt argument wins over
             the fmt argument.

    Example:

    from logger import log
    log.setInfoLogLevel(log.INFO1)
    log.setDebugLogLevel(log.DEBUG1)
    for i in range(1, log.INFO_MAX+1):
        log.setInfoLogLabel(i, "INFO%d: " % i)
    log.setFormat("%(date)s %(module)s:%(line)d [%(domain)s] %(label)s: "
                  "%(level)d %(message)s")
    log.setDateFormat("%Y-%m-%d %H:%M:%S")

    fl = FileLog("/tmp/log", "a")
    log.addInfoLogging("*", fl)
    log.addDebugLogging("*", fl)
    log.addInfoLogging("*", log.syslog, fmt="%(label)s%(message)s")

    log.debug3("debug3")
    log.debug2("debug2")
    log.debug1("debug1")
    log.info2("info2")
    log.info1("info1")
    log.warning("warning\n", nl=0)
    log.error("error\n", nl=0)
    log.fatal("fatal")
    log.info(log.INFO1, "nofmt info", nofmt=1)

    iiiiiiii
cCsi|_i|_d|_d|_i|_i|_i|_i|_i|_i|_	|dkryt
d|n|dkrt
d|n|j|_||_
d|_||_|j|jd|j|jd|j|jd|j|jdxbtd|j
dD]J}t|d	|||j|dt|d
|d||q"Wxftd|jdD]N}t|d|||j|d
|t|d|d||qW|j|j|j|j|jd|jd|jd|j|j|j|jg|jd|jgt|j|j
dD]}|^qd|jd|jgtd|jdD]}|^qdS(s Logger class initialization tisLogger: info_max %d is too lowisLogger: debug_max %d is too lows
FATAL ERROR: sERROR: s	WARNING: sINFO%dsinfo%dcsfdS(Ncsj|||S(N(tinfo(tmessagetargstkwargs(Rtx(s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt<lambda>s((RR;((RR;s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR<ssDEBUG%ds	DEBUG%d: sdebug%dcsfdS(Ncsj|||S(N(tdebug(R8R9R:(RR;(s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR<$s((RR;((RR;s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR<#ss%(label)s%(message)ss%d %b %Y %H:%M:%St*N( t_levelt_debug_levelt_formatt_date_formatt_labelt_debug_labelt_loggingt_debug_loggingt_domainst_debug_domainst
ValueErrorR%tNO_INFOtINFO_MAXtNO_DEBUGt	DEBUG_MAXtsetInfoLogLabelR)t	TRACEBACKR'trangetsetattrtsetDebugLogLabeltsetInfoLogLevelR#tsetDebugLogLevelt	setFormatt
setDateFormattsetInfoLoggingRRtsetDebugLogging(Rtinfo_maxt	debug_maxR?ti((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRsX													




-cCshxat|j|jdD]F}||jkr5qnx(|j|D]\}}}|jqCWqWdS(s Close all logging targets iN(RPR)RMRER(RRtdummyttarget((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR3s
 R>cCs.|j|||jkr'|j|S|jS(s Get info log level. (t_checkDomainR?tNOTHING(Rtdomain((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytgetInfoLogLevel;s
cCsT|j|||jkr(|j}n||jkrC|j}n||j|<dS(s% Set log level [NOTHING .. INFO_MAX] N(R^R_RKR?(RRR`((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRSBs
cCs5|j|||jkr.|j||jS|jS(s Get debug log level. (R^R@RL(RR`((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytgetDebugLogLevelKs
cCsU|j||dkr"d}n||jkr=|j}n||j|j|<dS(s- Set debug log level [NO_DEBUG .. DEBUG_MAX] iN(R^RMRLR@(RRR`((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRTRs
	cCs|jS(N(RA(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt	getFormat[scCs
||_dS(N(RA(RRA((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRU^scCs|jS(N(RB(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt
getDateFormatascCs
||_dS(N(RB(RRA((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRVdscCsP|j|}x:|D]2}|j|d|jd|j||j|<qWdS(sU Set log label for level. Level can be a single level or an array
        of levels. t	min_levelt	max_levelN(t
_getLevelst_checkLogLevelR)RKRC(RRtlabeltlevels((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRNgs


cCsV|j|dd}x:|D]2}|j|d|jd|j||j|<qWdS(sU Set log label for level. Level can be a single level or an array
        of levels. R
iReRfN(RgRhR#RMRD(RRRiRj((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRRps


cCs |j||||dddS(s Set info log target for domain and level. Level can be a single
        level or an array of levels. Use level ALL to set for all levels.
        If no format is specified, the default format will be used. R
iN(t_setLogging(RR`R]Rtfmt((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRWyscCs |j||||dddS(s Set debug log target for domain and level. Level can be a single
        level or an array of levels. Use level ALL to set for all levels.
        If no format is specified, the default format will be used. R
iN(Rk(RR`R]RRl((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRXscCs |j||||dddS(s Add info log target for domain and level. Level can be a single
        level or an array of levels. Use level ALL to set for all levels.
        If no format is specified, the default format will be used. R
iN(t_addLogging(RR`R]RRl((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytaddInfoLoggingscCs |j||||dddS(s Add debg log target for domain and level. Level can be a single
        level or an array of levels. Use level ALL to set for all levels.
        If no format is specified, the default format will be used. R
iN(Rm(RR`R]RRl((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytaddDebugLoggingscCs |j||||dddS(s Delete info log target for domain and level. Level can be a single
        level or an array of levels. Use level ALL to set for all levels.
        If no format is specified, the default format will be used. R
iN(t_delLogging(RR`R]RRl((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytdelInfoLoggingscCs |j||||dddS(s Delete debug log target for domain and level. Level can be a single
        level or an array of levels. Use level ALL to set for all levels.
        If no format is specified, the default format will be used. R
iN(Rp(RR`R]RRl((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytdelDebugLoggingscCs|j|ddS(sN Is there currently any info logging for this log level (and
        domain)? R
i(t_isLoggingHere(RR((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytisInfoLoggingHerescCs|j|ddS(sO Is there currently any debug logging for this log level (and
        domain)? R
i(Rs(RR((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytisDebugLoggingHerescOs4|j|d|d<|j|j|||dS(s Fatal error log. iR
N(t_checkKWargst_logR)(RRAR9R:((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytfatals

cOs4|j|d|d<|j|j|||dS(s Error log. iR
N(RvRwR'(RRAR9R:((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyterrors

cOs4|j|d|d<|j|j|||dS(s Warning log. iR
N(RvRwR%(RRAR9R:((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pytwarnings

cOsT|j|ddd|j|j|d|d<|j||j|||dS(s Information log using info level [1..info_max].
        There are additional infox functions according to info_max from
        __init__ReiRfiR
N(RhRKRvRwRJ(RRRAR9R:((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR7s

cOsM|j|ddd|j|j|d|d<|j||||dS(s Debug log using debug level [1..debug_max].
        There are additional debugx functions according to debug_max
        from __init__ReiRfR
N(RhRMRvRw(RRRAR9R:((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR=s

cCs)|j|jtjdgdidS(NR9R:(RwROt	tracebackt
format_exc(R((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt	exceptionscCs8||ks||kr4td|||fndS(Ns*Level %d out of range, should be [%d..%d].(RI(RRReRf((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRhscCsD|s
dSx3|jD]%}|dkrtd|qqWdS(NtnlRltnofmts0Key '%s' is not allowed as argument for logging.(snlsfmtsnofmt(tkeysRI(RR:tkey((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRvs
cCs*|s|dkr&td|ndS(NR6sDomain '%s' is not valid.(RI(RR`((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyR^scCs||jkrt|ts-t|tr6|}n	|g}x|D]J}|rq|j|ddd|jqF|j|d|jd|jqFWnY|rgt|j	|jD]}|^q}n(gt|j|jD]}|^q}|S(s Generate log level array. ReiRf(
tALLt
isinstancetlistttupleRhRMR)RKRPtDEBUG1(RRR
RjR[((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRgs		

+(cCspt|tst|tr'|}n	|g}x9|D]1}t|jts7td|jjq7q7W|S(s Generate target array. s '%s' is no valid logging target.(RRRt
issubclasst	__class__RRIR(RR]ttargetst_target((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt_getTargetss		
cCs|r.|j}|j}d|jdf}n(|j}|j}|j|jdf}t|dkru|jnxwt	|d|dD]^}||krqnxC||D]7\}}}||kr|j
|gj|qqWqWdS(s% Generate dict with domain by level. iiN(RHRFRMRGRER)RKR,tclearRPt
setdefaulttappend(RR
RGREt_rangeRR`R\((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt_genDomainss				
c	Cs|j||j||}|j|}|r@|j}n	|j}x5|D]-}x$|D]}|||fg||<q]WqPW|j|dS(N(R^RgRRFRER(	RR`R]RRlR
RjRRE((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRks
	

c	Cs|j||j||}|j|}|r@|j}n	|j}xA|D]9}x0|D](}|j|gj|||fq]WqPW|j|dS(N(R^RgRRFRERRR(	RR`R]RRlR
RjRRE((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRm(s
	

*c
Cs|j||j||}|j|}|r@|j}n	|j}x|D]}	x|D]}|	|kruq]n|||f||	kr||	j|||ft||	dkr||	=q]qn||jkr]td|	||j	j
|fq]q]WqPW|j|dS(NisDNo mathing logging for level %d, domain %s, target %s and format %s.(R^RgRRFREtremoveR,RRIRRR(
RR`R]RRlR
RjRRER?((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRp7s&
	

	'cCs|j||}|stS|dd}|r<|j}n	|j}xP||D]D\}}}|dks|j|stj|d|rPtSqPWtS(NR`t.R>(t_genDicttFalseRFREt
startswithtfnmatchtfnmatchcasetTrue(RRR
t_dicttpoint_domainRER`R\((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRsPs	c	Csr|jjdkrf|jjd}||jkrf|j|}|j|j|j}|rc|Sqfntj|j}|j}|j|j	krt
|j	|jdr|j	|jj|krdSnx|j	j
D]\}}trt|tjstrt|trt
||jrjt||j}t|tjkrg|j|krd|SqgqjqqWdS(s7 Function to get calling class. Returns class or None. it	func_codeN(tf_codetco_argcounttco_varnamestf_localst
_getClass2Rtinspectt	getmoduletco_namet__dict__thasattrt__code__RtitemstPY2Rttypest	ClassTypetPY3ttypetgetattrtFunctionType(	Rtframetselfnamet_selftobjtmoduletcodeR\tvalue((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt	_getClassds,

	cCsyxB|jjD]1}t|tjkr|j|krA|SqqWx-|jD]"}|j||}|rO|SqOWdS(s@ Internal function to get calling class. Returns class or None. N(	RtvaluesRRRRt	__bases__RR(RRRRtbaset_obj((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRscOsd}d|kr|d}nd}d|kr>|d}nd}d|kr]|d}n|j||}|sydSt|dkr|||d<n1t|dkr||d|d<n
||d<|dd}	|r|j}
n	|j}
g}x|
|D]\}}
}|
|kr(qn|d	ks]|	j|ds]tj|d|r|so|j}nd
|kr|d
}n|r|
j|d|||n|
j||||||r|
jd|||n|j	|
qqWdS(NiR
iR~RR8R`RR>Rls
(
RR,RFRERRRRARR(RRRAR9R:R
R~RRRREtused_targetsR`R]((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRwsL



	
cCs6g}t}|r0|j}|j}|j}n|j}|j}|j}xr|D]j}|dkr|||krt}t|dkrg}nPqqR|||krR|j	|qRqRW|rt|dkrdS||krdStj}	x2|	r-|	j
r-|	jd|jkr-|	j
}	qW|	sCtdn|	jd}
|
d}x'|D]}|j|rag}PqaqaW|	j}t|
}
x||D]}|jd}|dkrqn|dkr|| }n|}|
t|kr|
j|s%dSq|j|
sdSqWd}||krH||}ni	|jd6|	jd	6|
d
6dd6|jd6dd
6|d6|d6tj|jtjd6}|ddkrd|d<nt}x+||D]}|dkrqnt}PqW|jjddksD|jjddksD|sDt|dkrl|j|	}|rl|j|d<qlnd|d
|d
<|ddkr|d
cd|d7<n|ddkr|d
cd|d7<nt|dkr|S|d
d}x7|D]/}|j|s*tj|d
|r|SqWdS(s Internal function. R>iiRs Frame information not available.RR6tfiletlineRtclasstfunctionR`RiRtdatet?s	%(domain)s%(class)N( RR@RHRDR?RGRCRR,RRRtcurrentframetf_backt	f_globalsRRIRRtfindtco_filenametf_linenoRttimetstrftimeRBt	localtimeRARRRR(RRR
t
check_domainstsimple_matchRRGRCR`tftmodule_nametpoint_moduletcot_lenR[tdt	level_strt
domain_neededRR((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRs					
	(



	






N(8RRRRR_R)ROR'R%RRRRRRRRRaRSRbRTRcRURdRVRNRRRRWRXRnRoRqRrRtRuRxRyRzR7R=R}RhRvR^RgRRRkRmRpRsRRRwR(((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyRsdG			;																										!		4(t__all__RRRRRRR{R3tos.pathRtversionRRtobjectRRRRRRR(((s8/usr/lib/python2.7/site-packages/firewall/core/logger.pyt<module>s*-!	4

OHA YOOOO