2020-04-06 03:19:32 +09:00
package main
import (
"bufio"
"encoding/json"
"flag"
"fmt"
"golang.org/x/net/html"
"io"
"io/ioutil"
"net/http"
"net/url"
"os"
"strconv"
"strings"
)
/ *
template
| [ WebHackersWeapons ] ( https : //github.com/hahwul/WebHackersWeapons) | template | data:image/s3,"s3://crabby-images/eb817/eb817100ffaa2a30c16c47658e2b4165fc2b8b52" alt="" | data:image/s3,"s3://crabby-images/2c213/2c213613690069a99b8e5b0938f70d01ce1a1bfc" alt="" | data:image/s3,"s3://crabby-images/d1fa3/d1fa31fd791ebf572f79a913b27df53271361a13" alt=""<br>data:image/s3,"s3://crabby-images/a6646/a6646f985949a7b3ce4c2617b99b04841f1258ff" alt="" <br> data:image/s3,"s3://crabby-images/f4f5a/f4f5aeb6f71250c4f3e039a7e598f74a29fcf48e" alt="" <br> data:image/s3,"s3://crabby-images/2df73/2df738bc37cf9bd7b712259dd9e156243dca28bc" alt="" |
* /
type Tools struct {
2020-04-07 23:52:40 +09:00
Type , Data , Method string
2020-04-06 03:19:32 +09:00
}
func isTitleElement ( n * html . Node ) bool {
return n . Type == html . ElementNode && n . Data == "title"
}
func traverse ( n * html . Node ) ( string , bool ) {
if isTitleElement ( n ) {
return n . FirstChild . Data , true
}
for c := n . FirstChild ; c != nil ; c = c . NextSibling {
result , ok := traverse ( c )
if ok {
return result , ok
}
}
return "" , false
}
func GetHtmlTitle ( r io . Reader ) ( string , bool ) {
doc , err := html . Parse ( r )
if err != nil {
panic ( "Fail to parse html" )
}
return traverse ( doc )
}
2020-04-07 23:52:40 +09:00
func writeJSON ( category string , name string , method string , data string ) {
2020-04-06 03:19:32 +09:00
jsonFile , err := os . Open ( "data.json" )
// if we os.Open returns an error then handle it
if err != nil {
fmt . Println ( err )
}
fmt . Println ( "Successfully Opened data.json" )
// defer the closing of our jsonFile so that we can parse it later on
defer jsonFile . Close ( )
byteValue , _ := ioutil . ReadAll ( jsonFile )
var result map [ string ] interface { }
json . Unmarshal ( [ ] byte ( byteValue ) , & result )
tool := Tools {
2020-04-07 23:52:40 +09:00
Type : category ,
Data : data ,
Method : method ,
2020-04-06 03:19:32 +09:00
}
result [ name ] = tool
file , _ := json . MarshalIndent ( result , "" , " " )
_ = ioutil . WriteFile ( "data.json" , file , 0644 )
}
func main ( ) {
2020-04-08 02:13:26 +09:00
repourl := flag . String ( "url" , "" , "any url" )
2020-04-06 03:19:32 +09:00
first := flag . Bool ( "isFirst" , false , "if you add new type, it use" )
flag . Parse ( )
if flag . NFlag ( ) == 0 {
flag . Usage ( )
return
}
u , err := url . Parse ( * repourl )
if err != nil {
panic ( err )
}
if u . Host == "github.com" {
//fmt.Println(u.Path)
name := strings . Split ( u . Path , "/" ) [ 2 ]
//fmt.Println(name)
desc := "asdf"
resp , err := http . Get ( * repourl )
if err != nil {
panic ( err )
}
defer resp . Body . Close ( )
if title , ok := GetHtmlTitle ( resp . Body ) ; ok {
2020-04-11 02:28:57 +09:00
if strings . Contains ( string ( title ) , ": " ) {
desc = strings . Split ( string ( title ) , ": " ) [ 1 ]
} else {
reader1 := bufio . NewReader ( os . Stdin )
fmt . Println ( "[+] Don't have descriptions / input description" )
a , _ := reader1 . ReadString ( '\n' )
desc = strings . TrimRight ( a , "\r\n" )
}
2020-04-06 03:19:32 +09:00
} else {
println ( "Fail to get HTML title" )
}
typeFile , err := os . Open ( "type.lst" )
// if we os.Open returns an error then handle it
if err != nil {
fmt . Println ( err )
}
fmt . Println ( "Successfully Opened type.lst" )
// defer the closing of our jsonFile so that we can parse it later on
defer typeFile . Close ( )
index := 0
m := make ( map [ int ] string )
reader := bufio . NewReader ( typeFile )
for {
line , isPrefix , err := reader . ReadLine ( )
if isPrefix || err != nil {
break
}
m [ index ] = string ( line )
fmt . Println ( "[" + strconv . Itoa ( index ) + "] " + string ( line ) )
index = index + 1
}
var choicetype int
2020-04-07 23:52:40 +09:00
fmt . Println ( "[+] What is type?" )
2020-04-06 03:19:32 +09:00
_ , err = fmt . Scan ( & choicetype )
fmt . Println ( m [ choicetype ] )
2020-04-07 23:52:40 +09:00
reader1 := bufio . NewReader ( os . Stdin )
fmt . Println ( "[+] What is method(e.g XSS, WVS, SSL, ETC..)?" )
method , _ := reader1 . ReadString ( '\n' )
method = strings . TrimRight ( method , "\r\n" )
2020-04-08 00:29:23 +09:00
writeJSON ( m [ choicetype ] , name , method , "| " + m [ choicetype ] + "/" + method + " | [" + name + "](" + * repourl + ") | " + desc + " | data:image/s3,"s3://crabby-images/34d39/34d396906012675b8b6b2d2bdb459b172c61ca51" alt="" | data:image/s3,"s3://crabby-images/223b2/223b26a6da49cc76148e8b880ac17982f04f257d" alt="" |" )
2020-04-06 03:19:32 +09:00
} else {
reader := bufio . NewReader ( os . Stdin )
fmt . Println ( "[+] What is name?" )
name , _ := reader . ReadString ( '\n' )
name = strings . TrimRight ( name , "\r\n" )
fmt . Println ( "[+] Input Description?" )
udesc , _ := reader . ReadString ( '\n' )
udesc = strings . TrimRight ( udesc , "\r\n" )
typeFile , err := os . Open ( "type.lst" )
// if we os.Open returns an error then handle it
if err != nil {
fmt . Println ( err )
}
fmt . Println ( "Successfully Opened type.lst" )
// defer the closing of our jsonFile so that we can parse it later on
defer typeFile . Close ( )
index := 0
m := make ( map [ int ] string )
readerF := bufio . NewReader ( typeFile )
for {
line , isPrefix , err := readerF . ReadLine ( )
if isPrefix || err != nil {
break
}
m [ index ] = string ( line )
fmt . Println ( "[" + strconv . Itoa ( index ) + "] " + string ( line ) )
index = index + 1
}
var choicetype int
fmt . Println ( "What is type?" )
_ , err = fmt . Scan ( & choicetype )
fmt . Println ( m [ choicetype ] )
2020-04-07 23:52:40 +09:00
reader1 := bufio . NewReader ( os . Stdin )
fmt . Println ( "[+] What is method(e.g XSS, WVS, SSL, ETC..)?" )
method , _ := reader1 . ReadString ( '\n' )
method = strings . TrimRight ( method , "\r\n" )
2020-04-11 00:17:42 +09:00
writeJSON ( m [ choicetype ] , name , method , "| " + m [ choicetype ] + "/" + method + " | [" + name + "](" + * repourl + ") | " + udesc + "|data:image/s3,"s3://crabby-images/05e52/05e52cd1fe7a069ca6256810873caf896fac8d6d" alt=""|data:image/s3,"s3://crabby-images/05e52/05e52cd1fe7a069ca6256810873caf896fac8d6d" alt=""" )
2020-04-06 03:19:32 +09:00
}
if * first {
2020-04-07 23:52:40 +09:00
fmt . Println ( "| Type | Name | Description | Popularity | Language |" )
2020-04-06 03:19:32 +09:00
fmt . Println ( "| ---------- | :---------- | :----------: | :----------: | :----------: |" )
}
//fmt.Println("| [" + name + "](" + *repourl + ") | " + desc + " | data:image/s3,"s3://crabby-images/6ee68/6ee6847bf399019e3b6acd4a8f184e4512de646a" alt="" | data:image/s3,"s3://crabby-images/dd62e/dd62e06487e8051b1169e2ef26eb4608e8ed7de7" alt="" | data:image/s3,"s3://crabby-images/dea31/dea311eee943196983bf51cbe02e00b9ebd0ad65" alt=""<br>data:image/s3,"s3://crabby-images/0195d/0195d302aa60a11badb1afb6b3e50aa755a59999" alt="" <br> data:image/s3,"s3://crabby-images/85e62/85e6239a048a3e3d42842ccd819f0c4304c28447" alt="" <br> data:image/s3,"s3://crabby-images/ee1ba/ee1ba2d997cdc6254183b512e220a5d58e5f2b1b" alt="" |")
}