Skip to content

Instantly share code, notes, and snippets.

@speeddragon
speeddragon / kali-linux-wl-fix.sh
Last active February 18, 2024 13:05
Kali Linux fix for "modprobe: FATAL: Module wl not found"
# Update and install necessary packages
apt-get update
apt-get install linux-image-$(uname -r|sed 's,[^-]*-[^-]*-,,') linux-headers-$(uname -r|sed 's,[^-]*-[^-]*-,,')
# Download some extra packages, that do the trick for "wl module not found"
wget http://http.kali.org/kali/pool/main/l/linux-tools/linux-kbuild-4.3_4.3.1-2kali1_amd64.deb
wget http://http.kali.org/kali/pool/main/l/linux/linux-headers-4.3.0-kali1-common_4.3.3-5kali4_amd64.deb
wget http://http.kali.org/kali/pool/main/l/linux/linux-headers-4.3.0-kali1-amd64_4.3.3-5kali4_amd64.deb
# Install with correct order
@speeddragon
speeddragon / bin_split.exs
Created September 13, 2023 18:03
Split binary file by odd/even bytes in Elixir
{:ok, binary} = File.read("original.bin")
{f1, f2} = binary
|> :binary.bin_to_list()
|> Enum.reduce({"", ""}, fn hex, {f1, f2} ->
if byte_size(f1) != byte_size(f2) do
{f1, f2 <> <<hex>>}
else
{f1 <> <<hex>>, f2}
end
@speeddragon
speeddragon / wordpress-backdoor.yml
Last active July 1, 2023 09:36
Wordpress Backdoor Search with Ansible
- hosts: www_servers
user: ubuntu
sudo: yes
vars:
folder: /usr/share/nginx/html
backdoor_keywords:
- "FilesMan" # OK
- "<?php \\${" # OK
- 'mail(stripslashes(' # OK
- "<?php \\$array = array(" # OK
@speeddragon
speeddragon / facebook.js
Created December 10, 2019 23:14
Facebook Image Crawler for Puppeteer
/**
* Facebook Image Crawler
*/
const puppeteer = require("puppeteer");
var https = require("https");
/**
* Get the biggest image possivel from FBID.
* @param {string} fbid
@speeddragon
speeddragon / php-backdoor-removal.sh
Last active May 6, 2022 15:48
PHP/Wordpress Backdoor Removal
#
#
# WORDPRESS BASH SCRIPT TO CLEAN BACKDOOR FILES
#
#
DOMAIN=$1
FOLDER=$2
AWS_KEYFILE=~/aws.pem
@speeddragon
speeddragon / streaming_file_sink.scala
Created January 10, 2020 02:51
StreamingFileSink
val env = StreamExecutionEnvironment.getExecutionEnvironment
val source = new FlinkKafkaConsumer(settings.kafkaTopic(), new AugmentedMessageDeserializer, kafkaProperties)
val writer = Writer(settings.s3Path(), GenericRecordSchema.schema.toString()).build()
env
.enableCheckpointing(checkpointInterval)
.addSource(source)
.addSink(writer)
@speeddragon
speeddragon / AugmentedMessageDeserializer.scala
Created January 25, 2020 23:11
AugmentedMessageDeserializer
class AugmentedMessageDeserializer extends MessageKafkaDeserializer[GenericRecord] with LazyLogging {
override def deserialize(record: ConsumerRecord[Array[Byte], Array[Byte]]): GenericRecord = {
val genericRecord: Try[GenericRecord] = retrieveGenericRecord(record)
genericRecord match {
case Success(value) => value
case Failure(exception) =>
val key = new String(record.key(), UTF_8)
val value = new String(record.value(), UTF_8)
@speeddragon
speeddragon / custom_file_sink.scala
Last active January 16, 2020 13:30
Custom File Sink for Parquet( List[GenericRecord] )
val env = StreamExecutionEnvironment.getExecutionEnvironment
env.setStreamTimeCharacteristic(TimeCharacteristic.EventTime)
...
val source = new FlinkKafkaConsumer(settings.kafkaTopic(), new AugmentedMessageDeserializer, kafkaProperties)
.assignTimestampsAndWatermarks(new AscendingTimestampExtractor[GenericRecord] {
def extractAscendingTimestamp(element: GenericRecord): Long =
Instant
.parse(element.get("timestamp").asInstanceOf[String])
@speeddragon
speeddragon / streaming_file_sink_row_encode.scala
Created January 10, 2020 02:47
StreamingFileSink with Custom Rolling Policy
case class Writer(pathString: String, schema: String) {
def build(): StreamingFileSink[GenericRecord] = {
val path = new Path(pathString)
val encoder = new ParquetEncoder();
StreamingFileSink
.forRowFormat(path, encoder)
.withRollingPolicy(new MyRollingPolicy(60000))
.withBucketAssigner(new MessageBucketAssigner)
@speeddragon
speeddragon / server.py
Created August 29, 2019 11:07
Python Server without CORS enabled
#!/usr/bin/env python3
from http.server import HTTPServer, SimpleHTTPRequestHandler, test
import sys
class CORSRequestHandler (SimpleHTTPRequestHandler):
def end_headers (self):
self.send_header('Access-Control-Allow-Origin', '*')
SimpleHTTPRequestHandler.end_headers(self)
if __name__ == '__main__':