2019-10-22 15:10:32 +02:00
|
|
|
import * as plugins from './smartlog-interfaces.plugins';
|
|
|
|
|
2019-10-22 16:53:22 +02:00
|
|
|
import * as requestInterfaces from './smartlog-interfaces.requests';
|
|
|
|
|
2020-06-04 15:12:36 +00:00
|
|
|
export { requestInterfaces as request };
|
2019-10-22 16:53:22 +02:00
|
|
|
|
2018-11-07 18:39:30 +01:00
|
|
|
/**
|
|
|
|
* the different available log types
|
|
|
|
*/
|
|
|
|
export type TLogType =
|
|
|
|
| 'log'
|
|
|
|
| 'increment'
|
|
|
|
| 'gauge'
|
|
|
|
| 'error'
|
|
|
|
| 'success'
|
|
|
|
| 'value'
|
|
|
|
| 'finance'
|
2018-11-16 20:27:21 +01:00
|
|
|
| 'compliance';
|
2018-11-07 18:39:30 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* the available log levels
|
|
|
|
*/
|
2018-11-16 20:27:21 +01:00
|
|
|
export type TLogLevel =
|
|
|
|
| 'silly'
|
|
|
|
| 'info'
|
|
|
|
| 'debug'
|
|
|
|
| 'note'
|
|
|
|
| 'ok'
|
|
|
|
| 'success'
|
|
|
|
| 'warn'
|
|
|
|
| 'error'
|
|
|
|
| 'lifecycle';
|
2018-11-07 18:39:30 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* the available environments
|
|
|
|
*/
|
2018-03-01 22:33:47 +01:00
|
|
|
export type TEnvironment = 'local' | 'test' | 'staging' | 'production';
|
2018-11-07 18:39:30 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* the available runtimes
|
|
|
|
*/
|
2020-06-04 15:04:44 +00:00
|
|
|
export type TRuntime = 'node' | 'chrome' | 'rust' | 'deno';
|
2018-02-08 01:52:08 +01:00
|
|
|
|
2020-06-04 15:04:44 +00:00
|
|
|
/**
|
2020-06-04 15:12:36 +00:00
|
|
|
* the log context e.g. what app in what version on what server
|
2020-06-04 15:04:44 +00:00
|
|
|
*/
|
2018-02-08 01:52:08 +01:00
|
|
|
export interface ILogContext {
|
|
|
|
company?: string;
|
|
|
|
companyunit?: string;
|
|
|
|
containerName?: string;
|
|
|
|
environment: TEnvironment;
|
|
|
|
runtime: TRuntime;
|
2018-11-04 18:15:46 +01:00
|
|
|
zone: string;
|
2018-02-08 01:52:08 +01:00
|
|
|
}
|
|
|
|
|
2020-06-04 15:04:44 +00:00
|
|
|
/**
|
|
|
|
* the main logpackage
|
|
|
|
*/
|
|
|
|
export interface ILogPackage<T = unknown> {
|
|
|
|
/**
|
|
|
|
* a unix timestamp in milliseconds
|
|
|
|
*/
|
2018-11-04 18:15:46 +01:00
|
|
|
timestamp: number;
|
2018-11-03 23:02:58 +01:00
|
|
|
type: TLogType;
|
|
|
|
context: ILogContext;
|
|
|
|
level: TLogLevel;
|
2020-06-04 15:04:44 +00:00
|
|
|
/**
|
|
|
|
* allows grouping of log messages
|
|
|
|
*/
|
|
|
|
correlationId: string;
|
2018-03-01 22:33:47 +01:00
|
|
|
message: string;
|
2020-06-04 15:04:44 +00:00
|
|
|
data?: T;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ILogPackageDataRequest {
|
|
|
|
url: string;
|
|
|
|
pathname: string;
|
|
|
|
method: string;
|
|
|
|
status: string;
|
2018-03-01 00:32:21 +01:00
|
|
|
}
|
|
|
|
|
2018-10-31 13:49:12 +01:00
|
|
|
export interface ILogPackageAuthenticated {
|
|
|
|
auth: string;
|
|
|
|
logPackage: ILogPackage;
|
|
|
|
}
|
|
|
|
|
2020-06-04 15:04:44 +00:00
|
|
|
/**
|
|
|
|
* a destination interface for extending smartlog modules
|
|
|
|
*/
|
2018-03-01 00:32:21 +01:00
|
|
|
export interface ILogDestination {
|
2018-03-01 23:31:47 +01:00
|
|
|
handleLog: (logPackage: ILogPackage) => void;
|
2018-03-01 22:33:47 +01:00
|
|
|
}
|