NATS wrapper for fast scanner development
Project description
from scanner_api.wrappers import scanner_wrapper
- Define the worker function which takes two argumentw (source, data).
source - infromation about publisher (e.g. nmap.reporter.masscan - this can catch only in ‘nmap.**’) data - dict with JSON data for scanner, which NATS scheduler send
worker returns a list with data to be sent to next scanner or reporter. (each element of list will be sent as separate message)
You can redefine log format according logging module.
- def worker(source, data, meta):
result = [] result = processing…(data) logging.info(“i do work”) logging.warning(“i warn you”) logging.error(“i made a mistake”) return result
Make a wrapper with define scanner name. The data will be collected from NATS by this name. (e.g. name.***.*** or name). Also name its a queue name.
Define NATS host addr.
- wrapper = scanner_wrapper(
nats=[“nats://127.0.0.1:4222”], name=”reporter”)
Run by passing an argument worker function. This is blocking call!
wrapper.run(worker)
LOG FORMAT: Connected to nats. Started module named ‘{name}’ Received from ‘{subject}’: {data} Starting ‘{name}’ Result: {result} n Was sent to ‘{pipeline}’
- Here:
{name} - scanner name {subject} - queue name {data} - json from NATS {result} - out data from worker function {pipeline} - new addr in NATS queue
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for nats_scan_wrapper-0.1.8-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8bae205bb94ae82a73bf2544676b7c27ffbc97f71065e37cb1aaae65d52185cc |
|
MD5 | d3aadd5a9969ef417073ca1b667c0b45 |
|
BLAKE2b-256 | 8301cbaa8fea05c649d80bcff7334a81f4b77c7eaa7b489f55f732991f6f29a6 |