Skip to content

Commit 1783400

Browse files
Enrich secret patterns and able to skip files during scans
1 parent 1f02738 commit 1783400

File tree

12 files changed

+1115
-18
lines changed

12 files changed

+1115
-18
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,7 @@ OOTT suits for pentesters and for code reviewing
1010
./oott -localscan # Current directory
1111
./oott -localscan -lp /tmp/
1212
```
13+
Feel free to contribute the `secretpatterns.json` file to enrich the secret scanning capability
1314

1415
## Sub-domain scanning
1516
```

cli/emailscan.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,7 @@ func StartEmailScan(domain string) []emails.EmailDetails {
3030
}
3131
helper.InfoPrintln("<========================================================================================")
3232
helper.InfoPrintln("If you agree the uses of modules, press Enter to continue...")
33-
fmt.Scanln()
33+
_, _ = fmt.Scanln()
3434

3535
var emailLists []emails.EmailDetails
3636
emailMap := make(map[string]string)

cli/root.go

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -59,6 +59,7 @@ func Start() {
5959

6060
// Util
6161
flag.BoolVar(&lib.Config.LocalScanOnly, "localscan", false, "Perform local scanning only.")
62+
flag.BoolVar(&lib.Config.LocalScanOnly, "l", false, "Perform local scanning only. (shorthand)")
6263
flag.StringVar(&lib.Config.LocalScanPath, "lp", ".", "Local scanning path.")
6364

6465
flag.Parse()

cli/secretscan.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@ func StartSecretScan(domain string) []secrets.SecretDetails {
2828
}
2929
helper.InfoPrintln("<========================================================================================")
3030
helper.InfoPrintln("If you agree the uses of modules, press Enter to continue...")
31-
fmt.Scanln()
31+
_, _ = fmt.Scanln()
3232

3333
var secretsLists []secrets.SecretDetails
3434
for _, ss := range secretsScanner {

cli/subdomainscan.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -42,7 +42,7 @@ func StartSubDomainScan(domain string) []subdomains.SubDomainDetails {
4242
}
4343
helper.InfoPrintln("<========================================================================================")
4444
helper.InfoPrintln("If you agree the uses of modules, press Enter to continue...")
45-
fmt.Scanln()
45+
_, _ = fmt.Scanln()
4646

4747
var subdomainLists []subdomains.SubDomainDetails
4848
for _, sf := range subdomainScanResults {

cli/webscan.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,7 @@ func StartWebScan(domains []string) []webscans.WebsiteDetails {
4747
}
4848
helper.InfoPrintln("<========================================================================================")
4949
helper.InfoPrintln("If you agree the uses of modules, press Enter to continue...")
50-
fmt.Scanln()
50+
_, _ = fmt.Scanln()
5151

5252
var websiteResults []webscans.WebsiteDetails
5353
for _, sf := range webscanners {

common/github.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,7 @@ func SearchGithubRepoByKeyword(keywords string) []GithubRepo {
3131
helper.ErrorPrintln("[!] No personal access token provided. Process can not be proceed...")
3232
helper.ErrorPrintln("[!] Please go to https://github.com/settings/tokens to create one, no any permission needed.")
3333
helper.ErrorPrintln("Press Enter to continue...")
34-
fmt.Scanln()
34+
_, _ = fmt.Scanln()
3535
return nil
3636
}
3737

defaults/secretpatterns.json

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -44,8 +44,12 @@
4444
"HockeyApp": "(?i)hockey.{0,50}(\\\"|'|`)?[0-9a-f]{32}(\\\"|'|`)?",
4545
"Username and password in URI": "([\\w+]{1,24})(://)([^$<]{1})([^\\s\";]{1,}):([^$<]{1})([^\\s\";/]{1,})@[-a-zA-Z0-9@:%._\\+~#=]{1,256}\\.[a-zA-Z0-9()]{1,24}([^\\s]+)",
4646
"Password in file": "(?i)(?:password|pwd|passwd|pass)\\s*=\\s*(?:\"([^\"]+)\"|'([^']+)')",
47+
"Password in URL": "[a-zA-Z]{3,10}://[^/\\s:@]{3,50}:[^/\\s:@]{3,50}@.{1,100}",
4748
"NuGet API Key": "oy2[a-z0-9]{43}",
49+
"Base64 Encoded RSA Private Key": "LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0t[%a-zA-Z0-9+\/]+={0,2}",
4850
"OpenWeather API Key": "(?i)appid=(\\\"|'|`)?[0-9a-f]{32}(\\\"|'|`)?",
51+
"JFrog API Key": "AKCp8[a-zA-Z0-9]{68}",
4952
"StackHawk API Key": "hawk\\.[0-9A-Za-z\\-_]{20}\\.[0-9A-Za-z\\-_]{20}",
50-
"OpenAI API Key": "api_key=(\"|'|`)([a-zA-Z0-9-]{32,})(\"|'|`)"
53+
"OpenAI API Key": "api_key=(\"|'|`)([a-zA-Z0-9-]{32,})(\"|'|`)",
54+
"Azure Open AI API Key": "[a|A][z|Z][u|U][r|R][e|E]_[o|O][p|P][e|E][n|N][a|A][i|I].+[k|K][e|E][y|Y].+['\"\\s][a-z0-9]{32}['\"\\s]"
5155
}

go.mod

Lines changed: 182 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1,20 +1,194 @@
11
module oott
22

3-
go 1.20
3+
go 1.22.1
44

55
require (
6+
4d63.com/gocheckcompilerdirectives v1.2.1 // indirect
7+
4d63.com/gochecknoglobals v0.2.1 // indirect
8+
github.com/4meepo/tagalign v1.3.4 // indirect
9+
github.com/Abirdcfly/dupword v0.1.1 // indirect
10+
github.com/Antonboom/errname v0.1.13 // indirect
11+
github.com/Antonboom/nilnil v0.1.9 // indirect
12+
github.com/Antonboom/testifylint v1.4.3 // indirect
13+
github.com/BurntSushi/toml v1.4.1-0.20240526193622-a339e1f7089c // indirect
14+
github.com/Crocmagnon/fatcontext v0.5.2 // indirect
15+
github.com/Djarvur/go-err113 v0.0.0-20210108212216-aea10b59be24 // indirect
16+
github.com/GaijinEntertainment/go-exhaustruct/v3 v3.3.0 // indirect
17+
github.com/Masterminds/semver/v3 v3.3.0 // indirect
18+
github.com/OpenPeeDeeP/depguard/v2 v2.2.0 // indirect
619
github.com/PuerkitoBio/goquery v1.8.1 // indirect
20+
github.com/alecthomas/go-check-sumtype v0.1.4 // indirect
21+
github.com/alexkohler/nakedret/v2 v2.0.4 // indirect
22+
github.com/alexkohler/prealloc v1.0.0 // indirect
23+
github.com/alingse/asasalint v0.0.11 // indirect
724
github.com/andybalholm/cascadia v1.3.1 // indirect
25+
github.com/ashanbrown/forbidigo v1.6.0 // indirect
26+
github.com/ashanbrown/makezero v1.1.1 // indirect
27+
github.com/beorn7/perks v1.0.1 // indirect
28+
github.com/bkielbasa/cyclop v1.2.1 // indirect
29+
github.com/blizzy78/varnamelen v0.8.0 // indirect
30+
github.com/bombsimon/wsl/v4 v4.4.1 // indirect
31+
github.com/breml/bidichk v0.2.7 // indirect
32+
github.com/breml/errchkjson v0.3.6 // indirect
33+
github.com/butuzov/ireturn v0.3.0 // indirect
34+
github.com/butuzov/mirror v1.2.0 // indirect
35+
github.com/catenacyber/perfsprint v0.7.1 // indirect
36+
github.com/ccojocar/zxcvbn-go v1.0.2 // indirect
37+
github.com/cespare/xxhash/v2 v2.1.2 // indirect
38+
github.com/charithe/durationcheck v0.0.10 // indirect
39+
github.com/chavacava/garif v0.1.0 // indirect
40+
github.com/ckaznocha/intrange v0.2.0 // indirect
41+
github.com/curioswitch/go-reassign v0.2.0 // indirect
42+
github.com/daixiang0/gci v0.13.5 // indirect
843
github.com/dave/dst v0.27.3 // indirect
44+
github.com/davecgh/go-spew v1.1.1 // indirect
45+
github.com/denis-tingaikin/go-header v0.5.0 // indirect
946
github.com/ditashi/jsbeautifier-go v0.0.0-20141206144643-2520a8026a9c // indirect
10-
github.com/fatih/color v1.15.0 // indirect
47+
github.com/ettle/strcase v0.2.0 // indirect
48+
github.com/fatih/color v1.17.0 // indirect
49+
github.com/fatih/structtag v1.2.0 // indirect
50+
github.com/firefart/nonamedreturns v1.0.5 // indirect
51+
github.com/fsnotify/fsnotify v1.5.4 // indirect
52+
github.com/fzipp/gocyclo v0.6.0 // indirect
53+
github.com/ghostiam/protogetter v0.3.6 // indirect
54+
github.com/go-critic/go-critic v0.11.4 // indirect
55+
github.com/go-toolsmith/astcast v1.1.0 // indirect
56+
github.com/go-toolsmith/astcopy v1.1.0 // indirect
57+
github.com/go-toolsmith/astequal v1.2.0 // indirect
58+
github.com/go-toolsmith/astfmt v1.1.0 // indirect
59+
github.com/go-toolsmith/astp v1.1.0 // indirect
60+
github.com/go-toolsmith/strparse v1.1.0 // indirect
61+
github.com/go-toolsmith/typep v1.1.0 // indirect
62+
github.com/go-viper/mapstructure/v2 v2.1.0 // indirect
63+
github.com/go-xmlfmt/xmlfmt v1.1.2 // indirect
64+
github.com/gobwas/glob v0.2.3 // indirect
65+
github.com/gofrs/flock v0.12.1 // indirect
66+
github.com/golang/protobuf v1.5.3 // indirect
67+
github.com/golangci/dupl v0.0.0-20180902072040-3e9179ac440a // indirect
68+
github.com/golangci/gofmt v0.0.0-20240816233607-d8596aa466a9 // indirect
69+
github.com/golangci/golangci-lint v1.61.0 // indirect
70+
github.com/golangci/misspell v0.6.0 // indirect
71+
github.com/golangci/modinfo v0.3.4 // indirect
72+
github.com/golangci/plugin-module-register v0.1.1 // indirect
73+
github.com/golangci/revgrep v0.5.3 // indirect
74+
github.com/golangci/unconvert v0.0.0-20240309020433-c5143eacb3ed // indirect
75+
github.com/google/go-cmp v0.6.0 // indirect
76+
github.com/gordonklaus/ineffassign v0.1.0 // indirect
77+
github.com/gostaticanalysis/analysisutil v0.7.1 // indirect
78+
github.com/gostaticanalysis/comment v1.4.2 // indirect
79+
github.com/gostaticanalysis/forcetypeassert v0.1.0 // indirect
80+
github.com/gostaticanalysis/nilerr v0.1.1 // indirect
81+
github.com/hashicorp/go-version v1.7.0 // indirect
82+
github.com/hashicorp/hcl v1.0.0 // indirect
83+
github.com/hexops/gotextdiff v1.0.3 // indirect
84+
github.com/inconshreveable/mousetrap v1.1.0 // indirect
85+
github.com/jgautheron/goconst v1.7.1 // indirect
86+
github.com/jingyugao/rowserrcheck v1.1.1 // indirect
87+
github.com/jirfag/go-printf-func-name v0.0.0-20200119135958-7558a9eaa5af // indirect
88+
github.com/jjti/go-spancheck v0.6.2 // indirect
89+
github.com/julz/importas v0.1.0 // indirect
90+
github.com/karamaru-alpha/copyloopvar v1.1.0 // indirect
91+
github.com/kisielk/errcheck v1.7.0 // indirect
92+
github.com/kkHAIKE/contextcheck v1.1.5 // indirect
93+
github.com/kulti/thelper v0.6.3 // indirect
94+
github.com/kunwardeep/paralleltest v1.0.10 // indirect
95+
github.com/kyoh86/exportloopref v0.1.11 // indirect
96+
github.com/lasiar/canonicalheader v1.1.1 // indirect
97+
github.com/ldez/gomoddirectives v0.2.4 // indirect
98+
github.com/ldez/tagliatelle v0.5.0 // indirect
99+
github.com/leonklingele/grouper v1.1.2 // indirect
100+
github.com/lufeee/execinquery v1.2.1 // indirect
101+
github.com/macabu/inamedparam v0.1.3 // indirect
102+
github.com/magiconair/properties v1.8.6 // indirect
103+
github.com/maratori/testableexamples v1.0.0 // indirect
104+
github.com/maratori/testpackage v1.1.1 // indirect
105+
github.com/matoous/godox v0.0.0-20230222163458-006bad1f9d26 // indirect
11106
github.com/mattn/go-colorable v0.1.13 // indirect
12-
github.com/mattn/go-isatty v0.0.17 // indirect
107+
github.com/mattn/go-isatty v0.0.20 // indirect
108+
github.com/mattn/go-runewidth v0.0.9 // indirect
109+
github.com/matttproud/golang_protobuf_extensions v1.0.1 // indirect
110+
github.com/mgechev/revive v1.3.9 // indirect
111+
github.com/mitchellh/go-homedir v1.1.0 // indirect
112+
github.com/mitchellh/mapstructure v1.5.0 // indirect
113+
github.com/moricho/tparallel v0.3.2 // indirect
114+
github.com/nakabonne/nestif v0.3.1 // indirect
115+
github.com/nishanths/exhaustive v0.12.0 // indirect
116+
github.com/nishanths/predeclared v0.2.2 // indirect
117+
github.com/nunnatsa/ginkgolinter v0.16.2 // indirect
118+
github.com/olekukonko/tablewriter v0.0.5 // indirect
119+
github.com/pelletier/go-toml v1.9.5 // indirect
120+
github.com/pelletier/go-toml/v2 v2.2.3 // indirect
121+
github.com/pmezard/go-difflib v1.0.0 // indirect
122+
github.com/polyfloyd/go-errorlint v1.6.0 // indirect
123+
github.com/prometheus/client_golang v1.12.1 // indirect
124+
github.com/prometheus/client_model v0.2.0 // indirect
125+
github.com/prometheus/common v0.32.1 // indirect
126+
github.com/prometheus/procfs v0.7.3 // indirect
127+
github.com/quasilyte/go-ruleguard v0.4.3-0.20240823090925-0fe6f58b47b1 // indirect
128+
github.com/quasilyte/go-ruleguard/dsl v0.3.22 // indirect
129+
github.com/quasilyte/gogrep v0.5.0 // indirect
130+
github.com/quasilyte/regex/syntax v0.0.0-20210819130434-b3f0c404a727 // indirect
131+
github.com/quasilyte/stdinfo v0.0.0-20220114132959-f7386bf02567 // indirect
132+
github.com/ryancurrah/gomodguard v1.3.5 // indirect
133+
github.com/ryanrolds/sqlclosecheck v0.5.1 // indirect
134+
github.com/sanposhiho/wastedassign/v2 v2.0.7 // indirect
135+
github.com/santhosh-tekuri/jsonschema/v5 v5.3.1 // indirect
136+
github.com/sashamelentyev/interfacebloat v1.1.0 // indirect
137+
github.com/sashamelentyev/usestdlibvars v1.27.0 // indirect
138+
github.com/securego/gosec/v2 v2.21.2 // indirect
13139
github.com/sergi/go-diff v1.3.1 // indirect
140+
github.com/shazow/go-diff v0.0.0-20160112020656-b6b7b6733b8c // indirect
141+
github.com/sirupsen/logrus v1.9.3 // indirect
142+
github.com/sivchari/containedctx v1.0.3 // indirect
143+
github.com/sivchari/tenv v1.10.0 // indirect
144+
github.com/sonatard/noctx v0.0.2 // indirect
145+
github.com/sourcegraph/go-diff v0.7.0 // indirect
146+
github.com/spf13/afero v1.11.0 // indirect
147+
github.com/spf13/cast v1.5.0 // indirect
148+
github.com/spf13/cobra v1.8.1 // indirect
149+
github.com/spf13/jwalterweatherman v1.1.0 // indirect
150+
github.com/spf13/pflag v1.0.5 // indirect
151+
github.com/spf13/viper v1.12.0 // indirect
152+
github.com/ssgreg/nlreturn/v2 v2.2.1 // indirect
153+
github.com/stbenjam/no-sprintf-host-port v0.1.1 // indirect
154+
github.com/stretchr/objx v0.5.2 // indirect
155+
github.com/stretchr/testify v1.9.0 // indirect
156+
github.com/subosito/gotenv v1.4.1 // indirect
157+
github.com/tdakkota/asciicheck v0.2.0 // indirect
158+
github.com/tetafro/godot v1.4.17 // indirect
159+
github.com/timakin/bodyclose v0.0.0-20230421092635-574207250966 // indirect
160+
github.com/timonwong/loggercheck v0.9.4 // indirect
161+
github.com/tomarrell/wrapcheck/v2 v2.9.0 // indirect
162+
github.com/tommy-muehle/go-mnd/v2 v2.5.1 // indirect
163+
github.com/ultraware/funlen v0.1.0 // indirect
164+
github.com/ultraware/whitespace v0.1.1 // indirect
165+
github.com/uudashr/gocognit v1.1.3 // indirect
166+
github.com/xen0n/gosmopolitan v1.2.2 // indirect
167+
github.com/yagipy/maintidx v1.0.0 // indirect
168+
github.com/yeya24/promlinter v0.3.0 // indirect
169+
github.com/ykadowak/zerologlint v0.1.5 // indirect
14170
github.com/yosssi/gohtml v0.0.0-20201013000340-ee4748c638f4 // indirect
15-
golang.org/x/mod v0.7.0 // indirect
16-
golang.org/x/net v0.18.0 // indirect
17-
golang.org/x/sys v0.14.0 // indirect
18-
golang.org/x/time v0.3.0 // indirect
19-
golang.org/x/tools v0.3.0 // indirect
171+
gitlab.com/bosi/decorder v0.4.2 // indirect
172+
go-simpler.org/musttag v0.12.2 // indirect
173+
go-simpler.org/sloglint v0.7.2 // indirect
174+
go.uber.org/atomic v1.7.0 // indirect
175+
go.uber.org/automaxprocs v1.5.3 // indirect
176+
go.uber.org/multierr v1.6.0 // indirect
177+
go.uber.org/zap v1.24.0 // indirect
178+
golang.org/x/exp v0.0.0-20240904232852-e7e105dedf7e // indirect
179+
golang.org/x/exp/typeparams v0.0.0-20240314144324-c7f7c6466f7f // indirect
180+
golang.org/x/mod v0.21.0 // indirect
181+
golang.org/x/net v0.28.0 // indirect
182+
golang.org/x/sync v0.8.0 // indirect
183+
golang.org/x/sys v0.25.0 // indirect
184+
golang.org/x/text v0.18.0 // indirect
185+
golang.org/x/time v0.6.0 // indirect
186+
golang.org/x/tools v0.24.0 // indirect
187+
google.golang.org/protobuf v1.34.2 // indirect
188+
gopkg.in/ini.v1 v1.67.0 // indirect
189+
gopkg.in/yaml.v2 v2.4.0 // indirect
190+
gopkg.in/yaml.v3 v3.0.1 // indirect
191+
honnef.co/go/tools v0.5.1 // indirect
192+
mvdan.cc/gofumpt v0.7.0 // indirect
193+
mvdan.cc/unparam v0.0.0-20240528143540-8a5130ca722f // indirect
20194
)

0 commit comments

Comments
 (0)