تابع wp_untrash_post در وردپرس
تابع wp_untrash_post() در هسته وردپرس برای بازگردانی (Restore) پستهایی که به «زبالهدان» (Trash) منتقل شدهاند استفاده میشود. این تابع وضعیت پست را از trash به وضعیت قبلیای که پیش از انتقال به زبالهدان داشته است بازمیگرداند و متادیتاهای مرتبط با زبالهدان را پاک میکند. در این مقاله به صورت کاربردی، مثالهای کدنویسی، نکات امنیتی و سناریوهای متداول استفاده از این تابع را بررسی میکنیم.
چرا و چه زمانی از wp_untrash_post() استفاده میکنیم؟
- بازگردانی پستهایی که به اشتباه حذف یا به زبالهدان منتقل شدهاند.
- پیادهسازی عملیات گروهی (bulk) برای بازیابی مجموعهای از پستها.
- ساخت قابلیتهای سفارشی در پلاگین/قالب که امکان «بازیابی» را در رابط کاربری فراهم میکند.
- بررسی وضعیت پستها در زمان مهاجرت، بکاپریستور یا اسکریپتهای مدیریتی.
رفتار کلی و نکات فنی
وقتی پستی با wp_trash_post() به زبالهدان میرود، وردپرس مقدار وضعیت قبلی را در متا با کلیدهای _wp_trash_meta_status و _wp_trash_meta_time ذخیره میکند. هنگام فراخوانی wp_untrash_post()، وردپرس این متادیتا را میخواند و وضعیت پست را به وضعیت قبلی برمیگرداند و سپس آن متاها را پاک میکند. علاوه بر این، تغییر وضعیت از طریق مکانیزم انتقال وضعیت پست (wp_transition_post_status) انجام میشود که باعث فعال شدن هوکهای مرتبط میشود و پلاگینها میتوانند به تغییر وضعیت واکنش نشان دهند.
پارامترها و مقدار بازگشتی (خلاصه)
| پارامتر | توضیح |
|---|---|
| post_id | آیدی پست (integer) که باید از زبالهدان بازگردانده شود. |
مقدار بازگشتی معمولاً در شرایط موفقیت، مقدار قابل استفاده (truthy) و در صورت عدم موفقیت false یا خطا خواهد بود. برای کنترل دقیقتر توصیه میشود نتیجه را بررسی کنید و خطاها را هندل کنید.
مثال: بازگرداندن یک پست به صورت برنامهنویسی
function my_restore_post( $post_id ) {
// چک اجازه: تنها کاربرانی که حق ویرایش پست را دارند مجازند
if ( ! current_user_can( 'edit_post', $post_id ) ) {
return false;
}
$post = get_post( $post_id );
if ( ! $post || 'trash' !== $post->post_status ) {
// اگر پست وجود نداشته یا در زبالهدان نباشد، کاری انجام نده
return false;
}
// فراخوانی اصلی برای بازگردانی
return wp_untrash_post( $post_id );
}توضیح: این کد ابتدا با current_user_can('edit_post') اجازه کاربر را بررسی میکند تا فقط کاربرانی که مجازند بتوانند عمل بازگردانی را انجام دهند. سپس مطمئن میشود که پست وجود دارد و وضعیت آن فعلاً trash است. در نهایت wp_untrash_post() فراخوانی میشود و نتیجه بازگردانی برگشت داده میشود.
مثال: بازیابی همه پستهای زبالهدانی برای یک نوع پست خاص
$trashed = get_posts( array(
'post_type' => 'your_post_type',
'post_status' => 'trash',
'numberposts' => -1,
'fields' => 'ids',
) );
foreach ( $trashed as $id ) {
wp_untrash_post( $id );
}توضیح: این قطعه با get_posts همه آیدیهای پستهای زبالهای از نوع مشخص را میگیرد و با حلقه آنها را یکییکی بازیابی میکند. توجه داشته باشید در عملیات گروهی بهتر است مدیریت حافظه و محدودیتهای اجرایی (time limit) را در نظر بگیرید.
واکنش به بازگردانی: چگونه بفهمیم یک پست بازگردانده شد؟
بهترین روش برای شنیدن رویداد بازگردانی، استفاده از هوک transition_post_status است. این هوک هنگام تغییر وضعیت هر پستی اجرا میشود و میتوان با بررسی «وضعیت قبلی» و «وضعیت جدید» تشخیص داد که پست از trash خارج شده است.
add_action( 'transition_post_status', 'my_after_untrash', 10, 3 );
function my_after_untrash( $new_status, $old_status, $post ) {
// مثال: پست از trash به publish بازگشته
if ( 'trash' === $old_status && 'publish' === $new_status ) {
// کارهایی که باید بعد از بازیابی انجام شود
}
// مثال: بازیابی پیوست (attachment) معمولاً از trash به inherit بازمیگردد
if ( 'trash' === $old_status && 'inherit' === $new_status && 'attachment' === $post->post_type ) {
// پردازش اختصاصی برای فایلهای پیوست
}
}
توضیح: به جای تکیه بر نامهای دقیق اکشنهای داخلی، استفاده از transition_post_status مطمئن و پایدار است چون همیشه هنگام تغییر وضعیت پست فراخوانی میشود.
نکات امنیتی و بهترین شیوهها
- همیشه قبل از فراخوانی
wp_untrash_post()به قابلیت (capability) کاربر توجه کنید. معمولاًedit_postیاdelete_postباید بررسی شوند. - در رابطهای مبتنی بر فرم از nonce استفاده کنید تا از درخواستهای CSRF جلوگیری شود.
- در عملیات گروهی، مدیریت زمان اجرا و مصرف حافظه را در نظر بگیرید و در صورت نیاز از WP-CLI یا تسکهای پسزمینه استفاده کنید.
- برای پستهای سفارشی (custom post type) مطمئن شوید که ثبت نوع پست قابلیتهای موردنیاز را دارد تا مجوزها درست عمل کنند.
موارد خاص: بازگرداندن فایلهای پیوست (attachments)
فایلهای پیوست هم مثل سایر پستها وضعیت ذخیره میکنند. هنگام بازگردانی پیوست، ممکن است وضعیت جدید inherit باشد و رابطه با والد (post_parent) حفظ شود. هنگام بازگردانی حتماً لینکها و مسیرهای فایل را بررسی کنید تا اگر لازم است پیوست به پست والد درست متصل باشد، اصلاح شود.
جمعبندی و توصیهها
- wp_untrash_post() تابعی ساده اما حیاتی برای بازگردانی پستهاست و وضعیت قبلی را از متادیتای ذخیرهشده بازمیگرداند.
- همیشه دسترسیها و امنیت را چک کنید و در عملیات خودکار از محدودیتهای اجرایی آگاه باشید.
- برای واکشی رویداد بازگردانی، از
transition_post_statusاستفاده کنید تا همگام با تغییر وضعیت پست اجرا شوید. - در پروژههای بزرگتر، عملیات دستهای را با WP-CLI، cron یا پردازش پسزمینه انجام دهید تا از مشکلات performance جلوگیری شود.
با رعایت نکات بالا میتوانید از wp_untrash_post() به صورت ایمن و مؤثر در پلاگینها، تمها یا اسکریپتهای مدیریتی خود استفاده کنید و تجربه کاربری و نگهداری محتوا را بهبود دهید.
آیا این مطلب برای شما مفید بود ؟




