-
Notifications
You must be signed in to change notification settings - Fork 72
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Co-authored-by: Sam Johnson <[email protected]>
- Loading branch information
1 parent
a1ff4e9
commit 5bef749
Showing
10 changed files
with
187 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
--- | ||
sidebar_label: datadog-log-integration | ||
title: datadog-log-integration | ||
--- | ||
|
||
This feature forwards logs emitted by the Flex Project Template to Datadog. | ||
|
||
### Configuration | ||
|
||
This feature allows the following configuration settings. | ||
|
||
![datadog-log-integration settings](../../static/img/features/datadog-log-integration/settings.png) | ||
|
||
| Setting | Description | | ||
| --------| ------------| | ||
| Api key | Your Datadog Account [client token](https://docs.datadoghq.com/account_management/api-app-keys/#client-tokens) | ||
| Log Level | The minimum log level to send to Datadog. See [Logging](/flex-project-template/building/template-utilities/logging) for more details. | ||
| Intake Region | The [Datadog Site](https://docs.datadoghq.com/getting_started/site/) for your account. Valid values are `us` | `us5` | `us3` | `eu`. | ||
| Flush Timeout | In milliseconds. Because we send logs to datadog over HTTP - we do not want to make an HTTP request for every log written. This feature will buffer log messages for the flush timeout before making a single HTTP request to Datadog with all buffered log messages. If there are no logs within the Flush timeout, there is no HTTP request to Datadog. | | ||
|
||
### Flex User Experience | ||
|
||
Logs are forwarded automatically with no indication to the Flex User. | ||
|
||
### Dependencies | ||
|
||
You will need a Datadog account, with a [client token](https://docs.datadoghq.com/account_management/api-app-keys/#client-tokens), as well as your intake region, or [Datadog Site](https://docs.datadoghq.com/getting_started/site/). | ||
|
||
_Client tokens are safe for use in browsers._ | ||
|
||
### Metadata | ||
|
||
All logs sent to Datadog are decorated with common metadata. In this case, we add the worker name and workerSid to every log message sent to Datadog automatically! | ||
|
||
### Note | ||
|
||
Logs are forwarded to Datadog through HTTP, not the datadog sdk client. This is done to save build size of the template. If you're looking for a tighter integration with Datadog, consider a custom feature that implements their client sdk. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
README.md | ||
README.md |
30 changes: 30 additions & 0 deletions
30
plugin-flex-ts-template-v2/src/feature-library/datadog-log-integration/config.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
import { getFeatureFlags } from '../../utils/configuration'; | ||
import DatadogLogIntegrationConfig from './types/ServiceConfiguration'; | ||
|
||
const { | ||
enabled = false, | ||
api_key, | ||
intake_region, | ||
flush_timeout, | ||
log_level, | ||
} = (getFeatureFlags()?.features?.datadog_log_integration as DatadogLogIntegrationConfig) || {}; | ||
|
||
export const isFeatureEnabled = () => { | ||
return enabled; | ||
}; | ||
|
||
export const getApiKey = () => { | ||
return api_key; | ||
}; | ||
|
||
export const getIntakeRegion = () => { | ||
return intake_region; | ||
}; | ||
|
||
export const getFlushTimeout = () => { | ||
return flush_timeout; | ||
}; | ||
|
||
export const getLogLevel = () => { | ||
return log_level; | ||
}; |
75 changes: 75 additions & 0 deletions
75
...in-flex-ts-template-v2/src/feature-library/datadog-log-integration/destination/Datadog.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
import querystring from 'querystring'; | ||
|
||
import Destination from '../../../utils/logger/destination'; | ||
import { LogLevel } from '../../../utils/logger'; | ||
import { DatadogDestinationConfig } from '../types/ServiceConfiguration'; | ||
|
||
export default class DatadogDestination extends Destination { | ||
buffer: any[] = []; | ||
|
||
api: string = ''; | ||
|
||
constructor(opts: DatadogDestinationConfig) { | ||
super({ minLogLevel: opts.minLogLevel }); | ||
|
||
const { flushTimeout, apiKey, intakeRegion } = opts; | ||
|
||
if (intakeRegion === 'eu') { | ||
this.api = `https://http-intake.logs.datadoghq.eu/api/v2/logs`; | ||
} else if (intakeRegion === 'us3') { | ||
this.api = `https://http-intake.logs.us3.datadoghq.com/api/v2/logs`; | ||
} else if (intakeRegion === 'us5') { | ||
this.api = `https://http-intake.logs.us5.datadoghq.com/api/v2/logs`; | ||
} else { | ||
this.api = `https://http-intake.logs.datadoghq.com/api/v2/logs`; | ||
} | ||
|
||
const query = { | ||
'dd-api-key': apiKey, | ||
}; | ||
const qs = querystring.encode(query); | ||
|
||
this.api = `${this.api}?${qs}`; | ||
|
||
setInterval(() => { | ||
this.flush(); | ||
}, flushTimeout); | ||
} | ||
|
||
async handle(level: LogLevel, message: string, context: any, meta: any): Promise<void> { | ||
return new Promise((resolve) => { | ||
this.buffer.push({ | ||
level, | ||
message, | ||
context, | ||
meta, | ||
}); | ||
return resolve(); | ||
}); | ||
} | ||
|
||
hasUnsentLogs(): boolean { | ||
return Boolean(this.buffer.length); | ||
} | ||
|
||
async flush(): Promise<void> { | ||
if (!this.hasUnsentLogs()) { | ||
return; | ||
} | ||
|
||
try { | ||
await fetch(this.api, { | ||
method: 'POST', | ||
headers: { | ||
'content-type': 'application/json', | ||
}, | ||
body: JSON.stringify(this.buffer), | ||
}); | ||
} catch (err) { | ||
console.error(err); | ||
} finally { | ||
// reset the buffer | ||
this.buffer = []; | ||
} | ||
} | ||
} |
11 changes: 11 additions & 0 deletions
11
...lex-ts-template-v2/src/feature-library/datadog-log-integration/flex-hooks/logger/index.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
import Datadog from '../../destination/Datadog'; | ||
import { getLogLevel, getApiKey, getIntakeRegion, getFlushTimeout } from '../../config'; | ||
|
||
export const loggerHook = function sendLogsToDataDog() { | ||
return new Datadog({ | ||
apiKey: getApiKey(), | ||
intakeRegion: getIntakeRegion(), | ||
flushTimeout: getFlushTimeout(), | ||
minLogLevel: getLogLevel(), | ||
}); | ||
}; |
9 changes: 9 additions & 0 deletions
9
plugin-flex-ts-template-v2/src/feature-library/datadog-log-integration/index.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
import { FeatureDefinition } from '../../types/feature-loader'; | ||
import { isFeatureEnabled } from './config'; | ||
// @ts-ignore | ||
import hooks from './flex-hooks/**/*.*'; | ||
|
||
export const register = (): FeatureDefinition => { | ||
if (!isFeatureEnabled()) return {}; | ||
return { name: 'datadog-log-integration', hooks: typeof hooks === 'undefined' ? [] : hooks }; | ||
}; |
16 changes: 16 additions & 0 deletions
16
...-ts-template-v2/src/feature-library/datadog-log-integration/types/ServiceConfiguration.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
import { LogLevel } from 'utils/logger'; | ||
|
||
export default interface DatadogLogIntegrationConfig { | ||
enabled: boolean; | ||
log_level: LogLevel; | ||
api_key: string; | ||
intake_region: string; | ||
flush_timeout: number | undefined; | ||
} | ||
|
||
export interface DatadogDestinationConfig { | ||
minLogLevel: LogLevel; | ||
apiKey: string; | ||
intakeRegion: string; | ||
flushTimeout: number | undefined; | ||
} |