CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.
Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].
Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.
Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.
Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.
Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.
Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.
Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.
Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.
Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …
Ale tipnul bych si na adresář /var/log
To ostatní jsou jen takové vaše plky, takže no comment ... snad jen
http://www.abclinuxu.cz/forum/show/78150
#!/bin/env python
import os
handler = os.popen('rpm -qa', 'r')
packages = handler.readlines()
packages.sort()
handler.close()
cmd = 'rpm -e %s --test 2> /dev/null'
for package in packages:
package=package.strip()
if os.system(cmd%package) == 0:
print package
#!/usr/bin/env python
import rpm
timeflag = rpm.RPMTAG_INSTALLTIME
class packages:
def __init__(self):
print "Fetching packages from database"
ts = rpm.TransactionSet()
mi = ts.dbMatch()
self.pckgs = list(mi)
print "done. %d items found" %len(self.pckgs)
def wholename(self, pkg_obj):
return "%s-%s-%s.%s" % (pkg_obj['name'],
pkg_obj['version'],
pkg_obj['release'],
pkg_obj['arch'])
def orphans_only(self):
print 'Searching orphans'
orphans = []
req_lookup = {}
for h in self.pckgs:
for r in h[rpm.RPMTAG_REQUIRENAME]:
req_lookup[r] = h
for h in self.pckgs:
is_orphan = True
for prov in h[rpm.RPMTAG_PROVIDES] + h[rpm.RPMTAG_FILENAMES]:
try:
whowants = req_lookup[prov]
if h is not whowants: #does not want itself
is_orphan = False
break
except KeyError:
pass
if is_orphan: orphans.append(h)
self.pckgs = orphans
print "done. %d orphans found." %len(self.pckgs)
def sort_key(self, keyname):
def compare(a, b):
return cmp(a[keyname], b[keyname])
self.pckgs.sort(cmp = compare)
def show(self):
print "Printing names of %d packages:" %len(self.pckgs)
for h in self.pckgs:
print self.wholename(h)
if __name__ == '__main__':
rpms = packages()
rpms.orphans_only()
rpms.sort_key(timeflag)
rpms.show()
Vyhledá to všechny balíčky, na kterých nic nezávisí (kromě sebe sama). Balíčky to setřídí podle data instalace, přičemž poslední vypsaný je nejnovější. Formát výpisu obsahuje i verzi a architekturu, takže i na 64bitu lze název vzít do myši a předat příkazu
rpm -eaniž by to psalo "specifies multiple packages".
def show(self):
print "Printing names of %d packages:" %len(self.pckgs)
for h in self.pckgs:
print '%8d %s' %(h[rpm.RPMTAG_SIZE], self.wholename(h))
if __name__ == '__main__':
rpms = packages()
rpms.orphans_only()
rpms.sort_key(rpm.RPMTAG_SIZE)
rpms.show()
Tak to vypíše odinstalovatelné balíčky setříděné podle velikosti. Hned je vidět, kterého žrouta lze rovnou odstranit.
/var/log/yum.log.
Tiskni
Sdílej: