The reconnaissance of the company's network resources mainly consists in brute-force subdomains with the subsequent resolution of the found network blocks. Then new level 2 domains can be found and the procedure is repeated again. This allows new IP addresses to be found at each iteration.
This method is perhaps the most effective. However, there were situations where the whole / 24 subnet was not found.
Nowadays, another powerful tool has appeared - passive dns, which allows you to do the same as a classic DNS resolution, but using a special API. This can be, for example, "virustotal" or "passive-total". These services record DNS requests and responses that are collected from popular DNS servers. The advantage of this approach is that we don't need brute force. We just enter the IP address and get all known DNS records. Or, conversely, by specifying DNS, we get all the IP addresses that are associated with this name. This approach has an undeniable advantage - we can find old site servers that were resolved earlier. After all, older sites are more likely to contain vulnerabilities.
Despite the techniques described above, there are still several slightly less popular, but still giving results. In this article, we will look at two more intelligence techniques - looking up IP addresses by geographic data (geo2ip) and finding IP addresses by company name (reverse-whois).
Geo2ip
I think many of us know what geoip is. It is used quite often by both developers and administrators. However, geoip is mainly used in the ip -> geo direction. In our case, it is not so interesting. It's funny, but before developing your own solution, not a single library was found that allows you to make requests in the opposite direction geo → ip. Therefore, it was decided to write our own tool, moreover, it is not so difficult to implement it.
, python2.
:
geoip — ip → geo, city → ip, country → ip, lat:long → ip ..;
rwhois — whois ( ).
, geoip-:
, 2020 , geoip . .
geoip , . , , , . «%» (SQL-).
, IP-, , :
geoip , , - :
() . :
.
geoip- shodan:
, .
apache, , :
dns-:
. – mongo :
– memcached :
Reverse whois
Whois , 43/tcp . – IP-. . 5 , 5 :
(RIPE);
(APNIC);
(AFRINIC);
(ARIN);
(LACNIC).
whois :
whois 8.8.8.8
, telnet:
telnet whois.ripe.net 43
1.2.3.4
IP-. :
whois -h whois.ripe.net -T person admin@somecompany.com
whois -h whois.ripe.net -- '-i mnt-by RIPE-NCC-MNT'
, RIPE :
as-set;
aut-num;
domain;
inetnum;
organisation;
person;
role;
route.
, - «netname» «descr», . . , «-T person *@somecompany.com».
web-, , https://apps.db.ripe.net/db-web-ui/#/fulltextsearch. RIPE .
whois- :
RIPE: ftp://ftp.ripe.net/ripe/dbase/ripe.db.gz
APNIC: https://ftp.apnic.net/apnic/whois/apnic.db.inetnum.gz
AFRINIC: https://ftp.afrinic.net/dbase/afrinic.db.gz
LACNIC: https://ftp.lacnic.net/lacnic/dbase/lacnic.db.gz
ARIN: https://ftp.arin.net/pub/rr/arin.db.gz
, grep:
grep netname: *company* ripe.db
ripe.db () 5 GB. . , CIDR (, 77.77.0.0/16), grep .
– rwhois, geoip.
, :
5 . IP- :
:
-. IP- :
«descr»:
, :
CIDR-:
geo2ip + reverse whois
geoip rwhois .
, «telecom»:
— , :
, RECON . , - , . .
Author: Specialist of the Ural Center for Security Systems