V neděli 17. května 2026 proběhne v Českých Budějovicích první MobileLinux Hackday zaměřený na Linux v mobilech, embedded platformy a open source hardware. Po sedmi úspěšných měsíčních setkáních v Praze se akce přesouvá také do jižních Čech, aby se komunita mobilního Linuxu mohla potkat i mimo hlavní město. Akce se uskuteční v konferenčním sále Vajgar v Clarion Congress Hotelu (Pražská tř. 2306/14) se zahájením mezi 14:00 až 15:00 a … více »
Vývojáři Debianu zhruba v polovině vývojového cyklu Debianu 14 s kódovým názvem Forky rozhodli, že Debian musí dodávat reprodukovatelné balíčky, tj. kdokoli si může nezávisle ověřit, že daný binární balíček vznikl překladem a sestavením z konkrétních zdrojových kódů. Aktuálně je reprodukovatelných 98,29 % balíčků.
Německý e-shop Škoda Auto byl hacknut. Útočníci získali přístup k uživatelským údajům (jméno, adresa, e-mail, heslo, telefon, …).
Na webu konference Den IPv6 2026, která se uskuteční 4. června v Národní technické knihovně v pražských Dejvicích, je nyní k dispozici kompletní program této tradiční akce věnované tématům spojeným s protokolem IPv6. Na celodenní pásmo přednášek je třeba se přihlásit a zaplatit účastnický poplatek 242 korun. Registrační formulář najdou zájemci opět na webu akce. Konferenci Den IPv6 2026 organizují i letos společně sdružení CESNET, CZ.NIC a NIX.CZ.
Byl představen emulátor terminálu Ratty (GitHub) s podporu 3D grafiky přímo v terminálu. Inspirací byl operační systém TempleOS od Terryho Davise. Ratty je napsán v jazyce Rust. Využívá knihovnu Ratatui pro tvorbu rozhraní a herní engine Bevy pro 3D vykreslování.
Evropské instituce i některé americké státy dál zpřísňují pravidla pro ověřování věku na internetu. Cílem je zabránit dětem v přístupu k obsahu pro dospělé. Úřady ale narážejí na zásadní problém – stále více lidí používá VPN, tedy služby umožňující skrýt identitu i skutečnou polohu na internetu. Právě VPN nyní Evropská parlamentní výzkumná služba (EPRS) označila za „mezeru v legislativě, kterou je potřeba uzavřít“ [Novinky.cz].
Multiplatformní open source aplikace pro psaní poznámek Joplin (Wikipedie) byla vydána v nové verzi 3.6. Nově lze mít v poznámkách embedovaný externí obsah, např. YouTube videa.
Open Hardware Summit 2026 organizovaný OSHWA (Open Source Hardware Association) proběhne o víkendu 23. a 24. května v Berlíně na Technické univerzitě Berlín.
Navigace se soukromím CoMaps postavena nad OpenStreetMap byla vydána v nové verzi 2026.05.06. Přibyla možnost aktualizovat mapy v aplikaci CoMaps, aniž by bylo nutné aktualizovat i verzi aplikace. CoMaps je komunitní fork aplikace Organic Maps.
OCCT3D (Open CASCADE Technology) Open Source 8.0 bylo vydáno. OCCT3D (Wikipedie, GitHub) je objektově orientovaná knihovna pro 3D CAD, CAM nebo CAE. Používá se například v softwarech FreeCAD a KiCad.
V minulém díle jsem popsal jak rozchodit xrdp a guacamole za pomoci několika "aptitude install" a chvilky konfigurace. Dnes si ukážeme jak se to dělá "the hard way".
Motivací ke kompilaci ze zdrojáků mi byla snaha rozchodit zvuk v Xrdp - podpora pro přesměrování zvuku je v Xrdp těžce experimentální a je potřeba sestavovat z gitu.
Nejdříve je potřeba nainstalovat závislosti:
aptitude build-dep xrdp aptitude install git vnc4server pkg-config
A kompilujeme:
git clone https://github.com/FreeRDP/xrdp.git cd xrdp # git checkout d90431a # mnou testovana verza ./bootstrap ./configure --prefix=/opt/xrdp make su make install
A ještě trocha poinstalačního tuningu:
useradd xrdp mkdir /var/run/xrdp chown xrdp:xrdp /var/run/xrdp chown -R xrdp /opt/xrdp/var/
ln -s /opt/xrdp/etc/init.d/xrdp /etc/init.d/ update-rc.d xrdp defaults
cd /opt/xrdp bin/xrdp-keygen xrdp etc/xrdp/rsakeys.ini chown xrdp /opt/xrdp/etc/xrdp/rsakeys.ini
service xrdp start
Teď můžeme otestovat připojení z klienta (např. xfreerdp adresa_serveru; pro přihlášení je potřeba vybrat "sesman-Xvnc" - doporučuji odstranit nepotřebné možnosti smazáním příslušných sekcí z /opt/xrdp/etc/xrdp/xrdp.ini), ale nečekejte že už bude chodit zvuk
.
K rozchození zvuku je ještě potřeba zkompilovat a nainstalovat speciálni sink pro PulseAudio. Pokud vás zajímá návod v originále, tak koukněte sem.
Začneme instalací pulseaudio a build závislostí
aptitude install pulseaudio pavucontrol aptitude build-dep pulseaudio
Nyní je potřeba stáhnout zdrojáky samotného PulseAudio (ne, -dev balíčky opravdu nestačí, protože .h soubory, které budou potřeba nejsou součástí stabilního API).
pulseaudio --version wget http://freedesktop.org/software/pulseaudio/releases/pulseaudio-2.0.tar.gz # 2.0 je verze v Debian Wheezy tar xfz pulseaudio-2.0.tar.gz cd pulseaudio-2.0 ./configure
Nyní můžeme zkompilovat xrdp pulseaudio sink
cd $ZdrojakyXRDP/sesman/chansrv/pulse/
V Makefile je potřeba upravit PULSE_DIR na cestu ke zdrojákům pulseaudio.
make # překopírujeme hotový modul do systemového adresáře s pulseaudio moduly cp module-xrdp-sink.so /usr/lib/pulse-2.0/modules/
A teď už stačí nakonfigurovat PulseAudio aby tento modul používalo.
Do /etc/pulse/default.pa přidáme řádek "load-module module-xrdp-sink" pod ".fail". Ukázkový /etc/pulse/default.pa pak může vypadat napřkílad takto:
.nofail .fail load-module module-augment-properties load-module module-xrdp-sink load-module module-native-protocol-unix
Také upravíme (resp. vytvoříme) /etc/asound.conf:
pcm.pulse {
type pulse
}
ctl.pulse {
type pulse
}
pcm.!default {
type pulse
}
ctl.!default {
type pulse
}
Vyresetujeme pulseaudio a pomocí "pavucontrol", případně "pacmd list-sinks", ověříme že se používá xrdp sink.
pulseaudio --kill pulseaudio --start pacmd list-sinks
Konečně můžeme zkusit Xrdp i s přesměrováním zvuku!
# pro jistotu ještě vyresetujeme xrdp service xrdp force-stop service xrdp start
Je potřeba si dát pozor a ověřit, že klient podporuje přesměrování zvuku (rdpsnd) a je správně nakonfigurován. V případě xfreerdp by mělo fungovat:
xfreerdp --plugin rdpsnd --data alsa -- adresa_serveru
případně
xfreerdp --plugin rdpsnd --data pulse -- adresa_serveru
V nových verzích ale už můžou být parametry jiné, takže rozhodně doporučuji kouknout se do dokumentace.
Guacamole podporuje přesměrování zvuku pro RDP od verze 0.7, takže bychom mohli jednoduše použít balíčky přímo od vývojářů Guacamole, ale když už máme ze zdrojáků Xrdp, tak si zkompilujeme i nejnovější guacamole (resp. guacamole-server (=guacd) ).
Jako vždy začneme instalací build závislostí:
aptitude build-dep libguac3 libguac-client-rdp0 libguac-client-vnc0 aptitude remove libguac3 libguac-dev # abychom zamezili pripadnym konfliktum! aptitude install libssh-dev
Stáhneme nejnovější zdrojáky, zkompilujeme a nainstalujme do /opt/guacamole:
wget http://downloads.sourceforge.net/project/guacamole/current/source/guacamole-server-0.8.2.tar.gz tar xf guacamole-server-0.8.2.tar.gz cd guacamole-server-0.8.2/ ./configure --prefix=/opt/guacamole --with-init-dir=/opt/guacamole/etc/init.d/ make make installVytvoříme symlinky pro freerdp moduly, které guacamole používá pro přesměrování zvuku. Cílový adresář (v mém případě /usr/lib/x86_64-linux-gnu/freerdp/) se bude lišit v závislosti na distribuci/architektuře (na Debianu/Ubuntu pomůže "dpkg -L libfreerdp-plugins-standard")
ln -s /opt/guacamole/lib/freerdp/* /usr/lib/x86_64-linux-gnu/freerdp/
Příjde mi zbytečné, aby guacd bežel pod rootem, takže ještě lehká poinstalační úprava:
useradd guacamole mkdir /opt/guacamole/run chown guacamole:guacamole /opt/guacamole/run
A následná úprava init scriptu:
getpid > /dev/null || $exec -p "$pidfile"na
getpid > /dev/null || sudo -u guacamole -- $exec -p "$pidfile"
Přidáme init skript do /etc/init.d a pustíme guacd:
ln -s /opt/guacamole/etc/init.d/guacd /etc/init.d update-rc.d guacd defaults service guacd startNyní ještě zbývá stáhnout a nakonfigurovat "Guacamole Web Application" (aka guacamole-client), což je jednoduchá webová aplikace napsaná v Javě, která sedí mezi guacd a web browserem. Narozdíl od minulého dílu, nepoužijeme overkill řešení v podobě tomcat, ale minimalistický Winstone (respektivě jeho fork udržovaný vývojáři Jenkins). V tomto případě ani nebudeme kompilovat, ale využijeme přenositelnosti Javy a stáhneme hotový .war soubor.
aptitude install libjenkins-winstone-java openjdk-6-jre mkdir /opt/guacweb cd /opt/guacweb wget http://downloads.sourceforge.net/project/guacamole/current/binary/guacamole-0.8.2.war
Nyní je na řadě samozřejmě konfigurace - výchozí konfiguráky je možné získat například z githubu a nebo z tarballu se zdrojákama (viz ukázka).
wget http://sourceforge.net/projects/guacamole/files/current/source/guacamole-client-0.8.2.tar.gz tar xfz guacamole-client-0.8.2.tar.gz mkdir etc cp guacamole-client-0.8.2/guacamole/doc/example/* etc/ rm -rf guacamole-client-0.8.2 guacamole-client-0.8.2.tar.gz
V guacamole.properties změníme hodnotu basic-user-mapping na /opt/guacweb/etc/user-mapping.xml.
Samotný user-mapping.xml upravíme podle potřeby - to XML je celkem jednoduché a jednoznačné (dokumentace v originále). Například:
<user-mapping>
<authorize username="luv" password="abclinuxu">
<protocol>rdp</protocol>
<param name="hostname">localhost</param>
<param name="port">3389</param>
</authorize>
</user-mapping>
Teď už stačí pustit winstone (opět, je zbytečné aby bežel jako root). Osobně jsem se tady neobtěžoval s init skriptem, ale prostě přidal ten druhý řádek do /etc/rc.local.
useradd guacweb nohup sudo -u guacweb GUACAMOLE_HOME="/opt/guacweb/etc/" -- java -jar /usr/share/java/jenkins-winstone.jar --warfile=/opt/guacweb/guacamole-0.8.2.war --httpPort=8080 --ajp13Port=-1 &
Nyní už konečně můžeme vítězoslavně v prohlížeči otevřít "http://adresa_serveru:8080" a doufat, že bude fungovat i zvuk
. Mě zvuk fungoval správně bohužel pouze v Chromium (resp Chrome).
Závěrem bych ještě velice doporučil přidat před winstone reverzní proxy (lighttpd funguje skvěle) a povolil připojení pouze přes HTTPS a také změnil heslo v user-mapping.xml na md5 hash - obojí jsem popsal na konci minulého dílu (winstone bude poslouchat pouze na localhostu pokud mu dáte parametr --httpListenAddress=127.0.0.1).
Tiskni
Sdílej:
. Vzponinam si ze jsem cetl ze se rad aktivne podilis na vyvoji open-source, celkem by me zajimalo na cem ted delas.