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 13:33 | Komunita

    Byl publikován říjnový přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Pracuje se na podpoře M3. Zanedlouho vyjde Fedora Asahi Remix 43. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.

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

    Iniciativa Open Device Partnership (ODP) nedávno představila projekt Patina. Jedná se o implementaci UEFI firmwaru v Rustu. Vývoj probíhá na GitHubu. Zdrojové kódy jsou k dispozici pod licencí Apache 2.0. Nejnovější verze Patiny je 13.0.0.

    Ladislav Hagara | Komentářů: 0
    včera 05:11 | Zajímavý článek

    Obrovská poptávka po plynových turbínách zapříčinila, že datová centra začala používat v generátorech dodávajících energii pro provoz AI staré dobré proudové letecké motory, konvertované na plyn. Jejich výhodou je, že jsou menší, lehčí a lépe udržovatelné než jejich průmyslové protějšky. Proto jsou ideální pro dočasné nebo mobilní použití.

    karkar | Komentářů: 5
    24.10. 19:55 | Nová verze

    Typst byl vydán ve verzi 0.14. Jedná se o rozšiřitelný značkovací jazyk a překladač pro vytváření dokumentů včetně odborných textů s matematickými vzorci, diagramy či bibliografií.

    Ladislav Hagara | Komentářů: 0
    24.10. 13:33 | Bezpečnostní upozornění

    Specialisté společnosti ESET zaznamenali útočnou kampaň, která cílí na uživatele a uživatelky v Česku a na Slovensku. Útočníci po telefonu zmanipulují oběť ke stažení falešné aplikace údajně od České národní banky (ČNB) nebo Národní banky Slovenska (NBS), přiložení platební karty k telefonu a zadání PINu. Malware poté v reálném čase přenese data z karty útočníkovi, který je bezkontaktně zneužije u bankomatu nebo na platebním terminálu.

    Ladislav Hagara | Komentářů: 16
    24.10. 13:22 | Upozornění

    V Ubuntu 25.10 byl balíček základních nástrojů gnu-coreutils nahrazen balíčkem rust-coreutils se základními nástroji přepsanými do Rustu. Ukázalo se, že nový "date" znefunkčnil automatickou aktualizaci. Pro obnovu je nutno balíček rust-coreutils manuálně aktualizovat.

    Ladislav Hagara | Komentářů: 12
    24.10. 04:55 | Komunita

    VST 3 je nově pod licencí MIT. S verzí 3.8.0 proběhlo přelicencování zdrojových kódů z licencí "Proprietary Steinberg VST3 License" a "General Public License (GPL) Version 3". VST (Virtual Studio Technology, Wikipedie) je softwarové rozhraní pro komunikaci mezi hostitelským programem a zásuvnými moduly (pluginy), kde tyto moduly slouží ke generování a úpravě digitálního audio signálu.

    Ladislav Hagara | Komentářů: 1
    24.10. 03:22 | Nová verze

    Open source 3D herní a simulační engine Open 3D Engine (O3DE) byl vydán v nové verzi 25.10. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    23.10. 20:11 | Komunita

    V Londýně probíhá dvoudenní Ubuntu Summit 25.10. Na programu je řada zajímavých přednášek. Zhlédnout je lze také na YouTube (23. 10. a 24. 10.).

    Ladislav Hagara | Komentářů: 0
    23.10. 13:22 | Nová verze

    Gemini CLI umožňuje používání AI Gemini přímo v terminálu. Vydána byla verze 0.10.0.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (20%)
     (20%)
     (23%)
     (17%)
     (20%)
     (17%)
     (18%)
    Celkem 274 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    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: 133×
    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.