Version: 0.1.0
All ThreatConnect™ Spaces Apps are provided default parameters via the query parameters of the URI when executed. The Spaces Base Service provides access to these params via a subscription on the Router params observable. In order to guarantee the parameters are retrieved before execution of App logic Add the SpacesParamsResolve to the routes as shown below.
const routes: Routes = [{
path: '',
component: MainComponent,
resolve: {
params: SpacesParamsResolve
}
}];
The Spaces Base service provides access to a few key properties that can be access after the service is initialized. The tcToken
property will always provide a current API token (automatic renewal) to use when communicating with the ThreatConnect API.
ngOnInit() {
/* store app parameters */
this.storage.create('tcSelectedItem', this.spacesBase.param('tcSelectedItem'));
this.storage.create('tcType', this.spacesBase.param('tcType'));
}
The Spaces Logging Service provides a wrapper around console.log()
with additional features such as Submodule, Method, file and line number detection. Logging colors to quickly identify which log message comes from which module. Logging level for the app to allow easy debugging/troubleshooting.
constructor(
private logging: SpacesLoggingService
) {
this.logging.logLevel = 'debug'; // set app default logging level
this.logging.moduleColor('#633974', '#fff', 'AppComponent'); // set logging console colors
}
constructor(
private logging: SpacesLoggingService
) {
this.logging.logLevel = 'debug'; // set app default logging level
/* optional set non default colors */
this.logging.criticalColor('#633974', '#fff'); // set logging level console colors
this.logging.debugColor('#666', '#fff'); // set logging level console colors
<...snipped>
}
constructor(
private logging: SpacesLoggingService
) {
this.logging.logLevel = 'debug'; // set app default logging level
this.logging.disableColor();
}
ngOnInit() {
this.logging.critical('Critial Title', 'Something failed and can not recover.')
this.logging.error('Error Title', 'Something failed.')
this.logging.warn('Warn Title', 'This probably should not happen.')
this.logging.info('Info Title', 'An informative message.')
this.logging.debug('Debug Title', 'Lots of noise.')
this.logging.important('Important Title', 'Look at me!!!')
}
The Spaces Messaging Service provides a wrapper on PrimeNg Growl. This service allows the App to send a message to the base App Component from any custom compponent.
<div class="spaces-content">
<p-growl [value]="messages.msgs"></p-growl>
<router-outlet></router-outlet>
</div>
From custom component that imports the SpacesMessagesService
a Growl messages can be triggered using the examples below. Or just using this.message.showSuccess()
, this.message.showInfo()
, this.message.showWarning()
, or this.message.showError()
directly in any method.
import {
SpacesMessagesService
}
from 'spaces-ng/main';
// <snipped...>
constructor(
private messages: SpacesMessagesService
) { /* empty block */ }
/* example of spaces-ng message feature */
public errorMessage(msg) {
this.messages.showError('Error Message', msg);
}
/* example of spaces-ng message feature */
public successMessage(msg) {
this.messages.showSuccess('Success Message', msg);
}
The Spaces Request Service provides a wrapper around the @angular/http
module to simplify interaction with the ThreatConnect API or any Remote endpoint. The Spaces Request Service provides easy access to the ThreatConnect API Secury Proxy service.
import {
SpacesRequestService
}
from 'spaces-ng/main';
import { Observable } from 'rxjs/Rx';
// <snipped...>
constructor(
private request: SpacesRequestService
) { /* empty block */ }
public getData(
apiUser: string,
apiKey: string
): Observable<any> {
let myRequest = this.request
.resetOptions()
.proxy(true)
.url(url)
.param('api_username', apiUser)
.param('api_key', apiKey)
.method('GET');
return dtRequest.request()
.map(res => res.json() || {},
this.handleError);
}
Generated using TypeDoc