meraki.go 1.2 KB

1234567891011121314151617181920212223242526272829
  1. package rules
  2. import (
  3. "github.com/zricethezav/gitleaks/v8/cmd/generate/config/utils"
  4. "github.com/zricethezav/gitleaks/v8/cmd/generate/secrets"
  5. "github.com/zricethezav/gitleaks/v8/config"
  6. )
  7. func Meraki() *config.Rule {
  8. // define rule
  9. r := config.Rule{
  10. RuleID: "cisco-meraki-api-key",
  11. Description: "Cisco Meraki is a cloud-managed IT solution that provides networking, security, and device management through an easy-to-use interface.",
  12. Regex: utils.GenerateSemiGenericRegex([]string{`(?-i:[Mm]eraki|MERAKI)`}, `[0-9a-f]{40}`, false),
  13. Entropy: 3,
  14. Keywords: []string{"meraki"},
  15. }
  16. // validate
  17. tps := utils.GenerateSampleSecrets("meraki", secrets.NewSecret(utils.Hex("40")))
  18. fps := []string{
  19. `meraki: aaaaaaaaaa1111111111bbbbbbbbbb2222222222`, // low entropy
  20. `meraki-api-key: acdeFf05b1a6d4c890237bf08c5e6e8d2b4d0f2e`, // invalid case
  21. `meraki: abdefghjk0123456789mnopqrstuvwx12345678`, // invalid character
  22. `meraki_token = 5cb4a5f04cd412fe946667b17f0129ba17aeb2e0c7b5b7264efcebf7d022bfe2R21`, // invalid length
  23. `ReactNativeCameraKit: f15a5a04b0f6dc6073e6db0296e6ef2d8b8d2522`,
  24. }
  25. return utils.Validate(r, tps, fps)
  26. }