Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/franccesco/getaltname
Extract subdomains from SSL certificates in HTTPS sites.
https://github.com/franccesco/getaltname
certificates discovery dns extract-subdomains https information-retrieval infosec pentest pentest-scripts pentest-tool pentesting ssl ssl-certificate ssl-certificates subdomain tool
Last synced: 2 months ago
JSON representation
Extract subdomains from SSL certificates in HTTPS sites.
- Host: GitHub
- URL: https://github.com/franccesco/getaltname
- Owner: franccesco
- License: mit
- Created: 2017-11-13T03:28:10.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-11-01T17:53:01.000Z (2 months ago)
- Last Synced: 2024-11-01T18:29:07.496Z (2 months ago)
- Topics: certificates, discovery, dns, extract-subdomains, https, information-retrieval, infosec, pentest, pentest-scripts, pentest-tool, pentesting, ssl, ssl-certificate, ssl-certificates, subdomain, tool
- Language: Python
- Homepage: https://franccesco.github.io/getaltname/
- Size: 561 KB
- Stars: 366
- Watchers: 12
- Forks: 74
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-hacking-lists - franccesco/getaltname - Extract subdomains from SSL certificates in HTTPS sites. (Python)
README
# GSAN - Get Subject Alternative Names
**GSAN** is a tool that can extract [Subject Alternative Names](https://en.wikipedia.org/wiki/Subject_Alternative_Name) (SAN) found in SSL Certificates directly from https servers which can provide you with DNS names (subdomains) or virtual servers.
It doesn't rely on Certificate Transparency logs, it connects directly to the server and extracts the SANs from the certificate, which can be specially useful when you're analyzing internal servers or self-signed certificates.
## Installation
Use pip (or pipx - recommended) to avoid contaminating your system with a bunch of dependencies.
```bash
$ pipx install --user gsan
```You can also install and run it using Docker.
```bash
$ docker run --rm -i francc3sco/gsan
```## Usage
Basic usage is just passing the domain of an HTTPS server to the tool, and it will return a list of subdomains found in the certificate.
```bash
$ gsan microsoft.commicrosoft.com [126]:
- microsoft.com
- successionplanning.microsoft.com
- explore-security.microsoft.com
...
- wwwbeta.microsoft.com
- gigjam.microsoft.com
- mspartnerira.microsoft.com
...
```Alternatively, you can pass a text file with a list of domains to scan by using the `xargs` command.
```bash
$ cat domains.txt | xargs gsangoogle.com [93]:
- google.fr
...
- google.com.auamazon.com [37]:
- uedata.amazon.com
...
- origin-www.amazon.com.auyoutube.com [93]:
- google.fr
...
- google.com.au
```If you're using the dockerized version, you can achieve the same by doing:
```bash
$ cat domains.txt | xargs docker run --rm -i francc3sco/gsan
```You can combine gsan with other tools like shodan to get a list of SANs found in a list of domains or IP addresses as long as you respect the IP|DOMAIN:PORT format.
```bash
$ shodan search --fields ip_str,port --separator : --limit 100 https | cut -d : -f 1,2 | xargs gsan --timeout 1207.21.195.58 [1]:
- orielstat.com162.159.135.42 [4]:
- temp927.kinsta.cloud
- temp312.kinsta.cloud34.230.178.151 [2]:
- procareltc.com
- clarest.com20.62.53.137 [1]:
- budget.lis.virginia.gov199.60.103.228 [3]:
- hscoscdn40.net
- sites-proxy.hscoscdn40.net
...
```You can also output to a file by using the `--output` flag which can be useful to then pass the output to other tools such as Nmap.
```bash
$ gsan microsoft.com --output microsoft.txt | nmap -iL microsoft.txt
```Or, if you have a large list of domains:
```bash
$ cat domains.txt | xargs gsan --output domains.txt | nmap -iL domains.txt
```Or, if you want chaos to take the world:
```bash
$ shodan search --fields ip_str,port --separator : --limit 1000 has_ipv6:false https | \
cut -d : -f 1,2 | \
xargs gsan --timeout 1 --output sans.txt && \
sudo nmap -sS -F -vvv -iL sans.txt -oX import_to_metasploit.xml
```