?¡ëPNG  IHDR ? f ??C1 sRGB ??¨¦ gAMA ¡À? ¨¹a pHYs ? ??o¡§d GIDATx^¨ª¨¹L¡±¡Âe¡ÂY?a?("Bh?_¨°???¡é¡ì?q5k?*:t0A-o??£¤]VkJ¡éM??f?¡À8\k2¨ªll¡ê1]q?¨´???T
Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /home/user1137782/www/china1.by/classwithtostring.php on line 86

Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 213

Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 214

Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 215

Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 216

Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 217

Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 218
# emacs: -*- mode: python; py-indent-offset: 4; indent-tabs-mode: t -*- # vi: set ft=python sts=4 ts=4 sw=4 noet : # This file is part of Fail2Ban. # # Fail2Ban is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # Fail2Ban is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with Fail2Ban; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # Author: Daniel Black # __author__ = "Daniel Black" __copyright__ = "Copyright (c) 2013 Daniel Black" __license__ = "GPL" import time import os import tempfile from ..server.actions import Actions from ..server.ticket import FailTicket from .dummyjail import DummyJail from .utils import LogCaptureTestCase TEST_FILES_DIR = os.path.join(os.path.dirname(__file__), "files") class ExecuteActions(LogCaptureTestCase): def setUp(self): """Call before every test case.""" super(ExecuteActions, self).setUp() self.__jail = DummyJail() self.__actions = Actions(self.__jail) self.__tmpfile, self.__tmpfilename = tempfile.mkstemp() def tearDown(self): super(ExecuteActions, self).tearDown() os.remove(self.__tmpfilename) def defaultActions(self): self.__actions.add('ip') self.__ip = self.__actions['ip'] self.__ip.actionstart = 'echo ip start 64 >> "%s"' % self.__tmpfilename self.__ip.actionban = 'echo ip ban >> "%s"' % self.__tmpfilename self.__ip.actionunban = 'echo ip unban >> "%s"' % self.__tmpfilename self.__ip.actioncheck = 'echo ip check >> "%s"' % self.__tmpfilename self.__ip.actionstop = 'echo ip stop >> "%s"' % self.__tmpfilename def testActionsAddDuplicateName(self): self.__actions.add('test') self.assertRaises(ValueError, self.__actions.add, 'test') def testActionsManipulation(self): self.__actions.add('test') self.assertTrue(self.__actions['test']) self.assertIn('test', self.__actions) self.assertNotIn('nonexistant action', self.__actions) self.__actions.add('test1') del self.__actions['test'] del self.__actions['test1'] self.assertNotIn('test', self.__actions) self.assertEqual(len(self.__actions), 0) self.__actions.setBanTime(127) self.assertEqual(self.__actions.getBanTime(),127) self.assertRaises(ValueError, self.__actions.removeBannedIP, '127.0.0.1') def testActionsOutput(self): self.defaultActions() self.__actions.start() with open(self.__tmpfilename) as f: time.sleep(3) self.assertEqual(f.read(),"ip start 64\n") self.__actions.stop() self.__actions.join() self.assertEqual(self.__actions.status(),[("Currently banned", 0 ), ("Total banned", 0 ), ("Banned IP list", [] )]) def testAddActionPython(self): self.__actions.add( "Action", os.path.join(TEST_FILES_DIR, "action.d/action.py"), {'opt1': 'value'}) self.assertLogged("TestAction initialised") self.__actions.start() time.sleep(3) self.assertLogged("TestAction action start") self.__actions.stop() self.__actions.join() self.assertLogged("TestAction action stop") self.assertRaises(IOError, self.__actions.add, "Action3", "/does/not/exist.py", {}) # With optional argument self.__actions.add( "Action4", os.path.join(TEST_FILES_DIR, "action.d/action.py"), {'opt1': 'value', 'opt2': 'value2'}) # With too many arguments self.assertRaises( TypeError, self.__actions.add, "Action5", os.path.join(TEST_FILES_DIR, "action.d/action.py"), {'opt1': 'value', 'opt2': 'value2', 'opt3': 'value3'}) # Missing required argument self.assertRaises( TypeError, self.__actions.add, "Action5", os.path.join(TEST_FILES_DIR, "action.d/action.py"), {}) def testAddPythonActionNOK(self): self.assertRaises(RuntimeError, self.__actions.add, "Action", os.path.join(TEST_FILES_DIR, "action.d/action_noAction.py"), {}) self.assertRaises(RuntimeError, self.__actions.add, "Action", os.path.join(TEST_FILES_DIR, "action.d/action_nomethod.py"), {}) self.__actions.add( "Action", os.path.join(TEST_FILES_DIR, "action.d/action_errors.py"), {}) self.__actions.start() time.sleep(3) self.assertLogged("Failed to start") self.__actions.stop() self.__actions.join() self.assertLogged("Failed to stop") def testBanActionsAInfo(self): # Action which deletes IP address from aInfo self.__actions.add( "action1", os.path.join(TEST_FILES_DIR, "action.d/action_modifyainfo.py"), {}) self.__actions.add( "action2", os.path.join(TEST_FILES_DIR, "action.d/action_modifyainfo.py"), {}) self.__jail.putFailTicket(FailTicket("1.2.3.4", 0)) self.__actions._Actions__checkBan() # Will fail if modification of aInfo from first action propagates # to second action, as both delete same key self.assertNotLogged("Failed to execute ban") self.assertLogged("action1 ban deleted aInfo IP") self.assertLogged("action2 ban deleted aInfo IP") self.__actions._Actions__flushBan() # Will fail if modification of aInfo from first action propagates # to second action, as both delete same key self.assertNotLogged("Failed to execute unban") self.assertLogged("action1 unban deleted aInfo IP") self.assertLogged("action2 unban deleted aInfo IP")