Changelog
=========

2015/12/05 (v0.5.0-1)
 - updating example.py

2015/11/18 (v0.5.0)
 - Closes bugs :
   - #11 Display only one osclass/osmatch instead of multiple

 - Change in data structure :
   - osmatch is a list of osclass	
   - osclass is a list of dictionnary
   - added cpe which is a list of string
   - added portused which is a list of dictionnary

   Data structure for a host looks like :
```python	
      {'addresses': {'ipv4': '127.0.0.1'},
       'hostnames': [],
       'osmatch': [{'accuracy': '98',
                    'line': '36241',
                    'name': 'Juniper SA4000 SSL VPN gateway (IVE OS 7.0)',
                    'osclass': [{'accuracy': '98',
                                 'cpe': ['cpe:/h:juniper:sa4000',
                                         'cpe:/o:juniper:ive_os:7'],
                                 'osfamily': 'IVE OS',
                                 'osgen': '7.X',
                                 'type': 'firewall',
                                 'vendor': 'Juniper'}]},
                   {'accuracy': '91',
                    'line': '17374',
                    'name': 'Citrix Access Gateway VPN gateway',
                    'osclass': [{'accuracy': '91',
                                 'cpe': [],
                                 'osfamily': 'embedded',
                                 'osgen': None,
                                 'type': 'proxy server',
                                 'vendor': 'Citrix'}]}],
       'portused': [{'portid': '443', 'proto': 'tcp', 'state': 'open'},
                    {'portid': '113', 'proto': 'tcp', 'state': 'closed'}],
       'status': {'reason': 'syn-ack', 'state': 'up'},
       'tcp': {113: {'conf': '3',
                     'cpe': '',
                     'extrainfo': '',
                     'name': 'ident',
                     'product': '',
                     'reason': 'conn-refused',
                     'state': 'closed',
                     'version': ''},
               443: {'conf': '10',
                     'cpe': '',
                     'extrainfo': '',
                     'name': 'http',
                     'product': 'Juniper SA2000 or SA4000 VPN gateway http config',
                     'reason': 'syn-ack',
                     'state': 'open',
                     'version': ''}},
       'vendor': {}}
```

2015/11/17 (v0.4.7)
 - Closes bugs :
   - #10 Error when trying to parse 'osclass' , 'osmatch'
     removed addresses, hostnames, status, vendor, osclass, uptime, osmatch
     from all_protocols()
 - Changed shebang line from python3 to python as it works with python2

2015/11/13 (v0.4.6)
 - Closes bugs :
   - #10 Error when trying to parse 'osclass' , 'osmatch'

2015/10/25 (v0.4.5)
 - Closes bugs :
   - #9 Can not pass ports with unicode string at scan function

2015/10/17 (v0.4.4)
 - Closes bugs :
   - #8 IPv6 Async scanner doesn't work

2015/09/11 (v0.4.3)
 - Change in url for __get_last_online_version

2015/09/11 (v0.4.2)
 - Closes bugs :
   - #7: Error with empty hostname
   - #6: Windows support of close_fds if you redirect stdin/stdout/stderr

2015/08/21 (v0.4.1)
 - Closes bugs :
   - #5: only one hostname stored per host
 - Add hostnames() method which return the list of hostnames as a list of
   dict [{'name':'hostname1', 'type':'PTR'}, {'name':'hostname2', 'type':'user'}]

2015/08/01 (v0.4.0)
 - Closes bugs :
   - #2: use close_fds in subprocess.Popen
   - #3: memory leak parsing xml using xml.dom.minidom
 - Corrects a bug in parsing osclass
 - Add nosetests for case testing
 - Removed test case in docstring

2015/05/08 (v0.3.7)
 - adding sudo parameter for scanning (idea from scupython)

2015/05/08 (v0.3.6)
 - correcting issue 7 : Issues under windows

2015/05/08 (v0.3.5)
 - correcting a bug in all_protocols()
 - correcting issue 8 : PortScannerAsync Doesn't work in windows...

2014/06/22 (v0.3.4)
 - adding PortScannerYield class with generator
   >>> nm = nmap.PortScannerYield()
   >>> for i in nm.scan('127.0.0.1/24', '22-25'):
   >>>     print(i)

2014/03/13 (v0.3.3)
 - moving file example.py
 - adding function convert_nmap_output_to_encoding
 - adding vendor for mac address

2013/09/23 (v0.3.2)
 - adding acces to CPE values under [host][proto][port]['cpe'] key

2013/07/27 (v0.3.1)
 - Bug correction on callback's assert in PortScannerAsync.scan
   proposed by Robert Bost

2013/06/23 (v0.3.0)
 - added support for NMAP SCRIPT ENGINE
   >>> r=nm.scan(hosts='127.0.0.1', ports='139', arguments="-sC ")
   >>> print(nm._scan_result['scan']['127.0.0.1']['hostscript'])

2013/02/24 (v0.2.7)
 - added an address block in host scan result which contains ipv4, mac and other addresses :
   nm = nmap.PortScanner()
   r = nm.scan(arguments='-sS -p T:22', hosts='192.168.1.3')
   print r['scan']['192.168.1.3']['addresses']
   {u'mac': u'02:50:43:F4:02:B1', u'ipv4': u'192.168.1.3'}
 - Adding a CSV scan output as a string.
 - Changes examples.py to make it python3 compliant

2012/12/13 (v0.2.6)
 - patch from lundberg.johan
 - bug correction : when nmap doesn't work displays stderr instead of stdout

2012/11/23 (v0.2.5)
 - corrected : Issue 2: "map.nmap.PortScannerError: 'nmap program was not found in path'" on CentOS
 - corrected : Issue 3: nmap.scan() short-circuits prematurely

2011/11/09 (v0.2.4)
 - implemented a request from Santhosh Edukulla <santhosh.edukulla@gmail.com> :
   parse OS scanning output
 - Error with multiple host specifications :
   bug and patch from old.schepperhand@gmail.com 

2011/11/04
 - bug in example.py : if no tcp port was open between 22-443

2010/12/17 (v0.2.3)
 - adding __get_last_online_version to check if current version is the last published

2010/12/17 (v0.2.2)
 - bug in handling nmap_error output (returned value was bin, string was expected)
 - removed test strings form __init__.py file.

2010/12/15 (v0.2.1)
 - corrected bug in __init__.py about scope problem
 - try to find nmap executable in known directories
 - raise AssertionError when trying to call command_line, scaninfo, scanstats, has_host before scanning

2010/12/14 (v0.2.0)
 - Make python-nmap works with Python 3.x
 - Contribution from Brian Bustin <brian at bustin.us>

2010/06/07 (v0.1.4)
 - Patches from Steve 'Ashcrow' Milner <steve at gnulinux.net>
 - remove shebang from __init__.py as it is not a runnable script
 - allow use with ALPHA and BETA nmap releases
 - .has_key() is deprecated, replaced instances with in
 - move to using the print function for python2 and 3 usage

2010/06/04
 - adding PortScanner.listscan
 - PortScanner.scan now returns scan_result
 - adding class PortScannerAsync (idea from Steve 'Ashcrow' Milner <steve at gnulinux.net>)

2010/06/03
 - Import on google code
   svn checkout https://python-nmap.googlecode.com/svn/trunk/ python-nmap --username  XXXXX
 - added PortScanner.scanstats method
 - updated example.py and documentation for pingsweep
 - updated Makefile for generating documentation

2010/03/09
 - Modified packaging. v0.1.1 [norman]

2010/03/08
 - Initial release. v0.1.0 [norman]
