%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /backups/router/usr/local/lib/suricata/python/suricata/ctl/
Upload File :
Create Path :
Current File : //backups/router/usr/local/lib/suricata/python/suricata/ctl/filestore.py

# Copyright (C) 2018 Open Information Security Foundation
#
# You can copy, redistribute or modify this Program under the terms of
# the GNU General Public License version 2 as published by the Free
# Software Foundation.

# This program 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
# version 2 along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
# 02110-1301, USA.

from __future__ import print_function

import sys
import os
import os.path
import time
import re
import logging

logger = logging.getLogger("filestore")


class InvalidAgeFormatError(Exception):
    pass


def register_args(parser):
    subparser = parser.add_subparsers(help="sub-command help")
    prune_parser = subparser.add_parser("prune",
            help="Remove files in specified directory older than specified age")
    required_args = prune_parser.add_argument_group("required arguments")
    required_args.add_argument("-d", "--directory",
            help="filestore directory", required=True)
    required_args.add_argument("--age",
            help="prune files older than age, units: s, m, h, d")
    prune_parser.add_argument(
        "-n", "--dry-run", action="store_true", default=False,
        help="only print what would happen")
    prune_parser.add_argument(
        "-v", "--verbose", action="store_true",
        default=False, help="increase verbosity")
    prune_parser.add_argument(
        "-q", "--quiet", action="store_true", default=False,
        help="be quiet, log warnings and errors only")
    prune_parser.set_defaults(func=prune)


def is_fileinfo(path):
    return path.endswith(".json")


def parse_age(age):
    matched_age = re.match(r"(\d+)\s*(\w+)", age)
    if not matched_age:
        raise InvalidAgeFormatError(age)
    val = int(matched_age.group(1))
    unit = matched_age.group(2)
    ts_units = ["s", "m", "h", "d"]
    try:
        idx = ts_units.index(unit)
    except ValueError:
        raise InvalidAgeFormatError("bad unit: %s" % (unit))
    multiplier = 60 ** idx if idx != 3 else 24 * 60 ** 2
    return val * multiplier


def get_filesize(path):
    return os.stat(path).st_size


def remove_file(path, dry_run):
    size = 0
    size += get_filesize(path)
    if not dry_run:
        os.unlink(path)
    return size


def set_logger_level(args):
    if args.verbose:
        logger.setLevel(logging.DEBUG)
    if args.quiet:
        logger.setLevel(logging.WARNING)


def perform_sanity_checks(args):
    set_logger_level(args)
    err_msg = {
            "directory": "filestore directory must be provided",
            "age": "no age provided, nothing to do",
            }
    for val, msg in err_msg.items():
        if not getattr(args, val):
            print("Error: {}".format(msg), file=sys.stderr)
            sys.exit(1)
    required_dirs = ["tmp", "00", "ff"]
    for required_dir in required_dirs:
        if not os.path.exists(os.path.join(args.directory, required_dir)):
            logger.error("Provided directory is not a filestore directory")
            sys.exit(1)


def prune(args):
    perform_sanity_checks(args)
    age = parse_age(args.age)
    now = time.time()
    size = 0
    count = 0

    for dirpath, dirnames, filenames in os.walk(args.directory, topdown=True):
        # Do not go into the tmp directory.
        if "tmp" in dirnames:
            dirnames.remove("tmp")
        for filename in filenames:
            path = os.path.join(dirpath, filename)
            mtime = os.path.getmtime(path)
            this_age = now - mtime
            if this_age > age:
                logger.debug("Deleting %s; age=%ds", path, this_age)
                size += remove_file(path, args.dry_run)
                count += 1
    logger.info("Removed %d files; %d bytes.", count, size)
    return 0

Zerion Mini Shell 1.0