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 12:33 | Zajímavý projekt

    MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.

    NUKE GAZA! 🎆 | Komentářů: 11
    dnes 03:55 | Bezpečnostní upozornění

    Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.

    Ladislav Hagara | Komentářů: 2
    včera 17:22 | Nová verze

    Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.

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

    Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).

    Ladislav Hagara | Komentářů: 4
    včera 02:11 | Komunita

    Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.

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

    Google Chrome 146 byl prohlášen za stabilní. Nejnovější stabilní verze 146.0.7680.71 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 29 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

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

    D7VK byl vydán ve verzi 1.5. Jedná se o fork DXVK implementující překlad volání Direct3D 3 (novinka), 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    11.3. 23:22 | Nová verze

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

    Ladislav Hagara | Komentářů: 4
    11.3. 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 14
    11.3. 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

    Ladislav Hagara | Komentářů: 36
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (0%)
     (12%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (25%)
    Celkem 1068 hlasů
     Komentářů: 26, poslední včera 08:56
    Rozcestník

    Dotaz: Cast skriptu..kontrola parametru a IF

    6.6.2005 17:32 xhonzax | skóre: 1
    Cast skriptu..kontrola parametru a IF
    Přečteno: 141×
    Potrebuju aby tato cast skriptu zkontrolovala jestli uzivatel, ktery je zadavan jako parametr skriptu existuje nebo jestli bylo zadano all...jinak konec s chybobou hlaskou>>

    if test $1 != "cat /etc/passwd | grep ^[^:]*:[^:]*:[^:]*|cut -f 1 -d ":"" || test $1 != all
    then
    echo "Zadali jste uzivatele, ktery neexistuje, tudiz nespustil zadne procesy"
    exit
    fi

    Toto mi nefunguje, jak to upravit? Diky moc za odpovedi Honza

    Odpovědi

    6.6.2005 17:48 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    "cat /etc/passwd | grep ^[^:]*:[^:]*:[^:]*|cut -f 1 -d ":""
    je nesmysl, to se expanduje na ten řetězec v uvozovkách, měls asi na mysli $(...) nebo `...`, i tak by to moc nefungovalo.

    No nic, nejlepší co jsem vymyslel je
    if cut -d: -f1 | grep -F -x -q "$1"; then
      echo "OK"
    else
      echo "neexistuje"
    fi
    
    najdi si v man grep co ty optiony znamenají (btw asi nebudou přenositelné)

    Aby to bylo skutečně korektní, tak by to chtělo C prográmek, co zavolá getpwnam(argv[1]).
    6.6.2005 17:49 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    cut -d: -f1 /etc/passwd samozřejmě.
    6.6.2005 17:58 xhonzax | skóre: 1
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Dekuju. Funguje to.
    6.6.2005 21:08 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Vím, že na Python se tu nikdo neptal, ale funguje mi tohle:
    #!/usr/bin/env python
    import pwd
    
    user = 'all'
    
    if (cmp(user,'all')):
      try:
        print pwd.getpwnam(user)
      except KeyError:
        print "Tento uzivatel neexistuje"
    else:
      print "Tohle se tyka vsech uzivatelu"
    
    Odteďka chci mít všude login "all" ;-)
    6.6.2005 21:46 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    IMHO to děláte zbytečně složitě, stačí využít návratový kód (e)grepu:
    if egrep -q "^${1}:" /etc/passwd || [ "x$1" = xall ]; then
      echo OK
    else
      echo chyba
    fi
    
    6.6.2005 22:06 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Tohle je zase až moc jednoduše, nehlídá to tečky a pod. v "$1" ("regexp injection"? :-)).
    6.6.2005 22:36 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    OK, OK, tak se z toho nejdřív vyházejí nepohodlné znaky:
      x=`echo "$1" | LC_CTYPE=C tr -cd '[a-zA-Z0-9_]'`
      if [ "x$1" != "x$x" ];
        echo "Nech toho, darebáku, sic ti hnáty zpřerážím!" # :-)
        exit 1
      fi
    

    Na druhou stranu, kdyby si s tím člověk trochu pohrál, mohl by v tom být i určitý záměr: mohl by se zadávat regulární výraz a hledaly by se procesy kteréhokoli uživatele, který mu vyhovuje (nebo co to měl ten skript dělat)… :-)

    7.6.2005 00:45 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    :-)

    BTW, nevíte kde má původ ten zápis
    test "x$param" = "xvalue"
          ^           ^
    
    ? Používá to i Autoconf, takže asi existoval systém, kde nefungoval test s prázdným parametrem, ale netuším jaký (PDP-11 ve škole nemáme :-)).
    7.6.2005 00:58 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Ten problém není AFAIK kvůli prázdným parametrům, ale kvůli parametrům, které vypadají jako standardní podmínky příkazu test. Nějak se mi ale nedaří vyrobit nějaký dostatečně úderný příklad ('test -e = -f' i 'test -e = -e' mi kupodivu fungují správně s interním i externím testem).
    7.6.2005 01:19 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    A jo. GNU test, bash, ash a pdksh (víc toho u sebe nemám) se chovají podle očekávání; našel jsem tohle
    $ uname -srv 
    IRIX64 6.5 04091957
    $ /usr/bin/test -n = blabla; echo $?
    0
    
    Takže smysl to asi má pořád.
    7.6.2005 10:53 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
      x=`echo "$1" | LC_CTYPE=C tr -cd '[a-zA-Z0-9_]'`
      if [ "x$1" != "x$x" ];
        echo "Nech toho, darebáku, sic ti hnáty zpřerážím!" # :-)
        exit 1
      fi
    
    To se nám to krásně zjednodušilo. Až na ten fork, fork, exec a přitom je to úplně zbytečné.
    case "$1" in
        *[^a-zA-Z0-9_]*)
             echo "Nech toho, darebáku, sic ti hnáty zpřerážím!" # :-)
             exit 1;;
    esac
    To je ekvivalent uvedeného, ale víc jak 20x rychlejší. Nechce hledat přesné omezení na username abych to napsal přesněji.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.6.2005 11:28 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Bez case je to ještě jednodušší
    [[ "$1" == *[^a-zA-Z0-9_]* ]] && {
      echo "Nech toho, darebáku, sic ti hnáty zpřerážím!" # :-)
      exit 1
    }
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.6.2005 13:06 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Všichni jste ostudy. Nikoho nenapadlo použít to nejjednodužší a nejbezpečnější řešení.
    if ! id "$1" >&/dev/null && [ "x$1" != xall ]
    then
        echo "Zadali jste uzivatele, ktery neexistuje, tudiz nespustil zadne procesy"
        exit 1
    fi
    P.S.: Ano, opravdu tam má být && a ne || protože chyba nastane, když uživatel není a zároveň není zadáno all.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.6.2005 13:26 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Sakra :-) já věděl, že něco takového musí existovat, ale odradil mě finger
    $ finger chroustal; echo $?
    finger: chroustal: no such user.
    0
    
    7.6.2005 13:40 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Já jsem jsem přesvědčený, že jsem někde viděl utilitu, která byla ekvivalentem getpwnam(3), ale nemůžu se teď spomenout ani ji nikde najít. To přece není možné aby taková utilita nebyla. To by bylo padlé nahlavu, přece nebudu při zjišťování uživatelova shellu parsovat passwd(5). Nehledě na to, že tam taky vůbec nemusí být.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.6.2005 18:45 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    Přinejhorším by nebyl problém si ji za chvíli napsat…
    7.6.2005 18:50 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Cast skriptu..kontrola parametru a IF
    No jo, něco v tom duchu mne napadlo, jenže jsem zkoušel laborovat s něčím ve stylu ~$1, ale když jsem zjistil, že pořadí expanzí je opačné, než bych potřeboval, opustil jsem tuto cestu a vrhnul se na parsování /etc/passwd. Na druhou stranu, v praxi bych to asi stejně radši napsal v céčku…

    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.