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 23:11 | Zajímavý software

    Komunita kolem Linux Containers po roce vývoje představila (YouTube) neměnný operační systém IncusOS speciálně navržený pro běh Incusu, tj. komunitního forku nástroje pro správu kontejnerů LXD. IncusOS poskytuje atomické aktualizace prostřednictvím mechanismu A/B aktualizací s využitím samostatných oddílů a vynucuje zabezpečení bootování pomocí UEFI Secure Bootu a modulu TPM 2.0. Postaven je na Debianu 13.

    Ladislav Hagara | Komentářů: 2
    včera 22:44 | IT novinky

    Mozilla začne od ledna poskytovat komerční podporu Firefoxu pro firmy. Jedná se o podporu nad rámec stávající podpory, která je k dispozici pro všechny zdarma.

    Ladislav Hagara | Komentářů: 0
    včera 03:44 | Komunita

    V Bolzanu probíhá konference SFSCON (South Tyrol Free Software Conference). Jean-Baptiste Kempf, zakladatel a prezident VideoLAN a klíčový vývojář VLC media playeru, byl na ní oceněn cenou European SFS Award 2025 udělovanou Free Software Foundation Europe (FSFE) a Linux User Group Bolzano‑Bozen (LUGBZ).

    Ladislav Hagara | Komentářů: 2
    včera 02:44 | Zajímavý projekt

    Open-source minimalistický trackball Ploopy Nano byl po modelech modelech Classic a Thumb Trackball také aktualizován. Nová verze Nano 2 používá optický senzor PAW3222 a k původně beztlačítkovému designu přidává jedno tlačítko, které ve výchozí konfiguraci firmwaru QMK přepíná režim posouvání koulí. Sestavený trackball nyní vyjde na 60 kanadských dolarů (bez dopravy a DPH).

    |🇵🇸 | Komentářů: 3
    7.11. 14:22 | Zajímavý článek

    Github publikoval Octoverse 2025 (YouTube), tj. každoroční přehled o stavu open source a veřejných softwarových projektů na GitHubu. Každou sekundu se připojil více než jeden nový vývojář. Nejpoužívanějším programovacím jazykem se stal TypeScript.

    Ladislav Hagara | Komentářů: 0
    7.11. 09:55 | Komunita

    Kit je nový maskot webového prohlížeče Firefox.

    Ladislav Hagara | Komentářů: 17
    7.11. 00:11 | Nová verze

    Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.5. Přehled novinek s náhledy v oznámení na blogu.

    Ladislav Hagara | Komentářů: 2
    6.11. 23:55 | IT novinky

    Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.

    Ladislav Hagara | Komentářů: 1
    6.11. 18:00 | Komunita

    Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.

    karkar | Komentářů: 9
    6.11. 11:00 | IT novinky

    Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.

    Ladislav Hagara | Komentářů: 16
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (18%)
     (17%)
     (22%)
     (15%)
     (22%)
     (15%)
     (16%)
    Celkem 325 hlasů
     Komentářů: 15, poslední 2.11. 08:25
    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: 118×

    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.