Holmes-Interrogation: An Interrogation Planner for Holmes Processing
Overview
The Holmes-Interrogation Planner is defined by the SKALD Architecture and serves as the focal point for performing analysis and render the data derived from Holmes-Totem.
WARNING: State of Development
Holmes-Interrogation is currently in an very early state. Please keep in mind that configuration options and significant code changes are expected and can occur at any time.
We also current only support a Service for API interaction.
Compilation
After cloning this project you can simple build it using go build
or go install
. This requires a configured and working Go environment and the following packages:
go get github.com/aws/aws-sdk-go
go get github.com/gocql/gocql
Installation
You can deploy the binary everywhere you want, per default it is statically linked and does not need any libraries on the machine.
Next up you need to fill the config.json.example
with your own values and rename it to config.json
, after this simply execute the binary.
Dependencies
All necessary dependencies can be found in the Compilation
section.
Usage
The binary accepts one command line parameter: --config
to specify where it should look for the configuration file. If this is omitted it will search for the file in the current working directory.
Internal structure
The main process starts a few listeners to support multiple protocols. Currently only HTTP is supported, AMQP is planned and others are possible.
The listeners then wait for requests, parse them protocol specific and generate a generic request.
This generic request is then passed to a internal router that matches the request to a module and function and calls said function.
This produces a generic result which is then passed back from the router to the lister and the lister packs the result protocol specific and sends it back.