Český úřad zeměměřický a katastrální zavedl u anonymního nahlížení do katastru nemovitostí novou CAPTCHA ve formě mapové puzzle: nepřihlášení uživatelé musí nově správně otočit devět dlaždic v 3x3 poli tak, aby dohromady daly souvislý obrázek výseče reálné mapy, přičemž na to mají pouze jeden časově omezený pokus. Test je podle uživatelů i odborníků příliš obtížný a na sociálních sítích pochopitelně schytává zaslouženou kritiku a
… více »Byla vydána verze 1.95.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Mozilla prostřednictvím své dceřiné společnosti MZLA Technologies Corporation představila open-source AI klienta Thunderbolt. Primárně je určený pro firemní nasazení.
Firma Cal.com oznámila, že přesouvá svůj produkční kód z otevřeného do uzavřeného repozitáře z důvodu bezpečnostního rizika umělé inteligence, která prý dokáže vyhledávat a zneužívat zranitelnosti rychleji, než by je jejich vývojářský tým stíhal opravovat. Zároveň zveřejnila samostatnou, open-source verzi Cal.diy pod licencí MIT, ovšem bez řady původních funkcí. O tom, zda je toto opatření rozumné, existují pochyby. … více »
Vývojáři KDE na Mastodonu oznámili vydání balíku aplikací KDE Gear 26.04. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Kryptografická knihovna OpenSSL byla vydána v nové verzi 4.0. Přehled změn v souboru CHANGES.md na GitHubu. Odstraněna byla podpora SSLv2 Client Hello a SSLv3. Ve výchozím nastavení byla zakázána podpora odmítnutých eliptických křivek v TLS dle RFC 8422. Přibyla například podpora Encrypted Client Hello (ECH, RFC 9849).
curl up 2026, tj. setkání vývojářů a uživatelů curlu, proběhne opět v Praze. O víkendu 23. a 24. května v Pracovně.
Aplikace pro ověřování věku uživatelů on-line platforem je technicky hotová a brzy bude k dispozici pro občany EU, oznámila dnes předsedkyně Evropské komise Ursula von der Leyenová. Půjde podle ní o bezplatné a snadno použitelné řešení, které pomůže chránit děti před škodlivým a nelegálním obsahem. Aplikace bude podle ní fungovat na jakémkoli zařízení a bude zcela anonymní.
V prosinci 2012 byla z linuxového jádra odstraněna podpora procesorů 386. Včera započalo odstraňování podpory procesorů 486.
IuRe (Iuridicum Remedium) vyhlásila Ceny Velkého bratra za rok 2025. Slídily roku jsou automobilka Volkswagen, Meta a česká Ministerstva vnitra a průmyslu a obchodu. Autorem Výroku Velkého bratra je dánský ministr spravedlnosti zpochybňující právo na šifrovanou komunikaci. Naopak Pozitivní cenu získali studenti Masarykovy univerzity za odpor proti nucení do používaní aplikace ISIC.
Ďakujem za komentáre a podnety ku minulému článku. Týmto ho skúsim ešte trochu doplniť.
Príkaz
ssh -D 12345 PC2
otvorí šifrované spojenie z PC0:12345 na PC2 a sshd na PC2 bude plniť úlohu SOCKS proxy. Ľubovoľná aplikácia na PC0 (alebo v sieti PC0, ak je port 12345 otvorený do siete), ktorá dokáže používať SOCKS proxy, získa prístup ku prostriedkom, ako keby bežala priamo na PC2.
Díky @jiwopene za tip!
ProxyCommand /bin/ncat --proxy-type socks5 --proxy socks_server:socks_port PC2 ssh_port2
prípadne, ak socks_server sprístupňuje viaceré stroje/viaceré porty, dá sa napísať univerzálne
ProxyCommand /bin/ncat --proxy-type socks5 --proxy socks_server:socks_port %h %p
(viď. TOKENS v man ssh_config).
Netcat binárka sa môže v niektorých distribúciách volať aj /bin/nc, treba pozrieť svoj systém.
ssh umožňuje zdieľať jeden tunel nielen pre viacero použití v rámci jedného príkazu (ako napr. viacero -L), ale aj v čase, pre viacero klientov. Toto zdieľanie môže riadiť programátor v skripte, alebo môže byť nastavené ako automatické.
Príklad, ako zapnúť automatické zdieľanie spojení v ~/.ssh/config:
Host *
ControlMaster auto
ControlPath ~/.ssh/control_%r@%h_%p
ControlPersist 1m
Príkazy, ako napr.
#!/bin/bash
scp skript{1,2}.sh PC2:./
ssh PC2 ./skript1.sh
ssh PC2 ./skript2.sh
sa potom všetky udejú v rámci jedného ssh spojenia.
Poznámka: Zdieľanie spojenia nefunguje v rámci Cygwin-u a z nejakých dôvodov sa mne nedalo kombinovať s X11 forwardingom. Keďže s X11 forwardingom som robil len pokusy a reálne som ho nepotreboval, hlbšiu príčinu som nezisťoval.
Skript beží na PC5, je spúšťaný pravidelne cez crontab a udržiava "živý" reverzný tunel, ktorý vyúsťuje na PC1. Ku prihlasovaniu na PC1 sa používa ssh kľúč bez hesla. Verejnú časť kľúča je nutné nahrať nielen do /home/user1/.ssh/authorized_keys na PC1 ale aj do /home/user5/.ssh/authorized_keys na PC5, kvôli overovaniu funkčnosti tunela. Voľba StrictHostKeyChecking accept-new uľahčuje prvé spustenie. Voľby ServerAlive... boli pridané vďaka námetu od @Jenda, díky!
Skript funguje vďaka mechanizmu zdieľania spojenia, tentokrát nie v automatickom režime, ako v minulej kapitole, ale "manuálne" riadenému: -M štartuje nový master, -O posiela riadiace príkazy masteru cez socket -S.
Spustenie skriptu s parametrom stop ukončí tunel a súčasne pozastaví proces jeho obnovovania (netreba editovať crontab). Parameter start tunel zase obnoví, rovnako, ako reštart PC5 (pri reštarte sa obvykle zmaže /tmp/.)
Poznámka: Riešenie s reverzným tunelom nesie zo sebou istú nepríjemnosť v podobe otravných pokusov o neautorizované pripojenie. PC1 o výsledku pripojovania klienta nič nevie, iba posiela nejaké dáta do tunela, takže nemôže takéto pokusy blokovať. Z pohľadu PC5 prichádzajú všetky spojenia z localhost-u, takže vie, ktoré prípady by sa mali blokovať, ale nevidí adresu. Jednoduché riešenie formou povedzme fail2ban sa nedá nasadiť. Ak máte niekto nápad, ako sa neautorizovaných pokusov zbaviť, podeľte sa, prosím, v diskusii. Vysoké číslo portu (54321) dnes už nepomáha. Ja som skeptický.
#!/bin/bash
MyPort=54321
TheServer='PC1'
TheServerSshPort=22
TheServerLogin='user1'
LocalSshPort=22
ControlPath="$HOME/.ssh/server_tunnel_control"
BlockPath='/tmp/server_tunnel_block'
Identity="$HOME/tunel_test/id_rsa_port_forward"
# Kluc musi byt ako v $Identity, tak aj v ~/.ssh/authorized_keys a to kvoli kontrole funkcnosti spojenia (function is_tunnel_working)!
self="$(readlink -mn "$0")"
function start_connection()
{
ssh -M -S "$ControlPath" -fnN -g -2 -4 \
-o 'StrictHostKeyChecking accept-new' \
-o 'ControlPersist yes' \
-o 'ExitOnForwardFailure yes' -o 'ServerAliveInterval 30' -o 'ServerAliveCountMax 3' \
-R "*:$MyPort:localhost:$LocalSshPort" \
-i "$Identity" \
-p "$TheServerSshPort" "$TheServerLogin"@"$TheServer" \
&& rm -f "$BlockPath"
}
function control()
{
cmd=$1
ssh -S "$ControlPath" \
-O "$cmd" \
-i "$Identity" \
-p "$TheServerSshPort" "$TheServerLogin"@"$TheServer"
}
function stop_connection()
{
touch "$BlockPath"
control exit >/dev/null
}
function ping_server()
{
ping -c 2 "$TheServer" >/dev/null
}
function is_tunnel_working()
{
# Tunel sa povazuje za funkcny, ak cez neho skript vidi sam seba.
ssh -o 'StrictHostKeyChecking accept-new' \
-i "$Identity" -p "$MyPort" "$USER"@"$TheServer" \
/bin/ls "$(dirname "$self")" \
| grep -cxF "$(basename "$self")"
}
###============================================================================
case "$1" in
"start") ## iba pre pripad startu po zablokovani
start_connection
E=$?
logger --stderr -t "[THESERVER_SSH]" "Port forwarding start ($E)"
;;
"stop") ## zablokovanie forwardu, aby ho cron neobnovoval
stop_connection
E=$?
logger --stderr -t "[THESERVER_SSH]" "Port forwarding stop ($E)"
;;
"restart")
stop_connection && start_connection
E=$?
logger --stderr -t "[THESERVER_SSH]" "Port forwarding restart ($E)"
;;
*) ## default - ak nie je zablokovany, forward ma fungovat
[ -f $BlockPath ] && exit 0
if ! ping_server ; then
>&2 echo "Cannot ping $TheServer. Internet off?"
exit 1
fi
if [ ! -e "$ControlPath" ] ; then
"$self" start
exit $?
fi
T="$(mktemp)"
control check >"$T" 2>&1
E=$?
if [ "$E" -ne 0 ] ; then
logger --stderr -t "[THESERVER_SSH]" "($E) $(cat "$T")"
rm "$T"
if [ "$E" -ne 255 ] ; then
"$self" start
exit $?
fi
else
rm "$T"
fi
# funguje naozaj?
C="$(is_tunnel_working)"
if [ -z "$C" -o "$C" -eq 0 ] ; then
"$self" restart
E=$?
else
E=0
fi
;;
esac
exit $E
Tiskni
Sdílej:
ssh -N -D3081 user@machine -p 22Nebo aby byl proxy dostupny z jakehokoli PC v lokalni siti:
ssh -N -D192.168.1.100:3081 user@machine -p 22Pro pouziti proxy treba k webovemu prohlizeci Chromium:
chromium --incognito --proxy-server="socks5://192.168.1.100:3081"