abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 19:44 | Zajímavý software

    Společnost Kagi stojící za stejnojmenným placeným vyhledávačem vydala (𝕏) alfa verzi linuxové verze (flatpak) svého proprietárního webového prohlížeče Orion.

    Ladislav Hagara | Komentářů: 3
    včera 19:11 | IT novinky

    Firma Bose se po tlaku uživatelů rozhodla, že otevře API svých chytrých reproduktorů SoundTouch, což umožní pokračovat v jejich používání i po plánovaném ukončení podpory v letošním roce. Pro ovládání také bude stále možné využívat oficiální aplikaci, ale už pouze lokálně bez cloudových služeb. Dokumentace API dostupná zde (soubor PDF).

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 14:22 | Zajímavý článek

    Jiří Eischmann se v příspěvku na svém blogu rozepsal o open source AdGuard Home jako domácí ochraně nejen před reklamou. Adguard Home není plnohodnotným DNS resolverem, funguje jako DNS forwarder s možností filtrování. To znamená, že když přijme DNS dotaz, sám na něj neodpoví, ale přepošle ho na vybraný DNS server a odpovědi zpracovává a filtruje dle nastavených pravidel a následně posílá zpět klientům. Dá se tedy používat k blokování reklamy a škodlivých stránek a k rodičovské kontrole na úrovni DNS.

    Ladislav Hagara | Komentářů: 5
    včera 03:33 | Zajímavý software

    AI Claude Code od Anthropicu lépe rozumí frameworku Nette, tj. open source frameworku pro tvorbu webových aplikací v PHP. David Grudl napsal plugin Nette pro Claude Code.

    Ladislav Hagara | Komentářů: 1
    včera 00:11 | Nová verze

    Byla vydána prosincová aktualizace aneb nová verze 1.108 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.108 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    8.1. 20:44 | IT novinky

    Na lasvegaském veletrhu elektroniky CES byl předveden prototyp notebooku chlazeného pomocí plazmových aktuátorů (DBD). Ačkoliv se nejedná o první nápad svého druhu, nepochybně to je první ukázka praktického použití tohoto způsobu chlazení v běžné elektronice. Co činí plazmové chladící akční členy technologickou výzvou je především vysoká produkce jedovatého ozonu, tu se prý podařilo firmě YPlasma zredukovat dielektrickou

    … více »
    NUKE GAZA! 🎆 | Komentářů: 8
    8.1. 16:33 | Zajímavý projekt

    Patchouli je open source implementace EMR grafického tabletu (polohovací zařízení). Projekt je hostován na GitLabu.

    Ladislav Hagara | Komentářů: 0
    8.1. 14:11 | IT novinky

    Český Nejvyšší soud potvrdil, že česká právní úprava plošného uchování dat o elektronické komunikaci porušuje právo Evropské unie. Pravomocným rozsudkem zamítl dovolání ministerstva průmyslu a obchodu. To se teď musí omluvit novináři Českého rozhlasu Janu Cibulkovi za zásah do práv na ochranu soukromí a osobních údajů. Ve sporu jde o povinnost provozovatelů sítí uchovávat údaje, ze kterých lze odvodit, kdo, s kým a odkud komunikoval.

    Ladislav Hagara | Komentářů: 16
    8.1. 02:11 | Komunita

    Google bude vydávat zdrojové kódy Androidu pouze dvakrát ročně. Ve 2. a 4. čtvrtletí.

    Ladislav Hagara | Komentářů: 1
    7.1. 17:22 | Zajímavý článek

    Bezpečnostní specialista Graham Helton z Low Orbit Security si všímá podezřelých anomálií v BGP, zaznamenaných krátce před vstupem ozbrojených sil USA na území Venezuely, které tam během bleskové speciální vojenské operace úspěšně zatkly venezuelského diktátora Madura za narkoterorismus. BGP (Border Gateway Protocol) je 'dynamický směrovací protokol, který umožňuje routerům automaticky reagovat na změny topologie počítačové sítě' a je v bezpečnostních kruzích znám jako 'notoricky nezabezpečený'.

    NUKE GAZA! 🎆 | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (3%)
     (5%)
     (0%)
     (9%)
     (21%)
     (4%)
     (5%)
     (3%)
     (11%)
     (53%)
    Celkem 317 hlasů
     Komentářů: 7, poslední 8.1. 15:35
    Rozcestník

    Rukověť baliče RPM - VII (Podepisování, verze)

    30. 6. 2005 | David Nečas | Návody | 6336×

    Podepisování balíčků. Vedlejší balíčky vytvořené z hlavního zdrojového balíku. Verze, epochy a algoritmus řazení verzí.

    Podepisování

    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.

    Konfigurace

    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.

    Podepisování

    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.

    Vedlejší balíčky

    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.rpmlobster-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?

    Sekce %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
    

    Ostatní změny

    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%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
    …

    Verze a epocha

    V úvodu jsem psal o položkách hlavičky VersionRelease, 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

    Nejčtenější články posledního měsíce

    Týden na ITBiz: Agenti AI přinášejí revoluci do obchodování na trzích
    Událo se v týdnu 50/2025
    Windows 11 Pro jen za €21,80 od Goodoffer24.com!

    Nejkomentovanější články posledního měsíce

    Týden na ITBiz: Prodejci věří, že AI dokáže vylepšit většinu IT produktů
      všechny statistiky »

    Seriál Rukověť baliče RPM (dílů: 15)

    Rukověť baliče RPM - I (Úvod) (první díl)
    <—« Rukověť baliče RPM - VI (Makro %setup)
    »—> Rukověť baliče RPM - VIII (Závislosti)
    Rukověť baliče RPM 15 - XV (Závěr) (poslední díl)

    Související články

    Rukověť baliče RPM - I (Úvod)
    Rukověť baliče RPM - II (Prostředí)
    Rukověť baliče RPM - III (Struktura spec souboru)
    Rukověť baliče RPM - IV (Fáze balení)
    Rukověť baliče RPM - V (Zdrojové soubory)
    Rukověť baliče RPM - VI (Makro %setup)
    Rukověť baliče RPM - VIII (Závislosti)
    Rukověť baliče RPM - IX (Sekce %files)
    Rukověť baliče RPM - X (Skriptíky)
    Rukověť baliče RPM - XI (Architektury. systémy, platformy)
    Rukověť baliče RPM - XII (Makra, úvod)
    Rukověť baliče RPM - XIII (Makra, dokončení)
    Rukověť baliče RPM - XIV (Přizpůsobení)
    Rukověť baliče RPM 15 - XV (Závěr)
    Na co se často ptáme: Balíčkovací systémy kromě posledního odstavce o checkinstallu.
    Nebojíme se kompilace - I (Teorie)
    Nebojíme se kompilace - II (GCC, configure, make, checkinstall) kompilace a instalace software, opět kromě části o checkinstallu.
    Balíčkovací systém Mandrake Linuxu RPM na uživatelské úrovni (a pro Mandrake).

    Odkazy a zdroje

    Doporučené čtení

    Další články z této rubriky

    VDR a DVB-T2, část 2.
    VDR a DVB-T2, část 1.
    Šifrovaný Proxmox VE 6: ZFS, LUKS, systemd_boot a Dropbear
    MapTiler – proměňte obrázek v zoomovatelnou mapu
    Syncthing
           

    Hodnocení: 100 %

            špatnédobré        

    Nástroje: Tisk bez diskuse

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    30.6.2005 08:36 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše GnuPG
    můžeme pohodlně podepsat několik balíčků jedním příkazem, což řeší jednu z nejotravnějších vlastností GnuPG
    Od čeho je gpg-agent? Nebo máš na mysli jinou otravnou vlastnost, která mi uniká?
    30.6.2005 11:53 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: GnuPG
    Když jsem se naposledy díval, byl gpg-agent feature experimentální verze GnuGP.

    Navíc často nechci -- na rozdíl do ssh-agenta -- aby běžel furt, chci aby bylo nutno zadat passphrase, ale mohl jsem podepsat několik souborů zároveň. To znamená dát agentovi passphrase, podepsat soubory (gpg se stále musí spustit na každý zvlášť, i když to samozřejmě udělá cyklus v shellu), zrušit agenta. Proč nemůže fungovat gpg -b * bez agentů?
    30.6.2005 12:14 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: GnuPG
    No je to už dlouho feature stabilní verze, viz NEWS:
    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 :-)
    30.6.2005 09:48 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Typo?
    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á :-)
    30.6.2005 11:54 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: Typo?
    Jo, to je typo/thinko.
    30.6.2005 12:02 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Typo?
    Opraveno.

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.