Now let’s get began with our implementation. For our instance, we’ll use a easy buying cart utility.
Create the mannequin lessons
Within the venture we created earlier, create the next lessons within the Fashions folder.
public class Product { public int Product_Id { get; set; } public string Product_Code { get; set; } public string Product_Name { get; set; } public double Product_Price { get; set; } } public class Order { public int Order_Id { get; set; } public Checklist Merchandise { get; set; } } public class KeyStore { public string Key { get; set; } public DateTime Expiry { get; set; } }
Whereas the Product and Order lessons are sometimes utilized in a ShoppingCart utility, the KeyStore class is used right here to retailer our idempotency keys. On this implementation, we’ll save these keys within the database (dbContext). Naturally, you would change the implementation to retailer the keys within the cache or some other information retailer.
Create the controller class
Proper-click on the Controllers folder within the Answer Explorer Window and create an API controller known as OrderController. Now, enter the next motion technique within the OrderController class. This technique creates a brand new order.
[HttpPost] public IActionResult CreateOrder([FromBody] Order order, [FromHeader(Name = "X-Idempotency_Key")] string key) { if (string.IsNullOrEmpty(key)) { return BadRequest("Idempotency secret is required."); } if (_dbContext.KeyStore.FirstOrDefault(okay => okay.Key == key)!= null) { var existingItem = _dbContext.Orders.FirstOrDefault(o => o.Order_Id == order.Order_Id); return Battle(new { message = "Request has already been processed.", merchandise = existingItem }); } _dbContext.KeyStore.Add(new KeyStore {Key = key, Expiry = DateTime.Now.AddDays(7)}); _dbContext.Add(order); _dbContext.SaveChanges(); return Okay(order.Order_Id); }
Look at the code above. An idempotency secret is generated on the consumer facet and handed within the request header. This key will probably be utilized by the server to make sure that repeated calls to the identical motion technique won’t create duplicate information within the database. In different phrases, if the hot button is already current within the KeyStore, then the request for creation of the useful resource will probably be ignored. The presence of the important thing within the KeyStore implies that the request was already processed earlier.
Takeaways
By embracing idempotency, you’ll be able to construct APIs which can be strong, dependable, and fault-tolerant. Idempotent APIs are notably necessary and helpful in distributed methods, the place community points may result in massive numbers of retried requests from the consumer facet. That mentioned, you need to all the time validate enter information to make sure information consistency earlier than storing information within the database.