formax is a tool for developing and executing user
friedly, character based database applications with extreme
efficiency. It joins the concept of venerable Oracle Forms
with curses as the terminal interface, ODBC for universal
database access and JavaScript for the trigger language. The
result is the most efficient solution possible for the end
user. The applications can be build with minimal effort
using the nocode approach from Oracle Forms.
Click on the image for a non technical description:
formax accesses the database and generate a screen that presents the data. The source form (.inp in practice a sql-script to create a sqlite3 database) is compiled into a binary (.frm in practice a sqlite3 database) that is run by the runtime component. The form is used to view and edit data in a database driven manner. The environment supplies builtin record creation, query, delete and update modes, each with its own default data manipulations. This minimizes the need for program code. formax is a "Nocode RAD". A fully functional (CRUD) form for a table can build within two seconds.
The running form has an event driven interface and implements event handling functions called triggers which are automatically invoked at critical steps in the processing of records and the receipt of keyboard strokes. Different triggers may be called before, during, and after each critical step. Each event function is initially a stub, containing a default action or nothing. Programming therefore generally consists of modifying the contents of these triggers in order to alter the default behavior if necessary.
formax encorporates the concept of Oracle Forms with modern standards and current database best practices and technologies:
- single column autoincrement primary key
- integrity enforced through database
- JavaScript for client scripting
- regular expressions for validation
- freedom to choose the database provider
- multiple differnt databases simultaneously
- full logging of all queries
- no free SQL for the enduser
- no operating system exits in the engine
- 3FA security can be setup easily
Enterprise requirements are fully accomplished:
- Security
high standards for source code
minimized use of libraries
3FA included in runtime - Reliability
low complexity system
only two interfaces - Cost
no license costs
easy deployment - Operational excellence
simple, no hassle updates
full logging of user actions - Performance efficience
very low resource demands
for bandwidth, cpu and memory - Sustainability
completely open source
database independent
NEVER LOOSE SUPPORT AGAIN
formax has all important features to create real live forms. It has not matured enough to call it fully production ready and complex triggers maybe challenging. Create an issue when in trouble, have found a bug or a security problem or for a feature request. Dont hesitate to start using it. Together we will make it suit your needs.
Product security complies with current standards. The code is -Wall -Werror clean and send through valgrind, compiled with stack protection and uses almost no system interfaces. This aspect can be seen as production ready, particularly when the three factor authentication is used.
- 2.5 list of values - subforms
- 3.0 menue multiple forms
- 3.5 transaction processing
- cqy.y: 5 shift/reduce conflicts
- sap-like batchinput
You can play with an example form simply by connecting ssh to formax.toarx.de with user scott and password tiger. If you are using PuTTY you must set for the session:
Window->Translation->Remote character set = ISO-8859-15
Connection->Data->Terminal-type string = putty
Fork in github and create codespace or download and extract https://github.com/freakout42/formax/archive/refs/heads/main.zip
System preparation is needed to install the dependencies:
On codespace/debian/Ubuntu do the following:
sudo apt-get -y update
sudo apt-get -y install build-essential
sudo apt-get -y install python
sudo apt-get -y install unixodbc
sudo apt-get -y install libsqliteodbc
sudo apt-get -y install libncurses5-dev
sudo apt-get -y install flex
On RHEL/CentOS/Oracle/Alma/Rocky do the following:
sudo yum -y update
sudo yum -y group install "Development Tools"
sudo yum -y install python3
sudo yum -y install unixODBC
sudo yum -y install unixODBC-devel
sudo yum -y install ncurses-devel
sudo yum -y install sqlite
rpm -i https://github.com/freakout42/formax/releases/download/v0.9.9/sqliteodbc-0.9998-1.x86_64.rpm
Then do the following to build and install formax into
/opt/arx/
. Nothing outside /opt/arx/
will be touched in
any way by the installation with the exception of
/etc/profile.d/arx.sh
which only adds /opt/arx/bin
to
the PATH.
./configure
make
sudo make install
. /etc/profile.d/arx.sh
Alternatively there is a rpm-file to install: rpm -i https://github.com/freakout42/formax/releases/download/v0.9.9/formax-current.x86_64.rpm
The following will guide you to creation, execution and
maintenance of a form by using the components of formax.
makeform
(create), runform
(execute) and editform
(maintain). First change into a new directory where your
development will live. Create a new database including the
table depts
with:
sqlite3 mydb.sq3
create table depts (id integer primary key not null, dname text, loc text);
insert into depts values (10, 'ACCOUNTING', 'NEW YORK');
insert into depts values (20, 'RESEARCH', 'DALLAS');
insert into depts values (30, 'SALES', 'CHICAGO');
insert into depts values (40, 'OPERATIONS', 'BOSTON');
.quit
You should now have a sqlite database in mydb.sq3
. Create
a default form for the table depts
and execute it:
makeform deptform Departments depts id dname loc | sqlite3 myform.frm
runform myform.frm mydb.sq3
You will be in Insert-Mode
and can enter data for new
records. Press Enter without new data will get you into
Query-Mode
. Quit from the form after playing around with
Ctrl-Y. Read the user guide for more information how to use
the form.
Change the form layout and the default behaviour of the form
with the editform
utility. This will bring up your editor
with the layout of the form and a form to maintain the field
behaviour and at least the editor again with the full
.inp-file
for your form. You can test your changes by
running runform again:
editform myform
runform myform.frm mydb.sq3
Read the developer guide to modify the form in detail.
User Guide Developer Guide Operator Guide Contributor Guide Have fun and profit.
GNU General Public License Version 3, 29 June 2007
Copyright (c) 2024, Axel K. Reinhold. All rights reserved.