Upgrade von Klay auf Elk.js

08.02.2020

Vor einiger Zeit berichtete ich darüber, wie ich versucht hatte, die Komponente, auf der unter anderem die sQLshell und dWb+ beruhen um eine Möglichkeit erweitern, die Module und Tabellen automatisch bestmöglich anzuordnen.

Da die Komponente, die ich dazu benutzt hatte nicht mehr aktiv weiterentwickelt wird, versuchte ich den Nachfolger - den Eclipse Layout Kernel (ELK) dazu zu nutzen.

Ich wollte dazu dasselbe Vorgehen adaptieren, das schon für die auf Klay basierende zum Einsatz kam: Die Javascript-Bibliothek wird mit ein wenig Wrapper-Code in eine HTML-Seite eingebunden und diese wiederum der JavaFX-Komponente zum Anzeigen von Webseiten übergeben. Das Layout wird in die von der Bibliothek erwartete JSON-Format gewandelt und damit eine Javascript-Funktion der HTML-Seite aufgerufen. Das Ergebnis wird dann zurückgegeben.

Leider funktioniert das mit der neuen Bibliothek nicht mehr so: die Implementierung nasiert jetzt auf Promises, was dazu führt, dass der Interpreter der JavaFX-Komponente die Abarbeitung abbricht, wenn er am Ende der Javascript-Funktion angekommen ist - auch wenn noch Promises existieren, die nicht beendet wurden. Damit kann auf das Ergebnis nicht mehr zugegriffen werden.

Ich habe keine Möglichkeit gefunden, diesen Mechanismus auszutricksen und die Javascript-Bibliothek stellt keine synchrone Alternative zu der auf Promises beruhenden zur Verfügung.

Also ließ ich mich ablenken und überlegte, ob man nicht statt dessen einfach einen MicroService bauen könnte, der die Definition des graphen als JSON entgegennimmt, ein passendes Layout erstellt und dieses als JSON wieder zurückgibt.

Nach meinen Erfahrungen mit Java und Python war das nicht mehr sehr schwer - zumal ich hervorragende Anleitungen fand: Daraus entstand ein entsprechendes Projekt auf Github, welches einen passenden Docker-Container erstellt, den man auf Wunsch mit docker-compose auch sofort starten kann. Auch die Integration mit Traefik ist bereits vorbereitet.

Artikel, die hierher verlinken

Linux-System SBOM visualisiert als Graph

12.10.2024

In meinem $dayjob kam neulich die Frage auf, ob es möglich wäre, die aktuelle Softwareinstallation eines Linux-Systems als Software Bill of Materials (SBOM) zu exportieren.

Alle Artikel rss Wochenübersicht Monatsübersicht Codeberg Repositories Mastodon Über mich home xmpp


Vor 5 Jahren hier im Blog

  • Links - Verschiedenes

    03.11.2020

    Hier einmal einige Links, die einfach in keine Kategorie passen...

    Weiterlesen

Neueste Artikel

  • Immich, Karakeep und Radicale neu im Docker-Zoo

    Ich habe längere Zeit keine Erweiterung meines Docker-Zoos vorgenommen - auch weil ich mir einige konzeptionelle Gedanken dazu gemacht habe. Aber ich habe auch Ideen gesammelt, was in meinem @homelab noch fehlt und was dringend ergänzt werden sollte.

    Weiterlesen
  • Thin Client als Notfall-NAS?

    Eine Diskussion brachte mich neulich auf eine Idee - und im Urlaub hatte ich an einem regnerischen Tag genug Zeit, die entsprechenden Experimente zu machen...

    Weiterlesen
  • Cloud - das unentdeckte Neuland (oder FDP: Digital first, Bedenken second)...

    Nachdem die Öffentlichkeit letzte Woche wieder mal mitgekriegt haben sollte, dass die Konzentration in der Cloud Schwachsinn ist und - vielleicht nicht - die ganze Öffentlichkeit vor zwei Wochen wieder einmal herzlich gelacht hat über die, die dennoch alles in die Cloud auslagern, aber offensichtlich nicht verstehen, wie sie funktioniert - hier einige Gedanken von mir dazu...

    Weiterlesen

Manche nennen es Blog, manche Web-Seite - ich schreibe hier hin und wieder über meine Erlebnisse, Rückschläge und Erleuchtungen bei meinen Hobbies.

Wer daran teilhaben und eventuell sogar davon profitieren möchte, muss damit leben, daß ich hin und wieder kleine Ausflüge in Bereiche mache, die nichts mit IT, Administration oder Softwareentwicklung zu tun haben.

Ich wünsche allen Lesern viel Spaß und hin und wieder einen kleinen AHA!-Effekt...

PS: Meine öffentlichen Codeberg-Repositories findet man hier.