App-Hack-Exe
view release on metacpan or search on metacpan
lib/App/Hack/Exe.pm view on Meta::CPAN
sub _dots {
my ($self, $text) = @_;
print $text;
# 10 = length of '[COMPLETE]'
my $num_dots = DOTS_WIDTH - 10 - length $text;
my $pause_for = DOTS_DURATION / $num_dots;
while ($num_dots --> 0) {
print '.';
$self->_sleep($pause_for);
}
say '[', colored('COMPLETE', 'bold green'), ']';
$self->_sleep(0.6);
return;
}
sub _get_ip {
my ($self, $hostname) = @_;
$self->_dots('Enumerating Target');
say ' [+] Host: ', $hostname;
my %ips = _lookup_ips($hostname);
my %to_get = (
'IPv4' => $self->{get_ipv4},
'IPv6' => $self->{get_ipv6},
);
foreach my $ip_type (sort keys %ips) {
my $addrs = $ips{$ip_type};
foreach my $addr (@{$addrs}) {
if ($to_get{$ip_type} --> 0) {
say " [+] $ip_type: $addr";
}
}
}
return;
}
sub _lookup_ips {
my $hostname = shift;
my %ips;
my %family_map = (
lib/App/Hack/Exe.pm view on Meta::CPAN
my $bracket_width = length "@proxies"; # (sic)
my $proxy_ct = scalar @proxies;
my @chained;
print " [+] 0/$proxy_ct proxies chained {", MEMORIZE_CURSOR, (' ' x $bracket_width), '}';
$self->_sleep(0.2);
while (@proxies) {
push @chained, shift @proxies;
print "\r [+] ", (scalar @chained), RECALL_CURSOR, "@chained";
$self->_sleep(0.2);
}
say '';
return;
}
sub _launchproxy {
my $self = shift;
$self->_dots('Opening SOCKS5 ports on infected hosts');
say ' [+] SSL entry point on 127.0.0.1:1337';
return;
}
sub _portknock {
my $self = shift;
my @ports = @{$self->{ports}};
$self->_dots('Launching port knocking sequence');
# Interpolation glue
local $" = ',';
my $bracket_width = length "@ports"; # (sic)
lib/App/Hack/Exe.pm view on Meta::CPAN
print ' [+] Knock on TCP<', MEMORIZE_CURSOR, (' ' x $bracket_width), '>', RECALL_CURSOR;
$self->_sleep(0.2);
while (@ports) {
push @knocked, shift @ports;
print $knocked[-1];
if (@ports) {
print $";
}
$self->_sleep(0.2);
}
say '';
return;
}
sub _prompt {
my $self = shift;
my $hostname = shift;
$self->_sleep(0.5);
my $prompt = "root\@$hostname:~# ";
print $prompt;
# Wait for the user to press Ctrl-d
lib/App/Hack/Exe.pm view on Meta::CPAN
my ($self, @args) = @_;
if ($self->{no_delay}) {
@args = (0);
}
return sleep @args;
}
sub _w00tw00t {
my $self = shift;
$self->_dots('Sending PCAP datagrams for fragmentation overlap');
say ' [+] Stack override ***** w00t w00t g0t r00t!';
say '';
print '[';
my $chars = 65;
while ($chars --> 0) {
print '=';
$self->_sleep(0.01);
}
say ']';
return;
}
=head1 METHODS
=head2 C<run( $hostname )>
Run the simulation.
=cut
lib/App/Hack/Exe.pm view on Meta::CPAN
local $| = 1;
print _colored_demon();
$self->_get_ip($hostname);
$self->_launchproxy;
$self->_chainproxies;
$self->_portknock;
$self->_w00tw00t;
$self->_prompt($hostname);
say 'Done';
return;
}
=head1 AUTHOR
Dan Church (h3xx<attyzatzat>gmx<dottydot>com)
=head1 LICENSE AND COPYRIGHT
Copyright (C) 2023 Dan Church.
( run in 0.444 second using v1.01-cache-2.11-cpan-a1f116cd669 )