forked from 18F/domain-scan
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnoop.py
82 lines (65 loc) · 2.69 KB
/
noop.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
import logging
from typing import Tuple
from utils.scan_utils import ArgumentParser, make_values_single
###
# Testing scan function. Does nothing time consuming or destructive,
# but exercises many of the main hooks of domain-scan.
# Set a default number of workers for a particular scan type.
# Overridden by a --workers flag.
workers = 2
# Optional one-time initialization for all scans.
# If defined, any data returned will be passed to every scan instance and used
# to update the environment dict for that instance
# Will halt scan execution if it returns False or raises an exception.
#
# Run locally.
def init(environment: dict, options: dict) -> dict:
logging.debug("Init function.")
return {'constant': 12345}
# Optional one-time initialization per-scan. If defined, any data
# returned will be passed to the instance for that domain and used to update
# the environment dict for that particular domain.
#
# Run locally.
def init_domain(domain: str, environment: dict, options: dict) -> dict:
logging.debug("Init function for %s." % domain)
return {'variable': domain}
# Required scan function. This is the meat of the scanner, where things
# that use the network or are otherwise expensive would go.
#
# Runs locally or in the cloud (Lambda).
def scan(domain: str, environment: dict, options: dict) -> dict:
logging.debug("Scan function called with options: %s" % options)
# Perform the "task".
complete = True
logging.warning("Complete!")
return {
'complete': complete,
'constant': environment.get('constant'),
'variable': environment.get('variable')
}
# Required CSV row conversion function. Usually one row, can be more.
#
# Run locally.
def to_rows(data):
return [
[data['complete'], data['constant'], data['variable']]
]
# CSV headers for each row of data. Referenced locally.
headers = ["Completed", "Constant", "Variable"]
# Optional handler for custom CLI parameters. Takes the args (as a list of
# strings) and returns a dict of the options values and names that the scanner
# expects, and a list of the arguments it didn't know how to parse.
#
# Should return a dict of the options parsed by this parser (not a mutated form
# of the opts that are passed to it) and a list of the remaining args that it
# didn't recognize.
def handle_scanner_args(args, opts) -> Tuple[dict, list]:
parser = ArgumentParser(prefix_chars="--")
parser.add_argument("--noop-delay", nargs=1)
parsed, unknown = parser.parse_known_args(args)
dicted = vars(parsed)
should_be_single = ["noop_delay"]
dicted = make_values_single(dicted, should_be_single)
dicted["noop_delay"] = int(dicted["noop_delay"], 10)
return dicted, unknown