Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.
Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.
Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).
Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.
Google Chrome 146 byl prohlášen za stabilní. Nejnovější stabilní verze 146.0.7680.71 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 29 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
D7VK byl vydán ve verzi 1.5. Jedná se o fork DXVK implementující překlad volání Direct3D 3 (novinka), 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.
Bylo vydáno Eclipse IDE 2026-03 aneb Eclipse 4.39. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.
Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.
Meta převezme sociální síť pro umělou inteligenci (AI) Moltbook. Tvůrci Moltbooku – Matt Schlicht a Ben Parr – se díky dohodě stanou součástí Meta Superintelligence Labs (MSL). Meta MSL založila s cílem sjednotit své aktivity na poli AI a vyvinout takovou umělou inteligenci, která překoná lidské schopnosti v mnoha oblastech. Fungovat by měla ne jako centralizovaný nástroj, ale jako osobní asistent pro každého uživatele.
Pěkný den (noc),
řeším triviální problém - potřebuji mít možnost voláním programu zjišťovat, zda je v mém mailboxu nový mail. Nic víc. Čekal jsem, že to vyřeším raz dva, a ejhle... biff, xbiff ani newmail mi nevyhovují, chovají se moc "po svém". Já potřebuju jenom zjistit návratovou hodnotu a podle ní vytisknout v promptu něco jako "NEPŘEČTENÝ MAIL". Je to oříšek, nechce se mi cyklem ověřovat časovou známku či velikost mailboxu. comsat je strašně špatně dokumentovaný. Je tu nějaké čisté, prosté řešení, které jsem přehlédnul? Děkuji
#!/usr/bin/env python
import poplib, time, getpass, sys
user = "username"
pop3server = "pop3.seznam.cz"
password = getpass.unix_getpass("Password for "+user+"@"+pop3server+":");
messages_prev = 0
while(1):
try:
M = poplib.POP3(pop3server)
M.user(user)
M.pass_(password)
except poplib.error_proto, detail:
print "Error occured", sys.exc_info()[0], detail
continue
res = M.stat()
messages = res[0]
M.quit()
if (messages != messages_prev):
print time.strftime("%H:%M:%S %d.%m.%Y"),": ", messages, "Messages\a"
messages_prev = messages
time.sleep(120)
a něco podobného se dá udělat i pro IMAP, na což jsem dělal applet: checknewmail.sh #!/bin/sh mtime=`stat -c%Y \$MAIL` atime=`stat -c%X \$MAIL` exit `test $atime -lt $mtime`A potom někde použít:
checknewmail.sh && echo "Máte nový mail"
Nebo si skript může pamatovat, kdy naposledy se díval, jestli je nový mail, a tento čas pak porovnat s nejnovějším mailem. Nevýhoda - zpráva o novém mailu se pokaždé zobrazí jen jednou.
#!/usr/bin/python
from pyinotify import WatchManager, Notifier, EventsCodes, ProcessEvent
import sys, pwd, os, posix
username = pwd.getpwuid(posix.getuid()).pw_name
path = os.path.join('/var/mail', username)
mask = EventsCodes.IN_MODIFY | EventsCodes.IN_CLOSE_WRITE
class mailPE(ProcessEvent):
def __init__(self):
self.was_modified = False
self.was_closed = False
def process_IN_CLOSE_WRITE(self, event):
self.was_closed = True
def process_IN_MODIFY(self, event):
self.was_modified = True
wm = WatchManager()
mbox = mailPE()
notifier = Notifier(wm, mbox)
wm.add_watch(path, mask)
while True:
notifier.read_events()
notifier.process_events()
if mbox.was_closed and mbox.was_modified:
break
Není nutné periodicky zjišťovat změnu něčeho, když tu máme takovou jadernou vymoženost. Proces celou dobu spí, ale přitom je schopen reagovat okamžitě.
Tiskni
Sdílej: