Ich musste neulich mein Projekt plantumlinterfaceproxy aktualisieren
Als ich mit den Planungen für das neue Feature der sQLshell begann, das es erlauben sollte die Syntax von Prepared Statements im SQL-Editor zu benutzen wälzte ich zuvor einige Ideen zur Umsetzung.
Eine war, mittels des in der sQLshell verbauten SQL-Parsers die Stellen der Platzhalter für Parameter zu ermitteln und darauf aufbauend entsprechende Formulare zu erstellen, die der Anwender für die Definition der Parameterwerte benutzen können sollte.
Ich entschied mich letztlich gegen diese Idee der Umsetzung, entdeckte aber dadurch etwas für mich interessantes und Nützliches: Ich versuchte, einen regulären Ausdruck zu erstellen, der die Parameter in einem SQL-Statement findet. Diese sind dort durch Fragezeichen markiert. Natürlich durfte dieser reguläre Ausdruck keine Fragezeichen finden, die zu einem Stringliteral gehören und daher innerhalb von Anführungszeichen stehen.
Ich entdeckte relativ schnell einen passenden regulären Ausdruck im Internet: (str)(?=(?:[^'"]|["'][^'"]*["'])*$) - man kann diesen zum Beispiel hier ausprobieren.
Ich hatte mit dem Projekt plantumlproxy ja unter anderem eine Gitlab-Integration zur Darstellung von regulären Ausdrücken mittels Rails-Diagrammen geschaffen - so würde der oben angegebene Ausdruck etwa folgendes Diagramm ergeben:
Beispiel für ein Rails-Diagramm für einen regulären Ausdruck
Ich stellte jedoch fest, dass das von mir eingesetzte Projekt regexper nicht mit lookbehind umgehen konnte.
Als ich daraufhin die Issues des Projektes nach einem Tipp durchforstete fand ich eines, das dasselbe Problem ansprach und in diesem Issue fand ich einen Verweis auf einen Fork des Projektes, das auch diese Elemente verdauen konnte.
Daraufhin passte ich mein Projekt entsprechend an und nutze ebenfalls den Fork.
08.06.2024
Es gibt eine neue Version des Projektes plantumlinterfaceproxy - Codename napkin look.
Alarmierung über Skripte
16.09.2019
Nachdem ich mich in letzter Zeit wieder verstärkt mit den Themen Monitoring und Alarmierung auseinandersetze, habe ich überlegt, ob ich die dabei gewonnenen Erkenntnisse nicht auch dazu nutzen könnte, die bestehende Lösung flexibler zu machen
Weiterlesen...Android Basteln C und C++ Chaos Datenbanken Docker dWb+ ESP Wifi Garten Geo Git(lab|hub) Go GUI Gui Hardware Java Jupyter Komponenten Links Linux Markdown Markup Music Numerik PKI-X.509-CA Python QBrowser Rants Raspi Revisited Security Software-Test sQLshell TeleGrafana Verschiedenes Video Virtualisierung Windows Upcoming...
Das Konzept eines CircuitBreaker ist schon lange bekannt. Ich habe mir zu Studienzwecken einen selber gebaut - eigentlich zwei: Einer ist dafür da, das Logging von gleichartigen Exceptions zu drosseln, der andere für das Entzerren von Versuchen, Ressourcen von URLs nachzuladen. Diese spezielle Variante benötigte ich für EBMap4D: Falls einer der Tile-Server ausfällt, wird ansonsten ständig versucht, die Kacheln neu herunterzuladen. Das frisst nicht nur Rechenzeit, sondern ist auch unnütz.
Weiterlesen...Nachdem ich mich nun schon so lange mit Origami beschäftige habe ich endlich einmal das älteste dokumentierte Ornament versucht - aus gutem Grund...
Weiterlesen...Eine neue Musikreihe/Show auf Youtube gefunden...
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, muß 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 GitHub-Repositories findet man hier - meine öffentlichen GitLab-Repositories finden sich dagegen hier.