mg_web for M and ObjectScript developers

57 views
Skip to first unread message

rtweed

unread,
May 2, 2024, 9:44:29 AMMay 2
to Hardhats

A few weeks ago I posted on various other groups an announcement about a JavaScript-based interface for our mg_web WebServer interfacing addon module.  mg_web isn't just restricted to use by JavaScript developers though.  Probably most Hardhats readers are M or ObjectScript developers, more used to using, eg CSP as their Cache or IRIS web gateway, or some other gateway (eg mgwsi) or perhaps a basic native M-based Web Server for YottaDB.  Some may even have much older legacy WebLink-based applications (and be wondering how to support them given that IRIS does not support WebLink).

This article aims to provide some more information on mg_web and to explain why it's worth a look.

The first thing to understand is that mg_web has been deliberately designed as a completely generic and adaptable interface module for the "big three" web servers (NGINX, Apache and IIS).  mg_web supports both HTTP version 1.1 and 2.0 and WebSockets.  The idea is that the core mg_web add-on module communicates, using its own low-level protocol, with a compatible server.

The JavaScript version of mg_web works by mg_web communicating with one such server script written in JavaScript (known as mg_web_js).

However, another of mg_web's included server options creates a connection directly between the Web Server and one or more YottaDB, IRIS and/or Cache servers. When used with this server interface, you can develop your request handling code in ObjectScript or M, and if you're using Cache or IRIS, you'll have access to Classes, SQL and all the other built-in ObjectScript functionality.  YottaDB, IRIS or Cache can be interfaced either via a network connection or an extremely high-performance in-process API connection, and you can optionally configure multiple servers for failover and/or load balancing.

By using different shims and configuration settings with the direct YottaDB/IRIS/Cache server mode, mg_web can be made to behave in pretty much any way you want.

For example, we've created a shim for use with the direct IRIS/Cache server connection that allows mg_web to emulate the behaviour of the original WebLink web gateway, therefore allowing legacy WebLink applications (including EWD applications) to be ported to IRIS (I haven't tried it but in theory you could probably also port legacy WebLink applications to YottaDB!).

Another interface we've created using mg_web is mgweb-server which is a simple framework that allows you to quickly and easily create ObjectScript-based REST API services that will run on either YottaDB, IRIS and/or Cache. 

You can try mg_web working with mgweb_server out for yourself as we've included ready-to-run examples in our mg-showcase Docker Containers for YottaDB and IRIS.  In particular check out the performance!!

If you're interested in finding out more, we've summarised what we believe to be the benefits of mg_web for ObjectScript and M developers here, and you can read the relevant documentation in the mg-showcase and mg_web repositories.

The configurations and emulations we've provided for mg_web are just some examples we've created of what's possible.  For example, mg_web should be an ideal technology for modern, M-based web enablement of VistA code, leveraging the big-three industry-standard Web Servers.  


Contact Rob or Chris at MGateway if you need more guidance or support.


Reply all
Reply to author
Forward
0 new messages