Dánské ministerstvo pro digitální záležitosti má v plánu přejít na Linux a LibreOffice [It's FOSS News].
V úterý Google vydal Android 16. Zdrojové kódy jsou k dispozici na AOSP (Android Open Source Project). Chybí (zatím?) ale zdrojové kódy specifické pro telefony Pixel od Googlu. Projekty jako CalyxOS a GrapheneOS řeší, jak tyto telefony nadále podporovat. Nejistá je podpora budoucích Pixelů. Souvisí to s hrozícím rozdělením Googlu (Google, Chrome, Android)?
Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.101 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.101 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
V Brně na FIT VUT probíhá třídenní open source komunitní konference DevConf.CZ 2025. Vstup je zdarma, nutná je ale registrace. Na programu je celá řada zajímavých přednášek, lightning talků, meetupů a workshopů. Přednášky lze sledovat i online na YouTube kanálu konference. Aktuální dění lze sledovat na Matrixu, 𝕏 nebo Mastodonu.
Vyloučení technologií, které by mohly představovat bezpečnostní riziko pro stát, má umožnit zákon o kybernetické bezpečnosti, který včera Senát schválil spolu s novelami navazujících právních předpisů. Norma, kterou nyní dostane k podpisu prezident, počítá rovněž s prověřováním dodavatelů technologií pro stát. Normy mají nabýt účinnosti od třetího měsíce po jejich vyhlášení ve Sbírce zákonů.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.6.
Po Red Hat Enterprise Linuxu a AlmaLinuxu byl v nové stabilní verzi 10.0 vydán také Rocky Linux. Přehled novinek v poznámkách k vydání.
Bylo vydáno Eclipse IDE 2025-06 aneb Eclipse 4.36. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
Americká filmová studia Walt Disney a Universal Pictures podala žalobu na provozovatele populárního generátoru obrázků pomocí umělé inteligence (AI) Midjourney. Zdůvodňují to údajným porušováním autorských práv. V žalobě podané u federálního soudu v Los Angeles označují firmu za „bezednou jámu plagiátorství“, neboť podle nich bez povolení bezostyšně kopíruje a šíří postavy z filmů jako Star Wars, Ledové království nebo Já, padouch, aniž by do nich investovala jediný cent.
Ultra Ethernet Consortium (UEC), jehož cílem je optimalizace a další vývoj Ethernetu s důrazem na rostoucí síťové požadavky AI a HPC, vydalo specifikaci Ultra Ethernet 1.0 (pdf, YouTube).
RPM balíčky lze pro ověření autorství a integrity digitálně podepisovat pomocí PGP či GnuPG.
S gpg
tedy můžeme podepsat jakýkoli soubor, ale protože je tato funkce důležitá, RPM digitální podpisy přímo podporuje. Měli bychom podepisovat všechny balíčky, které publikujeme, neboť že nejste paranoidní, ještě neznamená, že po vás nejdou.
Předpokládám, že klíč pro podepisování balíčků už máme. Používáme-li GnuPGP, nakonfigurujeme rpm pro gpg
. Do ~/.rpmmacros
napíšeme
%_signature gpg %_gpg_path ~/.gnupg %_gpg_name David Necas (Yeti) <yeti@trific.ath.cx> %__gpg /opt/gnupg/bin/gpg
Makro %_signature
určuje styl podpisu, možné honoty jsou: gpg
pro GnuPG, pgp
pro PGP, pgp5
pro staré PGP a implicitní hodnota none
pro vypnutí podpisů.
Makro %_gpg_name
určuje identitu, kterou budeme balíčky podepisovat. Makro %_gpg_path
definuje cestu k souboru klíčů (keyring). A konečně %__gpg
cestu k programu gpg
, nevyhovuje-li nám implicitní hodnota (typicky /usr/bin/gpg
). Používáme-li PGP, nahradíme v názvech maker gpg
za pgp
.
Hotový balíček podepíšeme volbou --addsign
(rpm se zeptá na passphrase):
rpm --addsign lobster-1.10-1.x86_64.rpm lobster-1.10-1.src.rpm Enter pass phrase: Pass phrase is good. /home/yeti/lobster-1.10-1.x86_64.rpm /home/yeti/lobster-1.10-1.src.rpm
Jak je vidět z příkladu, můžeme pohodlně podepsat několik balíčků jedním příkazem, což řeší jednu z nejotravnějších vlastností GnuPG. Namísto --addsign
bychom mohli použít i --resign
, jež dělá přesně totéž. Ve starších verzích RPM se lišily, ale dnes obě podepíší balíček, rušíce přitom všechny předešlé podpisy.
Také můžeme použít volbu --sign
přímo při kompilaci
rpmbuild -bb --sign lobster.spec
a při úspěšném zabalení se balíček podepíše.
Jeden zdrojový balíček může po kompilaci dát vzniknout několika binárním. Kompilací
lobster-1.10-1.src.rpm
může kupříkladu vzniknout lobster-1.10-1.i686.rpm
, lobster-devel-1.10-1.i686.rpm
a lobster-perl-1.10-1.i686.rpm
. Z toho mimo jiné plyne, že většina z toho, co jsem napsal o struktuře spec souboru, není ve skutečnosti tak jednoduchá…
Doposud jsme se zabývali spec soubory, které popisovaly jen jeden, hlavní balíček (main package). Vedle něj může spec soubor ovšem popisovat libovolný počet dalších, vedlejších balíčků (subpackages), které se kompilují z těchže zdrojových souborů – například z fedořího zdrojového rpm kde-i18n
vznikne po kompilaci 68 binárních balíčků. Jak tedy vypadá struktura spec souboru s vedlejšími balíčky?
%package
Předně se ve spec souboru objevují nové sekce: %package
. Ty obsahují hlavičky jednotlivých vedlejších balíčků. Popisné položky jako URL
se dědí z hlavního balíčku, pročež hlavičky vedlejších balíčků typicky obsahují jen Summary
, Group
(ty jsou povinné), Requires
, a případně další položky týkající se závislostí.
Sekce %package
má jeden argument, a to doplňující jméno vedlejšího balíčku. Připojuje se za jméno hlavního balíčku s pomlčkou. Deklarace vedlejšího balíčku lobster-devel
tak může vypadat:
%package devel Summary: Lobster development libraries and header files. Group: Development/Libraries Requires: %{name} = %{version}, libsandals-devel >= 1.2
Někdy bychom ovšem rádi, aby se vedlejší balíček jmenoval úplně jinak než hlavní. To lze zařídit volbou -n
, které dáme jako argument plné jméno:
%package -n perl-Fun-Lobster
Všechny ostatní sekce (včetně skriptíků) se dělí na společné pro hlavní balíček a všechny vedlejší a na specifické pro každý balíček. V první skupině jich mnoho není, společné jsou pouze kompilační fáze – zdrojový kód se překládá jen jednou a výsledek se rozdělí do balíčků. Konkrétně tedy %prep
, %build
, %install
, %check
a %clean
. Společný je také záznam změn (%changelog
); můžeme sice mít ve spec souboru samostatnou sekci pro každý balíček, ale při kompilaci se všechny sloučí do jednoho záznamu.
Zbylé sekce přijímají stejné argumenty jako %package
, tedy dodatečné jméno nebo
-n plné_jméno
. Popis vedlejšího balíčku perl-Fun-Lobster
tak bude vypadat (mimochodem, svůj popis musí mít každý vedlejší balíček):
%description -n perl-Fun-Lobster Perl interface to lobster.
a spoušť balíčku lobster-perl
aktivující se po instalaci perlu:
%triggerin perl -- perl …
V úvodu jsem psal o položkách hlavičky Version
a Release
, nic ovšem
není tak jednoduché, jak to napíši. Úplná verze, podle níž se balíčky porovnávají, má tvar
epocha:verze-vydání
kde verze a vydání jsou obecné řetězce, které jen nesmějí obsahovat pomlčku. Epocha je číslo s implicitní hodnotou nula a používá se, když se změní číslování verzí programu – díky své prioritě dokáže přebít každý autorův výmysl. Vydá-li kupříkladu verzi 1.0 po verzi 2005.3, musíme zvětšit epochu, protože bychom rpm asi nevysvětlili, že 2005 < 1:
Version: 1.0 Epoch: 1
Epocha je však krajní řešení, jehož bychom neměli zneužívat. Jeden problém je, že jakmile jednou epochu zavedeme, už se jí nikdy nezbavíme – balíček bez epochy, tj. s epochou 0, nebude pro rpm nikdy novější než balíček s kladnou epochou. Druhý problém je, že zatímco obyčejné verze jsou porovnatelné i mezi distribucemi, epochy nikdo nekoordinuje. Čísluje-li autor verze systematicky nepoužitelně, raději se je pokusíme převést na méně ztřeštěné.
Dříve se namísto Epoch
používala hlavička Serial
. Lze ji použít stále – jako synonymum pro Epoch
.
O přesném algoritmu porovnávání verzí říká dokumentace RPM, že na jeho detaily nemáme spoléhat a raději číslovat verze rozumně. S tím nelze než souhlasit. Nicméně algoritmus vypadá přibližně tak, že se verze rozdělí na segmenty na nealfanumerických znacích a jednotlivé segmenty se pak porovnají zleva. Kratší verze je starší, tudíž
1.10 < 1.10a 1.10 < 1.10.0
Segmenty se porovnávají numericky, a proto
5.6 < 5.00503
protože 6 < 503. Písmena se porovnávají podle ASCII hodnoty (to je poněkud záludné), pročež
1.10B < 1.10a
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
můžeme pohodlně podepsat několik balíčků jedním příkazem, což řeší jednu z nejotravnějších vlastností GnuPGOd čeho je gpg-agent? Nebo máš na mysli jinou otravnou vlastnost, která mi uniká?
gpg -b *
bez agentů?
Noteworthy changes in version 1.0.5 (2001-04-29) ------------------------------------------------ ... * New options: --ignore-crc-error, --no-sig-create-check, --no-sig-cache, --fixed_list_mode, --no-expensive-trust-checks, --enable-special-filenames and --use-agent. See man page.Ale nějak hrozně dlouho vyvíjeli toho agenta a ten je zatím jenom ve verzi 1.9.cosi. Ad poslední dotaz: protože „gpg: --sign does not yet work with --multifile“, předpokládám, že za patch se vývojáři zlobit nebudou
5.6 < 5.00503 protože 5 < 503.Tam má být asi 6 < 503. Ne že by 5 < 503 nebyla pravda, ale smysl mi to nedává