Skip to content

Latest commit

 

History

History
263 lines (208 loc) · 7.5 KB

README.md

File metadata and controls

263 lines (208 loc) · 7.5 KB

/** @class TOTEM SourceForge github geointapps gitlab

TOTEM

TOTEM replaces a slew of god-awful middleware by providing a basic http/https web service having the following configurable features:

+ routing methods for table, engine, and file objects
+ denial-of-service protection
+ web sockets for inter-client communications
+ client profiles (e.g. banning, journalling, hawking, challenging and polling)
+ account management by priviledged hawks and normal users
+ hyper-threading in a master-worker or master-only relationship
+ PKI channel encryption and authentication
+ no-faulting (protected) run state
+ indexing, uploading, downloading and cacheing mime files
+ per-client antibot challenges: profile challenges like (riddle), (card), (ids), (yesno), (rand)om, (bio)metric
+ syncronized crude operations on mutiple endpoints
+ database agnosticator (default MySQL-Cluster)
+ poll files and services
+ automattic server cert generation
+ task sharding

TOTEM defines the following CRUD endpoints:

POST / NODE ?? NODE ...
GET / NODE ?? NODE ...
PUT / NODE ?? NODE ...
DELETE / NODE ?? NODE ...

to access dataset, file or command NODEs:

DATASET.TYPE ? QUERY
AREA/PATH/FILE.TYPE ? QUERY
COMMAND.TYPE ? QUERY

By default, TOTEM provides the TYPEs:

db | xml | csv | json

for converting DATASETs; the COMMANDs:

riddle | task | ping

for validating a session, sharding tasks, and testing a connection; and the file AREAs:

stores | uploads | shares

for supervised/unsupervised FILE sharing.

Installation

Clone TOTEM base web service into your PROJECT/totem folder.
Clone ENUM basic enumerators into your PROJECT/enum folder.
Clone JSDB database agnosticator into your PROJECT/jsdb folder.

Start

npm run [ edit || start ]			# Configure environment
npm test [ ? || T1 || T2 || ...]			# Unit test
npm run [ prmprep || prmload ]		# Revise PRM

Required MySQL databases

  • openv.profiles Updates when a client arrives
  • openv.sessions Updates when a client session is established
  • openv.riddles Builds on config and updates when a client arrives
  • openv.apps Read on config to override config options and to define site context keys
  • openv.aspreqts Read on config to define asp requirements
  • openv.ispreqts Read on config to define isp requirements
  • openv.hwreqts Read on config to define hardware requirements
  • app.files Updated/read during file download/upload

Usage

Simply require, configure and start TOTEM:

var TOTEM = require("totem")({
	key: value, 						// set key
	"key.key": value, 					// indexed set
	"key.key.": value					// indexed append
}, err => {
	console.log( err ? "something evil is lurking" : "look mom - Im running!");
});

where its configuration keys follow the ENUM deep copy conventions.

T1 - Just an interface

var TOTEM = require("totem");

Trace({
	msg: "Im simply a Totem interface so Im not even running as a service", 
	default_fetcher_endpts: TOTEM.byTable,
	default_protect_mode: TOTEM.faultless,
	default_cores_used: TOTEM.cores
});

T2 - A do-little service

TOTEM.config({
	name: "iamwhoiam",
	faultless: true,
	cores: 2
}, err => {

	Trace( err || 
		`I'm a Totem service running in fault protection mode, no database, no UI; but I am running
		with 2 cores and the default endpoint routes` );

});

T3 - A service with a database

TOTEM.config({
	name: "Totem",

	mysql: {
		host: ENV.MYSQL_HOST,
		user: ENV.MYSQL_USER,
		pass: ENV.MYSQL_PASS
	}
},  err => {				
	Trace( err ||
		`I'm a Totem service with no cores. I do, however, now have a mysql database from which I've derived 
		my startup options (see the openv.apps table for the Nick="Totem").  
		No endpoints to speak off (execept for the standard wget, riddle, etc) but you can hit "/files/" to index 
		these files. `
	);
});

T4 - A service with custom endpoints

TOTEM.config({
	mysql: {
		host: ENV.MYSQL_HOST,
		user: ENV.MYSQL_USER,
		pass: ENV.MYSQL_PASS
	},
	byTable: {
		dothis: function dothis(req,res) {  //< named handlers are shown in trace in console
			res( "123" );

			Trace({
				do_query: req.query
			});
		},

		dothat: function dothat(req,res) {

			if (req.query.x)
				res( [{x:req.query.x+1,y:req.query.x+2}] );
			else
				res( new Error("We have a problem huston") );

			Trace({
				msg: `Like dothis, but needs an ?x=value query`, 
				or_query: req.query,
				or_user: [req.client,req.group]
			});
		}
	}
}, err => {
	Trace( err || {
		msg:
			`As always, if the openv.apps Encrypt is set for the Nick="Totem" app, this service is now **encrypted** [*]
			and has https (vs http) endpoints, here /dothis and /dothat endpoints.  Ive only requested only 1 worker (
			aka core), Im running unprotected, and have a mysql database.  
			[*] If my NICK.pfx does not already exists, Totem will create its password protected NICK.pfx cert from the
			associated public NICK.crt and private NICK.key certs it creates.`,
		my_endpoints: TOTEM.byTable
	});
});

T5 - A service with antibot protection

TOTEM.config({
	mysql: {
		host: ENV.MYSQL_HOST,
		user: ENV.MYSQL_USER,
		pass: ENV.MYSQL_PASS
	},

	name: "allmine",

	riddles: 20
}, err => {
	Trace( err || {
		msg:
			`I am Totem client, with no cores but I do have mysql database and I have an anti-bot shieldhttps://totem.west.ile.nga.ic.gov  Anti-bot
			shields require a Encrypted service, and a UI (like that provided by DEBE) to be of any use.`, 
		mysql_derived_parms: TOTEM.site
	});
});

T6 - A service with tasking endpoints

TOTEM.config({  // configure the service for tasking
	name: "Totem1",  // default parms from openv.apps nick=Totem1
	faultless: false,	// ex override default 
	cores: 3,		// ex override default
	mysql: { 		// provide a database
		host: ENV.MYSQL_HOST,
		user: ENV.MYSQL_USER,
		pass: ENV.MYSQL_PASS
	},
	"byTable.": {  // define endpoints
		test: function (req,res) {
			res(" here we go");  // endpoint must always repond to its client 
			if (CLUSTER.isMaster)  // setup tasking examples on on master
				switch (req.query.opt || 1) {  // test example tasker
					case 1: 
						TOTEM.tasker({  // setup tasking for loops over these keys
							keys: "i,j",
							i: [1,2,3],
							j: [4,5]
						}, 
							// define the task which returns a message msg
							($) => "hello i,j=" + [i,j] + " from worker " + $.worker + " on " + $.node, 

							// define the message msg handler
							(msg) => console.log(msg)
						);
						break;

					case 2:
						TOTEM.tasker({
							qos: 1,
							keys: "i,j",
							i: [1,2,3],
							j: [4,5]
						}, 
							($) => "hello i,j=" + [i,j] + " from worker " + $.worker + " on " + $.node, 
							(msg) => console.log(msg)
						);
						break;

					case 3:
						break;
				}

		}
	}

}, err => {
	Trace( err || "Testing tasker with database and 3 cores at /test endpoint" );
});

Contributing

To contribute to this module, see our issues and milestones.

License

MIT */