mirror of
https://github.com/projectdiscovery/nuclei.git
synced 2025-12-22 12:45:29 +00:00
* Adding support for code templates * adding support for python, powershell and echo (test) * removing debug code * introducing command + trivial trust store mechanism * updating tests * adding basic tests * removing deprecated oracle * mod tidy * adding signature proto with debug prints * removing debug code * fixing test * fixing param order * improving test conditional build * disable file+offlinehttp+code with cloud * adding env vars * removing debug code * reorganizing test folders * adding code template test prototype with dummy priv/pub keys * bump go to 1.20 * fixing go version * fixing lint errors * adding fatal on pub-key test failure * switching to ecdsa asn1 * removing unused signature * fixing signature * adding more tests * extending core with engine args + powershell win test * adding unsigned code test * skip template signing in particular test case * improving test coverage * refactoring key names + adding already signed algo * removing debug code * fixing syntax * fixing lint issues * removing test template * fixing dns tests path * output fmt * adding interact * fixing lint issues * adding -sign cli helper * fixing nil pointer + parse inline keys * making rsa default * adding code prot. ref * moving file to correct loc * moving test * Issue 3339 headless fuzz (#3790) * Basic headless fuzzing * Remove debug statements * Add integration tests * Update template * Fix recognize payload value in matcher * Update tempalte * use req.SetURL() --------- Co-authored-by: Tarun Koyalwar <tarun@projectdiscovery.io> * Auto Generate Syntax Docs + JSONSchema [Fri Jun 9 00:23:32 UTC 2023] 🤖 * Add headless header and status matchers (#3794) * add headless header and status matchers * rename headers as header * add integration test for header+status * fix typo * add retry to py-interactsh integration test --------- Co-authored-by: Sandeep Singh <sandeep@projectdiscovery.io> Co-authored-by: Shubham Rasal <shubham@projectdiscovery.io> Co-authored-by: Tarun Koyalwar <tarun@projectdiscovery.io> Co-authored-by: GitHub Action <action@github.com> Co-authored-by: Dogan Can Bakir <65292895+dogancanbakir@users.noreply.github.com> Co-authored-by: Tarun Koyalwar <45962551+tarunKoyalwar@users.noreply.github.com>
89 lines
1.5 KiB
Go
89 lines
1.5 KiB
Go
package randomip
|
|
|
|
import (
|
|
"crypto/rand"
|
|
"net"
|
|
|
|
"github.com/pkg/errors"
|
|
iputil "github.com/projectdiscovery/utils/ip"
|
|
randutil "github.com/projectdiscovery/utils/rand"
|
|
)
|
|
|
|
const (
|
|
maxIterations = 255
|
|
)
|
|
|
|
func GetRandomIPWithCidr(cidrs ...string) (net.IP, error) {
|
|
if len(cidrs) == 0 {
|
|
return nil, errors.Errorf("must specify at least one cidr")
|
|
}
|
|
|
|
randIdx, err := randutil.IntN(len(cidrs))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
cidr := cidrs[randIdx]
|
|
|
|
if !iputil.IsCIDR(cidr) {
|
|
return nil, errors.Errorf("%s is not a valid cidr", cidr)
|
|
}
|
|
|
|
baseIp, ipnet, err := net.ParseCIDR(cidr)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
switch {
|
|
case 255 == ipnet.Mask[len(ipnet.Mask)-1]:
|
|
return baseIp, nil
|
|
case iputil.IsIPv4(baseIp.String()):
|
|
return getRandomIP(ipnet, 4), nil
|
|
case iputil.IsIPv6(baseIp.String()):
|
|
return getRandomIP(ipnet, 16), nil
|
|
default:
|
|
return nil, errors.New("invalid base ip")
|
|
}
|
|
}
|
|
|
|
func getRandomIP(ipnet *net.IPNet, size int) net.IP {
|
|
ip := ipnet.IP
|
|
var iteration int
|
|
|
|
for iteration < maxIterations {
|
|
iteration++
|
|
ones, _ := ipnet.Mask.Size()
|
|
quotient := ones / 8
|
|
remainder := ones % 8
|
|
var r []byte
|
|
switch size {
|
|
case 4, 16:
|
|
r = make([]byte, size)
|
|
default:
|
|
return ip
|
|
}
|
|
|
|
_, err := rand.Read(r)
|
|
if err != nil {
|
|
break
|
|
}
|
|
|
|
for i := 0; i <= quotient; i++ {
|
|
if i == quotient {
|
|
shifted := byte(r[i]) >> remainder
|
|
r[i] = ipnet.IP[i] + (^ipnet.IP[i] & shifted)
|
|
} else {
|
|
r[i] = ipnet.IP[i]
|
|
}
|
|
}
|
|
|
|
ip = r
|
|
|
|
if !ip.Equal(ipnet.IP) {
|
|
break
|
|
}
|
|
}
|
|
|
|
return ip
|
|
}
|