Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.
Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.
Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.
Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.
Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.
Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.
Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.
Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.
GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.
Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.
Předevčírem jsem dostal náladu napsat si bota pro přístup do jabber chat roomu. Moc českých návodů pro python-jabber jsem nenašel a ono ani anglických, takže jsem nastudoval zdrojáky, přiložených příkladů a zkusím interpretovat co jsem se naučil.
Jabber je protokol pro IM komunikaci. Otevřenost je v tomto ohledu jeho obrovskou výhodou. Krom toho že si můžete napsat taky svého bota, můžete udělat i věci jako monitor nějakého svého serveru, který vám pošle zprávu, když se něco stane. Tady možnosti nekončí, ale mě zrovna nic jiného nenapadá :) Pokud jste o jabberu neslyšeli tak hup na jabber.cz a prostudovat wiki.
Nás bude ovšem zajímat samotný protokol a to ještě pouze knihovna python-jabber. Díky ní toho o protokolu zas tolik vědět nemusíme a s jabber serverem se dá krásně komunikovat. Něco ovšem vědět musíme. Začal bych tím, že jabber komunikuje v XML formátu. Využívá tři druhy zpráv a těmi jsou message, presence a iq. Message odesílá všechno co nevyžaduje odpověď. To jsou právě naše zprávy co si se všemi píšeme a asi to bude jediné co nás bude zajímat. Presence odesílá informace o stavu a iq jsou všechny zprávy vyžadující odpověď od serveru. Bližší vysvětlení najdete na root.cz, kde je seriál o kompletním protokolu.
Než začneme se samotným programem, tak si na najakém serveru vytvoříme účet pod kterým se náš program bude připojovat. Dále pak budeme potřebovat knihovnu python-jabber (takhle se označuje v mém Kubuntu, jinde bude mít obdobný název).
import jabber,sys
c = jabber.Client(host="jabber.cz") #tady vytvoříme instanci třídy Client
#zkusíme se připojit
try:
c.connect()
except:
print "Chyba při připojení."
sys.exit()
#autorizujeme se se svým jménem a heslem, poslední parametr označuje klienta
c.auth("Jmeno","Heslo","MujKlient")
#tahle metoda není v manuálu, ale registruje objekt, který má zpracovávat naše zprávy
c.registerHandler('presence',presenceCB)
c.registerHandler('message',messageCB)
c.registerHandler('iq',iqCB)
#tímhle vyžádáme roster (kontakt list)
c.requestRoster()
#tímhle pošleme initializační Presence zprávy
c.sendInitPresence()
Myslím, že uvedený kód je dobře okomentován, ale měl bych vysvětlit blíže metodu registerHandler(). Tato metoda registruje objekt (to může být metoda nebo fce), který se postárá o příchozí zprávy. Tento objekt je volán vždy s určitými parametry a všechny tři by mohli vypadat nějak takto:
def messageCB(con, msg): print msg.getFrom()+" - "+msg.getBody() def presenceCB(con, prs): pass def iqCB(con, iq): pass
Takže toto jsou ty tři fce co jsme registrovali výše. První se stará o příchozí zprávy a vypíše je na výstup. Pro další dvě jsem nenašel zatím uplatnění, tak tam nechávám pass. Parametry jsou vždy objekt jabber.Client a objekt jabber.Message, jabber.Presence nebo jabber.Iq podle druhu zprávy.
Zprávy si určitě zpracujete podle svého, ale to hlavní co musíme udělat, je vytvořit smyčku ve které se ty zprávy budou příjímat.
while 1: inputs, outputs, errors = select([sys.stdin], [], [],1) if sys.stdin in inputs: c.disconnect() sys.exit() else: c.process(1)
Tento kousek kódu je vzat z jednoho příkladu, který se dodává k python-jabber. Princip je jednoduchý, v nekonečně smyčce se čte pořád dokola jestli není něco na vstupu. Pokud je tak se program ukončí a pokud není tak se čtou zprávy. Rozšíření si každý udělá sám.
Nakonec se ještě zmíním o odesílání zpráv. Není na tom opět nic těžkého, využijeme objekt jabber.Message.
m = jabber.Message("ucet@jabber.cz","Ahoj světe")#vytvoříme zprávu
m.setType("chat")#nastavíme typ jako chat, můžeme použít i groupchat pokud jsme v místnosti (nebo jiný typ, najdeme je v dokumentaci)
c.send(m)#a odešleme
Tady bych doplnil, že pokud pracujeme v chat roomu, tak setType bude "groupchat". Příjemce zase jmeno_konference@konf.server.cz/nick (např. ubuntu@conf.jabber.cz/Cx).
Do roomu našeho bota příhlásíme či z něj odhlásíme následujícím způsobem.
c.send(jabber.Presence(to="jmeno_konference@konf.server.cz/NasNick"))#přihlásíme c.send(jabber.Presence(to="jmeno_konference@konf.server.cz/NasNick", type='unavailable'))#odhlásíme
To bude asi všechno, víc toho ani není potřeba a detaily si v manuálu už snad každý najde. Nakonec bych rád řek, že je důležité, že se s touto knihovnou dá na pár řádcích napsat program co se připojí k jabber serveru a je schopen s ním komunikovat a reagovat na něj. Na konci je uveden link na manuál, který je v ledasčem zastaralý, ale jinak dobrým pomocníkem. Hodně štěstí :)
Manuál k pythoní jabber knihovně
Tiskni
Sdílej: