این راهنمای توسعهدهنده توضیح میدهد که چگونه کنترلکننده خطمشی دستگاه شما (DPC) میتواند بهروزرسانیهای سیستم Android را از طرف کاربر دستگاه مدیریت کند.
مقدمه
دستگاههای Android میتوانند بهروزرسانیهای هوایی (OTA) را برای سیستم و نرمافزار برنامه دریافت و نصب کنند. اندروید به کاربر دستگاه اطلاع میدهد که بهروزرسانی سیستم در دسترس است و کاربر دستگاه میتواند فوراً یا بعداً بهروزرسانی را نصب کند.
با استفاده از DPC، یک سرپرست فناوری اطلاعات میتواند بهروزرسانیهای سیستم را برای کاربر دستگاه مدیریت کند. DPCها می توانند صاحب یک دستگاه کاملاً مدیریت شده (به نام مالک دستگاه) یا می توانند دارای یک نمایه کاری (به نام مالک نمایه) باشند. جدول 1 نشان می دهد که چگونه صاحبان دستگاه می توانند به روز رسانی های سیستم را مدیریت کنند، در حالی که مالکان نمایه فقط می توانند اطلاعات مربوط به به روز رسانی های سیستم را گزارش کنند.
جدول 1 : وظایف موجود برای DPCها به حالت مالک بستگی دارد
به روز رسانی های معلق را بررسی کنید
به روز رسانی معلق یک به روز رسانی سیستم برای دستگاهی است که هنوز نصب نشده است. DPC شما میتواند به سرپرستان فناوری اطلاعات کمک کند تا بررسی کنند کدام دستگاهها بهروزرسانیهای سیستم معلق دارند - و شاید از کاربران دستگاه بخواهند که بهروزرسانیهای مهم را فوراً نصب کنند.
دارندگان دستگاه و مالکان نمایهای که با Android نسخه ۸.۰ (سطح API ۲۶) یا بالاتر اجرا میشوند، میتوانند بررسی کنند که آیا دستگاهی بهروزرسانی سیستم معلق دارد یا خیر. DevicePolicyManager.getPendingSystemUpdate()
را فراخوانی کنید که اگر دستگاه به روز باشد، null
برمی گرداند. اگر بهروزرسانی سیستم در انتظار باشد، این روش اطلاعات مربوط به بهروزرسانی را برمیگرداند.
درباره بهروزرسانی معلق بیشتر بدانید
پس از فراخوانی getPendingSystemUpdate()
می توانید مقدار SystemUpdateInfo
برگشتی را بررسی کنید تا در مورد به روز رسانی معلق بیشتر بدانید. مثال زیر نشان می دهد که چگونه می توانید متوجه شوید که یک به روز رسانی معلق برای اولین بار در دستگاه در دسترس بوده است:
کاتلین
val firstAvailable = dpm.getPendingSystemUpdate(adminName)?.receivedTime firstAvailable?.let { Log.i(TAG, "Update first available: ${Date(firstAvailable)}") }
جاوا
SystemUpdateInfo updateInfo = dpm.getPendingSystemUpdate(adminName); if (updateInfo != null) { Long firstAvailable = updateInfo.getReceivedTime(); Log.i(TAG, "Update first available: " + new Date(firstAvailable)); }
تماس های سیستمی
هنگامی که یک بهروزرسانی در دسترس قرار میگیرد، سیستم Android صاحبان دستگاه را از بهروزرسانی جدید مطلع میکند. در اندروید 8.0 یا بالاتر، سیستم به صاحبان پروفایل نیز اطلاع میدهد.
در زیر کلاس DeviceAdminReceiver
، فراخوانی onSystemUpdatePending()
لغو کنید. برای دریافت پاسخ تماس نیازی به ثبت نام یا تبلیغ برای DPC خود ندارید. ممکن است سیستم برای یک بهروزرسانی، بیش از یک بار این روش را فراخوانی کند، بنابراین قبل از پاسخ دادن، وضعیت بهروزرسانی را بررسی کنید. با getPendingSystemUpdate()
تماس بگیرید تا در مورد به روز رسانی سیستم در callback اطلاعات بیشتری کسب کنید. مثال زیر نشان می دهد که چگونه می توانید این کار را انجام دهید:
کاتلین
/** * Called when a new update is available. */ override fun onSystemUpdatePending(context: Context?, intent: Intent?, receivedTime: Long) { // System update information is supported in API level 26 or higher. if (Build.VERSION.SDK_INT < Build.VERSION_CODES.O) { return } val updateInfo = getManager(context) .getPendingSystemUpdate(getWho(context)) ?: return if (updateInfo.securityPatchState == SystemUpdateInfo.SECURITY_PATCH_STATE_TRUE) { // Perhaps install because this is a security patch. // ... } }
جاوا
/** * Called when a new update is available. */ public void onSystemUpdatePending (Context context, Intent intent, long receivedTime) { // System update information is supported in API level 26 or higher. if (Build.VERSION.SDK_INT < Build.VERSION_CODES.O) { return; } SystemUpdateInfo updateInfo = getManager(context) .getPendingSystemUpdate(getWho(context)); if (updateInfo == null) { return; } if (updateInfo.getSecurityPatchState() == SystemUpdateInfo.SECURITY_PATCH_STATE_TRUE) { // Perhaps install because this is a security patch. // ... } }
هنگامی که یک سیستم بیش از یک DPC دارد، برای مثال نمایه های کاری در دستگاه های کاملاً مدیریت شده، مالک دستگاه و مالک نمایه هر دو پاسخ تماس را دریافت می کنند.
به روز رسانی سیاست ها
صاحب دستگاه می تواند با تنظیم خط مشی به روز رسانی سیستم محلی برای دستگاه، زمان نصب به روز رسانی ها را کنترل کند. خط مشی به روز رسانی سیستم می تواند یکی از سه نوع باشد:
- خودکار
- بهروزرسانیهای سیستم را به محض در دسترس شدن (بدون تعامل کاربر) نصب میکند. تنظیم این نوع خطمشی فوراً هر بهروزرسانی معلقی را که ممکن است به تعویق بیفتد یا منتظر یک پنجره تعمیر و نگهداری باشد، نصب میکند.
- پنجره دار
- به روز رسانی های سیستم را در طول یک پنجره تعمیر و نگهداری روزانه (بدون تعامل کاربر) نصب می کند. هنگام ایجاد یک خط مشی پنجرهدار جدید، شروع و پایان پنجره نگهداری روزانه را بهعنوان دقیقههای روز تنظیم کنید.
- به تعویق افتاد
- نصب به روز رسانی سیستم را به مدت 30 روز به تعویق می اندازد. پس از پایان دوره 30 روزه، سیستم از کاربر دستگاه می خواهد که به روز رسانی را نصب کند.
دوره های تعویق
سیستم هر به روز رسانی را به یک تعویق 30 روزه محدود می کند. این دوره زمانی شروع میشود که سیستم برای اولین بار بهروزرسانی را به تعویق میاندازد و تنظیم سیاستهای تعویق جدید باعث تمدید دوره نمیشود.
علاوه بر به تعویق انداختن، ممکن است اندروید به دلایل دیگری مانند عدم اتصال، فضای ناکافی دیسک یا باتری کم نتواند بهروزرسانی را نصب کند.
سیستم تایمر تعویق 30 روزه را بازنشانی میکند، اگر بهروزرسانی دیگری در طول دوره در دسترس باشد، به مدیران فناوری اطلاعات این فرصت را میدهد تا بهروزرسانیهای ترکیبی سیستم را امتحان کنند. پس از گذشت 30 روز بدون بهروزرسانی جدید، سیستم از کاربر میخواهد تمام بهروزرسانیهای معلق را نصب کند. بعداً، وقتی یک بهروزرسانی جدید سیستم در دسترس قرار گرفت، دوره 30 روزه دوباره شروع میشود.
نحوه تنظیم یک خط مشی
میتوانید خطمشیهای بهروزرسانی را در Android 8.0 (سطح API 26) یا بالاتر تنظیم کنید. برای تعیین زمانی که دستگاه باید بهروزرسانیهای سیستم را نصب کند، یک نمونه از SystemUpdatePolicy
را با استفاده از یکی از سه نوع ذکر شده در بالا ایجاد کنید. برای تنظیم یک خطمشی، مالک دستگاه شما روش DevicePolicyManager
setSystemUpdatePolicy()
را فراخوانی میکند. نمونه کد زیر نشان می دهد که چگونه می توانید این کار را انجام دهید. برای مشاهده مثالی از سیاست پنجره ای، به مستندات SystemUpdatePolicy
نگاه کنید.
کاتلین
// Create the system update policy to postpone installation for 30 days. val policy = SystemUpdatePolicy.createPostponeInstallPolicy() // Get a DevicePolicyManager instance to set the policy on the device. val dpm = context.getSystemService(Context.DEVICE_POLICY_SERVICE) as DevicePolicyManager val adminName = getComponentName(context) // Set the policy. dpm.setSystemUpdatePolicy(adminName, policy)
جاوا
// Create the system update policy to postpone installation for 30 days. SystemUpdatePolicy policy = SystemUpdatePolicy.createPostponeInstallPolicy(); // Get a DevicePolicyManager instance to set the policy on the device. DevicePolicyManager dpm = (DevicePolicyManager) context .getSystemService(Context.DEVICE_POLICY_SERVICE); ComponentName adminName = getComponentName(context); // Set the policy. dpm.setSystemUpdatePolicy(adminName, policy);
نمونههای خطمشی پس از ایجاد آنها قابل تغییر نیستند. برای تغییر زمانی که دستگاهی بهروزرسانیها را نصب میکند، میتوانید خطمشی جدیدی ایجاد و تنظیم کنید. برای حذف یک خط مشی از دستگاه، setSystemUpdatePolicy()
را به عنوان آرگومان policy
null
ارسال کنید. پس از اینکه DPC شما خطمشی را حذف کرد، کاربر دستگاه اعلانهایی را برای بهروزرسانیهای موجود سیستم میبیند.
برنامهها میتوانند برای دریافت خطمشی فعلی دستگاه، getSystemUpdatePolicy()
را فراخوانی کنند. اگر این روش null
را برگرداند، به این معنی است که یک خط مشی در حال حاضر تنظیم نشده است.
دوره های انجماد
برای مسدود کردن نسخه سیستم عامل در دورههای بحرانی، مانند تعطیلات یا دیگر زمانهای شلوغ، صاحبان دستگاهها میتوانند بهروزرسانیهای سیستم را تا 90 روز به حالت تعلیق درآورند. هنگامی که یک دستگاه در یک دوره انجماد قرار دارد به صورت زیر عمل می کند:
- دستگاه هیچ اعلانی درباره بهروزرسانیهای معلق سیستم دریافت نمیکند.
- به روز رسانی سیستم عامل نصب نشده است.
- کاربران دستگاه نمی توانند به صورت دستی به روز رسانی های سیستم را در تنظیمات بررسی کنند.
این سیستم یک دوره بافر اجباری 60 روزه را پس از هر دوره انجماد تعریف شده اعمال می کند تا از یخ زدن دستگاه به طور نامحدود جلوگیری کند. به یاد داشته باشید، ثابت کردن بهروزرسانیهای سیستم میتواند از دریافت بهروزرسانیهای حیاتی دستگاهها جلوگیری کند.
شما دوره های توقف را در یک خط مشی به روز رسانی تنظیم می کنید. شما نمی توانید دوره های توقف را بدون تنظیم خط مشی تنظیم کنید. وقتی دستگاه خارج از دورههای توقفی است که تنظیم کردهاید، رفتار خطمشی عادی (خودکار، پنجرهدار یا به تعویق افتاده) اعمال میشود.
نحوه تنظیم دوره انجماد
میتوانید دورههای توقف را در Android 9 (سطح API 28) یا بالاتر تنظیم کنید. مالک دستگاه قبل از تنظیم خطمشی برای دستگاه، یک دوره توقف را برای خطمشی بهروزرسانی سیستم تعیین میکند. مراحل عبارتند از:
- یک خط مشی به روز رسانی سیستم جدید (یا دریافت کنید) ایجاد کنید.
- با فراخوانی
setFreezePeriods()
دورههای انجماد را روی خطمشی تنظیم کنید. - با فراخوانی
setSystemUpdatePolicy()
، خط مشی و دوره های ثابت را برای دستگاه تنظیم کنید.
از آنجا که دوره انجماد سالانه تکرار می شود، تاریخ شروع و پایان دوره با مقادیر ماه و روز نمایش داده می شود. روز شروع باید حداقل 60 روز پس از پایان هر دوره انجماد قبلی شروع شود. مثال زیر نشان می دهد که چگونه می توانید دو دوره توقف را برای یک خط مشی به روز رسانی سیستم موجود تنظیم کنید:
کاتلین
// Get the existing policy from the DevicePolicyController instance. val policy = dpm.systemUpdatePolicy ?: return try { // Set the two annual freeze periods on the policy for our retail // point-of-sale devices. val summerSale = FreezePeriod( MonthDay.of(6, 1), MonthDay.of(7, 31)) // Jun 1 - Jul 31 inclusive val winterSale = FreezePeriod( MonthDay.of(11, 20), MonthDay.of(1, 12)) // Nov 20 - Jan 12 inclusive policy.freezePeriods = Arrays.asList(summerSale, winterSale) // Set the policy again to activate the freeze periods. dpm.setSystemUpdatePolicy(adminName, policy) } catch (e: SystemUpdatePolicy.ValidationFailedException) { // There must be previous periods recorded on the device because // summerSale and winterSale don’t overlap and are separated by more // than 60 days. Report the overlap ... }
جاوا
// Get the existing policy from the DevicePolicyController instance. SystemUpdatePolicy policy = dpm.getSystemUpdatePolicy(); try { // Set the two annual freeze periods on the policy for our // retail point-of-sale devices. FreezePeriod summerSale = new FreezePeriod( MonthDay.of(6, 1), MonthDay.of(7, 31)); // Jun 1 - Jul 31 inclusive FreezePeriod winterSale = new FreezePeriod( MonthDay.of(11, 20), MonthDay.of(1, 12)); // Nov 20 - Jan 12 inclusive policy.setFreezePeriods(Arrays.asList(summerSale, winterSale)); // Don’t forget to set the policy again to activate the freeze periods. dpm.setSystemUpdatePolicy(adminName, policy); } catch (SystemUpdatePolicy.ValidationFailedException e) { // There must be previous periods recorded on the device because summerSale // and winterSale don’t overlap and are separated by more than 60 days. // Report the overlap ... }
هم روز شروع و هم روز پایان شامل می شود. اگر روز شروع بزرگتر از روز پایان باشد (مانند winterSale
در مثال قبلی)، دوره انجماد تا سال بعد ادامه می یابد.
هنگام تنظیم دورههای توقف در خطمشی بهروزرسانی سیستم، Android این موارد را آزمایش میکند:
- هیچ دوره انجمادی بیش از 90 روز نیست.
- فاصله بین دوره های انجماد حداقل 60 روز است.
- دوره های انجماد با هم همپوشانی ندارند.
- هیچ دوره انجماد تکراری وجود ندارد.
هنگام تنظیم خطمشی بهروزرسانی سیستم برای دستگاه، Android این آزمایشها را تکرار میکند و دورههای ثابت فعلی یا گذشته دستگاه را شامل میشود.
Android یک SystemUpdatePolicy.ValidationFailedException
را زمانی که هر یک از این تست ها با شکست مواجه می شود، پرتاب می کند.
برای دریافت لیستی از دورههای انجماد که قبلاً روی یک شی سیاست بهروزرسانی سیستم تنظیم شدهاند، همه برنامههای نصب شده میتوانند SystemUpdatePolicy.getFreezePeriods()
را فراخوانی کنند. مثال زیر این روش را برای ثبت دوره های انجماد دستگاه فراخوانی می کند:
کاتلین
// Log any freeze periods that might be set on a system update policy. dpm.systemUpdatePolicy?.freezePeriods?.forEach { Log.i(TAG, "Freeze period: $it") }
جاوا
// Log any freeze periods that might be set on a system update policy. SystemUpdatePolicy currentPolicy = dpm.getSystemUpdatePolicy(); if (currentPolicy != null) { // A policy might not be set. for (FreezePeriod freezePeriod : currentPolicy.getFreezePeriods()) { Log.i(TAG, "Freeze period: " + freezePeriod.toString()); } }
سالهای کبیسه
اندروید از تقویم ISO 8601 (که تقویم میلادی نیز نامیده می شود) برای محاسبه دوره های انجماد استفاده می کند و سال های کبیسه را نادیده می گیرد. این بدان معنی است که 29 فوریه به عنوان یک تاریخ معتبر شناخته نمی شود و به گونه ای رفتار می شود که گویی 28 فوریه است. بنابراین، 29 فوریه هنگام محاسبه مدت یک دوره انجماد محاسبه نمی شود.
توسعه و آزمایش
در حالی که در حال توسعه و آزمایش ویژگی بهروزرسانی سیستم DPC خود هستید، ممکن است لازم باشد دورههای توقف زیادی ایجاد کنید. از آنجایی که Android فاصله 60 روزه بین دورههای انجماد گذشته را بررسی میکند، ممکن است نتوانید بدون پاک کردن رکورد دورههای گذشته، دوره ثابت جدیدی را تنظیم کنید. برای پاک کردن رکورد دوره انجماد دستگاه، دستور زیر را در پوسته Android Debug Bridge (adb) اجرا کنید:
adb shell dpm clear-freeze-period-record
با بررسی غیرفعال بودن رابط کاربری برای بهروزرسانیهای سیستم، میتوانید تأیید کنید که دستگاهی در دوره توقف قرار دارد.
بهروزرسانیهای سیستم Google Play (خط اصلی)
بهروزرسانیهای سیستم Google Play (که بهروزرسانیهای خط اصلی نیز گفته میشود) بهطور خودکار دانلود میشوند، اما برای نصب نیاز به راهاندازی مجدد دستگاه دارند. این بهروزرسانیها راهاندازی مجدد خودکار را راهاندازی نمیکنند و در عوض روی راهاندازی مجدد کاربر، سرپرست یا سیاستگذاری بعدی نصب میشوند. راهاندازی مجدد توسط خطمشی بهروزرسانی سیستم، بهروزرسانی سیستم Google/OEM مرتبط و هر بهروزرسانی سیستم Google Play را که قبلاً دانلود شده است، نصب میکند.
بهروزرسانیهای سیستم Google Play را نیز میتوانید با پیمایش به تنظیمات > درباره > نسخه اندروید > بهروزرسانی سیستم Google Play به صورت دستی نصب کنید.
منابع اضافی
برای کسب اطلاعات بیشتر درباره بهروزرسانیهای سیستم، اسناد بهروزرسانی OTA پروژه منبع باز Android را بخوانید.