Byly zpracovány a na YouTube zveřejněny videozáznamy z konference LinuxDays 2025.
Na konferenci LinuxDays 2025 byl oficiálně představen nový router Turris Omnia NG.
Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.
V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů
… více »Google Chrome 141 byl prohlášen za stabilní. Nejnovější stabilní verze 141.0.7390.54 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Za nejvážnější z nich (Heap buffer overflow in WebGPU) bylo vyplaceno 25 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.
eDoklady mají kvůli vysoké zátěži technické potíže. Ministerstvo vnitra doporučuje vzít si sebou klasický občanský průkaz nebo pas.
Novým prezidentem Free Software Foundation (FSF) se stal Ian Kelling.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za září (YouTube).
Vyšla kniha Počítačové programy a autorské právo. Podle internetových stránek nakladatelství je v knize "Významný prostor věnován otevřenému a svobodnému softwaru, jeho licencím, důsledkům jejich porušení a rizikům „nakažení“ proprietárního kódu režimem open source."
Red Hat řeší bezpečnostní incident, při kterém došlo k neoprávněnému přístupu do GitLab instance používané svým konzultačním týmem.
#!/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" doneChtě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.
Tiskni
Sdílej:
Uživatelům waylandu se omlouvámTakze ten tvuj skript je pro 80% uzivatelu nahouby.
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.
Uživatelům waylandu se omlouvámTakze ten tvuj skript je pro 80% uzivatelu nahouby.
ttssss, budoucnost stejně patří xlibre, wayland je už teďko mrtvej :D ;D
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
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
#!/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
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
|| truetá 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.
To vypadá jak nějaký AI výplod
imo to bude ta chrpnikova llama :D ;D
xset dpms force off
).