var __values = (this && this.__values) || function(o) { var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; if (m) return m.call(o); if (o && typeof o.length === "number") return { next: function () { if (o && i >= o.length) o = void 0; return { value: o && o[i++], done: !o }; } }; throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); }; var __read = (this && this.__read) || function (o, n) { var m = typeof Symbol === "function" && o[Symbol.iterator]; if (!m) return o; var i = m.call(o), r, ar = [], e; try { while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); } catch (error) { e = { error: error }; } finally { try { if (r && !r.done && (m = i["return"])) m.call(i); } finally { if (e) throw e.error; } } return ar; }; import { toAttributes } from '../common/internal'; import { sdkSpanToOtlpSpan } from './internal'; export function createExportTraceServiceRequest(spans, useHex) { return { resourceSpans: spanRecordsToResourceSpans(spans, useHex) }; } function createResourceMap(readableSpans) { var e_1, _a; var resourceMap = new Map(); try { for (var readableSpans_1 = __values(readableSpans), readableSpans_1_1 = readableSpans_1.next(); !readableSpans_1_1.done; readableSpans_1_1 = readableSpans_1.next()) { var record = readableSpans_1_1.value; var ilmMap = resourceMap.get(record.resource); if (!ilmMap) { ilmMap = new Map(); resourceMap.set(record.resource, ilmMap); } // TODO this is duplicated in basic tracer. Consolidate on a common helper in core var instrumentationLibraryKey = record.instrumentationLibrary.name + "@" + (record.instrumentationLibrary.version || '') + ":" + (record.instrumentationLibrary.schemaUrl || ''); var records = ilmMap.get(instrumentationLibraryKey); if (!records) { records = []; ilmMap.set(instrumentationLibraryKey, records); } records.push(record); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (readableSpans_1_1 && !readableSpans_1_1.done && (_a = readableSpans_1.return)) _a.call(readableSpans_1); } finally { if (e_1) throw e_1.error; } } return resourceMap; } function spanRecordsToResourceSpans(readableSpans, useHex) { var resourceMap = createResourceMap(readableSpans); var out = []; var entryIterator = resourceMap.entries(); var entry = entryIterator.next(); while (!entry.done) { var _a = __read(entry.value, 2), resource = _a[0], ilmMap = _a[1]; var scopeResourceSpans = []; var ilmIterator = ilmMap.values(); var ilmEntry = ilmIterator.next(); while (!ilmEntry.done) { var scopeSpans = ilmEntry.value; if (scopeSpans.length > 0) { var _b = scopeSpans[0].instrumentationLibrary, name_1 = _b.name, version = _b.version, schemaUrl = _b.schemaUrl; var spans = scopeSpans.map(function (readableSpan) { return sdkSpanToOtlpSpan(readableSpan, useHex); }); scopeResourceSpans.push({ scope: { name: name_1, version: version }, spans: spans, schemaUrl: schemaUrl }); } ilmEntry = ilmIterator.next(); } // TODO SDK types don't provide resource schema URL at this time var transformedSpans = { resource: { attributes: toAttributes(resource.attributes), droppedAttributesCount: 0, }, scopeSpans: scopeResourceSpans, schemaUrl: undefined }; out.push(transformedSpans); entry = entryIterator.next(); } return out; } //# sourceMappingURL=index.js.map