All rules
GCI0022WarnData Integrity

Idempotency and Retry Safety

Detects HTTP POST endpoints without idempotency keys and raw INSERT statements without upsert guards, which are unsafe under retry logic.

Why this rule exists

Networks retry. Clients retry. Job runners retry. A POST that creates a duplicate row on retry is the canonical cause of double-charged customers.

Code example

Triggers the rule
+ [HttpPost("/orders")]
+ public Task<Order> Create(OrderRequest req) => _svc.CreateAsync(req);
Passes the rule
+ [HttpPost("/orders")]
+ public Task<Order> Create([FromHeader(Name="Idempotency-Key")] Guid key, OrderRequest req)
+     => _svc.CreateAsync(key, req);

Configuration

Disable or adjust the severity of this rule in .gauntletci.json:

{
  "rules": {
    "GCI0022": { "enabled": true, "severity": "Warn" }
  }
}

See Configuration for the full schema.

Related rules

Implemented in src/GauntletCI.Core/Rules/Implementations/GCI0022_*.cs.

About the author

Eric Cogen -- Founder, GauntletCI

Twenty years as a senior technical consultant building and modernizing enterprise platforms across .NET, AWS, serverless, microservices, and AI-driven systems.