2022-03-10 06:22:28 +00:00
package pipedream
import (
"context"
"fmt"
2024-01-23 21:16:22 +00:00
regexp "github.com/wasilibs/go-re2"
2022-03-10 06:22:28 +00:00
"net/http"
"strings"
"time"
"github.com/trufflesecurity/trufflehog/v3/pkg/common"
"github.com/trufflesecurity/trufflehog/v3/pkg/detectors"
"github.com/trufflesecurity/trufflehog/v3/pkg/pb/detectorspb"
)
type Scanner struct { }
2022-05-16 16:03:10 +00:00
// Ensure the Scanner satisfies the interface at compile time.
2022-03-10 06:22:28 +00:00
var _ detectors . Detector = ( * Scanner ) ( nil )
var (
client = common . SaneHttpClient ( )
2022-05-16 16:03:10 +00:00
// Make sure that your group is surrounded in boundary characters such as below to reduce false positives.
2022-03-10 06:22:28 +00:00
keyPat = regexp . MustCompile ( detectors . PrefixRegex ( [ ] string { "pipedream" } ) + ` \b([a-z0-9] { 32})\b ` )
)
// Keywords are used for efficiently pre-filtering chunks.
// Use identifiers in the secret preferably, or the provider name.
func ( s Scanner ) Keywords ( ) [ ] string {
return [ ] string { "pipedream" }
}
// FromData will find and optionally verify Pipedream secrets in a given set of bytes.
func ( s Scanner ) FromData ( ctx context . Context , verify bool , data [ ] byte ) ( results [ ] detectors . Result , err error ) {
dataStr := string ( data )
matches := keyPat . FindAllStringSubmatch ( dataStr , - 1 )
for _ , match := range matches {
if len ( match ) != 2 {
continue
}
resMatch := strings . TrimSpace ( match [ 1 ] )
s1 := detectors . Result {
DetectorType : detectorspb . DetectorType_Pipedream ,
Raw : [ ] byte ( resMatch ) ,
}
if verify {
timeout := 15 * time . Second
client . Timeout = timeout
2024-05-22 13:58:12 +00:00
req , err := http . NewRequestWithContext ( ctx , "GET" , "https://api.pipedream.com/v1/users/me" , nil )
2022-03-23 23:42:34 +00:00
if err != nil {
continue
}
2022-03-10 06:22:28 +00:00
req . Header . Add ( "Authorization" , fmt . Sprintf ( "Bearer %s" , resMatch ) )
res , err := client . Do ( req )
if err == nil {
defer res . Body . Close ( )
if res . StatusCode >= 200 && res . StatusCode < 300 {
s1 . Verified = true
}
}
}
results = append ( results , s1 )
}
2022-10-31 16:36:10 +00:00
return results , nil
2022-03-10 06:22:28 +00:00
}
2023-02-09 22:46:03 +00:00
func ( s Scanner ) Type ( ) detectorspb . DetectorType {
return detectorspb . DetectorType_Pipedream
}
2024-09-24 23:10:16 +00:00
func ( s Scanner ) Description ( ) string {
return "Pipedream is an integration platform for developers to build and run workflows that integrate apps, data, and APIs. Pipedream API keys can be used to access and modify these workflows and data."
}