mirror of
https://github.com/nmap/nmap.git
synced 2025-12-06 12:41:29 +00:00
Note: Ndiff build will be broken until subsequent changes are made. Deprecation warnings will need to be addressed in future changes. Closes #2088
105 lines
5.9 KiB
Python
105 lines
5.9 KiB
Python
#!/usr/bin/env python3
|
|
|
|
# ***********************IMPORTANT NMAP LICENSE TERMS************************
|
|
# * *
|
|
# * The Nmap Security Scanner is (C) 1996-2022 Nmap Software LLC ("The Nmap *
|
|
# * Project"). Nmap is also a registered trademark of the Nmap Project. *
|
|
# * *
|
|
# * This program is distributed under the terms of the Nmap Public Source *
|
|
# * License (NPSL). The exact license text applying to a particular Nmap *
|
|
# * release or source code control revision is contained in the LICENSE *
|
|
# * file distributed with that version of Nmap or source code control *
|
|
# * revision. More Nmap copyright/legal information is available from *
|
|
# * https://nmap.org/book/man-legal.html, and further information on the *
|
|
# * NPSL license itself can be found at https://nmap.org/npsl/ . This *
|
|
# * header summarizes some key points from the Nmap license, but is no *
|
|
# * substitute for the actual license text. *
|
|
# * *
|
|
# * Nmap is generally free for end users to download and use themselves, *
|
|
# * including commercial use. It is available from https://nmap.org. *
|
|
# * *
|
|
# * The Nmap license generally prohibits companies from using and *
|
|
# * redistributing Nmap in commercial products, but we sell a special Nmap *
|
|
# * OEM Edition with a more permissive license and special features for *
|
|
# * this purpose. See https://nmap.org/oem/ *
|
|
# * *
|
|
# * If you have received a written Nmap license agreement or contract *
|
|
# * stating terms other than these (such as an Nmap OEM license), you may *
|
|
# * choose to use and redistribute Nmap under those terms instead. *
|
|
# * *
|
|
# * The official Nmap Windows builds include the Npcap software *
|
|
# * (https://npcap.com) for packet capture and transmission. It is under *
|
|
# * separate license terms which forbid redistribution without special *
|
|
# * permission. So the official Nmap Windows builds may not be *
|
|
# * redistributed without special permission (such as an Nmap OEM *
|
|
# * license). *
|
|
# * *
|
|
# * Source is provided to this software because we believe users have a *
|
|
# * right to know exactly what a program is going to do before they run it. *
|
|
# * This also allows you to audit the software for security holes. *
|
|
# * *
|
|
# * Source code also allows you to port Nmap to new platforms, fix bugs, *
|
|
# * and add new features. You are highly encouraged to submit your *
|
|
# * changes as a Github PR or by email to the dev@nmap.org mailing list *
|
|
# * for possible incorporation into the main distribution. Unless you *
|
|
# * specify otherwise, it is understood that you are offering us very *
|
|
# * broad rights to use your submissions as described in the Nmap Public *
|
|
# * Source License Contributor Agreement. This is important because we *
|
|
# * fund the project by selling licenses with various terms, and also *
|
|
# * because the inability to relicense code has caused devastating *
|
|
# * problems for other Free Software projects (such as KDE and NASM). *
|
|
# * *
|
|
# * The free version of Nmap is distributed in the hope that it will be *
|
|
# * useful, but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
# * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. Warranties, *
|
|
# * indemnification and commercial support are all available through the *
|
|
# * Npcap OEM program--see https://nmap.org/oem/ *
|
|
# * *
|
|
# ***************************************************************************/
|
|
|
|
import os
|
|
import os.path
|
|
import sys
|
|
|
|
from zenmapCore.Name import APP_NAME
|
|
|
|
|
|
def fs_dec(s): # This is unused now
|
|
"""Decode s from the filesystem decoding, handling various possible
|
|
errors."""
|
|
enc = sys.getfilesystemencoding()
|
|
if enc is None:
|
|
enc = "UTF-8"
|
|
return s.decode(enc)
|
|
|
|
|
|
def fs_enc(u):
|
|
"""Encode u to the filesystem decoding, handling various possible
|
|
errors."""
|
|
enc = sys.getfilesystemencoding()
|
|
if enc is None:
|
|
enc = "UTF-8"
|
|
return u.encode(enc)
|
|
|
|
# We can't just use os.path.expanduser(u"~") to get a unicode version of the
|
|
# home directory, because os.path.expanduser doesn't properly decode the raw
|
|
# byte string from the file system encoding. You get a UnicodeDecodeError on
|
|
# systems like Windows where the file system encoding is different from the
|
|
# result of sys.getdefaultencoding(). So we call os.path.expanduser with a
|
|
# plain string and decode it from the filesystem encoding.
|
|
HOME = os.path.expanduser("~")
|
|
|
|
# The base_paths dict in this file gives symbolic names to various files. For
|
|
# example, use base_paths.target_list instead of 'target_list.txt'.
|
|
|
|
base_paths = dict(user_config_file=APP_NAME + '.conf',
|
|
user_config_dir=os.path.join(HOME, '.' + APP_NAME),
|
|
scan_profile='scan_profile.usp',
|
|
profile_editor='profile_editor.xml',
|
|
recent_scans='recent_scans.txt',
|
|
target_list='target_list.txt',
|
|
options='options.xml',
|
|
user_home=HOME,
|
|
db=APP_NAME + ".db",
|
|
version=APP_NAME + "_version")
|