⛏✨ طراحی API و مفهوم Idempotency
⛏✨ طراحی API و مفهوم Idempotency
معنی idempotent : شاید بشه «همانندپذیر» رو معادل خوبی براش دونست؛ توی ریاضی «عدد ۱ در عملیات ضرب» همانندپذیر هست، چون هر چند بار که یک در خودش ضرب شه، باز هم ۱ به دست میاد. ولی ۲ اینطور نیست چون ۲ اگر در خودش ضرب شه میشه ۴.
پس idempotent عملیاتی هست که چندین بار اجرا کردنش، نتیجهای مشابه با یک بار اجرا کردنش داره.
یکی از دغدغههای اصلی توی سیستمهایی مثل پرداخت یا عملیات حساس، اینه که وقتی کاربر چندبار یک درخواست رو میفرسته، سیستمو نباید چندبار اون رو پردازش کنه. به بیان سادهتر، API ما باید idempotent باشه؛ یعنی خروجی و اثرش هر بار یکسان باشه، حتی اگر درخواست رو چند بار ارسال کنیم (حالا چه سهوی، چه تعمدی و با قصد بد!) مثلا کاربر اگر API پرداخت رو چند بار فراخوانی کنه ممکنه چند بار وجه از حسابش کسر بشه یا مواردی از این دست.
روشهای طراحی APIهای Idempotent
1️⃣ استفاده از Idempotency-Key
یکی از روشهای رایج برای حل این مشکل استفاده از یک کلید منحصر به فرد به نام Idempotency-Key است. وقتی کاربر یک درخواست حساس (مثلاً پرداخت) رو ارسال میکنه، یک کلید یکتا همراه درخواست ارسال میشه. سرور وقتی درخواست رو دریافت میکنه، اول چک میکنه که آیا قبلاً درخواستی با اون کلید دریافت شده یا نه.
POST /payments
Headers: {
"Idempotency-Key": "abc123"
}
Body: {
"amount": 1000,
"currency": "IRR"
}
2️⃣ روش Optimistic Concurrency Control
استفاده از کنترل همزمانی خوشبینانه (Optimistic Concurrency Control). هر موجودیت (entity) یه نسخه یا شناسه تغییر (مثلاً ETag) داره. وقتی کاربر میخواد تغییراتی رو روی اون موجودیت اعمال کنه، نسخه موجودیت رو همراه درخواست میفرسته.
اگر نسخهای که فرستاده شده با نسخه فعلی مطابقت داشته باشه، تغییر اعمال میشه؛ در غیر این صورت، یعنی کسی یا چیزی قبلاً تغییر ایجاد کرده و سرور خطا برمیگردونه.
PUT /orders/123
Headers: {
"If-Match": "v1"
}
Body: {
"status": "paid"
}
3️⃣ روش Conditional Requests
از Conditional Requests میشه استفاده کرد، یعنی با استفاده از هدرهای HTTP مثل If-None-Match یا If-Modified-Since وقتی کاربر درخواست میده، سرور بررسی میکنه که آیا دادههای موجود تغییر کرده یا نه.
اگر داده تغییر نکرده باشه، سرور یک پاسخ مشابه برمیگردونه بدون اینکه دوباره عملیات رو انجام بده. مثلا: فرض کن کاربر میخواد اطلاعات پروفایل خودش رو آپدیت کنه. همراه درخواست هدر If-Unmodified-Since ارسال میشه که نشان دهنده آخرین باریه که اطلاعات تغییر کردهاند. اگر اطلاعات بین اون زمان تغییر نکرده باشه، عملیات به درستی انجام میشه؛ در غیر این صورت، سرور خطا میده که نشان میده اطلاعات بهروزرسانی نشده یا تغییر کرده.
💬 نظر؟ بحث؟ گپ بزنیم؟
#API_Design