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í
×
    dnes 10:44 | Nová verze

    Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 1
    dnes 04:44 | Nová verze

    Apple container dospěl do verze 1.0.0. Jedná se o open source nástroj pro spouštění linuxových kontejnerů na macOS postavený nad containerization. Napsaný je v programovacím jazyce Swift a optimalizovaný pro Apple silicon.

    Ladislav Hagara | Komentářů: 1
    dnes 03:33 | Nová verze

    Bylo vydáno Eclipse IDE 2026-06 aneb Eclipse 4.40. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 0
    včera 15:44 | Zajímavý software

    Asterinas (GitHub) je v Rustu napsané jádro operačního systému poskytující s jádrem Linux kompatibilní ABI. Vydána byla verze 0.18.0. První distribucí postavenou nad jádrem Asterinas je Asterinas NixOS. Nejedná se o oficiální projekt NixOS a nemá nic společného s NixOS Foundation.

    Ladislav Hagara | Komentářů: 1
    včera 13:22 | Zajímavý článek

    Podrobně byla rozebrána kritická zranitelnost v nf_tables (CVE-2026-23111). Další lokální eskalace práv na Linuxu. V upstreamu byla zranitelnost již v únoru opravena. Ve zdrojovém kódu stačilo odstranit 1 vykřičník.

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

    Evropská komise (EK) nařídila americké společnosti Meta, že musí znovu umožnit bezplatný přístup konkurenčním obecně zaměřeným asistentům umělé inteligence (AI) k WhatsAppu a tento přístup musí zachovat až do ukončení antimonopolního šetření. Opatření je dočasné a má zabránit vážnému a nevratnému poškození konkurence na rychle rostoucím trhu s obecnými AI asistenty. Meta uvedla, že se proti rozhodnutí odvolá.

    Ladislav Hagara | Komentářů: 12
    včera 11:44 | IT novinky

    Společnost Anthropic představila AI modely Claude Fable 5 a Claude Mythos 5. Claude Fable 5 je první model třídy Mythos určený pro běžné použití.

    Ladislav Hagara | Komentářů: 0
    včera 04:44 | Nová verze

    Byla vydána nová stabilní verze 3.24.0, tj. první z nové řady 3.24, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 03:33 | Komunita

    Na čem pracují vývojáři v Rustu napsaného mikrokernelového unixového operačního systému Redox OS (Wikipedie)? Byl publikován přehled vývoje za květen. Vypíchnout lze nový scheduler EEVDF nebo port desktopového prostředí Xfce na Redox OS.

    Ladislav Hagara | Komentářů: 0
    9.6. 22:22 | Komunita

    Upozornění pro uživatele Asahi Linuxu: Neaktualizujte macOS na verzi 27 Golden Gate! Apple změnil detekci spouštěcích oddílů. Po aktualizaci oddíl s Asahi Linuxem nevidí. Snad je to jenom chyba.

    Ladislav Hagara | Komentářů: 6
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (15%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1873 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: programování, program s právy roota

    15.7.2005 14:13 Martin
    programování, program s právy roota
    Přečteno: 132×

    Přepsal jsem program, který byl původně napsán pro windows a používal ovladače z windows tak, aby šel přeložit a spustit pod linuxem. Program pracuje se zařízením připojeným na USB. Pod windows na to byl ovladač a knihovna pro ovládání přímo od výrobce, ale pod linuxem na to používám knihovnu libusb (nebudu psát modul do jádra), která umožnuje pracovat obyčejným programům se zařízením připojeným na USB.

    Problém je v tom, že pokud se volají funkce z libusb musí program běžet s právy roota, aby to celé fungovalo (alespoň se domnívám že to tak je, protože jinak některé funkce z libusb vrací chybu místo úspěšného provedení funkce). Z toho tedy plyne potenciální nebezpečí. Chci se zeptat, jak co nejjednodušeji a nejefektivněji zařídit to, aby program pracoval s právy roota pouze pokud volá funkce z libusb. Napadlo mě používat fce getuid, geteuid, seteuid a setuid, programu nastavit suid bit, vlastníka a skupinu root.

    Nikdy jsem nic podobného neprogramoval, tak potřebuji poradit jak na to a hlavně jak to udělat správně. Případně jak to celé vyřešit jinak. Díky.

    Odpovědi

    15.7.2005 14:28 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: programování, program s právy roota
    Lze nastavit práva pro zařízení v hotplugu, používá se to například pro foťáky (a už jsem to sem do diskuzí několikrát psal :-)).
    15.7.2005 14:28 0
    Rozbalit Rozbalit vše Re: programování, program s právy roota
    Nejjednoduzsi je nastavit tomu programu suid bit (chmod +s utilita), ale pokud je ten program komplexnejsi (pouziva napr nejakou grafickou knihovnu), je lepsi rozdelit architektoru programu tak, ze bud graficka nadstavba vola nejaky suid maly program nebo komunikuje se serverem, ktery bezi napriklad pod rootem. Dalsi rozumnou volbou je nastavit prislusnemu zarizeni vhodne prava tak aby napriklad lidi ze zvolene skupiny mohli zarizeni libovolne pouzivat.
    15.7.2005 14:52 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: programování, program s právy roota
    Co se týče používání getuid, geteuid, seteuid a podobně, doporučuji některou z mnoha knih o fungování UNIXu. Podrobné informace o použití lze najít v dokumentaci k libc, ale chce to mít naprosto jasno v tom, jak celý tento systém funguje.

    Spíš bych se ale podíval na to, proč to vrací chybu a zda tento problém nejde obejít jinak. Velmi pravděpodobně je problém jen v nedostatečných právech na zařízení a všechno půjde spravit pomocí chmod někam do /dev. Snad to půjde učit z chyby a dokumentace libusb, v nejhorším případě pomůže strace.

    Horší (ale málo pravděpodobné) by bylo, pokud by v knihovně byla vyžadována některá funkcionalita, kterou krenel povolí jen procesům v euid 0 nebo s některou capabilitou. Například raw sockety. V takovém případě bude nutné buď běžet s euid 0 (pod rootem) nebo si zajistit potřebnou capability (vesměs není přenositelné).
    15.7.2005 15:38 Martin
    Rozbalit Rozbalit vše Re: programování, program s právy roota
    No, problém je právě v tom, že nepoužívám pro komunikaci se zařízením žádný ovladač z jádra a tudíž k zařízení neexistuje ani odpovídající soubor v /dev, který by používal daný ovladač a kterému by se daly přiřadit nějaké práva. K danému zařízení neexistuje ovladač napsaný v linuxu a tudíž pro komunikaci s ním nelze použít nějaký soubor z /dev. Když jsem programoval něco co používalo sériový port stačilo nastavit práva k /dev/ttyS0 a bylo to. Ale tady není pravě k čemu ty práva přiřadit. Možná mi něco uniká nebo nechápu podstatu něčeho základního :(
    15.7.2005 17:15 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: programování, program s právy roota
    Možná mi něco uniká nebo nechápu podstatu něčeho základního :(
    Ano, evidentně.
    No, problém je právě v tom, že nepoužívám pro komunikaci se zařízením žádný ovladač z jádra
    To bude asi ono, není mi jasné z čeho vzniká tento názor. Přeci se používá ovladač na USB, ne?

    Nebo něco nechápu a ono záhadné zařízení je řadič USB?
    15.7.2005 17:20 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: programování, program s právy roota
    Nutno ovšem říci, že naprosto netuším jaké rozhraní používá libusb. Dokumentace je prakticky žádná, takže bude nutné ji prozkoumat :-(
    18.7.2005 08:03 Martin
    Rozbalit Rozbalit vše Re: programování, program s právy roota
    Tak jsem prošel zdrojáky od libusb a pro komunikaci se zařízením se používají soubory z adresáře /proc/bus/usb/xxx. Pokud se tomu správnému souboru, co odpovídá danému zařízení nastaví správná práva, tak to jede bez problémů. Takže to udélám asi tak, že napíšu krátký program, který najde dané zařízení, změní mu příslušně práva a pak se teprve spustí vlastní aplikace. Tak nebude muset být vlastní aplikace spouštěná s právy roota, ale s právy roota poběží jen aplikace na změnu práv.
    18.7.2005 09:09 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: programování, program s právy roota
    Proč na to vytvářet vlastní program, když to už řeší hotplug?
    $ echo 'nejaky_nazev           0x0003      vendor   product'\
    '    0x0000       0x0000      0x00         0x00            '\
    '0x00            0x00            0x00               0x00'\
    '               0x00000000' > /etc/hotplug/usb/nejaky_nazev.usermap
    $ cat > /etc/hotplug/usb/nejaky_nazev <<EOT
    #!/bin/bash
    
    GROUP=skupina
    
    if [ "$ACTION" = "add" ] && [ -f "$DEVICE" ]
    then
        # check if $GROUP really exists
        if getent group $GROUP > /dev/null; then
            chmod 660 "$DEVICE"
            chown root.$GROUP "$DEVICE"
        fi
    fi
    EOT
    $ chmod +x /etc/hotplug/usb/nejaky_nazev 
    

    Založit nové vláknoNahoru

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

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