Technical architecture
Overview
The figure below extends the previous figure Architecture overview by showing the different interfaces within nevisDetect:
data:image/s3,"s3://crabby-images/08118/08118d8cfe4106d78e2d7aa23d920a95e73003c9" alt="Technical architecture"
The table below lists the interfaces within nevisDetect:
Interface name | Description | Type | Provider | Consumer |
---|---|---|---|---|
ICAP (0) | ICAP interface | ICAP | nevisDetect Feature Correlator | nevisProxy (ICAP filter) |
Request Data (1) | Interface for forwarding the data of the actual request as well as returning the generated rule in case of synchronous communication. | JMS queue | nevisDetect Core | nevisDetect Feature Correlator |
Authentication Data (2) | Interface for forwarding the data of the actual authentication as well as returning the generated rule in case of synchronous communication. | JMSqueue | nevisDetect Core | nevisAuth (nevisDetect AuthState) |
Statistic (3) | Interface for updating the user related statistical data and for persisting generated rules. | REST | nevisDetect Persistency | nevisDetect Core |
Configuration (4) | Interface for reading the system configuration and the persisted rules. | REST | nevisDetect Persistency | nevisDetect CorenevisDetect Feature Correlator |
Entities (5) | Interface for read/write access to the persisted entities. | REST | nevisDetect Persistency | nevisDetect Web App |
Component Control (6) | Interface for getting the runtime status of all nevisDetect components. | REST | nevisDetect Controller | nevisDetect Web App |
Component Status (7) | Interface for getting the status of a single nevisDetect component. | JMS topic | nevisDetect CorenevisDetect Feature CorrelatornevisDetect Persistency | nevisDetect Controller |
The next table lists the runtime of the nevisDetect components:
Component | Runtime | Remarks |
---|---|---|
nevisDetect Feature Correlator | Standalone JVM | TCP/IP server listening on localhost |
nevisDetect AuthState | nevisAuth execution environment | AuthState deployed by nevisAuth |
nevisDetect Core | Standalone JVM | A JMS Messaging Listener |
nevisDetect Persistency | Servlet container | Web application implementing REST services |
nevisDetect Controller | Servlet container | Web application implementing REST servicesServes the nevisDetect Web App with static content |
nevisDetect Web App | Browser | Single Page Application (SPA) based on Angular 2 |
Runtime
The following figure shows the asynchronous processing of an HTTP request within nevisDetect:
data:image/s3,"s3://crabby-images/46f40/46f4058f865230e4842b26ca65abdd24aad99a18" alt="HTTP request processing"
The processing of an HTTP request during authentication is shown in the following figure:
data:image/s3,"s3://crabby-images/27c5e/27c5e7a3c1cad7a7af382e5d06c52554c69f5480" alt="Authentication request processing"
Scaling and fail-safeness
Fail-safeness and scaling of nevisDetect is guaranteed by the message bus. The figure below is therefore showing the system from a messaging point of view:
data:image/s3,"s3://crabby-images/db01d/db01d2c31d10cad7428b2849ce8bdd0cd19605c0" alt="Request data queue"
Monitoring
nevisDetect is a distributed system consisting of several components. The runtime status of all components is monitored by JMS topic:
data:image/s3,"s3://crabby-images/a25ef/a25efd3d596dc7dcb2beaf734c11e0ac6ba891c1" alt="Monitoring nevisDetect"
The monitoring described here is displayed in the nevisDetect web application. For machine-related monitoring services, see chapter Liveness and health services.