Skip to content

Instantly share code, notes, and snippets.

View zeroSteiner's full-sized avatar

Spencer McIntyre zeroSteiner

View GitHub Profile
#!/usr/bin/env ruby
# meterpreter_command_scanner.rb
#
# This script is used for analyzing Metasploit Framework library and module source code files to identify references to
# the Meterpreter API. Originally implemented in support of https://github.com/rapid7/metasploit-framework/pull/15079.
#
require 'find'
# These are ignored because they do not invoke a Meterpreter command.
@zeroSteiner
zeroSteiner / zpycompletion.py
Created April 2, 2021 00:23
ZSH completion from argparse
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
#
# zpycompletion
#
# Copyright 2015 Spencer McIntyre <[email protected]>
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
@zeroSteiner
zeroSteiner / pyenv-each
Created March 17, 2021 21:03
Python test harness
#!/usr/bin/env bash
set -e
py_stdout_fd=1
py_stderr_fd=2
delay=0
timeout=10
params=()
show_help () {
@zeroSteiner
zeroSteiner / Proxy Shim
Created August 12, 2020 18:13
Example of a proxy shim for external Metasploit modules
if __name__ == "__main__":
env = dict(os.environ)
if 'LD_PRELOAD' in env:
module.run(metadata, run)
else:
env['LD_PRELOAD'] = 'libproxychains4.so'
os.execve(os.path.realpath(__file__), sys.argv, env)
@zeroSteiner
zeroSteiner / request_redirect.yml
Created November 20, 2019 17:11
King Phisher Request Redirect Rules
# originally from Jason Lang (@curi0usJack)
# https://gist.github.com/curi0usJack/971385e8334e189d93a6cb4671238b10
# version 1.1
rules:
# TrendMicro
- source: 150.70.0.0/22
target: https://www.google.com/
- source: 150.70.104.0/22
target: https://www.google.com/
- source: 150.70.110.0/24
@zeroSteiner
zeroSteiner / log_handler.py
Last active April 6, 2022 19:14
Python logging.Handler for use in external Metasploit modules.
import logging
import metasploit.module as module
class MetasploitLogHandler(logging.Handler):
def emit(self, record):
log_entry = self.format(record)
level = 'debug'
if record.levelno >= logging.ERROR:
level = 'error'
elif record.levelno >= logging.WARNING:
$LOAD_PATH.unshift(File.dirname(__FILE__) + '/net-ssh/lib')
require 'net/ssh'
require 'socket'
if ARGV.length > 1
server = TCPServer.new 2000
loop do
client = server.accept
puts 'client connected'
@zeroSteiner
zeroSteiner / crontab
Created September 21, 2015 15:29
crontab one time payload execution template
# /etc/crontab: system-wide crontab
# Unlike any other crontab you don't have to run the `crontab'
# command to install the new version when you edit this file
# and files in /etc/cron.d. These files also have username fields,
# that none of the other crontabs do.
SHELL=/bin/sh
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
# m h dom mon dow user command
@zeroSteiner
zeroSteiner / bt_shell.py
Last active February 24, 2021 06:13
Python Bluetooth shell with PTY support
#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# bt_shell.py
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
@zeroSteiner
zeroSteiner / meterpreter_transport.rb
Created July 1, 2015 18:33
Metasploit meterpreter transport test module
require 'msf/core'
require 'rex'
lib = File.join(Msf::Config.install_root, "test", "lib")
$:.push(lib) unless $:.include?(lib)
require 'module_test'
class Metasploit4 < Msf::Post