macOS System Extensions

हैकट्रिक्स का समर्थन करें

सिस्टम एक्सटेंशन्स / एंडपॉइंट सिक्योरिटी फ्रेमवर्क

कर्नल एक्सटेंशन्स की तरह, सिस्टम एक्सटेंशन्स यूजर स्पेस में चलते हैं कर्नल स्पेस की बजाय, जिससे एक्सटेंशन के खराब होने से सिस्टम क्रैश का जोखिम कम होता है।

तीन प्रकार की सिस्टम एक्सटेंशन्स होती हैं: ड्राइवरकिट एक्सटेंशन्स, नेटवर्क एक्सटेंशन्स, और एंडपॉइंट सिक्योरिटी एक्सटेंशन्स।

ड्राइवरकिट एक्सटेंशन्स

ड्राइवरकिट कर्नल एक्सटेंशन्स की जगह है जो हार्डवेयर समर्थन प्रदान करता है। इसकी मदद से डिवाइस ड्राइवर्स (जैसे USB, सीरियल, NIC, और HID ड्राइवर्स) कर्नल स्पेस की बजाय यूजर स्पेस में चल सकते हैं। ड्राइवरकिट फ्रेमवर्क में कुछ I/O किट क्लासेस के यूजर स्पेस संस्करण शामिल हैं, और कर्नल सामान्य I/O किट इवेंट्स को यूजर स्पेस में फॉरवर्ड करता है, जिससे इन ड्राइवर्स को चलाने के लिए एक सुरक्षित वातावरण प्रदान किया जाता है।

नेटवर्क एक्सटेंशन्स

नेटवर्क एक्सटेंशन्स नेटवर्क व्यवहारों को अनुकूलित करने की क्षमता प्रदान करते हैं। कई प्रकार के नेटवर्क एक्सटेंशन्स होते हैं:

  • ऐप प्रॉक्सी: इसका उपयोग एक वीपीएन क्लाइंट बनाने के लिए किया जाता है जो एक फ्लो-ओरिएंटेड, कस्टम वीपीएन प्रोटोकॉल को लागू करता है। इसका मतलब है कि यह कनेक्शन्स (या फ्लोज) के आधार पर नेटवर्क ट्रैफिक का संचालन करता है बजाय व्यक्तिगत पैकेट्स के।

  • पैकेट टनल: इसका उपयोग एक वीपीएन क्लाइंट बनाने के लिए किया जाता है जो एक पैकेट-ओरिएंटेड, कस्टम वीपीएन प्रोटोकॉल को लागू करता है। इसका मतलब है कि यह व्यक्तिगत पैकेट्स के आधार पर नेटवर्क ट्रैफिक का संचालन करता है।

  • फ़िल्टर डेटा: इसका उपयोग नेटवर्क "फ्लोज" को फ़िल्टर करने के लिए किया जाता है। यह नेटवर्क डेटा को फ्लो स्तर पर मॉनिटर या संशोधित कर सकता है।

  • फ़िल्टर पैकेट: इसका उपयोग व्यक्तिगत नेटवर्क पैकेट्स को फ़िल्टर करने के लिए किया जाता है। यह नेटवर्क डेटा को पैकेट स्तर पर मॉनिटर या संशोधित कर सकता है।

  • DNS प्रॉक्सी: इसका उपयोग एक कस्टम DNS प्रोवाइडर बनाने के लिए किया जाता है। इसका उपयोग DNS अनुरोधों और प्रतिक्रियाओं को मॉनिटर या संशोधित करने के लिए किया जा सकता है।

एंडपॉइंट सिक्योरिटी फ्रेमवर्क

एंडपॉइंट सिक्योरिटी एक फ्रेमवर्क है जो Apple ने macOS में प्रदान किया है जो सिस्टम सुरक्षा के लिए एक सेट की एपीआई प्रदान करता है। इसका उद्देश्य है कि सुरक्षा विक्रेताओं और डेवलपर्स द्वारा उत्पादों का निगरानी और नियंत्रण करने के लिए उपयोग किया जाए।

यह फ्रेमवर्क सिस्टम गतिविधि को निगरानी और नियंत्रित करने के लिए एक संग्रहीत एपीआई प्रदान करता है, जैसे प्रोसेस एक्जीक्यूशन, फाइल सिस्टम इवेंट्स, नेटवर्क और कर्नल इवेंट्स।

इस फ्रेमवर्क का कोर कर्नल में लागू किया गया है, एक कर्नल एक्सटेंशन (KEXT) के रूप में, जो /System/Library/Extensions/EndpointSecurity.kext पर स्थित है। यह KEXT कई मुख्य घटकों से मिलकर बना है:

  • EndpointSecurityDriver: यह कर्नल एक्सटेंशन के लिए "प्रवेश बिंदु" के रूप में काम करता है। यह ओएस और एंडपॉइंट सिक्योरिटी फ्रेमवर्क के बीच मुख्य बातचीत का माध्यम है।

  • EndpointSecurityEventManager: यह घटक कर्नल हुक्स को लागू करने के लिए जिम्मेदार है। कर्नल हुक्स फ्रेमवर्क को सिस्टम कॉल्स को अंटरसेप्ट करके सिस्टम इवेंट्स को मॉनिटर करने की अनुमति देते हैं।

  • EndpointSecurityClientManager: यह यूजर स्पेस क्लाइंट्स के साथ संचार का प्रबंधन करता है, जिसमें यह ट्रैक करता है कि कौन से क्लाइंट्स कनेक्ट हैं और इवेंट सूचनाएं प्राप्त करने की आवश्यकता है।

  • EndpointSecurityMessageManager: यह मैसेज और इवेंट सूचनाएं यूजर स्पेस क्लाइंट्स को भेजता है।

एंडपॉइंट सिक्योरिटी फ्रेमवर्क द्वारा मॉनिटर किए जा सकने वाले इवेंट्स निम्नलिखित श्रेणियों में वर्गीकृत होते हैं:

  • फाइल इवेंट्स

  • प्रोसेस इवेंट्स

  • सॉकेट इवेंट्स

  • कर्नल इवेंट्स (जैसे कर्नल एक्सटेंशन लोड/अनलोड या आई/ओ किट डिवाइस खोलना)

एंडपॉइंट सिक्योरिटी फ्रेमवर्क आर्किटेक्चर

एंडपॉइंट सिक्योरिटी फ्रेमवर्क के साथ यूजर स्पेस संचार IOUserClient क्लास के माध्यम से होता है। दो विभिन्न सबक्लासेस का उपयोग किया जाता है, कॉलर के प्रकार के आधार पर:

tccutil reset All

इस बाईपास और संबंधित बाईपास के बारे में अधिक जानकारी के लिए टॉक देखें #OBTS v5.0: "The Achilles Heel of EndpointSecurity" - Fitzl Csaba

अंत में इसे ठीक कर दिया गया था नए अनुमति kTCCServiceEndpointSecurityClient को सुरक्षा ऐप्लिकेशन को दिया गया था जिसे tccd द्वारा प्रबंधित किया गया था ताकि tccutil इसकी अनुमतियों को साफ न करें जिससे इसे चलने से रोका जा सके।

संदर्भ

Last updated