HEX
Server: Apache
System: Linux vpshost0650.publiccloud.com.br 4.4.79-grsec-1.lc.x86_64 #1 SMP Wed Aug 2 14:18:21 -03 2017 x86_64
User: bandeirantesbomb3 (10068)
PHP: 8.0.7
Disabled: 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
Upload Files
File: //usr/lib/python2.7/site-packages/lap/check_log.py
import subprocess


def tail(file, lines):
    command = "tail -n {0} {1}".format(lines, file)
    process = subprocess.Popen(command.split(), stdout=subprocess.PIPE, stderr=subprocess.PIPE)
    output, err = process.communicate()
    return(output)


def __run__(params):
    repet = params.get("repeat", 20)
    lines = params.get("lastlines", 10000)
    files = params.get("files", False)
    search = params.get("search", False)
    witherrors = []

    if not (files or not search):
        return([1, "Arquivos e/ou Path e/ou Mensagem ausentes do YAML"])

    try:
        for file in files.split(","):
            log = tail(file, lines)
            count = [line for line in log.split("\n") if search in line]

            if len(count) >= repet:
                witherrors.append("%s=%s" % (file.split("/")[-1], len(count)))

        if witherrors:
            return([2, witherrors])
        else:
            return([0, "OK"])

    except IOError:
        return([2, "Arquivo informado inexistente no filesystem"])

    except Exception, err:
        return([2, err])