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:55 | Komunita

Společnost Librem na svém blogu oznámila, že jejich notebooky Librem jsou nově dodávány se zrušeným (neutralized and disabled) Intel Management Engine (ME). Aktualizací corebootu na již prodaných noteboocích lze Management Engine také zrušit. Více v podrobném článku.

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

Organizace Apache Software Foundation (ASF) na svém blogu slaví páté výročí kancelářského balíku Apache OpenOffice jako jejího Top-Level projektu. Při této příležitosti byl vydán Apache OpenOffice 4.1.4 (AOO 4.1.4). Podrobnosti v poznámkách k vydání. Dlouhé čekání na novou verzi tak skončilo.

Ladislav Hagara | Komentářů: 1
včera 19:22 | Pozvánky

Již příští týden - 26. a 27. října se v Praze v hotelu Olšanka odehraje OpenWRT Summit. Na webu konference naleznete program a možnost zakoupení lístků - ty stojí 55 dolarů. Čtvrtek bude přednáškový a v pátek se budou odehrávat převážně workshopy a meetingy.

Miška | Komentářů: 0
včera 13:44 | Nová verze

Bylo vydáno Ubuntu 17.10 s kódovým názvem Artful Aardvark. Ke stažení jsou Ubuntu Desktop a Server, Ubuntu Cloud Images, Ubuntu Netboot, Kubuntu, Lubuntu a Lubuntu Alternate, Lubuntu Next, Ubuntu Budgie, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio a Xubuntu. Podrobnosti v poznámkách k vydání.

Ladislav Hagara | Komentářů: 4
včera 13:00 | Komunita

MojeFedora.cz informuje, že Fedora 27 dostane podporu pro AAC. Podpora multimediálních formátů je ve výchozí instalaci Fedory tradičně limitovaná kvůli softwarovým patentům, ale desktopový tým Red Hatu se ji i tak snaží v poslední době co nejvíce rozšířit. Už nějaký čas obsahuje kodeky pro MP3, H.264, AC3 a nyní byl přidán také kodek pro další velmi rozšířený zvukový formát – AAC.

Ladislav Hagara | Komentářů: 2
18.10. 23:55 | Pozvánky

Spolek OpenAlt zve příznivce otevřených technologií a otevřeného přístupu na 145. brněnský sraz, který proběhne v pátek 20. října od 18:00 hodin v restauraci Time Out na adrese Novoměstská 2 v Řečkovicích. Jedná se o poslední sraz před konferencí OpenAlt 2017, jež proběhne o víkendu 4. a 5. listopadu 2017 na FIT VUT v Brně. Běží registrace účastníků.

Ladislav Hagara | Komentářů: 0
18.10. 21:44 | Nová verze

Byla vydána verze 5.2.0 multiplatformního virtualizačního nástroje Oracle VM VirtualBox. Jedná se o první stabilní verzi z nové větve 5.2. Z novinek lze zmínit například možnost exportování VM do Oracle Cloudu, bezobslužnou instalaci hostovaného systému nebo vylepšené GUI. Podrobnosti v seznamu změn. Aktualizována byla také dokumentace.

Ladislav Hagara | Komentářů: 1
18.10. 14:00 | Zajímavý projekt

Byl spuštěn Humble Down Under Bundle. Za vlastní cenu lze koupit multiplatformní hry The Warlock of Firetop Mountain, Screencheat, Hand of Fate a Satellite Reign. Při nadprůměrné platbě (aktuálně 3,63 $) také Hacknet, Hacknet Labyrinths, Crawl a Hurtworld. Při platbě 12 $ a více lze získat navíc Armello.

Ladislav Hagara | Komentářů: 0
18.10. 13:00 | Nová verze

Google Chrome 62 byl prohlášen za stabilní (YouTube). Nejnovější stabilní verze 62.0.3202.62 tohoto webového prohlížeče přináší řadu oprav a vylepšení. Vylepšeny byly také nástroje pro vývojáře (YouTube). Opraveno bylo 35 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 4
18.10. 11:00 | Zajímavý článek

Článek (en) na Mozilla.cz je věnován vykreslování stránek ve Firefoxu. V průběhu roku 2018 by se ve Firefoxu měl objevit WebRender, jenž by měl vykreslování stránek urychlit díky využití GPU.

Ladislav Hagara | Komentářů: 5
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (11%)
 (1%)
 (1%)
 (1%)
 (74%)
 (12%)
Celkem 107 hlasů
 Komentářů: 7, poslední včera 23:06
    Rozcestník

    Nebezpečné uninstall.sh

    22.11.2013 18:58 | Přečteno: 1350× | Bash | poslední úprava: 25.11.2013 17:17

    Podíváme se blíže na skript uninstall.sh, který šíří Princeton Instruments ve svém Picam_SDK-v2.6.0.run.

    #!/bin/sh
    # Default variables
    START_DIR=`dirname $0`
    START_DIR=`cd $START_DIR; pwd`
    echo "Start_DIR is" $START_DIR
    
    USR_LIB=/usr/lib64
    USR_LOC_LIB=/usr/local/lib64
    
    INSTALL_ROOT=$START_DIR
    PI_ROOT=`cd ..; pwd`
    PLEORA_ROOT=`cd $START_DIR/../../pleora; pwd`
    
    REMOVE_LINKS=yes
    INSTALL_DIR_OVERWRITE=yes
    
    # Initial screen
    clear
    echo -n "Remove Picam SDK installed in directory '$INSTALL_ROOT' (yes/no) ? "
    read ANSWER
    if [ ! "$ANSWER" = "yes" ]; then
      echo "Uninstall cancelled."
      exit;
    fi
    
    if [ ! -w $INSTALL_ROOT ]; then
      echo "You do not have write permissions to '$INSTALL_ROOT'."
      echo "Run installer as super user (root)."
      exit 1
    fi
    
    echo "Removing software on $INSTALL_ROOT"
    if [ -d $PI_ROOT ]; then
        rm -rf $PI_ROOT 
    fi
    
    #pleora removal
    if [ -d $PLEORA_ROOT ]; then
        rm -rf $PLEORA_ROOT 
    fi
    
    if [ "$REMOVE_LINKS" = "yes" ]; then
      rm -rf $USR_LOC_LIB/libPv*
      rm -rf $USR_LOC_LIB/libEb*
      rm -rf $USR_LOC_LIB/libPt*
      rm -rf $USR_LOC_LIB/libEbuser*
      rm -rf $USR_LOC_LIB/liblog*
      rm -rf $USR_LOC_LIB/libapr*
      rm -rf $USR_LOC_LIB/libG*
      rm -rf $USR_LOC_LIB/liblog*
      rm -rf $USR_LOC_LIB/libM*
    # Picam references
      rm -rf /var/run/pits
      rm -rf $USR_LOC_LIB/libpi*
      rm -rf $USR_LOC_LIB/*.dat
      rm -rf /etc/ld.so.conf.d/picam.conf
    fi
    
    
    echo "Removal complete."
    echo ""
    echo ""
    

    Skript se zachová třemi různými způsoby, dle toho odkud je zavolán. Před příkazy rm -rf dáme echo, abychom zjistili co se stane, ale bez následků.

    Smaže co má:

    # /opt/PrincetonInstruments/picam/
    # ./uninstall.sh
    Remove Picam SDK installed in directory '/opt/PrincetonInstruments/picam' (yes/no) ? yes
    Removing software on /opt/PrincetonInstruments/picam
    rm -rf /opt/PrincetonInstruments
    rm -rf /opt/pleora
    

    Zachrání nás inteligentní chování příkazu rm, jinak by nám smazal celý /:

    rm: it is dangerous to operate recursively on `/'
    rm: use --no-preserve-root to override this failsafe
    
    # cd /root
    # /opt/PrincetonInstruments/picam/uninstall.sh
    Remove Picam SDK installed in directory '/opt/PrincetonInstruments/picam' (yes/no) ? yes
    Removing software on /opt/PrincetonInstruments/picam
    rm -rf /
    rm -rf /opt/pleora
    

    Smaže nám celý /home:

    # cd /home/user
    # /opt/PrincetonInstruments/picam/uninstall.sh
    Remove Picam SDK installed in directory '/opt/PrincetonInstruments/picam' (yes/no) ? yes
    Removing software on /opt/PrincetonInstruments/picam
    rm -rf /home
    rm -rf /opt/pleora
    

    Chyba je na následujících řádcích:

    START_DIR=`cd $START_DIR; pwd`
    PI_ROOT=`cd ..; pwd`
    

    Autor si neuvědomil, že spouští příkaz cd v subshellu, takže pracovní adresář v nadřízeném shellu zůstane stejný.

    Pokud by se skript alespoň před spuštěním rm -rf zeptal, zda-li má smazat adresář XY, byla by větší šance, že si toho uživatel všimne.

    V případě, že by se skript správně otestoval, tak by tato chyba neprobublala až k zákazníkovi.

    Takže ponaučení na závěr. Nevěřte nikomu. Není od věci mrknou co je obsahem skriptu uninstall.sh, obzvláště pokud není příliš dlouhý. A do třetice. Zálohovat, zálohovat, zálohovat.

    UPDATE: David ještě správně poukázal na řádek:

    START_DIR=`dirname $0`
    

    Skript by v případě zavolání, pomocí symbolického linku z jiného adresáře, také selhal.

    Šlo by to vylepšit voláním:

    START_DIR=$(readlink -f ${BASH_SOURCE[0]})
    
           

    Hodnocení: 100 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    gtz avatar 22.11.2013 20:27 gtz | skóre: 27 | blog: merlins | Brno - Venkov / Rosicko
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    měl jste to autorovi reportovat ... ale jinak máte pravdu zálohovat, zálohovat.
    - nejhorší jsou trpaslíci ... Ti Vám vlezou úplně všude
    Fuky avatar 22.11.2013 21:23 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Samozřejmě jsem to tvůrcům reportoval, ovšem nedělám si iluze o rychlé nápravě, jejich reakční doba je několik měsíců, Linuxová verze pro ně evidentně není prioritou a malý zákazník pro ně nic neznamená. Je to velká škoda, protože by stačilo velice málo, aby jejich zákazníci byli nadmíru spokojeni.
    23.11.2013 17:54 trekker.dk | skóre: 71
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Ponaučení na závěr: skripty install.sh a uninstall.sh nikdy nespouštět a už vůbec ne pod rootem.
    Quando omni flunkus moritati
    23.11.2013 18:07 R
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Pripomina mi to uninstall nejakej hry pre Windows. Default cesta pri instalacii bola "C:\Program Files\Sierra\blabla". Zmenil som to na "C:\games\blabla". Ked som to potom chcel odinstalovat, trvalo to nejako podozrivo dlho. Tak som pozrel do C:\games, ze co to robi - a polovica hier uz bola v prdeli...
    23.11.2013 19:18 pavel
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Mohl by někdo napsat, jak se zjišťuje aktuální umístění souboru (absolutní cesta)? Co jsem se díval na internet, není to až tak triviální záležitost. Zajímalo by mě nejpoužívanější řešení v bashi - aby byla cesta správně v případě použití adresáře, symbolického odkazu, souboru a při použití .source ve skriptu.
    Jendа avatar 23.11.2013 19:57 Jendа | skóre: 74 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Fuky avatar 23.11.2013 20:01 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh

    Pokud jsem něco neopomněl, tak by to mělo jít např. takto:

    readlink -f ${BASH_SOURCE[0]}
    
    23.11.2013 22:55 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Mimo readlink by tě mohlo zajímat:
    includepath="$( cd -P "$( dirname "$0" )" && pwd )"
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    24.11.2013 13:52 z
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Autor si neuvědomil, že spouští příkaz cd v subshellu, takže pracovní adresář v nadřízeném shellu zůstane stejný.
    Tak v tom problém teda opravdu není.
    Fuky avatar 24.11.2013 14:09 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh

    Autorovi nikdo z nás do hlavy samozřejmě nevidí, ale nevidíme tam ani Tobě, takže klidně svou myšlenku rozveď.

    David Watzke avatar 25.11.2013 13:49 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Problém je očividně hned v
    START_DIR=`dirname $0`
    Tohle prostě v $0 dostane cestu toho, jak byl program zavolanej...
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    25.11.2013 14:46 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    To je pěkná ptákovina, co už jsem několikrát udělal taky :-(.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Fuky avatar 25.11.2013 16:58 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Nebezpečné uninstall.sh
    Jasně, určitě to není dobré takto řešit a je třeba na to upozorňovat, ostatní chyby mě tak naštvaly, že jsem si toho ani nevšiml, i když to řešíme v diskuzi. ;-) Každopádně pokud se špatně nastaví $START_DIR, tak to alespoň vypíše hlášku, kde uživatel zjistí, že se ho to ptá na smazání špatného adresáře, v případě, že se nezavolá skript přímo svým názvem, ale třeba pomocí linku, nebo se přesune na jiné místo.

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.