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.
/proc/self/exe
ukazuje na aktuální binárku...
#include <limits.h> #include <stdio.h> #include <string.h> #include <unistd.h> /* Finds the path containing the currently running program executable. The path is placed into BUFFER, which is of length LEN. Returns the number of characters in the path, or -1 on error. */ size_t get_executable_path (char* buffer, size_t len) { char* path_end; /* Read the target of /proc/self/exe. */ if (readlink ("/proc/self/exe", buffer, len) <= 0) return -1; /* Find the last occurrence of a forward slash, the path separator. */ path_end = strrchr (buffer, '/'); if (path_end == NULL) return -1; /* Advance to the character past the last slash. */ ++path_end; /* Obtain the directory containing the program by truncating the path after the last slash. */ *path_end = '\0'; /* The length of the path is the number of characters up through the last slash. */ return (size_t) (path_end - buffer); } int main () { char path[PATH_MAX]; get_executable_path (path, sizeof (path)); printf ("this program is in the directory %s\n", path); return 0; }
strrchr
na bufferu hned po readlink
? Mě se to nezdá:
readlink() does not append a null byte to buf.
int main(int argc, char* argv[]) { printf("%s\n", argv[0]) return 0; }
#include <libgen.h> int main(int argc, char* argv[]) { printf("%s\n", dirname(argv[0])) return 0; }argv[0] mi připadá mnohem portabilnější než /proc (který třeba nemusí být ani na všech Linuxových instalacích, o jiných unix-like OS či win/dos ani nemluvě).
#include <stdio.h> int main(int argc,char** argv) { int i; for(i=0;i<argc;i++) printf("ARG %d: %s\n", i, argv[i]); return 0; }
lubos@ares ~ $ ./test ARG 0: ./testTomu říkáte absolutní cesta?
$0
na funkční cestu k němu.
/proc/self/exe
.
Navíc je potřeba mít na paměti, že na otázku "ve kterém adresáři se nachází tento soubor" nemusí být jednoznačná odpověď nebo dokonce může odpověď znít "v žádném"…
PATH
, jen jménem, bude v argv[0]
jen to jméno.
Tiskni
Sdílej: