كيف تختار نموذج توزيع تطبيق Windows - MSI و MSIX و ClickOnce و xcopy والـ custom updaters
نزّل دفتر العمل Excel لاتّخاذ القرار، مع ورقتين باليابانيّة والإنجليزيّة
حين تناقش الفِرَق كيفيّة توزيع تطبيق Windows، يبدأ النقاش غالباً من المكان الخطأ. فالناس يسألون بطبيعتهم أيّ خيار أحدث، أو أيّها يبدو أبسط، أو أيّها يبدو أكثر حداثة.
أمّا في الواقع العملي، فالقرار المفيد ينبع عادةً من أسئلة مختلفة:
- هل ينبغي تثبيت هذا per-user أم per-machine؟
- هل ينبغي أن يملك سلوك التحديث منصّة التوزيع أم فريق التطبيق؟
- هل يحتاج التطبيق إلى services أو drivers أو shell extensions أو تسجيل COM؟
- هل عليه أن يصمد في التوزيع المغلق الشبكة أو offline أو عبر USB؟
- هل يحتاج إلى package identity، أم ينبغي أن يبقى تطبيق Win32 الكلاسيكي بلا قيود؟
إذن فالاختيار الحقيقي ليس أساساً حول صيغة الـ installer، بل حول مدى عمق اندماج التطبيق مع Windows ومن يملك مسؤوليّة التحديث.
تنظّم هذه المقالة MSI و MSIX و ClickOnce و xcopy deployment والـ custom updaters كجدول قرار عملي بدلاً من أن تكون مسابقة شعبيّة.
1. الإجابة المختصرة
إذا بسّطنا القرار بشدّة لكن أبقينا عليه مفيداً، يبدو هكذا:
- إن كان التطبيق يثبَّت machine-wide ويحتاج إلى services أو تسجيل COM أو متطلّبات على مستوى الجهاز، فابدأ من MSI
- إن كان الهدف هو Windows الحديث وأردت سلوك clean install / clean uninstall وتحديثاً متكرّراً و package identity، فإنّ MSIX يصبح جذّاباً جدّاً
- إن كان التطبيق تطبيق سطح مكتب .NET يُوزَّع per-user داخل المؤسّسة وأردت تحديثاً built-in بسيطاً، فإنّ ClickOnce لا يزال خياراً قويّاً
- إن كانت الأولويّة القصوى هي «انسخه إلى هناك وشغّله»، خاصّة في البيئات المغلقة أو offline، فإنّ xcopy deployment غالباً ما يكون الأنسب
- إن أردت التحكّم بالـ channels والـ staged rollout والـ custom update UX والـ telemetry وسلوك الـ rollback وتدفّق التحديث في الخلفيّة بنفسك، فأنت في منطقة الـ custom updater
- إن وُجدت drivers، فلا تبدأ بعقليّة MSIX-first
- إن احتجت إلى in-process Explorer shell extensions، فإنّ MSIX عادةً ليس المكان الصحيح للبدء
عادةً ما يتلخّص ذلك في:
- تسجيل ثقيل على نظام التشغيل -> MSI
- package identity وتغليف حديث -> MSIX
- تسليم .NET بسيط per-user مع تحديث built-in -> ClickOnce
- أدوات بنمط copy-and-run -> xcopy
- تحكّم بمستوى المنتج بالتحديث -> custom updater
2. هذه الخيارات الخمسة ليست فعلاً على المحور نفسه
هذا أهمّ ممّا يتوقّعه الناس.
MSI / MSIX / ClickOnce / xcopy تتعلّق أساساً بـ كيف يُدخَل التطبيق إلى الجهاز.
أمّا الـ custom updater فيتعلّق أساساً بـ كيف تُملَك التحديثات المستمرّة وتُسلَّم.
هذا يجعل النموذج ذا الطبقتين أسهل بكثير في التفكير:
| الطبقة | الخيارات النموذجيّة | القرار الرئيسي |
|---|---|---|
| التسليم الأوّلي | MSI / MSIX / ClickOnce / xcopy | إلى أين تذهب الملفّات، ماذا يُسجَّل، مستوى الصلاحيّات، قصّة الـ uninstall |
| التحديثات المستمرّة | MSIX App Installer / ClickOnce / استبدال يدوي / custom updater | فحوصات التحديث، مصدر التوزيع، التحقّق من التوقيع، الـ rollback، الـ channels، الـ update UX |
إذن فالـ custom updater عادةً ليس أوّل ما يُختار. هو الشيء الذي تضيفه حين لا تعود نماذج التحديث الـ built-in كافية.
هذا التمييز مهمّ في المشاريع الفعليّة لأنّ الفِرَق تنتهي غالباً بتركيبات مثل:
- xcopy + custom updater
- MSI للتثبيت الأوّل + تحديث يتحكّم به التطبيق لاحقاً
- MSIX + App Installer
- ClickOnce لكلٍّ من التسليم الأوّل والتحديث
قصّة التثبيت الأوّلي وقصّة التحديث المستمرّ تستحقّان غالباً قرارَين منفصلَين.
3. جدول قرار عملي
| الحالة | نقطة بداية جيّدة | السبب |
|---|---|---|
| تثبيت machine-wide مع services وتسجيل COM وحالة على مستوى الجهاز | MSI | يطابق مسؤوليّات تثبيت Windows الكلاسيكيّة بنظافة |
| استهداف Windows الحديث، clean install / uninstall، تحديثات متكرّرة، package identity | MSIX | يناسب نموذج التغليف والتحديث الحديث |
| تطبيق .NET per-user للأعمال مع توزيع بسيط وتحديث built-in | ClickOnce | يبقي احتكاك المستخدم منخفضاً |
| أدوات ينبغي فقط نسخها وتشغيلها | xcopy | يتجنّب تعقيد الـ installer كلّيّاً تقريباً |
| منتج تجاري يحتاج إلى staged rollout و channels و custom update UX | custom updater | نماذج التسليم الـ built-in تعطي عادةً تحكّماً أقلّ |
| وجود drivers | MSI أو مسار installer أكثر تخصّصاً | تغليف الـ drivers مسألة منفصلة |
| وجود shell extension يعمل in-process | MSI أو مسار installer أكثر تخصّصاً | اندماج الـ shell ينقل المشكلة نحو التسجيل وسلوك الـ host |
| وجود Windows service مع استهداف Windows الحديث | MSI أوّلاً، ثم قارن MSIX بحذر | دعم الـ service موجود في بعض سيناريوهات MSIX، لكنّ الشروط والقيود مهمّة |
أهمّ درس في هذا الجدول هو:
وجود التحديثات لا يبرّر تلقائيّاً custom updater.
4. مقارنة بحسب الاهتمام
| الاهتمام | MSI | MSIX | ClickOnce | xcopy | Custom updater |
|---|---|---|---|---|---|
| تثبيت per-user | جيّد | جيّد | ممتاز | ممتاز | جيّد |
| تثبيت per-machine | ممتاز | جيّد | محدود | ضعيف | جيّد |
| دعم التحديث الـ built-in | محدود | ممتاز | ممتاز | لا يوجد | ممتاز |
| package identity | لا | نعم | لا | لا | لا |
| التوافق مع الـ services | ممتاز | مشروط | ضعيف | ضعيف | مشروط |
| التوافق مع الـ drivers | مشروط | ضعيف | ضعيف | ضعيف | مشروط |
| التوافق مع shell extensions | ممتاز | ضعيف | ضعيف | ضعيف | مشروط |
| التوزيع offline / مغلق الشبكة | ممتاز | جيّد | جيّد | ممتاز | ممتاز |
| تكلفة التنفيذ والتشغيل | متوسّطة | متوسّطة | منخفضة | منخفضة | عالية |
| مرونة الـ update UX | محدودة | جيّدة | محدودة | لا توجد | ممتازة |
السؤال الصحيح ليس «أيّها الأقوى؟»، بل «أيّها يخلق أقلّ احتكاك لهذا التطبيق؟»
على سبيل المثال:
- إن احتجت إلى services
- إن ثبّتّ تحت Program Files
- إن أنشأت حالة على مستوى الجهاز
- إن سجّلت COM أو file associations
فإنّ MSI لا يزال يبدو طبيعيّاً في معظم الأحيان.
من جهة أخرى، إن كان ما تريده فعلاً هو:
- package identity
- سلوك تحديث وإزالة نظيف
- تسليم بأسلوب App Installer
- محاذاة أوثق مع تغليف Windows الحالي
فإنّ MSIX يصبح أكثر إقناعاً بكثير.
5. أين يلائم كلّ نهج
5.1 MSI
MSI لا يزال نقطة المرجع الأساسيّة حين يبدو المتطلّب هكذا:
«لدينا تطبيق سطح مكتب Windows كلاسيكي، ونريد قصّة install / uninstall / repair لائقة».
الملاءمة النموذجيّة:
- تطبيقات أعمال machine-wide
- تطبيقات تحوي Windows services
- تطبيقات تحتاج إلى تسجيل COM أو file associations أو إعدادات machine-wide
- منتجات تعيش بالفعل في نموذج دعم تقليدي تقوده الـ installers
- منتجات لا تكون التحديثات فيها متكرّرة جدّاً وتريد فِرَق التشغيل التحكّم بتوقيت الـ rollout
أكبر نقاط قوّته أنّه يطابق نموذج تثبيت Windows التقليدي بشكل طبيعي. قصّة الـ installer وقصّة الإزالة وقصّة الـ repair وقصّة الحالة على الجهاز كلّها أسهل في الشرح والدعم في البيئات التي تتوقّع بالفعل سلوك Windows Installer.
نقاط ضعفه مألوفة أيضاً:
- التأليف (authoring) قد يكون مرهقاً
- يحتاج تصميم الـ upgrade والـ patch إلى عناية
- كثرة الـ custom actions تجعل الحزم هشّة
- منتجات التحديث المتكرّر قد تجد تجربة المستخدم أثقل ممّا تريد
إن وُجدت drivers، قد يبقى MSI هو وسيلة التسليم الخارجيّة، لكن يجب التعامل مع driver package نفسه كمسألة توزيع منفصلة بدلاً من مجرّد ملفّ آخر داخل التطبيق.
5.2 MSIX
MSIX هو الأقوى حين يكون الهدف الحقيقي:
«نريد تغليفاً نظيفاً وتحديثاً نظيفاً وإزالة نظيفة و package identity».
الملاءمة النموذجيّة:
- تطبيقات سطح مكتب تستهدف Windows الحديث
- تطبيقات يتمّ تحديثها بشكل متكرّر نسبيّاً
- تطبيقات تريد package identity لميزات Windows
- منظّمات تريد المحاذاة مع App Installer أو Intune أو مسارات تسليم حديثة مماثلة
- سيناريوهات WinUI 3 / Windows App SDK المُغلَّفة
أكبر نقاط قوّته:
- سلوك install / uninstall نظيف
- قصّة تحديث قويّة
- package identity
- نموذج تغليف Windows حديث
لكنّه ليس عالميّاً. يصبح أقلّ ملاءمة حين يعتمد المنتج بشدّة على سيناريوهات مثل:
- in-process shell extensions
- نشر drivers
- افتراضات Win32 الكلاسيكيّة بلا قيود
- أنماط اندماج مع الجهاز لا تطابق سلوك الحزم بنظافة
إذن فإنّ MSIX ليس ببساطة «الافتراضي الجديد». بل هو الأداة الصحيحة حين يطابق نموذج التغليف فيه نموذج التشغيل الفعلي للمنتج.
5.3 ClickOnce
لا يزال ClickOnce يلائم حالة محدّدة لكن شائعة جدّاً:
«لدينا تطبيق سطح مكتب .NET، ونريد توزيعاً per-user، ونريد تحديثاً built-in بسيطاً مع احتكاك منخفض على المستخدم».
الملاءمة النموذجيّة:
- تطبيقات أعمال .NET داخليّة
- بيئات المستخدم القياسي
- توزيع per-user
- فِرَق تريد تدفّق تحديث بسيطاً دون تصميم منصّة تحديث كاملة
أكبر نقاط قوّته أنّه يبقي احتكاك التوزيع منخفضاً للمستخدم مع منح التطبيق نموذج تحديث حقيقي.
في الوقت نفسه، ليس المكان الصحيح لتوقّع:
- تسجيل عميق على نظام التشغيل
- سلوك تثبيت machine-level واسع
- نشر services و drivers
- دور installer متعدّد الأغراض كاملاً
بكلمات أخرى، ClickOnce قويّ حين ينبغي أن يبقى التطبيق خفيفاً وضمن نطاق المستخدم.
5.4 xcopy
xcopy deployment هو فعلاً:
التوزيع بدون تثبيت
لا يوجد package identity، ولا حالة installer، ولا نموذج repair، ولا تسجيل تلقائي على نظام التشغيل. في المقابل، إن كان التطبيق فعلاً self-contained، فإنّ النموذج التشغيلي يصبح بسيطاً للغاية.
الملاءمة النموذجيّة:
- أدوات التشخيص
- أدوات تكوين الأجهزة
- أدوات جمع السجلّات
- أدوات الدعم الميداني المسلَّمة عبر USB
- تطبيقات داخليّة صغيرة في بيئات مغلقة
- سيناريوهات side-by-side متعدّدة الإصدارات
أكبر نقاط قوّته أنّ أوضاع الفشل سهلة الفهم:
- استبدل المجلّد
- احتفظ بإصدارات متعدّدة
- ارجع للوراء باستعادة الدليل السابق
قيوده واضحة بالقدر نفسه:
- لا توجد قصّة Start menu / ARP / repair built-in
- لا حلّ تلقائي للـ services أو اندماج الـ shell أو الـ drivers أو file associations
- لا يوجد نموذج تحديث built-in
- يجب التعامل مع تصميم البيانات القابلة للتغيّر بحذر
xcopy هو الأقوى حين يستطيع التطبيق فعلاً العيش بـ:
انسخه ليعمل، احذفه لتزيله
5.5 الـ Custom updater
الـ custom updater هو خيار يتعلّق بالملكيّة أكثر من كونه يتعلّق بالراحة.
يلائم بأفضل صورة حين يصبح سلوك التحديث نفسه جزءاً من المنتج:
- release channels مثل stable / beta / preview
- staged rollout
- نوافذ صيانة
- تحكّم بالتحديث مدعوم بالـ telemetry
- منطق الـ rollback
- تدفّق تنزيل في الخلفيّة مخصّص
- update UX خاصّ بالمنتج
نقاط قوّته واضحة:
- تحكّم كامل بتجربة التحديث
- تحكّم كامل بشكل الـ manifest وسلوك الـ rollout
- channels و kill switches وتسليم متدرّج و rollback و UX مخصّص
- يمكن وضعه فوق نماذج توزيع بسيطة في غير ذلك
لكنّ تكلفة المسؤوليّة كبيرة أيضاً:
- التحقّق من التوقيع
- تصميم الـ manifest
- سلوك إعادة المحاولة والـ resume
- سلوك الـ proxy / firewall / offline
- التعامل مع الـ rollback
- التحديث الذاتي للـ updater
- الاسترداد من تحديثات معطّلة
- عبء الدعم حين يسوء سلوك التحديث
لذلك فإنّ الـ custom updaters هي الأقوى حين:
- يمتلك المنتج حجماً حقيقيّاً
- يمتلك الفريق ميزانيّة تشغيل مستمرّة
- يكون سلوك التحديث قريباً من قيمة المنتج
بالنسبة للأدوات الداخليّة الأصغر، السؤال الأوّل الصحيح عادةً هو:
«هل يمكن لـ MSI أو MSIX أو ClickOnce أو xcopy مع عمليّة تشغيل بسيطة أن يحلّ هذا بالفعل؟»
6. الأسئلة التي تجعل الفِرَق تتردّد عادةً
6.1 هل تحتاج إلى package identity؟
هذا غالباً ما يكون مفترق طرق رئيسيّاً.
إن كان التطبيق يريد ميزات Windows مرتبطة ارتباطاً وثيقاً بـ package identity، فإنّ MSIX يبدأ بأن يصبح أكثر أهمّيّة.
أمّا إن كان التطبيق يريد الحفاظ على:
- وصول غير مقيّد إلى نظام الملفّات
- وصول غير مقيّد إلى الـ registry
- سلوك process و elevation أكثر كلاسيكيّة
- افتراضات Win32 القديمة
فإنّ المقاربات غير المُغلَّفة تبقى غالباً أكثر طبيعيّة.
6.2 هل لديك services أو drivers أو shell integration؟
هذه الاهتمامات الثلاثة تجعل التوزيع أثقل بكثير وبسرعة كبيرة.
- الـ drivers: ملاءمة ضعيفة لتفكير MSIX-first
- الـ in-process shell extensions: ملاءمة ضعيفة لـ MSIX
- الـ Windows services: MSI طبيعي، يمكن مقارنة MSIX بحذر وبشروط فقط
كلّما تعمّق التطبيق في اندماج Windows، قلّت فائدة التحسين فقط من أجل installer ذي مظهر خفيف.
6.3 هل هذا per-user أم per-machine؟
ينبغي ألّا يبقى هذا غامضاً طويلاً.
- per-user يشير عادةً إلى:
- ClickOnce
- xcopy
- بعض سيناريوهات MSIX
- per-machine يشير عادةً إلى:
- MSI
- بعض سيناريوهات MSIX المختارة بعناية
«يجب أن يستطيع المستخدمون القياسيّون تثبيته» و«ينبغي أن يشارك جميع من على الجهاز التثبيت نفسه» ليسا المتطلّب نفسه.
6.4 كم مرّة تحدّث، ومن يملك تلك العمليّة؟
نظرة عمليّة تقريبيّة:
- تحديثات ربع سنويّة إلى شهريّة: MSI لا يزال غالباً جيّداً
- تحديثات شهريّة إلى أسبوعيّة: MSIX أو ClickOnce يصبح أكثر جاذبيّة
- تحديثات أسبوعيّة إلى يوميّة: تبدأ مبرّرات الـ custom updater في أن تصبح حقيقيّة
- تحديثات يدويّة أو يتحكّم بها المشغّل: xcopy قد يكون أكثر من كاف
التوزيع دائماً قرار تقني جزئيّاً وقرار تشغيلي جزئيّاً.
6.5 هل تستهدف بيئات مغلقة أو offline؟
في الشبكات المغلقة، البساطة تتفوّق غالباً على الأناقة.
- xcopy يبقى قويّاً
- MSI يبقى قويّاً
- ClickOnce لا يزال يعمل عبر file shares أو الوسائط القابلة للإزالة
- MSIX لا يزال يعمل، لكن يجب تصميم مسار التوزيع الفعلي بوضوح
إن كانت التحديثات المتكرّرة مطلوبة في بيئة مغلقة، فإنّ المشكلة الحقيقيّة لم تعد فقط «أيّ نموذج تغليف؟» بل أيضاً:
- من يضع الإصدار الجديد
- أين يُوضَع
- كيف يُحفَظ الإصدار السابق
- كيف يُتعامَل مع الـ rollback
7. ستّة أسئلة لطرحها قبل اتّخاذ القرار
إن كان فريق ما عالقاً، فإنّ هذه الأسئلة الستّة تقطع عادةً الالتباس:
- هل التطبيق per-user أم يحتاج إلى وجود machine-wide؟
- هل يحتاج إلى services أو drivers أو shell extensions أو تسجيل COM؟
- هل يحتاج إلى package identity؟
- هل يجب أن يثبّته المستخدمون القياسيّون دون مساعدة إداريّة؟
- ما هو تواتر التحديثات حقّاً؟
- هل البيئة المستهدفة مغلقة أو offline أو موحّدة بدرجة عالية؟
تلك الإجابات تضيق الخيار عادةً بسرعة:
- إن كان السؤال 2 «نعم»، فابدأ بالتفكير من افتراضات جانب MSI
- إن كان السؤال 3 «نعم»، فأعطِ الأولويّة لمقارنة MSIX
- إن كان per-user وتثبيتاً للمستخدم القياسي وتطبيق .NET سطح مكتب، فإنّ ClickOnce يصبح مرشّحاً جدّيّاً
- إن كان per-user وبدون تسجيل عميق على نظام التشغيل ويمكنه فعلاً أن يكون «انسخ وشغّل»، فإنّ xcopy يصبح مرشّحاً جدّيّاً
- إن كان تواتر التحديث مرتفعاً وكان الـ update UX نفسه قيمة منتج، فأدخل الـ custom updaters في المقارنة
8. الخلاصة
يمكن تلخيص خيارات توزيع Windows في جملة واحدة:
افصل كيف يصل التطبيق أوّلاً إلى الجهاز عن من يملك التحديثات المستمرّة.
من هناك، الملخّص العملي:
- MSI: برنامج سطح مكتب كلاسيكي مع اندماج أعمق مع نظام التشغيل
- MSIX: تغليف حديث، package identity، سلوك تحديث نظيف
- ClickOnce: تطبيقات .NET للأعمال per-user بسيطة
- xcopy: أدوات copy-and-run بأقلّ اقتران مع النظام
- Custom updater: منتجات تملك سلوك التحديث بنفسها عن قصد
وأهمّ تذكير هو هذا:
- إن وُجدت drivers أو shell integration أو services، يُحدَّد التوزيع باندماج نظام التشغيل أكثر من شكل الـ installer
- إن كانت package identity مهمّة، فإنّ MSIX أكثر أهمّيّة
- إن كانت البيئة مغلقة، فالبساطة تربح غالباً
- ينبغي أن يكون الـ custom updater آخر تصعيد عادةً، لا أوّل ردّة فعل
إن كان فريق ما لا يزال غير متأكّد، فإنّ تثبيت هذه النقاط الثلاث مبكّراً يساعد كثيراً غالباً:
- per-user أم per-machine
- ما الذي يُسجَّل في Windows
- كم مرّة تحدث التحديثات حقّاً
9. مراجع
- Microsoft Learn, Windows Installer
- Microsoft Learn, What is MSIX?
- Microsoft Learn, Packaging overview for Windows apps
- Microsoft Learn, MSIX features and supported platforms
- Microsoft Learn, App Installer file overview
- Microsoft Learn, Prepare to package a desktop application
- Microsoft Learn, Know your installer
- Microsoft Learn, Convert an installer that includes services
- Microsoft Learn, ClickOnce deployment and security
- Microsoft Learn, Manage updates for a ClickOnce application
- Microsoft Learn, Choosing a ClickOnce deployment strategy
- Microsoft Learn, ClickOnce cache overview
- Microsoft Learn, Windows App SDK deployment guide for self-contained apps
مقالات ذات صلة
أحدث المقالات التي تشترك في نفس الوسوم. عمّق فهمك بمواضيع مرتبطة.
ما هو ClickOnce - كيف يعمل، وكيف تعمل التحديثات، ومتى يلائم العمل الفعليّ ومتى لا يلائمه
نظرة عمليّة على ClickOnce لتوزيع تطبيقات .NET لسطح مكتب Windows: كيف تعمل manifests والتحديثات والـ cache، ومتى يلائم العمل الداخليّ ومتى...
أساسيّات أمان ميزة التحديث التلقائيّ - الأنماط السيّئة وأفضل الممارسات
نلخّص أساسيّات أمان ميزة التحديث التلقائيّ: لماذا لا يكفي HTTPS، وأهمّيّة signed metadata والتحقّق من جهة الـ client وفصل المفاتيح ومواجه...
إلى أيّ مدى يمكن لتطبيق Windows أن يكون فعلاً single binary - ما الذي يندرج في EXE واحد وما الذي يبقى معتمداً على Windows
متى يكون الـ EXE الواحد هدفاً واقعيّاً على Windows ومتى لا. تفصل المقالة بين عدد الملفّات وتجميع الـ runtime وتسجيل الـ OS، لتقرّر شكل ال...
كيف نُطيل عمر أنظمة الويب الداخليّة المعتمدة على IE mode وكيف نخرج منها - تنظيم الاستراتيجيّات الميدانيّة من الإدارة المركزيّة لقائمة المواقع، إلى WebView2، والإعادة الهيكليّة التدريجيّة، ووصولًا إلى عزل VDI
نتناول استراتيجيّةً عمليّةً لإطالة عمر أنظمة الويب الداخليّة المعتمدة على IE mode والخروج منها تدريجيًّا عبر إدارة قائمة المواقع وتغليف W...
ما يجب التحقّق منه عندما لا يعمل ActiveX على Office 2024 / Microsoft 365 - الترتيب العمليّ لتغطية التعطيل الافتراضيّ، 32bit / 64bit، تسجيل COM، DLL التابعة، ووصولًا إلى IE mode
دليل عمليّ لتشخيص توقّف ActiveX على Office 2024 و Microsoft 365، يرتّب الفحوص من التعطيل الافتراضيّ إلى تطابق 32bit / 64bit وتسجيل COM وD...
أين يتصل هذا الموضوع
ترتبط هذه المقالة بشكل طبيعي بصفحات الخدمات التالية.
تطوير تطبيقات ويندوز
ندعم تطوير برامج ويندوز للأعمال، وتكامل الأجهزة، وأدوات التواصل.
صيانة وتحديث برامج ويندوز الحالية
ندعم إضافة الميزات، والصيانة، والتحديث المتدرّج لبرامج ويندوز الحالية.