Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.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.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
ARR=( "xxx" "xxxxxxxxxxxxxx" "xxx" "xxxxxxxxxxxxxx" "xxx" "xxxxxxxxxxxxxx" "xxx" "ssssssssssssss" "xxx" "xxxxxxxxxxxxxx" "xxx" "xxxxxxxxxxxxxx" )A potřebuji nahradit v tomto poli hodnotu ssssssssssssss za xxxxxxxxxxxxxx. Neporadil by někdo jak to provéct v bash/shell? Děkuji
#!/bin/bash ARR=( "xxx" "xxxxxxxxxxxxxx" "xxx" "xxxxxxxxxxxxxx" "xxx" "xxxxxxxxxxxxxx" "xxx" "ssssssssssssss" "xxx" "xxxxxxxxxxxxxx" "xxx" "xxxxxxxxxxxxxx" ) x="ssssssssssssss" len=${#ARR[@]} for (( i=0; i< len; i++ )) do if [ "${ARR[i]}" == "$x" ] then ARR[i]="kkk" echo ${ARR[i]} fi done
ARR=${ARR[@]/ssssssssssssss/xxxxxxxxxxxxxx}
ARR=("${ARR[@]/ssssssssssssss/xxxxxxxxxxxxxx}")
To nie je spravne riesenie, spravne je to nasledovne:
ARR=( "${ARR[@]/ssssssssssssss/xxxxxxxxxxxxxx
}" )
alebo pre viac ako prvy vyskyt daneho retazca sssssssssssss je to nasledovne:
ARR=( "${ARR[@]//ssssssssssssss/xxxxxxxxxxxxxx
}" )
To je dobra poznamka a popravde dost dolezita, kedze je aj mojim nazorom, ze nahradzujeme hodnoty jednotlivych clenov pola. Ale co som opravil riesenie vyssie, je stale len nahradzovanie retazcov, kedy nahradenie retazca sss retazcom xxx plati aj pre aaasss a taktiez aj pre aaasssbbbssssss a podobne.
Riesenim pre nahradzovanie hodnot clenov pola by mohlo byt aj nasledovne:
patrik@thinkpad:~$ echo "${pole[@]}" aaaccc bbb ccc dddcccddd ccc patrik@thinkpad:~$ once=0; value1='ccc'; value2='xxx'; num=0; for item in "${pole[@]}"; do [[ "$item" == "$value1" ]] && { pole[$num]="$value2"; [[ "$once" -eq 0 ]] && break; }; (( num++ )); done patrik@thinkpad:~$ echo "${pole[@]}" aaaccc bbb xxx dddcccddd ccc
for item in array
a udělám prostý for cyklus přes prvky toho pole indexované tím indexem jako je uvedeno v příspěvku č. 3 od j, připadá mi to i konzistentnější ve smyslu že nahrazuji s jistotou přesně to, co jsme před tím porovnal a našel shodu a tedy nahradit chtěl.
Tiskni
Sdílej: