|
| 1 | +/* |
| 2 | +* Reports request metrics to InfluxDB |
| 3 | +* @param {Request} request - incoming request |
| 4 | +* @param {object} env - environment variables |
| 5 | +*/ |
| 6 | +export const reportRequestMetrics = async (request, env) => { |
| 7 | + await writeMetrics(createMetricsFromRequest(request, env), env) |
| 8 | +} |
| 9 | + |
| 10 | +/* |
| 11 | +* Returns request metrics in InfluxDB line protocol format |
| 12 | +* https://docs.influxdata.com/influxdb/cloud/reference/syntax/line-protocol/ |
| 13 | +* @param {Request} request - incoming request |
| 14 | +* @param {object} env - environment variables |
| 15 | +*/ |
| 16 | +export const createMetricsFromRequest = (request, env) => { |
| 17 | + const url = new URL(request.url); |
| 18 | + const timestamp = Date.now(); |
| 19 | + const apiKey = request.headers.get('api-key') || |
| 20 | + url.searchParams.get('api-key') || ( |
| 21 | + request.headers.get('Authorization')?.startsWith('Bearer ') |
| 22 | + ? request.headers.get('Authorization').substring(7) |
| 23 | + : 'unknown' |
| 24 | + ); |
| 25 | + |
| 26 | + return `${env.INFLUX_METRIC_NAME} api_key="${apiKey}" ${timestamp}` |
| 27 | +} |
| 28 | + |
| 29 | +/* |
| 30 | +* Sends request metrics to InfluxDB |
| 31 | +* https://docs.influxdata.com/enterprise_influxdb/v1/guides/write_data/ |
| 32 | +* @param {string} lineProtocolData - InfluxDB line protocol formatted data |
| 33 | +* @param {object} env - environment variables |
| 34 | +*/ |
| 35 | +export const writeMetrics = async (lineProtocolData, env) => { |
| 36 | + // Define API endpoint and headers |
| 37 | + const url = `${env.INFLUX_URL}/api/v2/write?&bucket=${env.INFLUX_DATABASE}&precision=ms`; |
| 38 | + |
| 39 | + return fetch(url, { |
| 40 | + method: 'POST', |
| 41 | + headers: { |
| 42 | + 'Authorization': `Token ${env.INFLUX_TOKEN}`, |
| 43 | + 'Content-Type': 'application/octet-stream' |
| 44 | + }, |
| 45 | + body: lineProtocolData, |
| 46 | + }) |
| 47 | +} |
0 commit comments