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 11:33 | Nová verze

    Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.

    |🇵🇸 | Komentářů: 0
    dnes 03:33 | Bezpečnostní upozornění

    Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.

    Ladislav Hagara | Komentářů: 1
    včera 14:11 | Komunita

    Vývojáři open source operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, se na síti 𝕏 pochlubili, že ReactOS zvládne počítačovou hru Half-Life.

    Ladislav Hagara | Komentářů: 3
    včera 10:44 | Nová verze

    Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

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

    Apple container dospěl do verze 1.0.0. Jedná se o open source nástroj pro spouštění linuxových kontejnerů na macOS postavený nad containerization. Napsaný je v programovacím jazyce Swift a optimalizovaný pro Apple silicon.

    Ladislav Hagara | Komentářů: 5
    včera 03:33 | Nová verze

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

    Ladislav Hagara | Komentářů: 0
    10.6. 15:44 | Zajímavý software

    Asterinas (GitHub) je v Rustu napsané jádro operačního systému poskytující s jádrem Linux kompatibilní ABI. Vydána byla verze 0.18.0. První distribucí postavenou nad jádrem Asterinas je Asterinas NixOS. Nejedná se o oficiální projekt NixOS a nemá nic společného s NixOS Foundation.

    Ladislav Hagara | Komentářů: 1
    10.6. 13:22 | Zajímavý článek

    Podrobně byla rozebrána kritická zranitelnost v nf_tables (CVE-2026-23111). Další lokální eskalace práv na Linuxu. V upstreamu byla zranitelnost již v únoru opravena. Ve zdrojovém kódu stačilo odstranit 1 vykřičník.

    Ladislav Hagara | Komentářů: 1
    10.6. 12:11 | Nová verze

    Evropská komise (EK) nařídila americké společnosti Meta, že musí znovu umožnit bezplatný přístup konkurenčním obecně zaměřeným asistentům umělé inteligence (AI) k WhatsAppu a tento přístup musí zachovat až do ukončení antimonopolního šetření. Opatření je dočasné a má zabránit vážnému a nevratnému poškození konkurence na rychle rostoucím trhu s obecnými AI asistenty. Meta uvedla, že se proti rozhodnutí odvolá.

    Ladislav Hagara | Komentářů: 20
    10.6. 11:44 | IT novinky

    Společnost Anthropic představila AI modely Claude Fable 5 a Claude Mythos 5. Claude Fable 5 je první model třídy Mythos určený pro běžné použití.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (15%)
     (31%)
     (3%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1883 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    vnc autolock

    24.8.2025 00:32 | Přečteno: 3122× | Výběrový blog | poslední úprava: 26.8.2025 09:15

    Před několika dny se tu v poradně objevil dotaz, jak na linuxu zamknout server po dobu kdy ho někdo ovládá vzdáleně přes VNC. Nikdy jsem něco takového nepotřeboval ale přijde mi to jako celkem zajímavý nápad. Dovedu si teoreticky představit situace kdy by se to dalo využít. Z diskuze jsem se dozvěděl, že windows prý mají podobnou fičuru už od nepaměti tak mě napadlo že zkusím něco zbastlit pro linux. Cestou jsem narazil na pár zádrhelů a k dokonalosti to má ještě daleko no prvotina už víceméně funguje. Je potřeba mít nainstalované xrandr xinput xset a vnc by mělo běžet na tcp portu 5900 rfb. Uživatelům waylandu se omlouvám ale wayland jsem nikdy nepoužíval a nevím o něm lautr nic.
    #!/bin/sh
    # vnc autolock skript
    if [ $(pgrep -fc "$(basename "$0")") -gt 1 ]; then exit 1; fi
    if [ -z $DISPLAY ]; then export DISPLAY=:0; fi
    
    v=$(xrandr | awk '/connected/{print $1}')
    d=$(xinput list | grep -v 'Virtual' | cut -d= -f2 | cut -f1)
    
    while sleep 5; do
        c=$(ss -t | awk '$4~/:rfb/')
        if [ -n "$c" ] && [ "$status" != "locked" ]; then
            s=$(xrandr | awk '/*/{print $1; exit}')
            # turn off video outputs
            for i in $v; do
                xrandr --fb $s --output $i --off
            done
            # disable input devices
            for i in $d; do
                xinput disable $i
            done
            status=locked
        elif [ -z "$c" ] && [ "$status" != "open" ]; then
            # turn on video output
            for i in $v; do
                xrandr --output $i --auto
            done
            # enable input devices
            for i in $d; do
                xinput enable $i
            done
            status=open
            # screensaver
            #pgrep xtrlock || xtrlock -b &
            xset s activate
        fi
        #echo "$(date +%X) $status"
    done      
    
    Chtěl jsem aby to bylo trochu přenositelné protože parsovat výstup programu xinput list je celkem peklo. Někdy ukazuje například klávesnicu dvakrát pod stejným jménem ale s jinačíma ID. Proto jsem se rozhodl odpojit kromě těch virtuálních zařízení preventivně všecko. Taky nevím jak ošetřit to vícenásobné spuštění(řádek 3). Když mám skript otevřený například ve vimu tak pgrep si myslí že už je ten skript jakože spuštěný a vrátí true. Program pidof -x ho nevidí vůbec. Řádek 4 je tam jenom pro případ když jsem to zkoušel spustit přes ssh kde terminál nevidí proměnnou DISPLAY. Jinak se skript chová celkem primitivně. Každých pět sekund kontroluje, jestli náhodou není někdo připojen na port 5900, průběžně si ukládá status, vypíná/zapíná monitory a vstupní zařízení. Kdyby to někoho napadlo zkoušet, tak doporučuju mít na serveru kromě vnc puštěné taky ssh. Když by se náhodou stalo, že skript z nějakého důvodu umře během vzdálené vnc session, mohla by teoreticky nastat situace, že na druhý den přijdete k zamčenému serveru. Ale do takových extrémů by snad dojít nemuselo. Přemýšlím jak udělat aby to bylo trochu víc user-friendly a aby to přitom moc nenabobtnalo. Berte to jenom jako takový počáteční nástřel.

    EDIT: Opraven velice nepříjemný bug který způsoboval, že při pokusu o připojení ze serveru na kterém skript běží někam dál přes vnc, to zamklo server pod rukama.        

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    24.8.2025 14:03 Wayland forever
    Rozbalit Rozbalit vše Re: vnc autolock
    Uživatelům waylandu se omlouvám
    Takze ten tvuj skript je pro 80% uzivatelu nahouby.
    24.8.2025 17:29 Bubak | skóre: 16 | blog: Čtvrtá cenová
    Rozbalit Rozbalit vše Re: vnc autolock
    Hm, a co radsi to udelat pri prihlaseni k vnc serveru? A co kdyz si spustim vzdalenou session s jinym X serverem (xdmcp)? A co kdyz si pustim na svuj X server jen urcitou aplikaci (a bude to zrovna nejaka, kvuli ktere bys chtel ostatnim zakazat pristup?
    ... máš jen mrtvou kočku a poškrábanýho jezevčíka ...
    24.8.2025 19:12 jejda | skóre: 27 | blog: jejda
    Rozbalit Rozbalit vše Re: vnc autolock
    Hm, a co radsi to udelat pri prihlaseni k vnc serveru?
    Však on ten skript prakticky nic nedělá až dokud se vzdáleně nepřihlásíš. Já jsem to původní zadání pochopil tak, že uživatel má nějakou rozdělanou práci na PC1 ale z nějakého důvodu se musí fyzicky přesunout na PC2 a chce v rozdělané práci pokračovat vzdáleně přes vnc. Nechce u toho žádné diváky nebo nedejbože aby mu nějaký nenechavec mačkal klávesy a táhal myš.
    A co kdyz si spustim vzdalenou session s jinym X serverem (xdmcp)? A co kdyz si pustim na svuj X server jen urcitou aplikaci (a bude to zrovna nejaka, kvuli ktere bys chtel ostatnim zakazat pristup?
    V takových případech by bylo asi potřeba to celé předělat. Není to žádné univerzální řešení pokrývající všecky myslitelné situace.
    24.8.2025 19:16 jejda | skóre: 27 | blog: jejda
    Rozbalit Rozbalit vše Re: vnc autolock
    Chtěl jsem akorát zkusit jestli vůbec jsou v linuxu možnosti pro to, aby uživatel vlastníma silama podobné funkcionality dosáhl, protože z diskuse pod tím dotazem v poradně jsem skoro začínal mít dojem, že to nejde. Taky mi nejde o to vytvořit nějaký super "produkt" který budou nadšeně používat masy. Já si s tím jenom tak ze zvědavosti hraju, ale třeba někdo řeší podobný problém a může to použít jako inspiraci pro nějaké svoje vlastní řešení. Hlavně proto jsem to sem dal.
    MakeIranBombedAgain❗ avatar 25.8.2025 11:35 MakeIranBombedAgain❗ | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: vnc autolock
    Uživatelům waylandu se omlouvám
    Takze ten tvuj skript je pro 80% uzivatelu nahouby.

    ttssss, budoucnost stejně patří xlibre, wayland je už teďko mrtvej :D ;D

    25.8.2025 12:27 wtf
    Rozbalit Rozbalit vše Re: vnc autolock
    To jako budoucnost patri zlodejum kodu? Co koukam ty repa https://yusi1.github.io/x11libre-website/download.html tak zatim nenapsali ani bajt noveho kodu jen forkli tu starozitnost kterou jiz nepouizva 82% telemetristu. Ani tolik namahy si nedali aby odevsad replacli "xorg" na "xf86". Btw blbej nazev, to armaci, riscasi a poweraci jse maji jit bodnout nebo co?
    MakeIranBombedAgain❗ avatar 25.8.2025 12:50 MakeIranBombedAgain❗ | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: vnc autolock
    zatim nenapsali ani bajt noveho kodu

    nešiř prorusTský dezinformace, ten projekt je hele celkem živej :D ;D

    Btw blbej nazev, to armaci, riscasi a poweraci jse maji jit bodnout nebo co?

    nejspiš to je vodkaz na xfree86 hele :O ;D

    25.8.2025 17:05 Editor
    Rozbalit Rozbalit vše Re: vnc autolock
    No podle commitu to vypada spise na one man show, neco jako woke forky Gimpu :)
    MakeIranBombedAgain❗ avatar 28.8.2025 16:06 MakeIranBombedAgain❗ | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: vnc autolock

    tady hele máš vobrovský množšství commitů který xorg nikdy nenechal zveřejnit ve stable verzi páč protěžuje ten svuj wayland. pokud všichni tydlecty lidi přejdou k xlibre který jim umožní narozdíl od xorg commitovat, možnáže navopak wayland zustane one traverzit show, viz ten jejich boj za diverzitu kuli kterýmu vykopli vajgla včetně jeho vic než tisicovky commitů :O ;D

    29.8.2025 21:16 Bubak | skóre: 16 | blog: Čtvrtá cenová
    Rozbalit Rozbalit vše Re: vnc autolock
    Hehe, jak te povazuju za priblblyho trolla, tak tohle mozna ma smysl :-D
    ... máš jen mrtvou kočku a poškrábanýho jezevčíka ...
    cbrpnk avatar 26.8.2025 12:53 cbrpnk | skóre: 10 | blog: bl0gium
    Rozbalit Rozbalit vše Re: vnc autolock
    #!/bin/sh
    # vnc autolock script — locks local console (video+input) while a VNC client is connected
    
    # --- safety / env ---
    set -eu
    
    # single-instance guard (best-effort)
    if [ "$(pgrep -fc "$(basename "$0")")" -gt 1 ]; then
      exit 0
    fi
    
    # Require X session
    if [ -z "${DISPLAY:-}" ]; then
      export DISPLAY=:0
    fi
    
    # Needed tools
    need() { command -v "$1" >/dev/null 2>&1; }
    for bin in xrandr xinput ss xset awk grep cut; do
      if ! need "$bin"; then
        echo "Missing dependency: $bin" >&2
        exit 1
      fi
    done
    
    # Collect connected video outputs once
    VIDEO_OUTS="$(xrandr | awk '/ connected/{print $1}')"
    
    # Collect non-virtual input device IDs once (store; we will toggle only these)
    INPUT_IDS="$(xinput --list --id-only 2>/dev/null | grep -vi 'virtual' || true)"
    
    STATUS="open"
    
    # Re-enable everything on exit
    unlock_all() {
      # turn on video outputs
      for o in $VIDEO_OUTS; do
        xrandr --output "$o" --auto || true
      done
      # enable input devices
      for id in $INPUT_IDS; do
        xinput enable "$id" 2>/dev/null || true
      done
      STATUS="open"
    }
    trap unlock_all EXIT INT TERM
    
    # Helper: is there any established TCP connection to ports 5900–5999?
    has_vnc_conn() {
      # Check local socket column for :59xx in ESTAB state
      ss -tan state established 2>/dev/null \
        | awk '{print $4}' \
        | grep -Eq ':[5]9[0-9]{2}$'
    }
    
    # Helper: current framebuffer size (mode with asterisk)
    current_fb() {
      # pick the first mode marked with '*'
      xrandr | awk '/\*/{print $1; exit}'
    }
    
    # Main loop
    while sleep 5; do
      if has_vnc_conn; then
        if [ "$STATUS" != "locked" ]; then
          FB_SIZE="$(current_fb || true)"
          # Turn off all connected outputs (keep fb consistent if we know size)
          if [ -n "${FB_SIZE:-}" ]; then
            for o in $VIDEO_OUTS; do
              xrandr --fb "$FB_SIZE" --output "$o" --off || true
            done
          else
            for o in $VIDEO_OUTS; do
              xrandr --output "$o" --off || true
            done
          fi
          # Disable inputs we selected
          for id in $INPUT_IDS; do
            xinput disable "$id" 2>/dev/null || true
          done
          STATUS="locked"
          # Optionally force screensaver immediately
          xset s activate || true
        fi
      else
        if [ "$STATUS" != "open" ]; then
          # Turn on all connected outputs
          for o in $VIDEO_OUTS; do
            xrandr --output "$o" --auto || true
          done
          # Re-enable input devices
          for id in $INPUT_IDS; do
            xinput enable "$id" 2>/dev/null || true
          done
          STATUS="open"
          # Nudge screensaver (turn off if running)
          xset s reset || true
        fi
      fi
      # Uncomment for debug:
      # printf '%s %s\n' "$(date +%T)" "$STATUS"
    done
    
    
    26.8.2025 14:10 H4x0ר
    Rozbalit Rozbalit vše Re: vnc autolock
    A co zabrani nekomu jinemu spustit ty prikazy v unlock_all pres lokalni konzoli nebo ssh?
    26.8.2025 16:28 jejda | skóre: 27 | blog: jejda
    Rozbalit Rozbalit vše Re: vnc autolock
    Já ti nevím. To vypadá jak nějaký AI výplod. Třeba ten řádek:
    INPUT_IDS="$(xinput --list --id-only 2>/dev/null | grep -vi 'virtual' || true)"
    to ti vyplivne ID všech zařízení včetně těch virtuálních ten grep a true tam nemají žádný smysl. Nebo ten
    VIDEO_OUTS="$(xrandr | awk '/ connected/{print $1}')"
    když necháš před tím connected mezeru tak ti to do proměnné uloží jenom aktivní video výstupy. Stačí potom přepojit monitor do jinačího výstupu a hned vidíš co se dějě na obrazovce. Taky moc nechápu, naco je tam skoro za každým druhým příkazem to
    || true
    tá smyčka for se nějak přeruší pokud nějaký příkaz uvnitř vrátí false neboco? Zkoušels to vůbec spustit? Já jo a nezamyká to nic.
    MakeIranBombedAgain❗ avatar 28.8.2025 15:56 MakeIranBombedAgain❗ | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: vnc autolock
    To vypadá jak nějaký AI výplod

    imo to bude ta chrpnikova llama :D ;D

    xkucf03 avatar 27.8.2025 23:34 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: vnc autolock
    Úplně pro to nemám využití, protože servery spravuji přes SSH a kdybych tam dával VNC, tak s Xvfb (tzn. bez fyzických klávesnic, myší a monitorů). Ale jinak díky za článek – to vypínání a zapínání vstupů by se někde hodit mohlo (běžně používám jen zhasnutí monitoru přes xset dpms force off).
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    28.8.2025 12:17 jejda | skóre: 27 | blog: jejda
    Rozbalit Rozbalit vše Re: vnc autolock
    Ten xvfb je super vychytávka no matně si vzpomínám, že jsem se mi kdysi jakýsi počítač odmítal spustit když neměl zapojenou grafickou kartu a klávesnici. Jenom pípal BIOS.
    28.8.2025 13:56 pavele
    Rozbalit Rozbalit vše Re: vnc autolock
    Mě se odmítal spustit, když jsem měl zapojený, ale vypnutý monitor. Nakonec jsem to vyřešil hardwarově zapojením emulátoru monitoru - něco jako "ATEN DVI EDID emulátor".

    Založit nové vláknoNahoru

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