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:22 | IT novinky

    Společnost Apple slaví padesáté narozeniny. Založena byla 1. dubna 1976.

    Ladislav Hagara | Komentářů: 0
    včera 22:33 | Nová verze

    FreeTube, desktopový klient pro YouTube využívající lokální API, byl vydán ve verzi 0.24.0. Toto velké opravné vydání implementuje SABR (Server-Based Adaptive Bit Rate), což řeší část nedávných problémů s načítáním videí z YouTube, a aktualizuje základní komponenty jako Electron nebo přehrávač Shaka Player.

    |🇵🇸 | Komentářů: 0
    včera 16:33 | Humor

    Je tu opět apríl. O víkendu zmizel kamion s 12 tunami tyčinek KitKat. Firmy to využívají k aprílovým žertům. Groupon má super akci. Koupíte 1 tyčinku a dostanete 100 zdarma. Ryanair si přelepil letadla. Šéf Outlooku se ptá, proč mají v baráku 14 beden tyčinek KitKat (𝕏). Prusa Research představuje Prusa Pro ACU a vysvětluje proč přílišné sušení škodí vaším filamentům. Telefon Sony Xperia má miliónnásobný zoom (𝕏). PC.net představil Super Ultrabox 2600 se zajímavými parametry. Další aprílové novinky například na April Fools' Day On The Web.

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

    Společnost OpenAI, která stojí za chatovacím robotem s umělou inteligencí (AI) ChatGPT, získala od investorů 122 miliard USD (2,6 bilionu Kč). Hodnota společnosti tak dosáhla 852 miliard dolarů (více než 18 bilionů Kč). Nejnovější kolo investování se stalo největší, jaké zatím firma uskutečnila, a peníze mají posílit ambiciózní plány rozšíření výpočetní kapacity, datových center a nábor talentů.

    Ladislav Hagara | Komentářů: 5
    včera 13:11 | IT novinky

    Nástroj k identifikaci občanů v on-line komunikaci s úřady byl dnes dopoledne zhruba dvě hodiny částečně nedostupný. Problém se objevil kolem 09:00 a podařilo se ho vyřešit kolem 11:00. Částečně nedostupná byla služba Národní identitní autority (NIA), problémy podle DIA (Digitální a informační agentura) ovlivňovaly přihlašování například i přes bankovní identitu. „Dostupnost NIA byla plně obnovena, přihlášení k digitálním službám

    … více »
    Ladislav Hagara | Komentářů: 3
    včera 13:00 | IT novinky

    Eben Upton oznámil další zdražení počítačů Raspberry Pi kvůli růstu cen pamětí a představil Raspberry Pi 4 s 3 GB RAM za 83,75 dolarů.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | Humor

    Anthropic patrně omylem zveřejnil celý zdrojový kód svého CLI nástroje Claude Code prostřednictvím přiloženého sourcemap souboru v npm balíčku. Únik odhalil doposud nijak nezveřejněné funkce jako je například režim v utajení, autonomní agent 'KAIROS', orchestrace multi‑agentů, režim snění nebo dokonce virtuální mazlíček Buddy. Zajímavostí je detekce naštvání uživatele pomocí obyčejného regexpu. Anthropic rychle odstranil sourcemap a vydal opravu, nicméně kopie kódu se již stihly na GitHubu rozšířit mezi prostým lidem.

    NUKE GAZA! 🎆 | Komentářů: 12
    31.3. 14:33 | Humor

    Copilot automaticky vkládal do pull requestů 'propagační tipy', reklamní text se na GitHubu objevil ve více než jedenácti tisících pull requestech. Po vlně kritiky byla tato funkce zablokována a produktový manažer Tim Rogers připustil, že umožnit Copilotovi upravovat cizí pull requesty bez vědomí autorů byla chyba.

    NUKE GAZA! 🎆 | Komentářů: 4
    31.3. 12:55 | Upozornění

    Je 31. března a tedy Světový den zálohování (World Backup Day). Co by se stalo, kdyby Vám právě teď odešel počítač, tablet nebo telefon, který používáte?

    Ladislav Hagara | Komentářů: 4
    31.3. 12:44 | Upozornění

    Digitální a informační agentura (DIA) přistupuje ke změně formátu důvěryhodného seznamu České republiky z verze TLv5 na verzi TLv6, která nastane 29. dubna 2026 v 00:00 (CET). Ke změně formátu důvěryhodných seznamů členských států (tzv. Trusted Lists) dochází na základě změn příslušné unijní legislativy. Důvěryhodné seznamy se používají v rámci informačních systémů a aplikací zejména pro účely ověřování platnosti elektronických

    … více »
    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (5%)
     (1%)
     (14%)
     (23%)
    Celkem 1203 hlasů
     Komentářů: 29, poslední 31.3. 11:17
    Rozcestník

    Dotaz: Spousteni BASH skriptu jako ROOT

    19.2.2010 08:07 Carth_Onasi
    Spousteni BASH skriptu jako ROOT
    Přečteno: 1434×

    Zdravim

    Je mozne, aby spustitelny BASH skript byl spustitelny pod obycejnym uzivatelem, ale aby tento skript mohl pouzivat rootovske prikazy (nastaveni firewallu) bez pouziti sudo nebo root-hesla?

    Diky.

    Odpovědi

    19.2.2010 08:32 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    U normálních binárek se toho dá docílit suid bitem, kterým způsobí, že se program spustí s právy vlastníka souboru. U skriptů tohle ale pod linuxem povolené není. Samozřejmě vám nikdo nezabrání udělat si Céčkový wrapper, který ten suid bit nastaven mít bude a uvnitř spustí ten váš skript – a nejspíš už něco takového dávno existuje. Problém ale je, že se vám nejspíš nepodaří ten skript napsat bezpečně, aby nebylo možné jej třeba manipulací s proměnnými prostředí donutit s právy roota vykonat jakýkoli program. Pokud potřebujete uživatelům jenom umožnit změny firewallu, a to ještě jenom nějaké povolené změny, bylo by lepší napsat si na to nějaký jednoúčelový program v jazyce, jehož chování můžete opravdu kontrolovat.

    Jinak když budete hledat „suid skript“ (případně setuid či bash), najdete toho spoustu.
    21.2.2010 22:42 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Samozřejmě vám nikdo nezabrání udělat si Céčkový wrapper, který ten suid bit nastaven mít bude a uvnitř spustí ten váš skript – a nejspíš už něco takového dávno existuje.
    Ano, sudo.

    Původnímu tazateli doporučuju se chvíli věnovat nastavení sudo a pak ho ve skriptu použít. Všechny ostatní metody pravděpodobně skončí hůř.
    In Ada the typical infinite loop would normally be terminated by detonation.
    19.2.2010 08:36 Miklik | skóre: 27 | Krnov
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Dle mě bude třeba použít sudo bez hesla na příkazy ve skriptu, které vyžadují root práva.
    Nebo možná u těch příkazu nastavit sticky bit. Pak se budou spouštět s právy vlastníka souboru.
    Netvrdím to, ale možná je to pravda.
    19.2.2010 10:40 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    sudo nebo suid bit ale umožní ty příkazy s právy roota spouštět komukoli (suid) nebo uživatelům povoleným pro sudo. Pokud to chce tazatel povolit, pak to není problém – ale pokud chtěl povolit jen omezenou množinu příkazů, pak tohle použít nemůže – např. pokud tazatel chtěl skriptem povolit upravovat jeden řetězec v iptabels, když nastaví suid bit nebo povolí sudo na iptables, umožní dotyčnému třeba kompletně smazat všechna pravidla firewallu.
    19.2.2010 15:05 miro
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Ale IMHO lze uživateli dát sudo na skript, který umožňuje měnit iptables striktně definovaným způsobem a odebrat uživateli právo zápisu. Nebo v tom vidíte nějaký bezpečnostní problém?
    19.2.2010 15:38 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Problém je, že ten skript se těžko zabezpečí, aby se nedal zneužít. Třeba když v tom skriptu použijete iptables (bez celé cesty), tak si uživatel může změnit cestu tak, aby na začátku měl nějaký vlastní program jménem iptables – a ten se spustí s právy roota. Shell není dělaný na to, aby se spouštěl s právy roota a pomocí skriptu se omezilo, co přesně může uživatel dělat. Naopak shelly mají normálně spoustu možností,jak spouštět další programy atd. Možná někdo, kdo zná třeba Bash opravdu dobře, by dokázal napsat skript a říci, že je bezpečné spouštět jej pod jiným uživatelem s právy roota. Já akorát vím, že Bash neznám tak dobře, abych to o jakémkoli skriptu dokázal říci.
    19.2.2010 17:58 miro
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Já akorát vím, že Bash neznám tak dobře, abych to o jakémkoli skriptu dokázal říci.

    Tak to zní trochu depresivně pro člověka, který si je vědom toho, že zná bash ještě podstatně míň než vy. Ale jak jsem tak letmo nakouknul do man sudoers, tak problémy, které naznačujete, zřejmě budou řešitelné. Ale neodvažuju se o tom kohokoli jakkoli poučovat.

    19.2.2010 18:46 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Já Bash skoro neznám, nemám moc důvod v shellu nějak moc dělat – akorát občas potřebuji udělat nějakou akci nad určitou množinou souborů, sem tam si napíšu nějaký skriptík tak do deseti řádků. Ale vzhledem k tomu, že je shell určen k tomu, aby se neustále pokoušel něco interpretovat a na základě toho spouštět nějaké další programy, bych se opravdu bál, že na něco zapomenu nebo že nějakou vlastnost, kterou půjde zneužít, vůbec neznám.
    21.2.2010 22:53 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Myslím, že to trochu zveličujete.

    Sudo většinu problémů řeší za Vás. Například uvedený útok s PATH nefunguje, neboť sudo zlikviduje většinu nastavení prostředí. Proto taky doporučuji použít sudo a nebastlit si vlastní "suid wrapper" - tvůrci suda už si tím vším prošli.

    Odstraněním proměnných prostředí se odfiltruje jediný možný vektor útoku z předchozího shellu. Pak už to je jen o tom, jak napíšete skript - návody jsou na netu. Samozřejmě čím jednodušší ten skript bude, tím lépe.

    Případně lze v sudo natvrdo naspecifikovat, že ten uživatel smí spustit iptables s takovými a takovými parametry. Pak se skriptu vyhnete úplně. Možnosti jsou v tomto dost široké.

    In Ada the typical infinite loop would normally be terminated by detonation.
    22.2.2010 11:45 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Proto taky doporučuji použít sudo a nebastlit si vlastní "suid wrapper" - tvůrci suda už si tím vším prošli.
    Jak složitou gramatiku pro popis přípustných kombinací parametrů umí nadefinovat sudo? Účelem toho mnou zmíněného wrapperu by byla právě kontrola parametrů. Třeba jestli IP adresa zadaná jako parametr je uvedená v databázi u příslušného uživatele – to mi asi sudo nezkontroluje.
    Odstraněním proměnných prostředí se odfiltruje jediný možný vektor útoku z předchozího shellu.
    To těžko. Když budete mít ve skriptu TEST=`$1`, pořád může uživatel snadno spustit cokoli s právy roota.
    22.2.2010 12:48 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Účelem toho mnou zmíněného wrapperu by byla právě kontrola parametrů. Třeba jestli IP adresa zadaná jako parametr je uvedená v databázi u příslušného uživatele – to mi asi sudo nezkontroluje.

    Asi by to chtělo konkrétní příklad, co a jak chcete kontrolovat? Obvykle se složitější kontroly provedou ještě před sudo, aby kód pod rootem byl co nejmenší. Pokud to je nezbytně nutné, můžete kontrolovat po sudo, ale zbytečně zesložiťujete privilegovaný kód. Nicméně psát z gruntu vlastní wrapper Vám dá to horší z obou: kontroly poběží pod rootem a navíc můžete udělat nějakou jinou chybku, kterou už sudo řeší samo o sobě.
    To těžko. Když budete mít ve skriptu TEST=`$1`, pořád může uživatel snadno spustit cokoli s právy roota.

    To je věc kontroly vstupu Vašeho skriptu. Zrovna tak, pokud skript explicitně používá nějakou proměnnou, soubor, bere vstup z stdin, a kdoví co.

    Já jsem mluvil o ovlivnění funkce Vašeho interpretu, tj. shellu. Ta se dá ovlivnit jen proměnnou prostředí, protože jiný vstup nebere.
    In Ada the typical infinite loop would normally be terminated by detonation.
    22.2.2010 15:51 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Asi by to chtělo konkrétní příklad, co a jak chcete kontrolovat?
    To, že uživatel má právo provést danou akci. Třeba přidělím uživatelům rozsahy portů s tím, že každý si na svém rozsahu může dělat DNAT, jaký chce. S pevnými rozsahy portů by to do sudoers ještě šlo nacpat, ale pokud budu chtít rozsahy mít třeba v databázi, sudoers už mi nepomůže a musím to kontrolovat programově.
    Obvykle se složitější kontroly provedou ještě před sudo
    Jenže to pak nikomu nezabrání spustit tu aplikaci (třeba iptables) přes sudo bez složitějších kontrol.
    To je věc kontroly vstupu Vašeho skriptu. Zrovna tak, pokud skript explicitně používá nějakou proměnnou, soubor, bere vstup z stdin, a kdoví co.
    Jenže udělat tyhle kontroly v shellu není nic jednoduchého, protože shell je určen k tomu, aby neustále něco interpretoval – a vy najednou chcete docílit toho, aby neinterpretoval skoro nic.
    22.2.2010 17:00 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Třeba přidělím uživatelům rozsahy portů s tím, že každý si na svém rozsahu může dělat DNAT, jaký chce.
    Tohle by asi šlo řešit dost jednoduše tak, že každej dostane svůj chain, kde si může dělat třeba suchý z vrby a do toho chainu se pošlou pakety z toho rozsahu. S trochou práce by to asi šlo naroubovat i na tu databázi. Sudo pak nastavíte tak, že povoluje něco jako "iptables -[AIDF] mujchain *".
    Jenže to pak nikomu nezabrání spustit tu aplikaci (třeba iptables) přes sudo bez složitějších kontrol.
    Sudo nastavíte samozřejmě tak, že se smí daná operace volat pouze z toho skriptu. Pokud někdo nabourá ten skript tak získá možnost si nastavit firewall (resp. DNAT) jak chce, ale už nezíská o moc víc (cf. kdyby celý skript běžel pod rootem).
    Jenže udělat tyhle kontroly v shellu není nic jednoduchého, protože shell je určen k tomu, aby neustále něco interpretoval – a vy najednou chcete docílit toho, aby neinterpretoval skoro nic.
    Tak to zase pr. Shell je pouze interpretovaný jazyk a většina normálních interpretovaných jazyků má prostředky k tomu aby nějaký řetězec interpretovala, nebo taky ne, podle toho, jak chce programátor. V bashi jsou na to uvozovky. Perl má navíc taint operátor, který kontrolu toho co kam strkáte dělá za Vás.
    In Ada the typical infinite loop would normally be terminated by detonation.
    22.2.2010 18:47 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Tohle by asi šlo řešit dost jednoduše tak…
    Tohle konkrétně ano, protože můžete použít jinou funkcionalitu iptables. Ale mohou existovat programy, které takové možnosti nemají.
    Sudo nastavíte samozřejmě tak, že se smí daná operace volat pouze z toho skriptu.
    To se nastaví jak?
    22.2.2010 20:12 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Tohle konkrétně ano, protože můžete použít jinou funkcionalitu iptables. Ale mohou existovat programy, které takové možnosti nemají.

    Pointa je, že stojíte vždy před konkrétním problémem a obvykle si vyberete to "lehčí" řešení.
    Sudo nastavíte samozřejmě tak, že se smí daná operace volat pouze z toho skriptu.
    To se nastaví jak?
    Nejjednodušší je pro skript rezervovat uid, uživatelům povolit sudo na skript pod tím uid, a teprve tomu uid povolit sudo iptables pod rootem.
    In Ada the typical infinite loop would normally be terminated by detonation.
    21.2.2010 08:51 Miklik | skóre: 27 | Krnov
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Myslím, že v sudoers se dá nastavit příkaz s cestou i s parametry, a pak jen tak, ho bude možno spouštět.
    Netvrdím to, ale možná je to pravda.
    21.2.2010 09:27 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Jenže v tomto případě je nejspíš potřeba ty parametry měnit.
    21.2.2010 20:19 Miklik | skóre: 27 | Krnov
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Jdou použít i zástupné znaky.
    Netvrdím to, ale možná je to pravda.
    19.2.2010 09:57 Zaphod | skóre: 37 | blog: zaphod_blog
    Rozbalit Rozbalit vše Re: Spousteni BASH skriptu jako ROOT
    Treba povoliť cez visudo použiť root príkazy pre užívateľa bez hesla. Potom sa dá v scripte použiť "sudo príkaz".

    Bez sudo sa dá použit policy kit alebo PAM. Neskúšal som - vyhovuje mi sudo.

    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.