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 11:55 | Humor

    Microsoft poskytl FBI uživatelské šifrovací klíče svého nástroje BitLocker, nutné pro odemčení dat uložených na discích třech počítačů zabavených v rámci federálního vyšetřování. Tento krok je prvním známým případem, kdy Microsoft poskytl klíče BitLockeru orgánům činným v trestním řízení. BitLocker je nástroj pro šifrování celého disku, který je ve Windows defaultně zapnutý. Tato technologie by správně měla bránit komukoli kromě

    … více »
    NUKE GAZA! 🎆 | Komentářů: 10
    dnes 01:44 | Komunita

    Spotify prostřednictvím svého FOSS fondu rozdělilo 70 000 eur mezi tři open source projekty: FFmpeg obdržel 30 000 eur, Mock Service Worker (MSW) obdržel 15 000 eur a Xiph.Org Foundation obdržela 25 000 eur.

    Ladislav Hagara | Komentářů: 3
    včera 18:11 | Zajímavý software

    Nazdar! je open source počítačová hra běžící také na Linuxu. Zdrojové kódy jsou k dispozici na GitHubu. Autorem je Michal Škoula.

    Ladislav Hagara | Komentářů: 1
    včera 16:55 | Nová verze

    Po více než třech letech od vydání verze 1.4.0 byla vydána nová verze 1.5.0 správce balíčků GNU Guix a na něm postavené stejnojmenné distribuci GNU Guix. S init systémem a správcem služeb GNU Shepherd. S experimentální podporou jádra GNU Hurd. Na vývoji se podílelo 744 vývojářů. Přibylo 12 525 nových balíčků. Jejich aktuální počet je 30 011. Aktualizována byla také dokumentace.

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

    Na adrese gravit.huan.cz se objevila prezentace minimalistického redakčního systému GravIT. CMS je napsaný ve FastAPI a charakterizuje se především rychlým načítáním a jednoduchým ukládáním obsahu do textových souborů se syntaxí Markdown a YAML místo klasické databáze. GravIT cílí na uživatele, kteří preferují CMS s nízkými nároky, snadným verzováním (např. přes Git) a možností jednoduchého rozšiřování pomocí modulů. Redakční

    … více »
    2012 | Komentářů: 0
    včera 12:55 | Zajímavý software

    Tým Qwen (Alibaba Cloud) uvolnil jako open-source své modely Qwen3‑TTS pro převádění textu na řeč. Sada obsahuje modely VoiceDesign (tvorba hlasu dle popisu), CustomVoice (stylizace) a Base (klonování hlasu). Modely podporují syntézu deseti různých jazyků (čeština a slovenština chybí). Stránka projektu na GitHubu, natrénované modely jsou dostupné na Hugging Face. Distribuováno pod licencí Apache‑2.0.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 01:11 | Nová verze

    Svobodný citační manažer Zotero (Wikipedie, GitHub) byl vydán v nové major verzi 8. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    22.1. 16:55 | Nová verze

    Byla vydána verze 1.93.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    22.1. 14:00 | Komunita

    Svobodný operační systém ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, slaví 30. narozeniny.

    Ladislav Hagara | Komentářů: 8
    22.1. 11:00 | IT novinky

    Společnost Raspberry Pi má nově v nabídce flash disky Raspberry Pi Flash Drive: 128 GB za 30 dolarů a 256 GB za 55 dolarů.

    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (6%)
     (0%)
     (10%)
     (21%)
     (3%)
     (5%)
     (2%)
     (11%)
     (35%)
    Celkem 591 hlasů
     Komentářů: 17, poslední 22.1. 15:24
    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: 122×

    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.