फ्लॅटपॅक 1.14.0 च्या स्वयंपूर्ण पॅकेजेसच्या प्रणालीचे प्रकाशन

Flatpak 1.14 टूलकिटची एक नवीन स्थिर शाखा प्रकाशित केली गेली आहे, जी विशिष्ट Linux वितरणाशी जोडलेली नसलेली स्वयं-समाविष्ट पॅकेजेस तयार करण्यासाठी एक प्रणाली प्रदान करते आणि विशिष्ट कंटेनरमध्ये चालते जी उर्वरित सिस्टमपासून अनुप्रयोग वेगळे करते. Arch Linux, CentOS, Debian, Fedora, Gentoo, Mageia, Linux Mint, Alt Linux आणि Ubuntu साठी Flatpak पॅकेजेस चालवण्यासाठी समर्थन पुरवले जाते. Flatpak पॅकेजेस Fedora रेपॉजिटरीमध्ये समाविष्ट केले जातात आणि मूळ GNOME ऍप्लिकेशन व्यवस्थापकाद्वारे समर्थित आहेत.

Flatpak 1.14 शाखेतील प्रमुख नवकल्पना:

  • Обеспечено создание каталога для файлов в состоянием (.local/state) и выставление указывающей на этот каталог переменной окружения XDG_STATE_HOME.
  • Добавлены условные проверки вида «have-kernel-module-имя» для определения наличия модулей ядра (универсальный аналог ранее предлагаемой проверке have-intel-gpu, вместо которой теперь можно использовать выражение «have-kernel-module-i915»).
  • Реализована команда «flatpak document-unexport —doc-id=…».
  • Обеспечен экспорт метаданных Appstream для использования в основном окружении.
  • Добавлены правила автодополнения команд flatpak для командной оболочки Fish
  • Разрешён сетевой доступ к сервисам X11 и PulseAudio (при добавлении соответствующих настроек).
  • Основная ветка в Git-репозитории переименована с «master» на «main», так как слово «master» считается последнее время неполиткорректным.
  • Обеспечена перезапись скриптов запуска в случае переименования приложения.
  • В команду install добавлены опции «—include-sdk» и «—include-debug» для установки SDK и файлов debuginfo.
  • В файлы flatpakref и flatpakrepo добавлена поддержка параметра «DeploySideloadCollectionID», при установке которого идентификатор коллекции будет выставлен во время добавления удалённого репозитория, а не после загрузки метаданных.
  • Разрешено создание вложенных sandbox-окружений для обработчиков в сеансах с отдельными именами MPRIS (Media Player Remote Interfacing Specification).
  • В утилитах командной строки обеспечен вывод сведений об использовании устаревших runtime-расширений.
  • В команде uninstall реализован запрос подтверждения перед удалением runtime или runtime-расширений, которые ещё используются.
  • В команды подобные «flatpak run» добавлена поддержка опции «—socket=gpg-agent».
  • В libostree устранена уязвимость, потенциально позволяющая пользователю удалить произвольные файлы в системе через манипуляции с обработчиком flatpak-system-helper (отправке запроса на удаление со специально оформленным именем ветки). Проблема проявляется только в старых версиях Flatpak и libostree, выпущенных до 2018 года (< 0.10.2), и не затрагивает актуальные выпуски.

आम्‍ही तुम्‍हाला स्मरण करून देऊ या की Flatpak अॅप्लिकेशन डेव्हलपर्सना त्‍यांच्‍या प्रोग्रॅमचे वितरण सुलभ करण्‍याची अनुमती देते जे मानक वितरण रेपॉजिटरीमध्‍ये समाविष्ट नसतात आणि प्रत्‍येक वितरणासाठी वेगळे असेंब्ली न बनवता एक सार्वत्रिक कंटेनर तयार करून. सुरक्षा-सजग वापरकर्त्यांसाठी, Flatpak तुम्हाला कंटेनरमध्ये संशयास्पद अॅप्लिकेशन चालवण्याची परवानगी देते, फक्त नेटवर्क फंक्शन्स आणि अॅप्लिकेशनशी संबंधित वापरकर्ता फाइल्समध्ये प्रवेश प्रदान करते. नवीन उत्पादनांमध्ये स्वारस्य असलेल्या वापरकर्त्यांसाठी, फ्लॅटपॅक तुम्हाला सिस्टममध्ये बदल न करता नवीनतम चाचणी आणि अॅप्लिकेशन्सचे स्थिर प्रकाशन स्थापित करण्याची परवानगी देते. उदाहरणार्थ, फ्लॅटपॅक पॅकेजेस LibreOffice, Midori, GIMP, Inkscape, Kdenlive, Steam, 0 AD, Visual Studio Code, VLC, Slack, Skype, Telegram Desktop, Android Studio इत्यादींसाठी तयार केले आहेत.

पॅकेजचा आकार कमी करण्यासाठी, त्यात फक्त ॲप्लिकेशन-विशिष्ट अवलंबनांचा समावेश आहे, आणि मूलभूत प्रणाली आणि ग्राफिक्स लायब्ररी (GTK, Qt, GNOME आणि KDE लायब्ररी, इ.) प्लग-इन मानक रनटाइम वातावरण म्हणून डिझाइन केल्या आहेत. फ्लॅटपॅक आणि स्नॅपमधील महत्त्वाचा फरक असा आहे की स्नॅप मुख्य सिस्टम वातावरणातील घटक आणि फिल्टरिंग सिस्टम कॉलवर आधारित अलगाव वापरते, तर फ्लॅटपॅक सिस्टमपासून वेगळे कंटेनर तयार करते आणि मोठ्या रनटाइम सेटसह ऑपरेट करते, पॅकेजेस अवलंबित्व म्हणून प्रदान करत नाही, परंतु मानक म्हणून प्रदान करते. एक प्रणाली वातावरण (उदाहरणार्थ, GNOME किंवा KDE प्रोग्राम्सच्या ऑपरेशनसाठी आवश्यक असलेली सर्व लायब्ररी).

विशेष रेपॉजिटरीद्वारे स्थापित मानक सिस्टम वातावरण (रनटाइम) व्यतिरिक्त, अनुप्रयोगाच्या ऑपरेशनसाठी आवश्यक अतिरिक्त अवलंबन (बंडल) पुरवले जातात. एकूण, रनटाइम आणि बंडल कंटेनर भरतात, रनटाइम स्वतंत्रपणे स्थापित केला आहे आणि एकाच वेळी अनेक कंटेनरशी बांधला आहे, जे आपल्याला कंटेनरसाठी सामान्य सिस्टम फाइल्सची डुप्लिकेट करणे टाळण्याची परवानगी देते. एका प्रणालीमध्ये अनेक भिन्न रनटाइम स्थापित केले जाऊ शकतात (GNOME, KDE) किंवा एकाच रनटाइमच्या अनेक आवृत्त्या (GNOME 3.40, GNOME 3.42). अवलंबित्व म्‍हणून अॅप्लिकेशन असलेले कंटेनर रनटाइम तयार करणार्‍या वैयक्तिक पॅकेजेस विचारात न घेता, केवळ विशिष्ट रनटाइमसाठी बंधनकारक वापरते. सर्व गहाळ घटक थेट अनुप्रयोगासह पॅकेज केलेले आहेत. कंटेनर तयार झाल्यावर, रनटाइम सामग्री /usr विभाजन म्हणून माउंट केली जाते, आणि बंडल /app निर्देशिकेमध्ये माउंट केले जाते.

रनटाइम आणि ऍप्लिकेशन कंटेनर्स OSTree तंत्रज्ञान वापरून तयार केले जातात, ज्यामध्ये Git-सारख्या रिपॉझिटरीमधून प्रतिमा आण्विकरित्या अद्यतनित केली जाते, जे वितरण घटकांवर आवृत्ती नियंत्रण पद्धती लागू करण्यास अनुमती देते (उदाहरणार्थ, आपण सिस्टमला द्रुतपणे रोल बॅक करू शकता. मागील स्थिती). RPM पॅकेजेस विशेष rpm-ostree स्तर वापरून OSTree रेपॉजिटरीमध्ये अनुवादित केले जातात. कार्यरत वातावरणात पॅकेजेसची स्वतंत्र स्थापना आणि अद्यतन समर्थित नाही; सिस्टम वैयक्तिक घटकांच्या पातळीवर नाही तर संपूर्णपणे, अणूची स्थिती बदलून अद्यतनित केली जाते. प्रत्येक अपडेटसह प्रतिमा पूर्णपणे बदलण्याची गरज काढून टाकून, वाढत्या प्रमाणात अद्यतने लागू करण्यासाठी साधने प्रदान करते.

व्युत्पन्न केलेले पृथक वातावरण वापरलेल्या वितरणापासून पूर्णपणे स्वतंत्र आहे आणि पॅकेजच्या योग्य सेटिंग्जसह, वापरकर्त्याच्या किंवा मुख्य प्रणालीच्या फाइल्स आणि प्रक्रियांमध्ये प्रवेश नाही, DRI द्वारे आउटपुटचा अपवाद वगळता उपकरणांमध्ये थेट प्रवेश करू शकत नाही, आणि नेटवर्क सबसिस्टमला कॉल करते. ग्राफिक्स आउटपुट आणि इनपुट संस्था वेलँड प्रोटोकॉल वापरून किंवा X11 सॉकेट फॉरवर्डिंगद्वारे लागू केली जाते. बाह्य वातावरणाशी संवाद DBus संदेशन प्रणाली आणि विशेष पोर्टल API वर आधारित आहे.

Для изоляции используется прослойка Bubblewrap и традиционные для Linux технологии контейнерной виртуализации, основанные на использовании cgroups, пространств имён (namespaces), Seccomp и SELinux. Для вывода звука применяется PulseAudio. При этом изоляция может быть отключена, чем пользуются разработчики многих популярных пакетов для получения полного доступа к ФС и всем устройствам в системе. Например, с ограниченным режимом изоляции, оставляющим полный доступ к домашнему каталогу, поставляются пакеты GIMP, VSCodium, PyCharm, Octave, Inkscape, Audacity и VLC. В случае компрометации пакетов с доступом к домашнему каталогу, несмотря на наличие в описании пакета метки «sandboxed», атакующему для выполнения своего кода достаточно изменить файл ~/.bashrc. Отдельным вопросом является контроль за внесением изменений в пакеты и доверие к сборщикам пакетов, которые часто не связаны с основным проектом или дистрибутивами.

स्त्रोत: opennet.ru

एक टिप्पणी जोडा