main.go 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. package main
  2. import (
  3. "os"
  4. "text/template"
  5. "github.com/rs/zerolog/log"
  6. "github.com/zricethezav/gitleaks/v8/cmd/generate/config/rules"
  7. "github.com/zricethezav/gitleaks/v8/config"
  8. )
  9. const (
  10. templatePath = "rules/config.tmpl"
  11. )
  12. //go:generate go run $GOFILE ../../../config/gitleaks.toml
  13. func main() {
  14. if len(os.Args) < 2 {
  15. os.Stderr.WriteString("Specify path to the gitleaks.toml config\n")
  16. os.Exit(2)
  17. }
  18. gitleaksConfigPath := os.Args[1]
  19. configRules := []*config.Rule{
  20. rules.AdafruitAPIKey(),
  21. rules.AdobeClientID(),
  22. rules.AdobeClientSecret(),
  23. rules.AgeSecretKey(),
  24. rules.Airtable(),
  25. rules.AlgoliaApiKey(),
  26. rules.AlibabaAccessKey(),
  27. rules.AlibabaSecretKey(),
  28. rules.AsanaClientID(),
  29. rules.AsanaClientSecret(),
  30. rules.Atlassian(),
  31. rules.Authress(),
  32. rules.AWS(),
  33. rules.BitBucketClientID(),
  34. rules.BitBucketClientSecret(),
  35. rules.BittrexAccessKey(),
  36. rules.BittrexSecretKey(),
  37. rules.Beamer(),
  38. rules.CodecovAccessToken(),
  39. rules.CoinbaseAccessToken(),
  40. rules.Clojars(),
  41. rules.CloudflareAPIKey(),
  42. rules.CloudflareGlobalAPIKey(),
  43. rules.CloudflareOriginCAKey(),
  44. rules.ConfluentAccessToken(),
  45. rules.ConfluentSecretKey(),
  46. rules.Contentful(),
  47. rules.Databricks(),
  48. rules.DatadogtokenAccessToken(),
  49. rules.DefinedNetworkingAPIToken(),
  50. rules.DigitalOceanPAT(),
  51. rules.DigitalOceanOAuthToken(),
  52. rules.DigitalOceanRefreshToken(),
  53. rules.DiscordAPIToken(),
  54. rules.DiscordClientID(),
  55. rules.DiscordClientSecret(),
  56. rules.Doppler(),
  57. rules.DropBoxAPISecret(),
  58. rules.DropBoxLongLivedAPIToken(),
  59. rules.DropBoxShortLivedAPIToken(),
  60. rules.DroneciAccessToken(),
  61. rules.Duffel(),
  62. rules.Dynatrace(),
  63. rules.EasyPost(),
  64. rules.EasyPostTestAPI(),
  65. rules.EtsyAccessToken(),
  66. rules.FacebookSecret(),
  67. rules.FacebookAccessToken(),
  68. rules.FacebookPageAccessToken(),
  69. rules.FastlyAPIToken(),
  70. rules.FinicityClientSecret(),
  71. rules.FinicityAPIToken(),
  72. rules.FlickrAccessToken(),
  73. rules.FinnhubAccessToken(),
  74. rules.FlutterwavePublicKey(),
  75. rules.FlutterwaveSecretKey(),
  76. rules.FlutterwaveEncKey(),
  77. rules.FlyIOAccessToken(),
  78. rules.FrameIO(),
  79. rules.FreshbooksAccessToken(),
  80. rules.GoCardless(),
  81. // TODO figure out what makes sense for GCP
  82. // rules.GCPServiceAccount(),
  83. rules.GCPAPIKey(),
  84. rules.GitHubPat(),
  85. rules.GitHubFineGrainedPat(),
  86. rules.GitHubOauth(),
  87. rules.GitHubApp(),
  88. rules.GitHubRefresh(),
  89. rules.GitlabPat(),
  90. rules.GitlabPipelineTriggerToken(),
  91. rules.GitlabRunnerRegistrationToken(),
  92. rules.GitterAccessToken(),
  93. rules.GrafanaApiKey(),
  94. rules.GrafanaCloudApiToken(),
  95. rules.GrafanaServiceAccountToken(),
  96. rules.HarnessApiKey(),
  97. rules.HashiCorpTerraform(),
  98. rules.HashicorpField(),
  99. rules.Heroku(),
  100. rules.HubSpot(),
  101. rules.HuggingFaceAccessToken(),
  102. rules.HuggingFaceOrganizationApiToken(),
  103. rules.Intercom(),
  104. rules.Intra42ClientSecret(),
  105. rules.JFrogAPIKey(),
  106. rules.JFrogIdentityToken(),
  107. rules.JWT(),
  108. rules.JWTBase64(),
  109. rules.KrakenAccessToken(),
  110. rules.KubernetesSecret(),
  111. rules.KucoinAccessToken(),
  112. rules.KucoinSecretKey(),
  113. rules.LaunchDarklyAccessToken(),
  114. rules.LinearAPIToken(),
  115. rules.LinearClientSecret(),
  116. rules.LinkedinClientID(),
  117. rules.LinkedinClientSecret(),
  118. rules.LobAPIToken(),
  119. rules.LobPubAPIToken(),
  120. rules.MailChimp(),
  121. rules.MailGunPubAPIToken(),
  122. rules.MailGunPrivateAPIToken(),
  123. rules.MailGunSigningKey(),
  124. rules.MapBox(),
  125. rules.MattermostAccessToken(),
  126. rules.MessageBirdAPIToken(),
  127. rules.MessageBirdClientID(),
  128. rules.NetlifyAccessToken(),
  129. rules.NewRelicUserID(),
  130. rules.NewRelicUserKey(),
  131. rules.NewRelicBrowserAPIKey(),
  132. rules.NewRelicInsertKey(),
  133. rules.NPM(),
  134. rules.NytimesAccessToken(),
  135. rules.OktaAccessToken(),
  136. rules.OpenAI(),
  137. rules.OpenshiftUserToken(),
  138. rules.PlaidAccessID(),
  139. rules.PlaidSecretKey(),
  140. rules.PlaidAccessToken(),
  141. rules.PlanetScalePassword(),
  142. rules.PlanetScaleAPIToken(),
  143. rules.PlanetScaleOAuthToken(),
  144. rules.PostManAPI(),
  145. rules.Prefect(),
  146. rules.PrivateKey(),
  147. rules.PulumiAPIToken(),
  148. rules.PyPiUploadToken(),
  149. rules.RapidAPIAccessToken(),
  150. rules.ReadMe(),
  151. rules.RubyGemsAPIToken(),
  152. rules.ScalingoAPIToken(),
  153. rules.SendbirdAccessID(),
  154. rules.SendbirdAccessToken(),
  155. rules.SendGridAPIToken(),
  156. rules.SendInBlueAPIToken(),
  157. rules.SentryAccessToken(),
  158. rules.ShippoAPIToken(),
  159. rules.ShopifyAccessToken(),
  160. rules.ShopifyCustomAccessToken(),
  161. rules.ShopifyPrivateAppAccessToken(),
  162. rules.ShopifySharedSecret(),
  163. rules.SidekiqSecret(),
  164. rules.SidekiqSensitiveUrl(),
  165. rules.SlackBotToken(),
  166. rules.SlackUserToken(),
  167. rules.SlackAppLevelToken(),
  168. rules.SlackConfigurationToken(),
  169. rules.SlackConfigurationRefreshToken(),
  170. rules.SlackLegacyBotToken(),
  171. rules.SlackLegacyWorkspaceToken(),
  172. rules.SlackLegacyToken(),
  173. rules.SlackWebHookUrl(),
  174. rules.Snyk(),
  175. rules.StripeAccessToken(),
  176. rules.SquareAccessToken(),
  177. rules.SquareSpaceAccessToken(),
  178. rules.SumoLogicAccessID(),
  179. rules.SumoLogicAccessToken(),
  180. rules.TeamsWebhook(),
  181. rules.TelegramBotToken(),
  182. rules.TravisCIAccessToken(),
  183. rules.Twilio(),
  184. rules.TwitchAPIToken(),
  185. rules.TwitterAPIKey(),
  186. rules.TwitterAPISecret(),
  187. rules.TwitterAccessToken(),
  188. rules.TwitterAccessSecret(),
  189. rules.TwitterBearerToken(),
  190. rules.Typeform(),
  191. rules.VaultBatchToken(),
  192. rules.VaultServiceToken(),
  193. rules.YandexAPIKey(),
  194. rules.YandexAWSAccessToken(),
  195. rules.YandexAccessToken(),
  196. rules.ZendeskSecretKey(),
  197. rules.GenericCredential(),
  198. rules.InfracostAPIToken(),
  199. }
  200. // ensure rules have unique ids
  201. ruleLookUp := make(map[string]config.Rule, len(configRules))
  202. for _, rule := range configRules {
  203. // check if rule is in ruleLookUp
  204. if _, ok := ruleLookUp[rule.RuleID]; ok {
  205. log.Fatal().Msgf("rule id %s is not unique", rule.RuleID)
  206. }
  207. // TODO: eventually change all the signatures to get ride of this
  208. // nasty dereferencing.
  209. ruleLookUp[rule.RuleID] = *rule
  210. }
  211. tmpl, err := template.ParseFiles(templatePath)
  212. if err != nil {
  213. log.Fatal().Err(err).Msg("Failed to parse template")
  214. }
  215. f, err := os.Create(gitleaksConfigPath)
  216. if err != nil {
  217. log.Fatal().Err(err).Msg("Failed to create rules.toml")
  218. }
  219. if err = tmpl.Execute(f, config.Config{Rules: ruleLookUp}); err != nil {
  220. log.Fatal().Err(err).Msg("could not execute template")
  221. }
  222. }