mirror of
https://github.com/trufflesecurity/trufflehog.git
synced 2024-11-10 07:04:24 +00:00
68f28a0e34
* pre filter detectors that include the keywords in the chunk. * Optimize the engine to prevent iterating overing all detectors. * use sync.Map for concurrent access. * lint. * use correct verify. * allow versioned detectors. * Break apart Start. * cleanup. * Update benchmark. * add comment. * remove Engine prefix. * update comments. * use regular map. * delete the pool. * remove old code. * refactor ahocorasickcore into own file. * update comments * move structs to ahocorasickcore * update comments * fix * address comments * exported some methods and constructor since it will need to be be used by the enterprise pipeline as well * remove extra log
48 lines
1.1 KiB
Go
48 lines
1.1 KiB
Go
package decoders
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/binary"
|
|
"unicode/utf8"
|
|
|
|
"github.com/trufflesecurity/trufflehog/v3/pkg/pb/detectorspb"
|
|
"github.com/trufflesecurity/trufflehog/v3/pkg/sources"
|
|
)
|
|
|
|
type UTF16 struct{}
|
|
|
|
func (d *UTF16) FromChunk(chunk *sources.Chunk) *DecodableChunk {
|
|
if chunk == nil || len(chunk.Data) == 0 {
|
|
return nil
|
|
}
|
|
|
|
decodableChunk := &DecodableChunk{Chunk: chunk, DecoderType: detectorspb.DecoderType_UTF16}
|
|
if utf16Data, err := utf16ToUTF8(chunk.Data); err == nil {
|
|
if len(utf16Data) == 0 {
|
|
return nil
|
|
}
|
|
chunk.Data = utf16Data
|
|
return decodableChunk
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// utf16ToUTF8 converts a byte slice containing UTF-16 encoded data to a UTF-8 encoded byte slice.
|
|
func utf16ToUTF8(b []byte) ([]byte, error) {
|
|
var bufBE, bufLE bytes.Buffer
|
|
for i := 0; i < len(b)-1; i += 2 {
|
|
if r := rune(binary.BigEndian.Uint16(b[i:])); b[i] == 0 && utf8.ValidRune(r) {
|
|
if isValidByte(byte(r)) {
|
|
bufBE.WriteRune(r)
|
|
}
|
|
}
|
|
if r := rune(binary.LittleEndian.Uint16(b[i:])); b[i+1] == 0 && utf8.ValidRune(r) {
|
|
if isValidByte(byte(r)) {
|
|
bufLE.WriteRune(r)
|
|
}
|
|
}
|
|
}
|
|
|
|
return append(bufLE.Bytes(), bufBE.Bytes()...), nil
|
|
}
|