File: RegistryAnalyzer.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 (42 lines) | stat: -rwxr-xr-x 1,173 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
/*
** 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 RegistryAnalyzer.h
* Contains the class definitions for Registry Analyzer.
*/

#pragma once

#include <string>

#include "rejistry++/include/librejistry++.h"
#include "tsk/tsk_tools_i.h"
#include "RegHiveType.h"

class RegistryAnalyzer {
public:
    RegistryAnalyzer(const std::string &outputFilePath);
    ~RegistryAnalyzer();
    int analyzeSAMUsers() const;

private:
    int parseSAMVRecord(const unsigned char *pVRec, size_t aVRecLen, std::wstring &userName,
        std::wstring &userFullName, std::wstring &comment, uint32_t &acctType) const;

    int RegistryAnalyzer::parseSAMFRecord(const unsigned char *pFRec, long aFRecLen, FILETIME &lastLoginDate,
        FILETIME &lastPWResetDate, FILETIME &accountExpiryDate, FILETIME &lastFailedLoginDate,
        unsigned short &loginCount, unsigned short &acbFlags) const;

    RegistryAnalyzer(const RegistryAnalyzer&) = delete;

    std::string m_outputFilePath;
    FILE *m_outputFile;
};