File: LogicalImagerRuleBase.h

package info (click to toggle)
sleuthkit 4.12.1%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 18,608 kB
  • sloc: ansic: 143,795; cpp: 52,225; java: 37,892; xml: 2,416; python: 1,076; perl: 874; makefile: 439; sh: 184
file content (52 lines) | stat: -rwxr-xr-x 1,213 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
/*
** The Sleuth Kit
**
** Brian Carrier [carrier <at> sleuthkit [dot] org]
** Copyright (c) 2010-2019 Brian Carrier.  All Rights reserved
**
** This software is distributed under the Common Public License 1.0
**
*/

/**
* \file LogicalImagerRuleBase.h
* Contains the base class definitions for the Logicial Imager Rule.
*/

#pragma once

#include <string>
#include <algorithm>

#include "tsk/tsk_tools_i.h"

/**
* Implement the logical imager rule.
*
*/
class LogicalImagerRuleBase
{
public:
    LogicalImagerRuleBase();
    ~LogicalImagerRuleBase();

    /**
    * Base method for matching a file and its path against derived classes.
    * Derived classes must implement the matches method.
    *
    * @param fs_file TSK_FS_FILE containing the filename
    * @param path parent path to fs_file
    * @returns true if the path is in the rule
    *          false otherwise
    */
    virtual bool matches(TSK_FS_FILE *fs_file, const char *path) const = 0;

    /**
    * Validate a path.
    * Path containing the backslash character is invalid.
    *
    * @param path parent path to a file
    * @throws std::logic_error if the path is invalid
    */
    void validatePath(const std::string &path) const;
};