یک دستگاه را بردارید

حذف یک دستگاه شامل از رده خارج کردن آن از ساختار است. کاربر می‌تواند این کار را با استفاده از Google Home app (GHA) انجام دهد و یک برنامه می‌تواند به صورت برنامه‌نویسی شده یک دستگاه خانه هوشمند را از رده خارج کند. محدودیت‌هایی در مورد اینکه کدام دستگاه‌ها می‌توانند حذف شوند وجود دارد. همچنین، حذف یک دستگاه می‌تواند بر ساختار و تجربه کاربری برنامه شما تأثیر بگذارد.

آنچه می‌توانید حذف کنید

شما می‌توانید دستگاه‌های زیر را از طریق APIهای Home و با استفاده از برنامه‌نویسی حذف کنید:

  • Matter دستگاه‌هایی است که برنامه شما به آنها مجوز می‌دهد.
  • پل‌های Matter ، مشروط بر اینکه برنامه شما به تمام دستگاه‌های متصل از طریق پل دسترسی داشته باشد. حذف پل، تمام دستگاه‌های Matter متصل به آن را حذف می‌کند.

آنچه را که نمی‌توانید حذف کنید

دستگاه‌های زیر را نمی‌توان از طریق APIهای Home به صورت برنامه‌نویسی شده حذف کرد:

  • دستگاه‌هایی که برنامه شما برای آنها مجوز کاربر ندارد، Matter .
  • دستگاه‌های مجزایی که از پشت یک پل Matter به هم متصل شده‌اند.
  • دستگاه‌های متصل Cloud-to-cloud .
  • دستگاه‌های دو مسیره (دستگاه‌هایی که هم Matter و Cloud-to-cloud را پیاده‌سازی می‌کنند).

نکات مهم قبل از حذف دستگاه

وقتی برنامه شما دستگاهی را حذف می‌کند، آن دستگاه از کل ساختار حذف می‌شود و بر همه کاربران و همه برنامه‌ها، از جمله GHA ، تأثیر می‌گذارد. بسته به نوع دستگاه، ممکن است عوارض جانبی دیگری نیز در از رده خارج کردن دستگاه وجود داشته باشد:

  • دستگاه‌هایی که چندین نوع دستگاه را پیاده‌سازی می‌کنند: اگر دستگاهی چندین عملکرد داشته باشد - برای مثال، یک چراغ هوشمند که به عنوان هاب نیز عمل می‌کند، حذف آن، تمام دستگاه‌های مرتبط را نیز حذف می‌کند. برنامه باید در صورت تحت تأثیر قرار گرفتن چندین عملکرد دستگاه، به کاربر اطلاع دهد.
  • تاریخچه دستگاه: حذف یک دستگاه ممکن است منجر به حذف تاریخچه دستگاه شود.
  • سطوح مشترک: هنگام برداشتن وسایل از روی سطوح مشترک احتیاط کنید، زیرا این کار می‌تواند عواقب ناخواسته‌ای برای دیگران داشته باشد.
  • احراز هویت: جداسازی دستگاه فقط باید روی سطوح دارای مجوز، مانند تلفن همراه، انجام شود، نه روی دستگاه‌های غیرمجاز مانند تلویزیون. انجام این کار نقض سیاست‌های توسعه‌دهندگان Google Home است.

حذف یک دستگاه

بررسی واجد شرایط بودن یک دستگاه برای حذف شدن پرهزینه است و فقط باید در صورت لزوم انجام شود. برای بررسی اینکه آیا یک دستگاه واجد شرایط حذف شدن است، از دستور زیر استفاده کنید:

swift let eligibility = try await device.decommissionEligibility

دستگاه‌های ماده

اگر دستگاه Matter پشت پل Matter نباشد، می‌توانید آن را به صورت برنامه‌نویسی حذف کنید.

برای حذف یک دستگاه Matter ، تابع decommission() را روی آن فراخوانی کنید:

swift let decommissionedDeviceIDs = try await device.decommission()

اگر فراخوانی خطایی ایجاد نکند، یعنی با موفقیت انجام شده است.

می‌توانید بررسی کنید که آیا شناسه دستگاه در میان شناسه‌های بازگردانده شده توسط decommission() وجود دارد یا خیر:

swift do { let decommissionedDeviceIDs = try await device.decommission() print("The following devices were decommissioned: \(decommissionedDeviceIDs)") } catch { print("An error occurred: \(error)") }

دستگاه‌های غیرمادی

دستگاه‌های غیر Matter را نمی‌توان به صورت برنامه‌نویسی حذف کرد. برای حذف یک دستگاه غیر Matter ، می‌توانید یک درخواست همگام‌سازی (به بخش درخواست همگام‌سازی مراجعه کنید) ارسال کنید، یا یکپارچه‌سازی Cloud-to-cloud را حذف کنید (به بخش حذف یکپارچه‌سازی Cloud-to-cloud راه‌اندازی شده مراجعه کنید).

اگر تابع decommission() را روی یک دستگاه غیر Matter فراخوانی کنید، HomeError رخ می‌دهد.

پس از حذف یک دستگاه Matter ، وجود دستگاه را بررسی کنید تا از حذف موفقیت‌آمیز آن اطمینان حاصل کنید:

swift guard try await !self.context.devices().list().contains(where: { $0.id == deviceID }) else { // The device still exists in Home APIs }

دستگاه‌های چند منبعی

دستگاه‌های چندمنبعی، دستگاه‌هایی هستند که از هر دو API Cloud-to-cloud و Matter استفاده می‌کنند. اگر واجد شرایط بودن برای از رده خارج کردن چنین دستگاهی را بررسی کنید، با خطای DecommissionIneligibleReason.multiSourceDevice مواجه خواهید شد که نشان می‌دهد چون دستگاه چندمنبعی است، نمی‌توان آن را از رده خارج کرد.

برای حذف یک دستگاه چند منبعی، از روش زیر استفاده کنید:

  1. ارتباط Cloud-to-cloud را همانطور که در دستگاه‌های غیرمادی توضیح داده شده است، حذف کنید.
  2. دستگاه Matter را همانطور که در بخش دستگاه‌های Matter توضیح داده شده است، از کار بیندازید.

ترتیب انجام این مراحل مهم است. اگر قبل از حذف ارتباط Cloud-to-cloud ، سعی کنید دستگاه Matter را از کار بیندازید، HomeError رخ می‌دهد.