Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pry0cc/tew
A quick ‘n dirty nmap parser written in Golang to convert nmap xml to IP:Port notation.
https://github.com/pry0cc/tew
Last synced: 18 days ago
JSON representation
A quick ‘n dirty nmap parser written in Golang to convert nmap xml to IP:Port notation.
- Host: GitHub
- URL: https://github.com/pry0cc/tew
- Owner: pry0cc
- License: mit
- Created: 2022-03-15T03:41:08.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-07-03T20:51:48.000Z (5 months ago)
- Last Synced: 2024-11-15T02:32:29.552Z (27 days ago)
- Language: Go
- Homepage:
- Size: 1.85 MB
- Stars: 121
- Watchers: 3
- Forks: 23
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hacking-lists - pry0cc/tew - A quick ‘n dirty nmap parser written in Golang to convert nmap xml to IP:Port notation. (Go)
README
# tew
`tew` is a simple, quick 'n' dirty nmap parser for converting nmap xml output files to IP:Port notation.For example:
```
tew -x data/ex1/nmap.xml1.1.1.1:80
1.1.1.1.1:443
```This is useful for internal penetration tests and can be piped to httpx easily. As it is go, it compiles into a neat and tidy binary!
![Example](screenshots/example.jpeg?raw=true "Example of Tew")
# Installation
## Go install
```
go install github.com/pry0cc/tew@latest
```## Binaries
Binaries are available for most platforms and archectectures in the [releases page](https://github.com/pry0cc/tew/releases/latest).# Usage
```
# Run Nmap and save to XML outputnmap -T4 1.1.1.1 8.8.8.8 -oX file.xml
tew -x file.xml
tew -x file.xml -o output.txt
tew -x file.xml | httpx -json -o http.json
```## Stdin support
```
cat data/ex1/nmap.xml | go run main.go -x -
```93.184.216.34:80
93.184.216.34:443
1.1.1.1:80
8.8.8.8:53
8.8.8.8:443
8.8.4.4:53
8.8.4.4:443
1.0.0.1:53
1.1.1.1:53
1.1.1.1:443
1.0.0.1:80
1.0.0.1:443## DNSx Parsing
If you want to correlate DNSx JSON output, simply generate a JSON file and import it using the following syntax.
```
subfinder -d domain.com -o subs.txt
dnsx -l subs.txt -json -o dns.json
cat dns.json | jq -r '.a[]' | tee ips.txt
nmap -T4 -iL ips.txt -oX nmap.xmltew -x nmap.xml -dnsx dns.json --vhost | httpx -json -o http.json
```## URL Generation
If you want to passively generate URLs, you can do so with the `--urls` option.Note: This does not replace using httpx, prefer for occasions where stealth matters over accuracy. This does not check to see if the port is running a HTTP service nor does it send any requests.
```
tew -x nmap.xml -dnsx dns.json --vhost --urlshttp://example.com
https://example.com
```# Todo
- [x] Create auto build using github ci & autobuild
- [x] Add Arm64 for Darwin to Build
- [x] Use proper flags library
- [x] Add ability to import and use dnsx JSON & text output files - working on it!
- [x] Clean up DNSX Parsing module and sort unique
- [x] Add output text file as option
- [x] Test on Windows, Linux & Mac for cross-compatibility# Credit
- @hakluke - Thank you man for helping me fix that dumb bug :)
- @vay3t - Go Help
- @BruceEdiger - Go Help
- @mortensonsam - Go help!!
- @xstp - stdin support
- https://www.golangprograms.com - A lot of the code here is copy-pasted from the internet, at the time of writing, my go skills are copy-paste :P And that's ok if it works, right?