line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
# |
2
|
|
|
|
|
|
|
# $Id$ |
3
|
|
|
|
|
|
|
# |
4
|
|
|
|
|
|
|
# forensic::scalpel Brik |
5
|
|
|
|
|
|
|
# |
6
|
|
|
|
|
|
|
package Metabrik::Forensic::Scalpel; |
7
|
1
|
|
|
1
|
|
699
|
use strict; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
28
|
|
8
|
1
|
|
|
1
|
|
6
|
use warnings; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
30
|
|
9
|
|
|
|
|
|
|
|
10
|
1
|
|
|
1
|
|
5
|
use base qw(Metabrik::Shell::Command Metabrik::System::Package); |
|
1
|
|
|
|
|
23
|
|
|
1
|
|
|
|
|
1683
|
|
11
|
|
|
|
|
|
|
|
12
|
|
|
|
|
|
|
# Default attribute values put here will BE inherited by subclasses |
13
|
|
|
|
|
|
|
sub brik_properties { |
14
|
|
|
|
|
|
|
return { |
15
|
0
|
|
|
0
|
1
|
|
revision => '$Revision$', |
16
|
|
|
|
|
|
|
tags => [ qw(unstable carving carve file filecarve filecarving) ], |
17
|
|
|
|
|
|
|
author => 'GomoR ', |
18
|
|
|
|
|
|
|
license => 'http://opensource.org/licenses/BSD-3-Clause', |
19
|
|
|
|
|
|
|
attributes => { |
20
|
|
|
|
|
|
|
datadir => [ qw(datadir) ], |
21
|
|
|
|
|
|
|
extensions => [ qw($extensions_list) ], |
22
|
|
|
|
|
|
|
conf => [ qw(file) ], |
23
|
|
|
|
|
|
|
}, |
24
|
|
|
|
|
|
|
attributes_default => { |
25
|
|
|
|
|
|
|
extensions => [ qw(doc pdf jpg png zip odt) ], |
26
|
|
|
|
|
|
|
conf => 'scalpel.conf', |
27
|
|
|
|
|
|
|
}, |
28
|
|
|
|
|
|
|
commands => { |
29
|
|
|
|
|
|
|
install => [ ], # Inherited |
30
|
|
|
|
|
|
|
generate_conf => [ qw($extensions_list|OPTIONAL file|OPTIONAL) ], |
31
|
|
|
|
|
|
|
scan => [ qw(file output|OPTIONAL conf|OPTIONAL) ], |
32
|
|
|
|
|
|
|
}, |
33
|
|
|
|
|
|
|
require_modules => { |
34
|
|
|
|
|
|
|
'Metabrik::File::Find' => [ ], |
35
|
|
|
|
|
|
|
'Metabrik::File::Text' => [ ], |
36
|
|
|
|
|
|
|
'Metabrik::File::Type' => [ ], |
37
|
|
|
|
|
|
|
'Metabrik::System::File' => [ ], |
38
|
|
|
|
|
|
|
}, |
39
|
|
|
|
|
|
|
require_binaries => { |
40
|
|
|
|
|
|
|
'scalpel' => [ ], |
41
|
|
|
|
|
|
|
}, |
42
|
|
|
|
|
|
|
need_packages => { |
43
|
|
|
|
|
|
|
ubuntu => [ qw(scalpel) ], |
44
|
|
|
|
|
|
|
debian => [ qw(scalpel) ], |
45
|
|
|
|
|
|
|
kali => [ qw(scalpel) ], |
46
|
|
|
|
|
|
|
}, |
47
|
|
|
|
|
|
|
}; |
48
|
|
|
|
|
|
|
} |
49
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
sub generate_conf { |
51
|
0
|
|
|
0
|
0
|
|
my $self = shift; |
52
|
0
|
|
|
|
|
|
my ($extensions, $file) = @_; |
53
|
|
|
|
|
|
|
|
54
|
0
|
|
|
|
|
|
my $datadir = $self->datadir; |
55
|
0
|
|
0
|
|
|
|
$extensions ||= $self->extensions; |
56
|
0
|
|
0
|
|
|
|
$file ||= $datadir.'/'.$self->conf; |
57
|
0
|
0
|
|
|
|
|
$self->brik_help_run_undef_arg('generate_conf', $extensions) or return; |
58
|
0
|
0
|
|
|
|
|
$self->brik_help_run_invalid_arg('generate_conf', $extensions, 'ARRAY') or return; |
59
|
0
|
0
|
|
|
|
|
$self->brik_help_run_undef_arg('generate_conf', $file) or return; |
60
|
|
|
|
|
|
|
|
61
|
0
|
0
|
|
|
|
|
my $sf = Metabrik::System::File->new_from_brik_init($self) or return; |
62
|
0
|
0
|
|
|
|
|
$sf->remove($file) or return; |
63
|
|
|
|
|
|
|
|
64
|
0
|
|
|
|
|
|
my $ext = [ |
65
|
|
|
|
|
|
|
{ case => "y", ext => "art", footer => "\\xcf\\xc7\\xcb", header => "\\x4a\\x47\\x04\\x0e", size => 150000, }, |
66
|
|
|
|
|
|
|
{ case => "y", ext => "art", footer => "\\xd0\\xcb\\x00\\x00", header => "\\x4a\\x47\\x03\\x0e", size => 150000, }, |
67
|
|
|
|
|
|
|
{ case => "y", ext => "gif", footer => "\\x00\\x3b", header => "\\x47\\x49\\x46\\x38\\x37\\x61", size => 5000000, }, |
68
|
|
|
|
|
|
|
{ case => "y", ext => "gif", footer => "\\x00\\x3b", header => "\\x47\\x49\\x46\\x38\\x39\\x61", size => 5000000, }, |
69
|
|
|
|
|
|
|
{ case => "y", ext => "jpg", footer => "\\xff\\xd9", header => "\\xff\\xd8\\xff\\xe0\\x00\\x10", size => 200000000, }, |
70
|
|
|
|
|
|
|
{ case => "y", ext => "png", footer => "\\xff\\xfc\\xfd\\xfe", header => "\\x50\\x4e\\x47?", size => 20000000, }, |
71
|
|
|
|
|
|
|
{ case => "y", ext => "bmp", footer => undef, header => "BM??\\x00\\x00\\x00", size => 100000, }, |
72
|
|
|
|
|
|
|
{ case => "y", ext => "tif", footer => undef, header => "\\x49\\x49\\x2a\\x00", size => 200000000, }, |
73
|
|
|
|
|
|
|
{ case => "y", ext => "tif", footer => undef, header => "\\x4D\\x4D\\x00\\x2A", size => 200000000, }, |
74
|
|
|
|
|
|
|
{ case => "y", ext => "avi", footer => undef, header => "RIFF????AVI", size => 50000000, }, |
75
|
|
|
|
|
|
|
{ case => "y", ext => "mov", footer => undef, header => "????moov", size => 10000000, }, |
76
|
|
|
|
|
|
|
{ case => "y", ext => "mov", footer => undef, header => "????mdat", size => 10000000, }, |
77
|
|
|
|
|
|
|
{ case => "y", ext => "mov", footer => undef, header => "????widev", size => 10000000, }, |
78
|
|
|
|
|
|
|
{ case => "y", ext => "mov", footer => undef, header => "????skip", size => 10000000, }, |
79
|
|
|
|
|
|
|
{ case => "y", ext => "mov", footer => undef, header => "????free", size => 10000000, }, |
80
|
|
|
|
|
|
|
{ case => "y", ext => "mov", footer => undef, header => "????idsc", size => 10000000, }, |
81
|
|
|
|
|
|
|
{ case => "y", ext => "mov", footer => undef, header => "????pckg", size => 10000000, }, |
82
|
|
|
|
|
|
|
{ case => "y", ext => "mpg", footer => "\\x00\\x00\\x01\\xb9", header => "\\x00\\x00\\x01\\xba", size => 50000000, }, |
83
|
|
|
|
|
|
|
{ case => "y", ext => "mpg", footer => "\\x00\\x00\\x01\\xb7", header => "\\x00\\x00\\x01\\xb3", size => 50000000, }, |
84
|
|
|
|
|
|
|
{ case => "y", ext => "fws", footer => undef, header => "FWS", size => 4000000 }, |
85
|
|
|
|
|
|
|
{ case => "y", ext => "doc", footer => "\\xd0\\xcf\\x11\\xe0\\xa1\\xb1\\x1a\\xe1\\x00\\x00", header => "\\xd0\\xcf\\x11\\xe0\\xa1\\xb1\\x1a\\xe1\\x00\\x00", size => 10000000, }, |
86
|
|
|
|
|
|
|
{ case => "y", ext => "doc", footer => undef, header => "\\xd0\\xcf\\x11\\xe0\\xa1\\xb1", size => 10000000, }, |
87
|
|
|
|
|
|
|
{ case => "y", ext => "pst", footer => undef, header => "\\x21\\x42\\x4e\\xa5\\x6f\\xb5\\xa6", size => 500000000, }, |
88
|
|
|
|
|
|
|
{ case => "y", ext => "ost", footer => undef, header => "\\x21\\x42\\x44\\x4e", size => 500000000, }, |
89
|
|
|
|
|
|
|
{ case => "y", ext => "dbx", footer => undef, header => "\\xcf\\xad\\x12\\xfe\\xc5\\xfd\\x74\\x6f", size => 10000000, }, |
90
|
|
|
|
|
|
|
{ case => "y", ext => "idx", footer => undef, header => "\\x4a\\x4d\\x46\\x39", size => 10000000, }, |
91
|
|
|
|
|
|
|
{ case => "y", ext => "mbx", footer => undef, header => "\\x4a\\x4d\\x46\\x36", size => 10000000, }, |
92
|
|
|
|
|
|
|
{ case => "y", ext => "wpc", footer => undef, header => "?WPC", size => 1000000 }, |
93
|
|
|
|
|
|
|
{ case => "n", ext => "htm", footer => " |