I'm writing a small script, that gathers some information using scapy and then returns some xml code, that I'll pass on to the xmlrpc interface of metasploit. I'd like it that my script only returns xml, and no additional warnings etc.
I can suppress most scapy output, with adding the option verbose=0
to my sr1 command. What I still get before every output, and I assume it returns this warning when I'm loading the module, is:
WARNING: No route found for IPv6 destination :: (no default route?)
I can easily redirect that output, by calling my script like this:
./myscript 2> /dev/null
but I'd like to incorporate this into the script. For that I've found a hint, that one could have a NullDevice class, that doesn't write anything, and then set sys.stderr
to an instantiation of that NullDevice class.
This only works unfortunately after I've already loaded the module, so I still have the Warning, and it only redirects any following messages sent to stderr.
How can I suppress that warning message to appear on my screen?
I think this is the correct way.
With Python3, redefining sys.stderr to None threw an exception AttributeError: 'NoneType' object has no attribute 'write'. Instead, defining it to
os.devnull
does the job:You can get rid of warnings by scapy by adding:
before importing Scapy. This will suppress all messages that have a lower level of seriousness than error messages.
for example:
I think perhaps the python3 version of scapy prints a message from a different logger or at a high level. Here's some code I've used to suppress output on module import.