UNPKG

@golemio/pid

Version:
42 lines 2.48 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.PresetLogTransformation = void 0; const AbstractTransformation_1 = require("@golemio/core/dist/helpers/transformation/AbstractTransformation"); const tsyringe_1 = require("@golemio/core/dist/shared/tsyringe"); let PresetLogTransformation = class PresetLogTransformation extends AbstractTransformation_1.AbstractTransformation { constructor() { super(...arguments); this.name = "PresetLogTransformation"; this.transformInternal = (dataItem) => { // Use dummy hostname to parse relative URLs // we want to normalize the relative URL without query params, leading slashes and other irregularities const url = new URL(dataItem.stream.req_url, "http://golemio"); const logTimestampInNanoseconds = BigInt(dataItem.values[0][0]); const receivedAtDateObject = new Date(Number(logTimestampInNanoseconds / BigInt(1000000))); return { received_at: receivedAtDateObject, device_alias: url.pathname.split("/pid/").at(-1).replace("/", ""), is_processed: false, request_url: dataItem.stream.req_url, request_method: dataItem.stream.req_method, request_user_agent: dataItem.stream.req_userAgent ?? "", response_status: Number.parseInt(dataItem.stream.res_status), response_time_ms: Number.parseInt(dataItem.stream.responseTime), updated_at: null, updated_by: null, update_batch_id: null, }; }; } }; exports.PresetLogTransformation = PresetLogTransformation; exports.PresetLogTransformation = PresetLogTransformation = __decorate([ (0, tsyringe_1.injectable)() ], PresetLogTransformation); //# sourceMappingURL=PresetLogTransformation.js.map